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

Side by Side Diff: chrome/browser/extensions/extension_browser_event_router.h

Issue 2111010: fix chrome.tabs.onUpdated bugs, add browsertest (Closed) Base URL: http://src.chromium.org/git/chromium.git
Patch Set: more cr changes Created 10 years, 7 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
« no previous file with comments | « no previous file | chrome/browser/extensions/extension_browser_event_router.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2009 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 CHROME_BROWSER_EXTENSIONS_EXTENSION_BROWSER_EVENT_ROUTER_H_ 5 #ifndef CHROME_BROWSER_EXTENSIONS_EXTENSION_BROWSER_EVENT_ROUTER_H_
6 #define CHROME_BROWSER_EXTENSIONS_EXTENSION_BROWSER_EVENT_ROUTER_H_ 6 #define CHROME_BROWSER_EXTENSIONS_EXTENSION_BROWSER_EVENT_ROUTER_H_
7 7
8 #include <map> 8 #include <map>
9 #include <string> 9 #include <string>
10 10
(...skipping 97 matching lines...) Expand 10 before | Expand all | Expand 10 after
108 // - distinguish between tab creation and tab insertion 108 // - distinguish between tab creation and tab insertion
109 // - not send tab-detached after tab-removed 109 // - not send tab-detached after tab-removed
110 // - reduce the "noise" of TabChangedAt() when sending events to extensions 110 // - reduce the "noise" of TabChangedAt() when sending events to extensions
111 class TabEntry { 111 class TabEntry {
112 public: 112 public:
113 // Create a new tab entry whose initial state is TAB_COMPLETE. This 113 // Create a new tab entry whose initial state is TAB_COMPLETE. This
114 // constructor is required because TabEntry objects placed inside an 114 // constructor is required because TabEntry objects placed inside an
115 // std::map<> by value. 115 // std::map<> by value.
116 TabEntry(); 116 TabEntry();
117 117
118 // Create a new tab entry whose initial state is derived from the given
119 // tab contents.
120 explicit TabEntry(const TabContents* contents);
121
122 // Returns the current state of the tab.
123 ExtensionTabUtil::TabStatus state() const { return state_; }
124
125 // Update the load state of the tab based on its TabContents. Returns true 118 // Update the load state of the tab based on its TabContents. Returns true
126 // if the state changed, false otherwise. Whether the state has changed or 119 // if the state changed, false otherwise. Whether the state has changed or
127 // not is used to determine if events needs to be sent to extensions during 120 // not is used to determine if events needs to be sent to extensions during
128 // processing of TabChangedAt(). This method will "hold" a state-change 121 // processing of TabChangedAt(). This method will "hold" a state-change
129 // to "loading", until the DidNavigate() method which should always follow 122 // to "loading", until the DidNavigate() method which should always follow
130 // it. Returns NULL if no updates should be sent. 123 // it. Returns NULL if no updates should be sent.
131 DictionaryValue* UpdateLoadState(const TabContents* contents); 124 DictionaryValue* UpdateLoadState(const TabContents* contents);
132 125
133 // Indicates that a tab load has resulted in a navigation and the 126 // Indicates that a tab load has resulted in a navigation and the
134 // destination url is available for inspection. Returns NULL if no updates 127 // destination url is available for inspection. Returns NULL if no updates
135 // should be sent. 128 // should be sent.
136 DictionaryValue* DidNavigate(const TabContents* contents); 129 DictionaryValue* DidNavigate(const TabContents* contents);
137 130
138 private: 131 private:
139 // Tab state used for last notification to extensions. 132 // Whether we are waiting to fire the 'complete' status change. This will
140 ExtensionTabUtil::TabStatus state_; 133 // occur the first time the TabContents stops loading after the
141 134 // NAV_ENTRY_COMMITTED was fired. The tab may go back into and out of the
142 // Remember that the LOADING state has been captured, but not yet reported 135 // loading state subsequently, but we will ignore those changes.
143 // because it is waiting on the navigation event to know what the 136 bool complete_waiting_on_load_;
144 // destination url is.
145 bool pending_navigate_;
146 137
147 GURL url_; 138 GURL url_;
148 }; 139 };
149 140
150 std::map<int, TabEntry> tab_entries_; 141 std::map<int, TabEntry> tab_entries_;
151 142
152 DISALLOW_COPY_AND_ASSIGN(ExtensionBrowserEventRouter); 143 DISALLOW_COPY_AND_ASSIGN(ExtensionBrowserEventRouter);
153 }; 144 };
154 145
155 #endif // CHROME_BROWSER_EXTENSIONS_EXTENSION_BROWSER_EVENT_ROUTER_H_ 146 #endif // CHROME_BROWSER_EXTENSIONS_EXTENSION_BROWSER_EVENT_ROUTER_H_
OLDNEW
« no previous file with comments | « no previous file | chrome/browser/extensions/extension_browser_event_router.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698