Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(191)

Side by Side Diff: third_party/WebKit/Source/core/css/invalidation/InvalidationSet.h

Issue 1317533002: Sibling invalidation sets (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Oilpan Created 5 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright (C) 2014 Google Inc. All rights reserved. 2 * Copyright (C) 2014 Google Inc. All rights reserved.
3 * 3 *
4 * Redistribution and use in source and binary forms, with or without 4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are 5 * modification, are permitted provided that the following conditions are
6 * met: 6 * met:
7 * 7 *
8 * * Redistributions of source code must retain the above copyright 8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer. 9 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above 10 * * Redistributions in binary form must reproduce the above
(...skipping 14 matching lines...) Expand all
25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29 */ 29 */
30 30
31 #ifndef InvalidationSet_h 31 #ifndef InvalidationSet_h
32 #define InvalidationSet_h 32 #define InvalidationSet_h
33 33
34 #include "core/CoreExport.h" 34 #include "core/CoreExport.h"
35 #include "wtf/Assertions.h"
35 #include "wtf/Forward.h" 36 #include "wtf/Forward.h"
36 #include "wtf/HashSet.h" 37 #include "wtf/HashSet.h"
37 #include "wtf/RefCounted.h" 38 #include "wtf/RefCounted.h"
38 #include "wtf/RefPtr.h" 39 #include "wtf/RefPtr.h"
39 #include "wtf/text/AtomicStringHash.h" 40 #include "wtf/text/AtomicStringHash.h"
40 #include "wtf/text/StringHash.h" 41 #include "wtf/text/StringHash.h"
41 42
42 namespace blink { 43 namespace blink {
43 44
45 class DescendantInvalidationSet;
44 class Element; 46 class Element;
45 class TracedValue; 47 class TracedValue;
46 48
47 // Tracks data to determine which elements of a DOM subtree need to have style 49 enum InvalidationType {
48 // recalculated. 50 InvalidateDescendants,
49 class CORE_EXPORT InvalidationSet final : public RefCounted<InvalidationSet> { 51 InvalidateSiblings
52 };
53
54 // Tracks data to determine which descendants in a DOM subtree, or
55 // siblings and their descendants, need to have style recalculated.
56 class CORE_EXPORT InvalidationSet : public RefCounted<InvalidationSet> {
50 WTF_MAKE_NONCOPYABLE(InvalidationSet); 57 WTF_MAKE_NONCOPYABLE(InvalidationSet);
51 public: 58 public:
52 static PassRefPtr<InvalidationSet> create() 59 virtual ~InvalidationSet() {}
53 { 60
54 return adoptRef(new InvalidationSet); 61 virtual bool isDescendantInvalidationSet() const { return false; }
55 } 62 virtual bool isSiblingInvalidationSet() const { return false; }
56 63
57 static void cacheTracingFlag(); 64 static void cacheTracingFlag();
58 65
59 bool invalidatesElement(Element&) const; 66 bool invalidatesElement(Element&) const;
60 67
61 void combine(const InvalidationSet& other);
62
63 void addClass(const AtomicString& className); 68 void addClass(const AtomicString& className);
64 void addId(const AtomicString& id); 69 void addId(const AtomicString& id);
65 void addTagName(const AtomicString& tagName); 70 void addTagName(const AtomicString& tagName);
66 void addAttribute(const AtomicString& attributeLocalName); 71 void addAttribute(const AtomicString& attributeLocalName);
67 72
68 void setWholeSubtreeInvalid(); 73 void setWholeSubtreeInvalid();
69 bool wholeSubtreeInvalid() const { return m_allDescendantsMightBeInvalid; } 74 bool wholeSubtreeInvalid() const { return m_allDescendantsMightBeInvalid; }
70 75
71 void setInvalidatesSelf() { m_invalidatesSelf = true; } 76 void setInvalidatesSelf() { m_invalidatesSelf = true; }
72 bool invalidatesSelf() const { return m_invalidatesSelf; } 77 bool invalidatesSelf() const { return m_invalidatesSelf; }
73 78
74 void setTreeBoundaryCrossing() { m_treeBoundaryCrossing = true; } 79 void setTreeBoundaryCrossing() { m_treeBoundaryCrossing = true; }
75 bool treeBoundaryCrossing() const { return m_treeBoundaryCrossing; } 80 bool treeBoundaryCrossing() const { return m_treeBoundaryCrossing; }
76 81
77 void setInsertionPointCrossing() { m_insertionPointCrossing = true; } 82 void setInsertionPointCrossing() { m_insertionPointCrossing = true; }
78 bool insertionPointCrossing() const { return m_insertionPointCrossing; } 83 bool insertionPointCrossing() const { return m_insertionPointCrossing; }
79 84
80 void setCustomPseudoInvalid() { m_customPseudoInvalid = true; } 85 void setCustomPseudoInvalid() { m_customPseudoInvalid = true; }
81 bool customPseudoInvalid() const { return m_customPseudoInvalid; } 86 bool customPseudoInvalid() const { return m_customPseudoInvalid; }
82 87
83 bool isEmpty() const { return !m_classes && !m_ids && !m_tagNames && !m_attr ibutes && !m_customPseudoInvalid; } 88 bool isEmpty() const { return !m_classes && !m_ids && !m_tagNames && !m_attr ibutes && !m_customPseudoInvalid; }
84 89
85 void toTracedValue(TracedValue*) const; 90 void toTracedValue(TracedValue*) const;
86 91
87 #ifndef NDEBUG 92 #ifndef NDEBUG
88 void show() const; 93 void show() const;
89 #endif 94 #endif
90 95
91 private: 96 const HashSet<AtomicString>& classSetForTesting() const { ASSERT(m_classes); return *m_classes; }
97 const HashSet<AtomicString>& idSetForTesting() const { ASSERT(m_ids); return *m_ids; }
98 const HashSet<AtomicString>& tagNameSetForTesting() const { ASSERT(m_tagName s); return *m_tagNames; }
99 const HashSet<AtomicString>& attributeSetForTesting() const { ASSERT(m_attri butes); return *m_attributes; }
100
101 protected:
92 InvalidationSet(); 102 InvalidationSet();
93 103
104 void combine(const InvalidationSet& other);
105
106 private:
94 HashSet<AtomicString>& ensureClassSet(); 107 HashSet<AtomicString>& ensureClassSet();
95 HashSet<AtomicString>& ensureIdSet(); 108 HashSet<AtomicString>& ensureIdSet();
96 HashSet<AtomicString>& ensureTagNameSet(); 109 HashSet<AtomicString>& ensureTagNameSet();
97 HashSet<AtomicString>& ensureAttributeSet(); 110 HashSet<AtomicString>& ensureAttributeSet();
98 111
99 // FIXME: optimize this if it becomes a memory issue. 112 // FIXME: optimize this if it becomes a memory issue.
100 OwnPtr<HashSet<AtomicString>> m_classes; 113 OwnPtr<HashSet<AtomicString>> m_classes;
101 OwnPtr<HashSet<AtomicString>> m_ids; 114 OwnPtr<HashSet<AtomicString>> m_ids;
102 OwnPtr<HashSet<AtomicString>> m_tagNames; 115 OwnPtr<HashSet<AtomicString>> m_tagNames;
103 OwnPtr<HashSet<AtomicString>> m_attributes; 116 OwnPtr<HashSet<AtomicString>> m_attributes;
104 117
105 // If true, all descendants might be invalidated, so a full subtree recalc i s required. 118 // If true, all descendants might be invalidated, so a full subtree recalc i s required.
106 unsigned m_allDescendantsMightBeInvalid : 1; 119 unsigned m_allDescendantsMightBeInvalid : 1;
107 120
108 // If true, the element itself is invalid. 121 // If true, the element itself is invalid.
109 unsigned m_invalidatesSelf : 1; 122 unsigned m_invalidatesSelf : 1;
110 123
111 // If true, all descendants which are custom pseudo elements must be invalid ated. 124 // If true, all descendants which are custom pseudo elements must be invalid ated.
112 unsigned m_customPseudoInvalid : 1; 125 unsigned m_customPseudoInvalid : 1;
113 126
114 // If true, the invalidation must traverse into ShadowRoots with this set. 127 // If true, the invalidation must traverse into ShadowRoots with this set.
115 unsigned m_treeBoundaryCrossing : 1; 128 unsigned m_treeBoundaryCrossing : 1;
116 129
117 // If true, insertion point descendants must be invalidated. 130 // If true, insertion point descendants must be invalidated.
118 unsigned m_insertionPointCrossing : 1; 131 unsigned m_insertionPointCrossing : 1;
119 }; 132 };
120 133
134 class CORE_EXPORT DescendantInvalidationSet final : public InvalidationSet {
135 public:
136 static PassRefPtr<DescendantInvalidationSet> create()
137 {
138 return adoptRef(new DescendantInvalidationSet);
139 }
140
141 bool isDescendantInvalidationSet() const final { return true; }
142
143 void combine(const DescendantInvalidationSet& other)
144 {
145 InvalidationSet::combine(other);
146 }
147
148 private:
149 DescendantInvalidationSet() {}
150 };
151
152 class CORE_EXPORT SiblingInvalidationSet final : public InvalidationSet {
153 public:
154 static PassRefPtr<SiblingInvalidationSet> create()
155 {
156 return adoptRef(new SiblingInvalidationSet);
157 }
158
159 bool isSiblingInvalidationSet() const final { return true; }
160
161 void combine(const SiblingInvalidationSet& other);
162
163 DescendantInvalidationSet& descendants() { return *m_descendantInvalidationS et; }
164 const DescendantInvalidationSet& descendants() const { return *m_descendantI nvalidationSet; }
165
166 unsigned maxDirectAdjacentSelectors() const { return m_maxDirectAdjacentSele ctors; }
167 void updateMaxDirectAdjacentSelectors(unsigned value) { m_maxDirectAdjacentS electors = std::max(value, m_maxDirectAdjacentSelectors); }
168
169 private:
170 SiblingInvalidationSet();
171
172 // Indicates the maximum possible number of siblings affected.
173 unsigned m_maxDirectAdjacentSelectors;
174
175 // Indicates the descendants of siblings.
176 RefPtr<DescendantInvalidationSet> m_descendantInvalidationSet;
177 };
178
179 using InvalidationSetVector = Vector<RefPtr<InvalidationSet>>;
180
181 struct InvalidationLists {
182 InvalidationSetVector descendants;
183 InvalidationSetVector siblings;
184 };
185
186 DEFINE_TYPE_CASTS(DescendantInvalidationSet, InvalidationSet, value, value->isDe scendantInvalidationSet(), value.isDescendantInvalidationSet());
187 DEFINE_TYPE_CASTS(SiblingInvalidationSet, InvalidationSet, value, value->isSibli ngInvalidationSet(), value.isSiblingInvalidationSet());
188
121 } // namespace blink 189 } // namespace blink
122 190
123 #endif // InvalidationSet_h 191 #endif // InvalidationSet_h
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698