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

Unified Diff: chrome/browser/extensions/api/tabs/tabs_windows_api.cc

Issue 23724026: BrowserEventRouter -> TabsEventRouter (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 7 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/extensions/api/tabs/tabs_windows_api.cc
diff --git a/chrome/browser/extensions/api/tabs/tabs_windows_api.cc b/chrome/browser/extensions/api/tabs/tabs_windows_api.cc
index 5f40de264d73ec1b98935d6e59d00dcd19e17750..605a7108b10174eb56a4727d578d5862e44bba97 100644
--- a/chrome/browser/extensions/api/tabs/tabs_windows_api.cc
+++ b/chrome/browser/extensions/api/tabs/tabs_windows_api.cc
@@ -5,23 +5,49 @@
#include "chrome/browser/extensions/api/tabs/tabs_windows_api.h"
#include "base/lazy_instance.h"
+#include "chrome/browser/extensions/api/tabs/tabs_event_router.h"
#include "chrome/browser/extensions/api/tabs/windows_event_router.h"
#include "chrome/browser/extensions/event_router.h"
#include "chrome/browser/extensions/extension_system.h"
+#include "chrome/common/extensions/api/tabs.h"
#include "chrome/common/extensions/api/windows.h"
namespace extensions {
-namespace windows = api::windows;
+TabsWindowsAPI::TabsWindowsAPI(Profile* profile) : profile_(profile) {
+ // Tabs API Events.
+ ExtensionSystem::Get(profile_)->event_router()->RegisterObserver(
+ this, api::tabs::OnCreated::kEventName);
+ ExtensionSystem::Get(profile_)->event_router()->RegisterObserver(
+ this, api::tabs::OnUpdated::kEventName);
+ ExtensionSystem::Get(profile_)->event_router()->RegisterObserver(
+ this, api::tabs::OnMoved::kEventName);
+ ExtensionSystem::Get(profile_)->event_router()->RegisterObserver(
+ this, api::tabs::OnSelectionChanged::kEventName);
+ ExtensionSystem::Get(profile_)->event_router()->RegisterObserver(
+ this, api::tabs::OnActiveChanged::kEventName);
+ ExtensionSystem::Get(profile_)->event_router()->RegisterObserver(
+ this, api::tabs::OnActivated::kEventName);
+ ExtensionSystem::Get(profile_)->event_router()->RegisterObserver(
+ this, api::tabs::OnHighlightChanged::kEventName);
+ ExtensionSystem::Get(profile_)->event_router()->RegisterObserver(
+ this, api::tabs::OnHighlighted::kEventName);
+ ExtensionSystem::Get(profile_)->event_router()->RegisterObserver(
+ this, api::tabs::OnDetached::kEventName);
+ ExtensionSystem::Get(profile_)->event_router()->RegisterObserver(
+ this, api::tabs::OnAttached::kEventName);
+ ExtensionSystem::Get(profile_)->event_router()->RegisterObserver(
+ this, api::tabs::OnRemoved::kEventName);
+ ExtensionSystem::Get(profile_)->event_router()->RegisterObserver(
+ this, api::tabs::OnReplaced::kEventName);
-TabsWindowsAPI::TabsWindowsAPI(Profile* profile)
- : profile_(profile) {
+ // Windows API Events.
ExtensionSystem::Get(profile_)->event_router()->RegisterObserver(
- this, windows::OnCreated::kEventName);
+ this, api::windows::OnCreated::kEventName);
ExtensionSystem::Get(profile_)->event_router()->RegisterObserver(
- this, windows::OnRemoved::kEventName);
+ this, api::windows::OnRemoved::kEventName);
ExtensionSystem::Get(profile_)->event_router()->RegisterObserver(
- this, windows::OnFocusChanged::kEventName);
+ this, api::windows::OnFocusChanged::kEventName);
}
TabsWindowsAPI::~TabsWindowsAPI() {
@@ -32,6 +58,12 @@ TabsWindowsAPI* TabsWindowsAPI::Get(Profile* profile) {
return ProfileKeyedAPIFactory<TabsWindowsAPI>::GetForProfile(profile);
}
+TabsEventRouter* TabsWindowsAPI::tabs_event_router() {
+ if (!tabs_event_router_.get())
+ tabs_event_router_.reset(new TabsEventRouter(profile_));
+ return tabs_event_router_.get();
+}
+
WindowsEventRouter* TabsWindowsAPI::windows_event_router() {
if (!windows_event_router_)
windows_event_router_.reset(new WindowsEventRouter(profile_));
@@ -49,8 +81,9 @@ ProfileKeyedAPIFactory<TabsWindowsAPI>* TabsWindowsAPI::GetFactoryInstance() {
return &g_factory.Get();
}
-void TabsWindowsAPI::OnListenerAdded(
- const extensions::EventListenerInfo& details) {
+void TabsWindowsAPI::OnListenerAdded(const EventListenerInfo& details) {
+ // Initialize the event routers.
+ tabs_event_router();
Devlin 2013/09/10 00:47:37 If we *really* wanted to, we could separate out in
windows_event_router();
ExtensionSystem::Get(profile_)->event_router()->UnregisterObserver(this);
}

Powered by Google App Engine
This is Rietveld 408576698