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

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

Issue 1776493002: IntersectionObserver: use an idle callback to send notifications. (Closed) Base URL: https://chromium.googlesource.com/chromium/src@master
Patch Set: syntax error Created 4 years, 9 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/IntersectionObserverController.h
diff --git a/third_party/WebKit/Source/core/dom/IntersectionObserverController.h b/third_party/WebKit/Source/core/dom/IntersectionObserverController.h
index 554f574b2beceb4717c5d85d37a2aa97746b1833..089f9fa0fdd252d5a2a0f56baf36aabbd7976a1a 100644
--- a/third_party/WebKit/Source/core/dom/IntersectionObserverController.h
+++ b/third_party/WebKit/Source/core/dom/IntersectionObserverController.h
@@ -7,8 +7,8 @@
#include "core/dom/ActiveDOMObject.h"
#include "core/dom/Element.h"
+#include "core/dom/IdleRequestCallback.h"
#include "core/dom/IntersectionObserver.h"
-#include "platform/Timer.h"
#include "platform/heap/Handle.h"
#include "wtf/HashSet.h"
@@ -17,16 +17,17 @@
namespace blink {
-class IntersectionObserverController : public GarbageCollectedFinalized<IntersectionObserverController>, public ActiveDOMObject {
+class IntersectionObserverController : public IdleRequestCallback, public ActiveDOMObject {
WILL_BE_USING_GARBAGE_COLLECTED_MIXIN(IntersectionObserverController);
public:
static IntersectionObserverController* create(Document*);
~IntersectionObserverController();
void resume() override;
+ void handleEvent(IdleDeadline*) override;
void scheduleIntersectionObserverForDelivery(IntersectionObserver&);
- void deliverIntersectionObservations(Timer<IntersectionObserverController>*);
+ void deliverIntersectionObservations();
void computeTrackedIntersectionObservations();
void addTrackedObserver(IntersectionObserver&);
void removeTrackedObserversForRoot(const Node&);
@@ -37,13 +38,13 @@ private:
explicit IntersectionObserverController(Document*);
private:
- Timer<IntersectionObserverController> m_timer;
// IntersectionObservers for which this is the tracking document.
HeapHashSet<WeakMember<IntersectionObserver>> m_trackedIntersectionObservers;
// IntersectionObservers for which this is the execution context of the callback.
HeapHashSet<Member<IntersectionObserver>> m_pendingIntersectionObservers;
- bool m_timerFiredWhileSuspended;
+ bool m_callbackIsScheduled;
+ bool m_callbackFiredWhileSuspended;
};
} // namespace blink

Powered by Google App Engine
This is Rietveld 408576698