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

Side by Side Diff: Source/core/dom/DocumentLifecycleNotifier.h

Issue 206603002: Add EventHandlerRegistry (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Added comments. Replaced nullptr with 0 to fix build. Created 6 years, 8 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) 2013 Google Inc. All Rights Reserved. 2 * Copyright (C) 2013 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 5 * modification, are permitted provided that the following conditions
6 * are met: 6 * are met:
7 * 1. Redistributions of source code must retain the above copyright 7 * 1. Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer. 8 * notice, this list of conditions and the following disclaimer.
9 * 2. Redistributions in binary form must reproduce the above copyright 9 * 2. Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the 10 * notice, this list of conditions and the following disclaimer in the
(...skipping 20 matching lines...) Expand all
31 #include "wtf/TemporaryChange.h" 31 #include "wtf/TemporaryChange.h"
32 32
33 namespace WebCore { 33 namespace WebCore {
34 34
35 class Document; 35 class Document;
36 36
37 class DocumentLifecycleNotifier : public LifecycleNotifier<Document> { 37 class DocumentLifecycleNotifier : public LifecycleNotifier<Document> {
38 public: 38 public:
39 static PassOwnPtr<DocumentLifecycleNotifier> create(Document*); 39 static PassOwnPtr<DocumentLifecycleNotifier> create(Document*);
40 40
41 void notifyDocumentWasAttached();
41 void notifyDocumentWasDetached(); 42 void notifyDocumentWasDetached();
43 void notifyWillDetachDocument();
42 void notifyDocumentWasDisposed(); 44 void notifyDocumentWasDisposed();
abarth-chromium 2014/04/10 21:25:58 Can we sort these in the order they are called?
Sami 2014/04/11 16:46:53 Done (removed willDetach).
43 45
44 virtual void addObserver(Observer*) OVERRIDE FINAL; 46 virtual void addObserver(Observer*) OVERRIDE FINAL;
45 virtual void removeObserver(Observer*) OVERRIDE FINAL; 47 virtual void removeObserver(Observer*) OVERRIDE FINAL;
46 48
47 private: 49 private:
48 explicit DocumentLifecycleNotifier(Document*); 50 explicit DocumentLifecycleNotifier(Document*);
49 51
50 typedef HashSet<DocumentLifecycleObserver*> DocumentObserverSet; 52 typedef HashSet<DocumentLifecycleObserver*> DocumentObserverSet;
51 DocumentObserverSet m_documentObservers; 53 DocumentObserverSet m_documentObservers;
52 }; 54 };
53 55
54 inline PassOwnPtr<DocumentLifecycleNotifier> DocumentLifecycleNotifier::create(D ocument* document) 56 inline PassOwnPtr<DocumentLifecycleNotifier> DocumentLifecycleNotifier::create(D ocument* document)
55 { 57 {
56 return adoptPtr(new DocumentLifecycleNotifier(document)); 58 return adoptPtr(new DocumentLifecycleNotifier(document));
57 } 59 }
58 60
61 inline void DocumentLifecycleNotifier::notifyDocumentWasAttached()
62 {
63 TemporaryChange<IterationType> scope(this->m_iterating, IteratingOverDocumen tObservers);
64 for (DocumentObserverSet::iterator i = m_documentObservers.begin(); i != m_d ocumentObservers.end(); ++i)
65 (*i)->documentWasAttached();
66 }
67
68 inline void DocumentLifecycleNotifier::notifyWillDetachDocument()
69 {
70 TemporaryChange<IterationType> scope(this->m_iterating, IteratingOverDocumen tObservers);
71 for (DocumentObserverSet::iterator i = m_documentObservers.begin(); i != m_d ocumentObservers.end(); ++i)
72 (*i)->willDetachDocument();
73 }
74
59 inline void DocumentLifecycleNotifier::notifyDocumentWasDetached() 75 inline void DocumentLifecycleNotifier::notifyDocumentWasDetached()
60 { 76 {
61 TemporaryChange<IterationType> scope(this->m_iterating, IteratingOverDocumen tObservers); 77 TemporaryChange<IterationType> scope(this->m_iterating, IteratingOverDocumen tObservers);
62 for (DocumentObserverSet::iterator i = m_documentObservers.begin(); i != m_d ocumentObservers.end(); ++i) 78 for (DocumentObserverSet::iterator i = m_documentObservers.begin(); i != m_d ocumentObservers.end(); ++i)
63 (*i)->documentWasDetached(); 79 (*i)->documentWasDetached();
64 } 80 }
65 81
66 inline void DocumentLifecycleNotifier::notifyDocumentWasDisposed() 82 inline void DocumentLifecycleNotifier::notifyDocumentWasDisposed()
67 { 83 {
68 TemporaryChange<IterationType> scope(this->m_iterating, IteratingOverDocumen tObservers); 84 TemporaryChange<IterationType> scope(this->m_iterating, IteratingOverDocumen tObservers);
69 for (DocumentObserverSet::iterator i = m_documentObservers.begin(); i != m_d ocumentObservers.end(); ++i) 85 for (DocumentObserverSet::iterator i = m_documentObservers.begin(); i != m_d ocumentObservers.end(); ++i)
70 (*i)->documentWasDisposed(); 86 (*i)->documentWasDisposed();
71 } 87 }
72 88
73 } // namespace WebCore 89 } // namespace WebCore
74 90
75 #endif // DocumentLifecycleNotifier_h 91 #endif // DocumentLifecycleNotifier_h
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698