b102ff2a58a95c22bd81e7fec534c91bc368d4c1
[WebKit-https.git] / Source / WebCore / rendering / RenderNamedFlowThread.h
1 /*
2  * Copyright (C) 2012 Apple Inc.  All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  * 1. Redistributions of source code must retain the above copyright
8  *    notice, this list of conditions and the following disclaimer.
9  * 2. Redistributions in binary form must reproduce the above copyright
10  *    notice, this list of conditions and the following disclaimer in the
11  *    documentation and/or other materials provided with the distribution.
12  *
13  * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
14  * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL APPLE COMPUTER, INC. OR
17  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
18  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
19  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
20  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
21  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
23  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24  */
25
26
27 #ifndef RenderNamedFlowThread_h
28 #define RenderNamedFlowThread_h
29
30 #include "RenderFlowThread.h"
31 #include "Timer.h"
32 #include <wtf/HashCountedSet.h>
33 #include <wtf/ListHashSet.h>
34 #include <wtf/text/AtomicString.h>
35
36 namespace WebCore {
37
38 class Node;
39 class RenderNamedFlowThread;
40 class WebKitNamedFlow;
41
42 typedef ListHashSet<RenderNamedFlowThread*> RenderNamedFlowThreadList;
43 typedef HashCountedSet<RenderNamedFlowThread*> RenderNamedFlowThreadCountedSet;
44 typedef ListHashSet<Element*> NamedFlowContentElements;
45
46 class RenderNamedFlowThread FINAL : public RenderFlowThread {
47 public:
48     explicit RenderNamedFlowThread(Document&, PassRefPtr<WebKitNamedFlow>);
49     virtual ~RenderNamedFlowThread();
50
51     const AtomicString& flowThreadName() const;
52
53     const RenderRegionList& invalidRenderRegionList() const { return m_invalidRegionList; }
54
55     RenderObject* nextRendererForNode(Node*) const;
56     RenderObject* previousRendererForNode(Node*) const;
57
58     void addFlowChild(RenderObject* newChild);
59     void removeFlowChild(RenderObject*);
60     bool hasChildren() const { return !m_flowThreadChildList.isEmpty(); }
61 #ifndef NDEBUG
62     bool hasChild(RenderObject* child) const { return m_flowThreadChildList.contains(child); }
63 #endif
64
65     void pushDependencies(RenderNamedFlowThreadList&);
66
67     virtual void addRegionToThread(RenderRegion*) OVERRIDE;
68     virtual void removeRegionFromThread(RenderRegion*) OVERRIDE;
69
70     virtual void regionChangedWritingMode(RenderRegion*) OVERRIDE;
71
72     bool overset() const { return m_overset; }
73     void computeOversetStateForRegions(LayoutUnit oldClientAfterEdge);
74
75     void registerNamedFlowContentElement(Element&);
76     void unregisterNamedFlowContentElement(Element&);
77     const NamedFlowContentElements& contentElements() const { return m_contentElements; }
78     bool hasContentElement(Element&) const;
79
80     bool isMarkedForDestruction() const;
81     void getRanges(Vector<RefPtr<Range> >&, const RenderRegion*) const;
82
83 protected:
84     void setMarkForDestruction();
85     void resetMarkForDestruction();
86
87 private:
88     virtual const char* renderName() const OVERRIDE;
89     virtual bool isRenderNamedFlowThread() const OVERRIDE { return true; }
90     virtual bool isChildAllowed(const RenderObject&, const RenderStyle&) const OVERRIDE;
91
92     virtual void dispatchRegionLayoutUpdateEvent() OVERRIDE;
93     virtual void dispatchRegionOversetChangeEvent() OVERRIDE;
94
95     bool dependsOn(RenderNamedFlowThread* otherRenderFlowThread) const;
96     void addDependencyOnFlowThread(RenderNamedFlowThread*);
97     void removeDependencyOnFlowThread(RenderNamedFlowThread*);
98
99     void addRegionToNamedFlowThread(RenderRegion*);
100
101     void checkInvalidRegions();
102
103     bool canBeDestroyed() const { return m_invalidRegionList.isEmpty() && m_regionList.isEmpty() && m_contentElements.isEmpty(); }
104     void regionLayoutUpdateEventTimerFired(Timer<RenderNamedFlowThread>*);
105     void regionOversetChangeEventTimerFired(Timer<RenderNamedFlowThread>*);
106     void clearContentElements();
107     void updateWritingMode();
108
109 private:
110     // Observer flow threads have invalid regions that depend on the state of this thread
111     // to re-validate their regions. Keeping a set of observer threads make it easy
112     // to notify them when a region was removed from this flow.
113     RenderNamedFlowThreadCountedSet m_observerThreadsSet;
114
115     // Some threads need to have a complete layout before we layout this flow.
116     // That's because they contain a RenderRegion that should display this thread. The set makes it
117     // easy to sort the order of threads layout.
118     RenderNamedFlowThreadCountedSet m_layoutBeforeThreadsSet;
119
120     // Holds the sorted children of a named flow. This is the only way we can get the ordering right.
121     typedef ListHashSet<RenderObject*> FlowThreadChildList;
122     FlowThreadChildList m_flowThreadChildList;
123
124     NamedFlowContentElements m_contentElements;
125
126     RenderRegionList m_invalidRegionList;
127
128     bool m_overset : 1;
129
130     // The DOM Object that represents a named flow.
131     RefPtr<WebKitNamedFlow> m_namedFlow;
132
133     Timer<RenderNamedFlowThread> m_regionLayoutUpdateEventTimer;
134     Timer<RenderNamedFlowThread> m_regionOversetChangeEventTimer;
135 };
136
137 inline RenderNamedFlowThread* toRenderNamedFlowThread(RenderObject* object)
138 {
139     ASSERT_WITH_SECURITY_IMPLICATION(!object || object->isRenderNamedFlowThread());
140     return static_cast<RenderNamedFlowThread*>(object);
141 }
142
143 inline const RenderNamedFlowThread* toRenderNamedFlowThread(const RenderObject* object)
144 {
145     ASSERT_WITH_SECURITY_IMPLICATION(!object || object->isRenderNamedFlowThread());
146     return static_cast<const RenderNamedFlowThread*>(object);
147 }
148
149 // This will catch anyone doing an unnecessary cast.
150 void toRenderNamedFlowThread(const RenderNamedFlowThread*);
151
152 } // namespace WebCore
153
154 #endif // RenderNamedFlowThread_h
155