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

Unified Diff: third_party/WebKit/Source/core/dom/ElementRareData.h

Issue 1449623002: IntersectionObserver: second cut. (Closed) Base URL: https://chromium.googlesource.com/chromium/src@master
Patch Set: Add RuntimeEnabled flags to all idl's, fix test expectations. Created 4 years, 11 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 side-by-side diff with in-line comments
Download patch
Index: third_party/WebKit/Source/core/dom/ElementRareData.h
diff --git a/third_party/WebKit/Source/core/dom/ElementRareData.h b/third_party/WebKit/Source/core/dom/ElementRareData.h
index 75b0375475067491e23ea50e03a7e00a76fc5210..e66e9f458c0991ba1add974a550675d28917e971 100644
--- a/third_party/WebKit/Source/core/dom/ElementRareData.h
+++ b/third_party/WebKit/Source/core/dom/ElementRareData.h
@@ -26,6 +26,7 @@
#include "core/dom/Attr.h"
#include "core/dom/CompositorProxiedPropertySet.h"
#include "core/dom/DatasetDOMStringMap.h"
+#include "core/dom/ElementIntersectionObserverData.h"
#include "core/dom/NamedNodeMap.h"
#include "core/dom/NodeRareData.h"
#include "core/dom/PseudoElement.h"
@@ -34,6 +35,7 @@
#include "core/html/ClassList.h"
#include "core/style/StyleInheritedData.h"
#include "platform/heap/Handle.h"
+#include "wtf/HashSet.h"
#include "wtf/OwnPtr.h"
namespace blink {
@@ -123,6 +125,14 @@ public:
AttrNodeList* attrNodeList() { return m_attrNodeList.get(); }
void removeAttrNodeList() { m_attrNodeList.clear(); }
+ ElementIntersectionObserverData* intersectionObserverData() const { return m_intersectionObserverData.get(); }
+ ElementIntersectionObserverData& ensureIntersectionObserverData()
+ {
+ if (!m_intersectionObserverData)
+ m_intersectionObserverData = new ElementIntersectionObserverData();
+ return *m_intersectionObserverData;
+ }
+
DECLARE_TRACE_AFTER_DISPATCH();
private:
@@ -139,10 +149,12 @@ private:
OwnPtrWillBeMember<ElementShadow> m_shadow;
OwnPtrWillBeMember<NamedNodeMap> m_attributeMap;
OwnPtrWillBeMember<AttrNodeList> m_attrNodeList;
- PersistentWillBeMember<ElementAnimations> m_elementAnimations;
OwnPtrWillBeMember<InlineCSSStyleDeclaration> m_cssomWrapper;
OwnPtr<CompositorProxiedPropertySet> m_proxiedProperties;
+ PersistentWillBeMember<ElementAnimations> m_elementAnimations;
+ PersistentWillBeMember<ElementIntersectionObserverData> m_intersectionObserverData;
+
RefPtr<ComputedStyle> m_computedStyle;
RefPtrWillBeMember<CustomElementDefinition> m_customElementDefinition;
@@ -172,6 +184,8 @@ inline ElementRareData::~ElementRareData()
#if !ENABLE(OILPAN)
if (m_elementAnimations)
m_elementAnimations->dispose();
+ if (m_intersectionObserverData)
+ m_intersectionObserverData->dispose();
ASSERT(!m_shadow);
#endif
ASSERT(!m_generatedBefore);

Powered by Google App Engine
This is Rietveld 408576698