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

Side by Side Diff: chrome/browser/extensions/event_router.cc

Issue 10836341: Add the basic code skeleton for system info event router (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: update with using std::string.size() instead of strlen Created 8 years, 3 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 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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 #include "chrome/browser/extensions/event_router.h" 5 #include "chrome/browser/extensions/event_router.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/command_line.h" 8 #include "base/command_line.h"
9 #include "base/message_loop.h" 9 #include "base/message_loop.h"
10 #include "base/values.h" 10 #include "base/values.h"
11 #include "chrome/browser/browser_process.h" 11 #include "chrome/browser/browser_process.h"
12 #include "chrome/browser/extensions/api/runtime/runtime_api.h" 12 #include "chrome/browser/extensions/api/runtime/runtime_api.h"
13 #include "chrome/browser/extensions/api/web_request/web_request_api.h" 13 #include "chrome/browser/extensions/api/web_request/web_request_api.h"
14 #include "chrome/browser/extensions/extension_devtools_manager.h" 14 #include "chrome/browser/extensions/extension_devtools_manager.h"
15 #include "chrome/browser/extensions/extension_host.h" 15 #include "chrome/browser/extensions/extension_host.h"
16 #include "chrome/browser/extensions/extension_process_manager.h" 16 #include "chrome/browser/extensions/extension_process_manager.h"
17 #include "chrome/browser/extensions/extension_processes_api.h" 17 #include "chrome/browser/extensions/extension_processes_api.h"
18 #include "chrome/browser/extensions/extension_processes_api_constants.h" 18 #include "chrome/browser/extensions/extension_processes_api_constants.h"
19 #include "chrome/browser/extensions/extension_service.h" 19 #include "chrome/browser/extensions/extension_service.h"
20 #include "chrome/browser/extensions/extension_system.h" 20 #include "chrome/browser/extensions/extension_system.h"
21 #include "chrome/browser/extensions/event_names.h"
21 #include "chrome/browser/extensions/lazy_background_task_queue.h" 22 #include "chrome/browser/extensions/lazy_background_task_queue.h"
22 #include "chrome/browser/extensions/process_map.h" 23 #include "chrome/browser/extensions/process_map.h"
24 #include "chrome/browser/extensions/system_info_event_router.h"
23 #include "chrome/browser/profiles/profile.h" 25 #include "chrome/browser/profiles/profile.h"
24 #include "chrome/browser/profiles/profile_manager.h" 26 #include "chrome/browser/profiles/profile_manager.h"
25 #include "chrome/common/chrome_notification_types.h" 27 #include "chrome/common/chrome_notification_types.h"
26 #include "chrome/common/chrome_switches.h" 28 #include "chrome/common/chrome_switches.h"
27 #include "chrome/common/extensions/extension.h" 29 #include "chrome/common/extensions/extension.h"
28 #include "chrome/common/extensions/extension_messages.h" 30 #include "chrome/common/extensions/extension_messages.h"
29 #include "chrome/common/extensions/api/extension_api.h" 31 #include "chrome/common/extensions/api/extension_api.h"
30 #include "chrome/common/view_type.h" 32 #include "chrome/common/view_type.h"
31 #include "content/public/browser/notification_service.h" 33 #include "content/public/browser/notification_service.h"
32 #include "content/public/browser/render_process_host.h" 34 #include "content/public/browser/render_process_host.h"
(...skipping 119 matching lines...) Expand 10 before | Expand all | Expand 10 after
152 extension_devtools_manager_->AddEventListener(listener->event_name, 154 extension_devtools_manager_->AddEventListener(listener->event_name,
153 listener->process->GetID()); 155 listener->process->GetID());
154 156
155 // We lazily tell the TaskManager to start updating when listeners to the 157 // We lazily tell the TaskManager to start updating when listeners to the
156 // processes.onUpdated or processes.onUpdatedWithMemory events arrive. 158 // processes.onUpdated or processes.onUpdatedWithMemory events arrive.
157 const std::string& event_name = listener->event_name; 159 const std::string& event_name = listener->event_name;
158 if (event_name.compare(extension_processes_api_constants::kOnUpdated) == 0 || 160 if (event_name.compare(extension_processes_api_constants::kOnUpdated) == 0 ||
159 event_name.compare( 161 event_name.compare(
160 extension_processes_api_constants::kOnUpdatedWithMemory) == 0) 162 extension_processes_api_constants::kOnUpdatedWithMemory) == 0)
161 ExtensionProcessesEventRouter::GetInstance()->ListenerAdded(); 163 ExtensionProcessesEventRouter::GetInstance()->ListenerAdded();
164
165 if (SystemInfoEventRouter::IsSystemInfoEvent(event_name))
166 SystemInfoEventRouter::GetInstance()->AddEventListener(profile_,
167 event_name);
162 } 168 }
163 169
164 void EventRouter::OnListenerRemoved(const EventListener* listener) { 170 void EventRouter::OnListenerRemoved(const EventListener* listener) {
165 // We don't care about lazy events being removed. 171 // We don't care about lazy events being removed.
166 if (!listener->process) 172 if (!listener->process)
167 return; 173 return;
168 174
169 const std::string& event_name = listener->event_name; 175 const std::string& event_name = listener->event_name;
170 if (extension_devtools_manager_.get()) 176 if (extension_devtools_manager_.get())
171 extension_devtools_manager_->RemoveEventListener( 177 extension_devtools_manager_->RemoveEventListener(
172 event_name, listener->process->GetID()); 178 event_name, listener->process->GetID());
173 179
174 // If a processes.onUpdated or processes.onUpdatedWithMemory event listener 180 // If a processes.onUpdated or processes.onUpdatedWithMemory event listener
175 // is removed (or a process with one exits), then we let the extension API 181 // is removed (or a process with one exits), then we let the extension API
176 // know that it has one fewer listener. 182 // know that it has one fewer listener.
177 if (event_name.compare(extension_processes_api_constants::kOnUpdated) == 0 || 183 if (event_name.compare(extension_processes_api_constants::kOnUpdated) == 0 ||
178 event_name.compare( 184 event_name.compare(
179 extension_processes_api_constants::kOnUpdatedWithMemory) == 0) 185 extension_processes_api_constants::kOnUpdatedWithMemory) == 0)
180 ExtensionProcessesEventRouter::GetInstance()->ListenerRemoved(); 186 ExtensionProcessesEventRouter::GetInstance()->ListenerRemoved();
181 187
182 BrowserThread::PostTask( 188 BrowserThread::PostTask(
183 BrowserThread::IO, FROM_HERE, 189 BrowserThread::IO, FROM_HERE,
184 base::Bind(&NotifyEventListenerRemovedOnIOThread, 190 base::Bind(&NotifyEventListenerRemovedOnIOThread,
185 profile_, listener->extension_id, listener->event_name)); 191 profile_, listener->extension_id, listener->event_name));
192
193 if (SystemInfoEventRouter::IsSystemInfoEvent(event_name))
194 SystemInfoEventRouter::GetInstance()->RemoveEventListener(profile_,
195 event_name);
186 } 196 }
187 197
188 void EventRouter::AddLazyEventListener(const std::string& event_name, 198 void EventRouter::AddLazyEventListener(const std::string& event_name,
189 const std::string& extension_id) { 199 const std::string& extension_id) {
190 scoped_ptr<EventListener> listener(new EventListener( 200 scoped_ptr<EventListener> listener(new EventListener(
191 event_name, extension_id, NULL, scoped_ptr<DictionaryValue>())); 201 event_name, extension_id, NULL, scoped_ptr<DictionaryValue>()));
192 bool is_new = listeners_.AddListener(listener.Pass()); 202 bool is_new = listeners_.AddListener(listener.Pass());
193 203
194 if (is_new) { 204 if (is_new) {
195 ExtensionPrefs* prefs = 205 ExtensionPrefs* prefs =
(...skipping 406 matching lines...) Expand 10 before | Expand all | Expand 10 after
602 event_args(event_args.Pass()), 612 event_args(event_args.Pass()),
603 event_url(event_url), 613 event_url(event_url),
604 restrict_to_profile(restrict_to_profile), 614 restrict_to_profile(restrict_to_profile),
605 cross_incognito_args(NULL), 615 cross_incognito_args(NULL),
606 user_gesture(user_gesture), 616 user_gesture(user_gesture),
607 info(info) {} 617 info(info) {}
608 618
609 Event::~Event() {} 619 Event::~Event() {}
610 620
611 } // namespace extensions 621 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698