| 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, |
| 27 EventHandlerClassCount, // Must be the last entry. | 25 EventHandlerClassCount, // Must be the last entry. |
| 28 }; | 26 }; |
| 29 | 27 |
| 30 static const char* supplementName(); | 28 static const char* supplementName(); |
| 31 static EventHandlerRegistry* from(Document&); | 29 static EventHandlerRegistry* from(Page&); |
| 32 | 30 |
| 33 // Returns true if the host Document or any child documents have any | 31 // Returns true if the page has event handlers of the specified class. |
| 34 // registered event handlers of the class. | |
| 35 bool hasEventHandlers(EventHandlerClass) const; | 32 bool hasEventHandlers(EventHandlerClass) const; |
| 36 | 33 |
| 37 // Returns a set of EventTargets which have registered handlers of the | 34 // 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; | 35 const EventTargetSet* eventHandlerTargets(EventHandlerClass) const; |
| 42 | 36 |
| 43 // Registration and management of event handlers attached to EventTargets. | 37 // Registration and management of event handlers attached to EventTargets. |
| 44 void didAddEventHandler(EventTarget&, const AtomicString& eventType); | 38 void didAddEventHandler(EventTarget&, const AtomicString& eventType); |
| 45 void didAddEventHandler(EventTarget&, EventHandlerClass); | 39 void didAddEventHandler(EventTarget&, EventHandlerClass); |
| 46 void didRemoveEventHandler(EventTarget&, const AtomicString& eventType); | 40 void didRemoveEventHandler(EventTarget&, const AtomicString& eventType); |
| 47 void didRemoveEventHandler(EventTarget&, EventHandlerClass); | 41 void didRemoveEventHandler(EventTarget&, EventHandlerClass); |
| 48 void didMoveFromOtherDocument(EventTarget&, Document& oldDocument); | |
| 49 void didRemoveAllEventHandlers(EventTarget&); | 42 void didRemoveAllEventHandlers(EventTarget&); |
| 43 void didMoveIntoPage(EventTarget&); |
| 44 void didMoveOutOfPage(EventTarget&); |
| 50 | 45 |
| 51 virtual void trace(Visitor*) OVERRIDE { } | 46 virtual void trace(Visitor*) OVERRIDE { } |
| 52 | 47 |
| 53 private: | 48 private: |
| 54 explicit EventHandlerRegistry(Document&); | 49 explicit EventHandlerRegistry(Page&); |
| 55 | 50 |
| 56 enum ChangeOperation { | 51 enum ChangeOperation { |
| 57 Add, // Add a new event handler. | 52 Add, // Add a new event handler. |
| 58 Remove, // Remove an existing event handler. | 53 Remove, // Remove an existing event handler. |
| 59 RemoveAll // Remove any and all existing event handlers for a given targ
et. | 54 RemoveAll // Remove any and all existing event handlers for a given targ
et. |
| 60 }; | 55 }; |
| 61 | 56 |
| 62 // Returns true if |eventType| belongs to a class this registry tracks. | 57 // Returns true if |eventType| belongs to a class this registry tracks. |
| 63 static bool eventTypeToClass(const AtomicString& eventType, EventHandlerClas
s* result); | 58 static bool eventTypeToClass(const AtomicString& eventType, EventHandlerClas
s* result); |
| 64 | 59 |
| 65 // Returns true if the operation actually added a new target or completely | 60 // Returns true if the operation actually added a new target or completely |
| 66 // removed an existing one. | 61 // removed an existing one. |
| 67 bool updateEventHandlerTargets(ChangeOperation, EventHandlerClass, EventTarg
et*); | 62 bool updateEventHandlerTargets(ChangeOperation, EventHandlerClass, EventTarg
et*); |
| 68 | 63 |
| 69 // Called on the EventHandlerRegistry of the root Document to notify | 64 // 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 | 65 // 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 | 66 // a given event class. |hasActiveHandlers| can be used to distinguish |
| 72 // between the two cases. | 67 // between the two cases. |
| 73 void notifyHasHandlersChanged(EventHandlerClass, bool hasActiveHandlers); | 68 void notifyHasHandlersChanged(EventHandlerClass, bool hasActiveHandlers); |
| 74 | 69 |
| 75 // Record a change operation to a given event handler class and notify any | 70 // Record a change operation to a given event handler class and notify any |
| 76 // parent registry and other clients accordingly. | 71 // parent registry and other clients accordingly. |
| 77 void updateEventHandlerOfType(ChangeOperation, const AtomicString& eventType
, EventTarget*); | 72 void updateEventHandlerOfType(ChangeOperation, const AtomicString& eventType
, EventTarget*); |
| 78 | 73 |
| 79 void updateEventHandlerInternal(ChangeOperation, EventHandlerClass, EventTar
get*); | 74 void updateEventHandlerInternal(ChangeOperation, EventHandlerClass, EventTar
get*); |
| 80 | 75 |
| 81 struct HandlerState { | 76 void updateAllEventHandlers(ChangeOperation, EventTarget&); |
| 82 HandlerState(); | |
| 83 ~HandlerState(); | |
| 84 | 77 |
| 85 OwnPtr<EventTargetSet> targets; | 78 Page& m_page; |
| 86 }; | 79 EventTargetSet m_targets[EventHandlerClassCount]; |
| 87 | |
| 88 Document& m_document; | |
| 89 HandlerState m_eventHandlers[EventHandlerClassCount]; | |
| 90 }; | 80 }; |
| 91 | 81 |
| 92 } // namespace WebCore | 82 } // namespace WebCore |
| 93 | 83 |
| 94 #endif // EventHandlerRegistry_h | 84 #endif // EventHandlerRegistry_h |
| OLD | NEW |