OLD | NEW |
---|---|
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef EventHandlerRegistry_h | 5 #ifndef EventHandlerRegistry_h |
6 #define EventHandlerRegistry_h | 6 #define EventHandlerRegistry_h |
7 | 7 |
8 #include "core/dom/DocumentSupplementable.h" | |
9 #include "core/events/Event.h" | 8 #include "core/events/Event.h" |
9 #include "core/page/Page.h" | |
10 #include "wtf/HashCountedSet.h" | 10 #include "wtf/HashCountedSet.h" |
11 | 11 |
12 namespace WebCore { | 12 namespace WebCore { |
13 | 13 |
14 typedef HashCountedSet<EventTarget*> EventTargetSet; | 14 typedef HashCountedSet<EventTarget*> EventTargetSet; |
15 | 15 |
16 // Registry for keeping track of event handlers. Handlers can either be | 16 // Registry for keeping track of event handlers. |
17 // associated with an EventTarget or be "external" handlers which live outside | 17 class EventHandlerRegistry FINAL : public Supplement<Page> { |
18 // the DOM (e.g., WebViewImpl). | |
19 class EventHandlerRegistry FINAL : public DocumentSupplement { | |
20 public: | 18 public: |
21 virtual ~EventHandlerRegistry(); | 19 virtual ~EventHandlerRegistry(); |
22 | 20 |
23 // Supported event handler classes. Note that each one may correspond to | 21 // Supported event handler classes. Note that each one may correspond to |
24 // multiple event types. | 22 // multiple event types. |
25 enum EventHandlerClass { | 23 enum EventHandlerClass { |
26 ScrollEvent, | 24 ScrollEvent, |
25 #if ASSERT_ENABLED | |
26 // Additional event categories for verifying handler tracking logic. | |
27 EventsForTesting, | |
28 #endif | |
27 EventHandlerClassCount, // Must be the last entry. | 29 EventHandlerClassCount, // Must be the last entry. |
28 }; | 30 }; |
29 | 31 |
30 static const char* supplementName(); | 32 static const char* supplementName(); |
31 static EventHandlerRegistry* from(Document&); | 33 static EventHandlerRegistry* from(Page&); |
32 | 34 |
33 // Returns true if the host Document or any child documents have any | 35 // Returns true if the page has event handlers of the specified class. |
34 // registered event handlers of the class. | |
35 bool hasEventHandlers(EventHandlerClass) const; | 36 bool hasEventHandlers(EventHandlerClass) const; |
36 | 37 |
37 // Returns a set of EventTargets which have registered handlers of the | 38 // Returns a set of EventTargets which have registered handlers of the given class. |
38 // given class. Only contains targets directly in this document; all | |
39 // handlers in a child Document are collapsed to a single respective | |
40 // Document instance in the set. | |
41 const EventTargetSet* eventHandlerTargets(EventHandlerClass) const; | 39 const EventTargetSet* eventHandlerTargets(EventHandlerClass) const; |
42 | 40 |
43 // Registration and management of event handlers attached to EventTargets. | 41 // Registration and management of event handlers attached to EventTargets. |
44 void didAddEventHandler(EventTarget&, const AtomicString& eventType); | 42 void didAddEventHandler(EventTarget&, const AtomicString& eventType); |
45 void didAddEventHandler(EventTarget&, EventHandlerClass); | 43 void didAddEventHandler(EventTarget&, EventHandlerClass); |
46 void didRemoveEventHandler(EventTarget&, const AtomicString& eventType); | 44 void didRemoveEventHandler(EventTarget&, const AtomicString& eventType); |
47 void didRemoveEventHandler(EventTarget&, EventHandlerClass); | 45 void didRemoveEventHandler(EventTarget&, EventHandlerClass); |
48 void didMoveFromOtherDocument(EventTarget&, Document& oldDocument); | |
49 void didRemoveAllEventHandlers(EventTarget&); | 46 void didRemoveAllEventHandlers(EventTarget&); |
47 void didMoveIntoPage(EventTarget&); | |
48 void didMoveOutOfPage(EventTarget&); | |
49 | |
50 void documentDetached(Document&); | |
Rick Byers
2014/04/30 17:28:50
Please add a comment saying that we require didMov
Sami
2014/05/01 13:29:34
That's right, better be explicit about it. I've ad
| |
50 | 51 |
51 virtual void trace(Visitor*) OVERRIDE { } | 52 virtual void trace(Visitor*) OVERRIDE { } |
52 | 53 |
53 private: | 54 private: |
54 explicit EventHandlerRegistry(Document&); | 55 explicit EventHandlerRegistry(Page&); |
55 | 56 |
56 enum ChangeOperation { | 57 enum ChangeOperation { |
57 Add, // Add a new event handler. | 58 Add, // Add a new event handler. |
58 Remove, // Remove an existing event handler. | 59 Remove, // Remove an existing event handler. |
59 RemoveAll // Remove any and all existing event handlers for a given targ et. | 60 RemoveAll // Remove any and all existing event handlers for a given targ et. |
60 }; | 61 }; |
61 | 62 |
62 // Returns true if |eventType| belongs to a class this registry tracks. | 63 // Returns true if |eventType| belongs to a class this registry tracks. |
63 static bool eventTypeToClass(const AtomicString& eventType, EventHandlerClas s* result); | 64 static bool eventTypeToClass(const AtomicString& eventType, EventHandlerClas s* result); |
64 | 65 |
65 // Returns true if the operation actually added a new target or completely | 66 // Returns true if the operation actually added a new target or completely |
66 // removed an existing one. | 67 // removed an existing one. |
67 bool updateEventHandlerTargets(ChangeOperation, EventHandlerClass, EventTarg et*); | 68 bool updateEventHandlerTargets(ChangeOperation, EventHandlerClass, EventTarg et*); |
68 | 69 |
69 // Called on the EventHandlerRegistry of the root Document to notify | 70 // Called on the EventHandlerRegistry of the root Document to notify |
70 // clients when we have added the first handler or removed the last one for | 71 // clients when we have added the first handler or removed the last one for |
71 // a given event class. |hasActiveHandlers| can be used to distinguish | 72 // a given event class. |hasActiveHandlers| can be used to distinguish |
72 // between the two cases. | 73 // between the two cases. |
73 void notifyHasHandlersChanged(EventHandlerClass, bool hasActiveHandlers); | 74 void notifyHasHandlersChanged(EventHandlerClass, bool hasActiveHandlers); |
74 | 75 |
75 // Record a change operation to a given event handler class and notify any | 76 // Record a change operation to a given event handler class and notify any |
76 // parent registry and other clients accordingly. | 77 // parent registry and other clients accordingly. |
77 void updateEventHandlerOfType(ChangeOperation, const AtomicString& eventType , EventTarget*); | 78 void updateEventHandlerOfType(ChangeOperation, const AtomicString& eventType , EventTarget*); |
78 | 79 |
79 void updateEventHandlerInternal(ChangeOperation, EventHandlerClass, EventTar get*); | 80 void updateEventHandlerInternal(ChangeOperation, EventHandlerClass, EventTar get*); |
80 | 81 |
81 struct HandlerState { | 82 void updateAllEventHandlers(ChangeOperation, EventTarget&); |
82 HandlerState(); | |
83 ~HandlerState(); | |
84 | 83 |
85 OwnPtr<EventTargetSet> targets; | 84 void checkConsistency() const; |
86 }; | |
87 | 85 |
88 Document& m_document; | 86 Page& m_page; |
89 HandlerState m_eventHandlers[EventHandlerClassCount]; | 87 EventTargetSet m_targets[EventHandlerClassCount]; |
90 }; | 88 }; |
91 | 89 |
92 } // namespace WebCore | 90 } // namespace WebCore |
93 | 91 |
94 #endif // EventHandlerRegistry_h | 92 #endif // EventHandlerRegistry_h |
OLD | NEW |