summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--chrome/browser/profiles/off_the_record_profile_impl.cc40
-rw-r--r--chrome/browser/profiles/off_the_record_profile_impl.h15
-rw-r--r--chrome/browser/profiles/off_the_record_profile_impl_unittest.cc35
-rw-r--r--chrome/browser/profiles/profile_impl.cc42
-rw-r--r--chrome/browser/profiles/profile_impl.h3
-rw-r--r--chrome/browser/ui/browser_browsertest.cc83
-rw-r--r--chrome/browser/ui/cocoa/wrench_menu/wrench_menu_controller.mm45
-rw-r--r--chrome/browser/ui/cocoa/wrench_menu/wrench_menu_controller_unittest.mm8
-rw-r--r--chrome/browser/ui/gtk/browser_toolbar_gtk.cc38
-rw-r--r--chrome/browser/ui/gtk/browser_toolbar_gtk.h4
-rw-r--r--chrome/browser/ui/gtk/location_bar_view_gtk_browsertest.cc20
-rw-r--r--chrome/browser/ui/toolbar/wrench_menu_model.cc30
-rw-r--r--chrome/browser/ui/toolbar/wrench_menu_model.h4
-rw-r--r--chrome/browser/ui/views/wrench_menu.cc27
-rw-r--r--chrome/browser/ui/zoom/zoom_controller.cc25
-rw-r--r--chrome/browser/ui/zoom/zoom_controller.h19
-rw-r--r--chrome/browser/ui/zoom/zoom_controller_unittest.cc9
-rw-r--r--content/browser/host_zoom_map_impl.cc29
-rw-r--r--content/browser/host_zoom_map_impl.h7
-rw-r--r--content/public/browser/host_zoom_map.h9
-rw-r--r--content/public/browser/notification_types.h5
21 files changed, 284 insertions, 213 deletions
diff --git a/chrome/browser/profiles/off_the_record_profile_impl.cc b/chrome/browser/profiles/off_the_record_profile_impl.cc
index ce72d61..87f30a2 100644
--- a/chrome/browser/profiles/off_the_record_profile_impl.cc
+++ b/chrome/browser/profiles/off_the_record_profile_impl.cc
@@ -44,8 +44,6 @@
#include "chrome/common/render_messages.h"
#include "content/public/browser/browser_thread.h"
#include "content/public/browser/host_zoom_map.h"
-#include "content/public/browser/notification_service.h"
-#include "content/public/browser/notification_types.h"
#include "content/public/browser/render_process_host.h"
#include "content/public/browser/storage_partition.h"
#include "content/public/browser/url_data_source.h"
@@ -87,7 +85,9 @@ OffTheRecordProfileImpl::OffTheRecordProfileImpl(Profile* real_profile)
: profile_(real_profile),
prefs_(real_profile->GetOffTheRecordPrefs()),
ALLOW_THIS_IN_INITIALIZER_LIST(io_data_(this)),
- start_time_(Time::Now()) {
+ start_time_(Time::Now()),
+ zoom_callback_(base::Bind(&OffTheRecordProfileImpl::OnZoomLevelChanged,
+ base::Unretained(this))) {
}
void OffTheRecordProfileImpl::Init() {
@@ -129,6 +129,9 @@ void OffTheRecordProfileImpl::Init() {
OffTheRecordProfileImpl::~OffTheRecordProfileImpl() {
MaybeSendDestroyedNotification();
+ HostZoomMap::GetForBrowserContext(profile_)->RemoveZoomLevelChangedCallback(
+ zoom_callback_);
+
#if defined(ENABLE_PLUGINS)
ChromePluginServiceFilter::GetInstance()->UnregisterResourceContext(
io_data_.GetResourceContextNoInit());
@@ -165,8 +168,7 @@ void OffTheRecordProfileImpl::InitHostZoomMap() {
host_zoom_map->CopyFrom(parent_host_zoom_map);
// Observe parent's HZM change for propagating change of parent's
// change to this HZM.
- registrar_.Add(this, content::NOTIFICATION_ZOOM_LEVEL_CHANGED,
- content::Source<HostZoomMap>(parent_host_zoom_map));
+ parent_host_zoom_map->AddZoomLevelChangedCallback(zoom_callback_);
}
#if defined(OS_ANDROID)
@@ -428,23 +430,6 @@ GURL OffTheRecordProfileImpl::GetHomePage() {
return profile_->GetHomePage();
}
-void OffTheRecordProfileImpl::Observe(
- int type,
- const content::NotificationSource& source,
- const content::NotificationDetails& details) {
- if (type == content::NOTIFICATION_ZOOM_LEVEL_CHANGED) {
- const std::string& host =
- *(content::Details<const std::string>(details).ptr());
- if (!host.empty()) {
- HostZoomMap* host_zoom_map = HostZoomMap::GetForBrowserContext(this);
- HostZoomMap* parent_host_zoom_map =
- HostZoomMap::GetForBrowserContext(profile_);
- double level = parent_host_zoom_map->GetZoomLevel(host);
- host_zoom_map->SetZoomLevel(host, level);
- }
- }
-}
-
#if defined(OS_CHROMEOS)
// Special case of the OffTheRecordProfileImpl which is used while Guest
// session in CrOS.
@@ -476,3 +461,14 @@ Profile* Profile::CreateOffTheRecordProfile() {
profile->Init();
return profile;
}
+
+void OffTheRecordProfileImpl::OnZoomLevelChanged(const std::string& host) {
+ if (host.empty())
+ return;
+
+ HostZoomMap* host_zoom_map = HostZoomMap::GetForBrowserContext(this);
+ HostZoomMap* parent_host_zoom_map =
+ HostZoomMap::GetForBrowserContext(profile_);
+ double level = parent_host_zoom_map->GetZoomLevel(host);
+ host_zoom_map->SetZoomLevel(host, level);
+}
diff --git a/chrome/browser/profiles/off_the_record_profile_impl.h b/chrome/browser/profiles/off_the_record_profile_impl.h
index 3066eae..8b659bd 100644
--- a/chrome/browser/profiles/off_the_record_profile_impl.h
+++ b/chrome/browser/profiles/off_the_record_profile_impl.h
@@ -11,8 +11,7 @@
#include "chrome/browser/profiles/off_the_record_profile_io_data.h"
#include "chrome/browser/profiles/profile.h"
#include "chrome/browser/ui/browser_list.h"
-#include "content/public/browser/notification_observer.h"
-#include "content/public/browser/notification_registrar.h"
+#include "content/public/browser/host_zoom_map.h"
using base::Time;
using base::TimeDelta;
@@ -26,8 +25,7 @@ using base::TimeDelta;
// Providing this header file is for unit testing.
//
////////////////////////////////////////////////////////////////////////////////
-class OffTheRecordProfileImpl : public Profile,
- public content::NotificationObserver {
+class OffTheRecordProfileImpl : public Profile {
public:
explicit OffTheRecordProfileImpl(Profile* real_profile);
virtual ~OffTheRecordProfileImpl();
@@ -105,11 +103,6 @@ class OffTheRecordProfileImpl : public Profile,
GetSpeechRecognitionPreferences() OVERRIDE;
virtual quota::SpecialStoragePolicy* GetSpecialStoragePolicy() OVERRIDE;
- // content::NotificationObserver implementation.
- virtual void Observe(int type,
- const content::NotificationSource& source,
- const content::NotificationDetails& details) OVERRIDE;
-
private:
FRIEND_TEST_ALL_PREFIXES(OffTheRecordProfileImplTest, GetHostZoomMap);
void InitHostZoomMap();
@@ -118,7 +111,7 @@ class OffTheRecordProfileImpl : public Profile,
void UseSystemProxy();
#endif
- content::NotificationRegistrar registrar_;
+ void OnZoomLevelChanged(const std::string& host);
// The real underlying profile.
Profile* profile_;
@@ -138,6 +131,8 @@ class OffTheRecordProfileImpl : public Profile,
scoped_ptr<PrefProxyConfigTracker> pref_proxy_config_tracker_;
+ content::HostZoomMap::ZoomLevelChangedCallback zoom_callback_;
+
DISALLOW_COPY_AND_ASSIGN(OffTheRecordProfileImpl);
};
diff --git a/chrome/browser/profiles/off_the_record_profile_impl_unittest.cc b/chrome/browser/profiles/off_the_record_profile_impl_unittest.cc
index b8572c5..4bd5c2b 100644
--- a/chrome/browser/profiles/off_the_record_profile_impl_unittest.cc
+++ b/chrome/browser/profiles/off_the_record_profile_impl_unittest.cc
@@ -16,24 +16,25 @@
#include "chrome/test/base/testing_pref_service.h"
#include "chrome/test/base/testing_profile.h"
#include "content/public/browser/host_zoom_map.h"
-#include "content/public/browser/notification_details.h"
-#include "content/public/browser/notification_source.h"
-#include "content/public/browser/notification_types.h"
using content::HostZoomMap;
namespace {
-class TestingProfileWithHostZoomMap : public TestingProfile,
- public content::NotificationObserver {
+class TestingProfileWithHostZoomMap : public TestingProfile {
public:
- TestingProfileWithHostZoomMap() {
- HostZoomMap* host_zoom_map = HostZoomMap::GetForBrowserContext(this);
- registrar_.Add(this, content::NOTIFICATION_ZOOM_LEVEL_CHANGED,
- content::Source<HostZoomMap>(host_zoom_map));
+ TestingProfileWithHostZoomMap()
+ : zoom_callback_(
+ base::Bind(&TestingProfileWithHostZoomMap::OnZoomLevelChanged,
+ base::Unretained(this))) {
+ HostZoomMap::GetForBrowserContext(this)->AddZoomLevelChangedCallback(
+ zoom_callback_);
}
- virtual ~TestingProfileWithHostZoomMap() {}
+ virtual ~TestingProfileWithHostZoomMap() {
+ HostZoomMap::GetForBrowserContext(this)->RemoveZoomLevelChangedCallback(
+ zoom_callback_);
+ }
virtual Profile* GetOffTheRecordProfile() OVERRIDE {
if (!off_the_record_profile_.get())
@@ -45,12 +46,8 @@ class TestingProfileWithHostZoomMap : public TestingProfile,
return GetPrefs();
}
- virtual void Observe(int type,
- const content::NotificationSource& source,
- const content::NotificationDetails& details) OVERRIDE {
- const std::string& host =
- *(content::Details<const std::string>(details).ptr());
- DCHECK(type == content::NOTIFICATION_ZOOM_LEVEL_CHANGED);
+ private:
+ void OnZoomLevelChanged(const std::string& host) {
if (host.empty())
return;
@@ -66,11 +63,11 @@ class TestingProfileWithHostZoomMap : public TestingProfile,
}
}
- private:
- content::NotificationRegistrar registrar_;
scoped_ptr<Profile> off_the_record_profile_;
scoped_ptr<SSLConfigServiceManager> ssl_config_service_manager_;
+ content::HostZoomMap::ZoomLevelChangedCallback zoom_callback_;
+
DISALLOW_COPY_AND_ASSIGN(TestingProfileWithHostZoomMap);
};
@@ -138,7 +135,7 @@ TEST_F(OffTheRecordProfileImplTest, GetHostZoomMap) {
ASSERT_EQ(parent_zoom_map->GetZoomLevel(host), zoom_level_25);
// TODO(yosin) We need to wait ProfileImpl::Observe done for
- // NOTIFICATION_ZOOM_LEVEL_CHANGED.
+ // OnZoomLevelChanged.
// Prepare child profile as off the record profile.
scoped_ptr<OffTheRecordProfileImpl> child_profile(
diff --git a/chrome/browser/profiles/profile_impl.cc b/chrome/browser/profiles/profile_impl.cc
index ddb9b5a..06716b8 100644
--- a/chrome/browser/profiles/profile_impl.cc
+++ b/chrome/browser/profiles/profile_impl.cc
@@ -322,7 +322,9 @@ ProfileImpl::ProfileImpl(
Delegate* delegate,
CreateMode create_mode,
base::SequencedTaskRunner* sequenced_task_runner)
- : path_(path),
+ : zoom_callback_(base::Bind(&ProfileImpl::OnZoomLevelChanged,
+ base::Unretained(this))),
+ path_(path),
ALLOW_THIS_IN_INITIALIZER_LIST(io_data_(this)),
host_content_settings_map_(NULL),
last_session_exit_type_(EXIT_NORMAL),
@@ -567,8 +569,7 @@ void ProfileImpl::InitHostZoomMap() {
}
}
- registrar_.Add(this, content::NOTIFICATION_ZOOM_LEVEL_CHANGED,
- content::Source<HostZoomMap>(host_zoom_map));
+ host_zoom_map->AddZoomLevelChangedCallback(zoom_callback_);
}
FilePath ProfileImpl::last_selected_directory() {
@@ -582,6 +583,9 @@ void ProfileImpl::set_last_selected_directory(const FilePath& path) {
ProfileImpl::~ProfileImpl() {
MaybeSendDestroyedNotification();
+ HostZoomMap::GetForBrowserContext(this)->RemoveZoomLevelChangedCallback(
+ zoom_callback_);
+
bool prefs_loaded = prefs_->GetInitializationStatus() !=
PrefService::INITIALIZATION_STATUS_WAITING;
@@ -930,23 +934,6 @@ void ProfileImpl::Observe(int type,
registrar_.Remove(this, chrome::NOTIFICATION_BOOKMARK_MODEL_LOADED,
content::Source<Profile>(this));
break;
- case content::NOTIFICATION_ZOOM_LEVEL_CHANGED: {
- const std::string& host =
- *(content::Details<const std::string>(details).ptr());
- if (!host.empty()) {
- HostZoomMap* host_zoom_map = HostZoomMap::GetForBrowserContext(this);
- double level = host_zoom_map->GetZoomLevel(host);
- DictionaryPrefUpdate update(prefs_.get(), prefs::kPerHostZoomLevels);
- DictionaryValue* host_zoom_dictionary = update.Get();
- if (level == host_zoom_map->GetDefaultZoomLevel()) {
- host_zoom_dictionary->RemoveWithoutPathExpansion(host, NULL);
- } else {
- host_zoom_dictionary->SetWithoutPathExpansion(
- host, Value::CreateDoubleValue(level));
- }
- }
- break;
- }
default:
NOTREACHED();
}
@@ -957,6 +944,21 @@ void ProfileImpl::OnDefaultZoomLevelChanged() {
pref_change_registrar_.prefs()->GetDouble(prefs::kDefaultZoomLevel));
}
+void ProfileImpl::OnZoomLevelChanged(const std::string& host) {
+ if (host.empty())
+ return;
+ HostZoomMap* host_zoom_map = HostZoomMap::GetForBrowserContext(this);
+ double level = host_zoom_map->GetZoomLevel(host);
+ DictionaryPrefUpdate update(prefs_.get(), prefs::kPerHostZoomLevels);
+ DictionaryValue* host_zoom_dictionary = update.Get();
+ if (level == host_zoom_map->GetDefaultZoomLevel()) {
+ host_zoom_dictionary->RemoveWithoutPathExpansion(host, NULL);
+ } else {
+ host_zoom_dictionary->SetWithoutPathExpansion(
+ host, Value::CreateDoubleValue(level));
+ }
+}
+
#if defined(ENABLE_SESSION_SERVICE)
void ProfileImpl::StopCreateSessionServiceTimer() {
create_session_service_timer_.Stop();
diff --git a/chrome/browser/profiles/profile_impl.h b/chrome/browser/profiles/profile_impl.h
index 87d2c1d..2c81c8c 100644
--- a/chrome/browser/profiles/profile_impl.h
+++ b/chrome/browser/profiles/profile_impl.h
@@ -19,6 +19,7 @@
#include "chrome/browser/profiles/profile_impl_io_data.h"
#include "content/public/browser/notification_observer.h"
#include "content/public/browser/notification_registrar.h"
+#include "content/public/browser/host_zoom_map.h"
class NetPrefObserver;
class PrefServiceSyncable;
@@ -159,6 +160,7 @@ class ProfileImpl : public Profile,
void InitHostZoomMap();
void OnDefaultZoomLevelChanged();
+ void OnZoomLevelChanged(const std::string& host);
void OnInitializationCompleted(PrefServiceBase* pref_service,
bool succeeded);
@@ -190,6 +192,7 @@ class ProfileImpl : public Profile,
int* max_size);
content::NotificationRegistrar registrar_;
+ content::HostZoomMap::ZoomLevelChangedCallback zoom_callback_;
PrefChangeRegistrar pref_change_registrar_;
FilePath path_;
diff --git a/chrome/browser/ui/browser_browsertest.cc b/chrome/browser/ui/browser_browsertest.cc
index 26275a5..5ec5439 100644
--- a/chrome/browser/ui/browser_browsertest.cc
+++ b/chrome/browser/ui/browser_browsertest.cc
@@ -49,11 +49,10 @@
#include "chrome/test/base/in_process_browser_test.h"
#include "chrome/test/base/ui_test_utils.h"
#include "content/public/browser/favicon_status.h"
+#include "content/public/browser/host_zoom_map.h"
#include "content/public/browser/interstitial_page.h"
#include "content/public/browser/interstitial_page_delegate.h"
#include "content/public/browser/navigation_entry.h"
-#include "content/public/browser/notification_service.h"
-#include "content/public/browser/notification_source.h"
#include "content/public/browser/render_process_host.h"
#include "content/public/browser/render_view_host.h"
#include "content/public/browser/render_widget_host_view.h"
@@ -1322,6 +1321,15 @@ IN_PROC_BROWSER_TEST_F(BrowserTest,
EXPECT_FALSE(command_updater->IsCommandEnabled(IDC_IMPORT_SETTINGS));
}
+namespace {
+
+void OnZoomLevelChanged(const base::Closure& callback,
+ const std::string& host) {
+ callback.Run();
+}
+
+} // namespace
+
#if defined(OS_WIN)
// Flakes regularly on Windows XP
// http://crbug.com/146040
@@ -1333,32 +1341,53 @@ IN_PROC_BROWSER_TEST_F(BrowserTest, MAYBE_PageZoom) {
WebContents* contents = browser()->tab_strip_model()->GetActiveWebContents();
bool enable_plus, enable_minus;
- content::WindowedNotificationObserver zoom_in_observer(
- content::NOTIFICATION_ZOOM_LEVEL_CHANGED,
- content::NotificationService::AllSources());
- chrome::Zoom(browser(), content::PAGE_ZOOM_IN);
- zoom_in_observer.Wait();
- EXPECT_EQ(contents->GetZoomPercent(&enable_plus, &enable_minus), 110);
- EXPECT_TRUE(enable_plus);
- EXPECT_TRUE(enable_minus);
-
- content::WindowedNotificationObserver zoom_reset_observer(
- content::NOTIFICATION_ZOOM_LEVEL_CHANGED,
- content::NotificationService::AllSources());
- chrome::Zoom(browser(), content::PAGE_ZOOM_RESET);
- zoom_reset_observer.Wait();
- EXPECT_EQ(contents->GetZoomPercent(&enable_plus, &enable_minus), 100);
- EXPECT_TRUE(enable_plus);
- EXPECT_TRUE(enable_minus);
+ {
+ scoped_refptr<content::MessageLoopRunner> loop_runner(
+ new content::MessageLoopRunner);
+ content::HostZoomMap::ZoomLevelChangedCallback callback(
+ base::Bind(&OnZoomLevelChanged, loop_runner->QuitClosure()));
+ content::HostZoomMap::GetForBrowserContext(
+ browser()->profile())->AddZoomLevelChangedCallback(callback);
+ chrome::Zoom(browser(), content::PAGE_ZOOM_IN);
+ loop_runner->Run();
+ content::HostZoomMap::GetForBrowserContext(
+ browser()->profile())->RemoveZoomLevelChangedCallback(callback);
+ EXPECT_EQ(contents->GetZoomPercent(&enable_plus, &enable_minus), 110);
+ EXPECT_TRUE(enable_plus);
+ EXPECT_TRUE(enable_minus);
+ }
- content::WindowedNotificationObserver zoom_out_observer(
- content::NOTIFICATION_ZOOM_LEVEL_CHANGED,
- content::NotificationService::AllSources());
- chrome::Zoom(browser(), content::PAGE_ZOOM_OUT);
- zoom_out_observer.Wait();
- EXPECT_EQ(contents->GetZoomPercent(&enable_plus, &enable_minus), 90);
- EXPECT_TRUE(enable_plus);
- EXPECT_TRUE(enable_minus);
+ {
+ scoped_refptr<content::MessageLoopRunner> loop_runner(
+ new content::MessageLoopRunner);
+ content::HostZoomMap::ZoomLevelChangedCallback callback(
+ base::Bind(&OnZoomLevelChanged, loop_runner->QuitClosure()));
+ content::HostZoomMap::GetForBrowserContext(
+ browser()->profile())->AddZoomLevelChangedCallback(callback);
+ chrome::Zoom(browser(), content::PAGE_ZOOM_RESET);
+ loop_runner->Run();
+ content::HostZoomMap::GetForBrowserContext(
+ browser()->profile())->RemoveZoomLevelChangedCallback(callback);
+ EXPECT_EQ(contents->GetZoomPercent(&enable_plus, &enable_minus), 100);
+ EXPECT_TRUE(enable_plus);
+ EXPECT_TRUE(enable_minus);
+ }
+
+ {
+ scoped_refptr<content::MessageLoopRunner> loop_runner(
+ new content::MessageLoopRunner);
+ content::HostZoomMap::ZoomLevelChangedCallback callback(
+ base::Bind(&OnZoomLevelChanged, loop_runner->QuitClosure()));
+ content::HostZoomMap::GetForBrowserContext(
+ browser()->profile())->AddZoomLevelChangedCallback(callback);
+ chrome::Zoom(browser(), content::PAGE_ZOOM_OUT);
+ loop_runner->Run();
+ content::HostZoomMap::GetForBrowserContext(
+ browser()->profile())->RemoveZoomLevelChangedCallback(callback);
+ EXPECT_EQ(contents->GetZoomPercent(&enable_plus, &enable_minus), 90);
+ EXPECT_TRUE(enable_plus);
+ EXPECT_TRUE(enable_minus);
+ }
chrome::Zoom(browser(), content::PAGE_ZOOM_RESET);
}
diff --git a/chrome/browser/ui/cocoa/wrench_menu/wrench_menu_controller.mm b/chrome/browser/ui/cocoa/wrench_menu/wrench_menu_controller.mm
index bb87814..8f1cc87 100644
--- a/chrome/browser/ui/cocoa/wrench_menu/wrench_menu_controller.mm
+++ b/chrome/browser/ui/cocoa/wrench_menu/wrench_menu_controller.mm
@@ -22,11 +22,6 @@
#import "chrome/browser/ui/cocoa/wrench_menu/recent_tabs_menu_model_delegate.h"
#include "chrome/browser/ui/toolbar/recent_tabs_sub_menu_model.h"
#include "chrome/browser/ui/toolbar/wrench_menu_model.h"
-#include "content/public/browser/host_zoom_map.h"
-#include "content/public/browser/notification_observer.h"
-#include "content/public/browser/notification_service.h"
-#include "content/public/browser/notification_source.h"
-#include "content/public/browser/notification_types.h"
#include "content/public/browser/user_metrics.h"
#include "grit/chromium_strings.h"
#include "grit/generated_resources.h"
@@ -64,35 +59,36 @@ class AcceleratorDelegate : public ui::AcceleratorProvider {
}
};
-class ZoomLevelObserver : public content::NotificationObserver {
+class ZoomLevelObserver {
public:
- explicit ZoomLevelObserver(WrenchMenuController* controller)
- : controller_(controller) {
- registrar_.Add(
- this, content::NOTIFICATION_ZOOM_LEVEL_CHANGED,
- content::NotificationService::AllBrowserContextsAndSources());
+ ZoomLevelObserver(WrenchMenuController* controller,
+ content::HostZoomMap* map)
+ : callback_(base::Bind(&ZoomLevelObserver::OnZoomLevelChanged,
+ base::Unretained(this))),
+ controller_(controller),
+ map_(map) {
+ map_->AddZoomLevelChangedCallback(callback_);
}
- void Observe(int type,
- const content::NotificationSource& source,
- const content::NotificationDetails& details) {
- DCHECK_EQ(type, content::NOTIFICATION_ZOOM_LEVEL_CHANGED);
- WrenchMenuModel* wrenchMenuModel = [controller_ wrenchMenuModel];
- if (HostZoomMap::GetForBrowserContext(
- wrenchMenuModel->browser()->profile()) !=
- content::Source<HostZoomMap>(source).ptr()) {
- return;
- }
+ ~ZoomLevelObserver() {
+ map_->RemoveZoomLevelChangedCallback(callback_);
+ }
+ private:
+ void OnZoomLevelChanged(const std::string& host) {
+ WrenchMenuModel* wrenchMenuModel = [controller_ wrenchMenuModel];
wrenchMenuModel->UpdateZoomControls();
const string16 level =
wrenchMenuModel->GetLabelForCommandId(IDC_ZOOM_PERCENT_DISPLAY);
[[controller_ zoomDisplay] setTitle:SysUTF16ToNSString(level)];
}
- private:
- content::NotificationRegistrar registrar_;
+ content::HostZoomMap::ZoomLevelChangedCallback callback_;
+
WrenchMenuController* controller_; // Weak; owns this.
+ content::HostZoomMap* map_; // Weak.
+
+ DISALLOW_COPY_AND_ASSIGN(ZoomLevelObserver);
};
} // namespace WrenchMenuControllerInternal
@@ -102,7 +98,8 @@ class ZoomLevelObserver : public content::NotificationObserver {
- (id)initWithBrowser:(Browser*)browser {
if ((self = [super init])) {
browser_ = browser;
- observer_.reset(new WrenchMenuControllerInternal::ZoomLevelObserver(self));
+ observer_.reset(new WrenchMenuControllerInternal::ZoomLevelObserver(
+ self, content::HostZoomMap::GetForBrowserContext(browser->profile())));
acceleratorDelegate_.reset(
new WrenchMenuControllerInternal::AcceleratorDelegate());
[self createModel];
diff --git a/chrome/browser/ui/cocoa/wrench_menu/wrench_menu_controller_unittest.mm b/chrome/browser/ui/cocoa/wrench_menu/wrench_menu_controller_unittest.mm
index f4f351b..a9aa99f 100644
--- a/chrome/browser/ui/cocoa/wrench_menu/wrench_menu_controller_unittest.mm
+++ b/chrome/browser/ui/cocoa/wrench_menu/wrench_menu_controller_unittest.mm
@@ -44,7 +44,7 @@ class MockWrenchMenuModel : public WrenchMenuModel {
class WrenchMenuControllerTest : public CocoaProfileTest {
public:
- virtual void SetUp() {
+ virtual void SetUp() OVERRIDE {
CocoaProfileTest::SetUp();
ASSERT_TRUE(browser());
@@ -52,6 +52,12 @@ class WrenchMenuControllerTest : public CocoaProfileTest {
fake_model_.reset(new MockWrenchMenuModel);
}
+ virtual void TearDown() OVERRIDE {
+ fake_model_.reset();
+ controller_.reset();
+ CocoaProfileTest::TearDown();
+ }
+
WrenchMenuController* controller() {
return controller_.get();
}
diff --git a/chrome/browser/ui/gtk/browser_toolbar_gtk.cc b/chrome/browser/ui/gtk/browser_toolbar_gtk.cc
index 11e1b2b..45b4581 100644
--- a/chrome/browser/ui/gtk/browser_toolbar_gtk.cc
+++ b/chrome/browser/ui/gtk/browser_toolbar_gtk.cc
@@ -99,7 +99,9 @@ BrowserToolbarGtk::BrowserToolbarGtk(Browser* browser, BrowserWindowGtk* window)
model_(browser->toolbar_model()),
is_wrench_menu_model_valid_(true),
browser_(browser),
- window_(window) {
+ window_(window),
+ zoom_callback_(base::Bind(&BrowserToolbarGtk::OnZoomLevelChanged,
+ base::Unretained(this))) {
wrench_menu_model_.reset(new WrenchMenuModel(this, browser_, false, false));
chrome::AddCommandObserver(browser_, IDC_BACK, this);
@@ -124,6 +126,9 @@ BrowserToolbarGtk::~BrowserToolbarGtk() {
offscreen_entry_.Destroy();
wrench_menu_.reset();
+
+ HostZoomMap::GetForBrowserContext(
+ browser()->profile())->RemoveZoomLevelChangedCallback(zoom_callback_);
}
void BrowserToolbarGtk::Init(GtkWindow* top_level_window) {
@@ -241,9 +246,8 @@ void BrowserToolbarGtk::Init(GtkWindow* top_level_window) {
// The bookmark menu model needs to be able to force the wrench menu to close.
wrench_menu_model_->bookmark_sub_menu_model()->SetMenuGtk(wrench_menu_.get());
- registrar_.Add(this, content::NOTIFICATION_ZOOM_LEVEL_CHANGED,
- content::Source<HostZoomMap>(
- HostZoomMap::GetForBrowserContext(profile)));
+ HostZoomMap::GetForBrowserContext(
+ browser()->profile())->AddZoomLevelChangedCallback(zoom_callback_);
if (ShouldOnlyShowLocation()) {
gtk_widget_show(event_box_);
@@ -416,18 +420,6 @@ void BrowserToolbarGtk::Observe(int type,
} else if (type == chrome::NOTIFICATION_GLOBAL_ERRORS_CHANGED) {
is_wrench_menu_model_valid_ = false;
gtk_widget_queue_draw(wrench_menu_button_->widget());
- } else if (type == content::NOTIFICATION_ZOOM_LEVEL_CHANGED) {
- // Since BrowserToolbarGtk create a new |wrench_menu_model_| in
- // RebuildWrenchMenu(), the ordering of the observers of
- // NOTIFICATION_ZOOM_LEVEL_CHANGED can change, and result in subtle bugs
- // like http://crbug.com/118823. Rather than depending on the ordering
- // of the notification observers, always update the WrenchMenuModel before
- // updating the WrenchMenu.
- wrench_menu_model_->UpdateZoomControls();
-
- // If our zoom level changed, we need to tell the menu to update its state,
- // since the menu could still be open.
- wrench_menu_->UpdateMenu();
} else {
NOTREACHED();
}
@@ -449,6 +441,20 @@ bool BrowserToolbarGtk::IsWrenchMenuShowing() const {
// BrowserToolbarGtk, private --------------------------------------------------
+void BrowserToolbarGtk::OnZoomLevelChanged(const std::string& host) {
+ // Since BrowserToolbarGtk create a new |wrench_menu_model_| in
+ // RebuildWrenchMenu(), the ordering of the observers of HostZoomMap
+ // can change, and result in subtle bugs like http://crbug.com/118823.
+ // Rather than depending on the ordering of the observers, always update
+ // the WrenchMenuModel before updating the WrenchMenu.
+ wrench_menu_model_->UpdateZoomControls();
+
+ // If our zoom level changed, we need to tell the menu to update its state,
+ // since the menu could still be open.
+ wrench_menu_->UpdateMenu();
+}
+
+
void BrowserToolbarGtk::SetUpDragForHomeButton() {
if (!home_page_.IsManaged() && !home_page_is_new_tab_page_.IsManaged()) {
gtk_drag_dest_set(home_->widget(), GTK_DEST_DEFAULT_ALL,
diff --git a/chrome/browser/ui/gtk/browser_toolbar_gtk.h b/chrome/browser/ui/gtk/browser_toolbar_gtk.h
index 932d142..e988156 100644
--- a/chrome/browser/ui/gtk/browser_toolbar_gtk.h
+++ b/chrome/browser/ui/gtk/browser_toolbar_gtk.h
@@ -15,6 +15,7 @@
#include "chrome/browser/ui/gtk/custom_button.h"
#include "chrome/browser/ui/gtk/menu_gtk.h"
#include "chrome/browser/ui/toolbar/wrench_menu_model.h"
+#include "content/public/browser/host_zoom_map.h"
#include "content/public/browser/notification_observer.h"
#include "content/public/browser/notification_registrar.h"
#include "ui/base/accelerators/accelerator.h"
@@ -112,6 +113,8 @@ class BrowserToolbarGtk : public CommandObserver,
bool should_restore_state);
private:
+ void OnZoomLevelChanged(const std::string& host);
+
// Connect/Disconnect signals for dragging a url onto the home button.
void SetUpDragForHomeButton();
@@ -211,6 +214,7 @@ class BrowserToolbarGtk : public CommandObserver,
StringPrefMember home_page_;
BooleanPrefMember home_page_is_new_tab_page_;
+ content::HostZoomMap::ZoomLevelChangedCallback zoom_callback_;
content::NotificationRegistrar registrar_;
// A GtkEntry that isn't part of the hierarchy. We keep this for native
diff --git a/chrome/browser/ui/gtk/location_bar_view_gtk_browsertest.cc b/chrome/browser/ui/gtk/location_bar_view_gtk_browsertest.cc
index 770f56e..5c53cf5 100644
--- a/chrome/browser/ui/gtk/location_bar_view_gtk_browsertest.cc
+++ b/chrome/browser/ui/gtk/location_bar_view_gtk_browsertest.cc
@@ -5,6 +5,7 @@
#include <gtk/gtk.h>
#include "base/string_number_conversions.h"
+#include "chrome/browser/profiles/profile.h"
#include "chrome/browser/ui/browser.h"
#include "chrome/browser/ui/browser_commands.h"
#include "chrome/browser/ui/browser_window.h"
@@ -16,6 +17,7 @@
#include "chrome/browser/ui/zoom/zoom_controller.h"
#include "chrome/test/base/in_process_browser_test.h"
#include "chrome/test/base/ui_test_utils.h"
+#include "content/public/browser/host_zoom_map.h"
#include "content/public/browser/notification_service.h"
#include "content/public/browser/notification_types.h"
#include "content/public/browser/web_contents.h"
@@ -44,8 +46,13 @@ void ExpectAtDefaultZoom(content::WebContents* contents) {
EXPECT_EQ(GetZoomPercent(contents), 100);
}
+void OnZoomLevelChanged(const base::Closure& callback,
+ const std::string& host) {
+ callback.Run();
}
+} // namespace
+
class LocationBarViewGtkZoomTest : public InProcessBrowserTest {
public:
LocationBarViewGtkZoomTest() {}
@@ -101,11 +108,16 @@ class LocationBarViewGtkZoomTest : public InProcessBrowserTest {
}
void WaitForZoom(content::PageZoom zoom_action) {
- content::WindowedNotificationObserver zoom_observer(
- content::NOTIFICATION_ZOOM_LEVEL_CHANGED,
- content::NotificationService::AllSources());
+ scoped_refptr<content::MessageLoopRunner> loop_runner(
+ new content::MessageLoopRunner);
+ content::HostZoomMap::ZoomLevelChangedCallback callback(
+ base::Bind(&OnZoomLevelChanged, loop_runner->QuitClosure()));
+ content::HostZoomMap::GetForBrowserContext(
+ browser()->profile())->AddZoomLevelChangedCallback(callback);
chrome::Zoom(browser(), zoom_action);
- zoom_observer.Wait();
+ loop_runner->Run();
+ content::HostZoomMap::GetForBrowserContext(
+ browser()->profile())->RemoveZoomLevelChangedCallback(callback);
}
DISALLOW_COPY_AND_ASSIGN(LocationBarViewGtkZoomTest);
diff --git a/chrome/browser/ui/toolbar/wrench_menu_model.cc b/chrome/browser/ui/toolbar/wrench_menu_model.cc
index 6956729..c24ce72 100644
--- a/chrome/browser/ui/toolbar/wrench_menu_model.cc
+++ b/chrome/browser/ui/toolbar/wrench_menu_model.cc
@@ -212,16 +212,17 @@ WrenchMenuModel::WrenchMenuModel(ui::AcceleratorProvider* provider,
: ALLOW_THIS_IN_INITIALIZER_LIST(ui::SimpleMenuModel(this)),
provider_(provider),
browser_(browser),
- tab_strip_model_(browser_->tab_strip_model()) {
+ tab_strip_model_(browser_->tab_strip_model()),
+ zoom_callback_(base::Bind(&WrenchMenuModel::OnZoomLevelChanged,
+ base::Unretained(this))) {
Build(is_new_menu, supports_new_separators);
UpdateZoomControls();
+ HostZoomMap::GetForBrowserContext(
+ browser->profile())->AddZoomLevelChangedCallback(zoom_callback_);
+
tab_strip_model_->AddObserver(this);
- registrar_.Add(
- this, content::NOTIFICATION_ZOOM_LEVEL_CHANGED,
- content::Source<HostZoomMap>(
- HostZoomMap::GetForBrowserContext(browser_->profile())));
registrar_.Add(this, content::NOTIFICATION_NAV_ENTRY_COMMITTED,
content::NotificationService::AllSources());
}
@@ -229,6 +230,11 @@ WrenchMenuModel::WrenchMenuModel(ui::AcceleratorProvider* provider,
WrenchMenuModel::~WrenchMenuModel() {
if (tab_strip_model_)
tab_strip_model_->RemoveObserver(this);
+
+ if (browser()) {
+ HostZoomMap::GetForBrowserContext(
+ browser()->profile())->RemoveZoomLevelChangedCallback(zoom_callback_);
+ }
}
bool WrenchMenuModel::DoesCommandIdDismissMenu(int command_id) const {
@@ -421,14 +427,8 @@ void WrenchMenuModel::TabStripModelDeleted() {
void WrenchMenuModel::Observe(int type,
const content::NotificationSource& source,
const content::NotificationDetails& details) {
- switch (type) {
- case content::NOTIFICATION_ZOOM_LEVEL_CHANGED:
- case content::NOTIFICATION_NAV_ENTRY_COMMITTED:
- UpdateZoomControls();
- break;
- default:
- NOTREACHED();
- }
+ DCHECK(type == content::NOTIFICATION_NAV_ENTRY_COMMITTED);
+ UpdateZoomControls();
}
// For testing.
@@ -697,3 +697,7 @@ void WrenchMenuModel::UpdateZoomControls() {
zoom_label_ = l10n_util::GetStringFUTF16(
IDS_ZOOM_PERCENT, base::IntToString16(zoom_percent));
}
+
+void WrenchMenuModel::OnZoomLevelChanged(const std::string& host) {
+ UpdateZoomControls();
+}
diff --git a/chrome/browser/ui/toolbar/wrench_menu_model.h b/chrome/browser/ui/toolbar/wrench_menu_model.h
index 21bbdc2..b78ab62 100644
--- a/chrome/browser/ui/toolbar/wrench_menu_model.h
+++ b/chrome/browser/ui/toolbar/wrench_menu_model.h
@@ -8,6 +8,7 @@
#include "base/file_path.h"
#include "base/memory/scoped_ptr.h"
#include "chrome/browser/ui/tabs/tab_strip_model_observer.h"
+#include "content/public/browser/host_zoom_map.h"
#include "content/public/browser/notification_observer.h"
#include "content/public/browser/notification_registrar.h"
#include "ui/base/accelerators/accelerator.h"
@@ -147,6 +148,8 @@ class WrenchMenuModel : public ui::SimpleMenuModel,
// |new_menu| should be set to true.
void CreateZoomMenu(bool new_menu);
+ void OnZoomLevelChanged(const std::string& host);
+
// Models for the special menu items with buttons.
scoped_ptr<ui::ButtonMenuItemModel> edit_menu_item_model_;
scoped_ptr<ui::ButtonMenuItemModel> zoom_menu_item_model_;
@@ -168,6 +171,7 @@ class WrenchMenuModel : public ui::SimpleMenuModel,
Browser* browser_; // weak
TabStripModel* tab_strip_model_; // weak
+ content::HostZoomMap::ZoomLevelChangedCallback zoom_callback_;
content::NotificationRegistrar registrar_;
DISALLOW_COPY_AND_ASSIGN(WrenchMenuModel);
diff --git a/chrome/browser/ui/views/wrench_menu.cc b/chrome/browser/ui/views/wrench_menu.cc
index c7b65df..2b2ad2a 100644
--- a/chrome/browser/ui/views/wrench_menu.cc
+++ b/chrome/browser/ui/views/wrench_menu.cc
@@ -480,8 +480,7 @@ static const int kTouchZoomPadding = 14;
// ZoomView contains the various zoom controls: two buttons to increase/decrease
// the zoom, a label showing the current zoom percent, and a button to go
// full-screen.
-class WrenchMenu::ZoomView : public WrenchMenuView,
- public content::NotificationObserver {
+class WrenchMenu::ZoomView : public WrenchMenuView {
public:
ZoomView(WrenchMenu* menu,
MenuModel* menu_model,
@@ -490,11 +489,17 @@ class WrenchMenu::ZoomView : public WrenchMenuView,
int fullscreen_index)
: WrenchMenuView(menu, menu_model),
fullscreen_index_(fullscreen_index),
+ zoom_callback_(base::Bind(&WrenchMenu::ZoomView::OnZoomLevelChanged,
+ base::Unretained(this))),
increment_button_(NULL),
zoom_label_(NULL),
decrement_button_(NULL),
fullscreen_button_(NULL),
zoom_label_width_(0) {
+ HostZoomMap::GetForBrowserContext(
+ menu_->browser_->profile())->AddZoomLevelChangedCallback(
+ zoom_callback_);
+
decrement_button_ = CreateButtonWithAccName(
IDS_ZOOM_MINUS2, MenuButtonBackground::LEFT_BUTTON, decrement_index,
NULL, IDS_ACCNAME_ZOOM_MINUS2);
@@ -555,11 +560,12 @@ class WrenchMenu::ZoomView : public WrenchMenuView,
AddChildView(fullscreen_button_);
UpdateZoomControls();
+ }
- registrar_.Add(
- this, content::NOTIFICATION_ZOOM_LEVEL_CHANGED,
- content::Source<HostZoomMap>(
- HostZoomMap::GetForBrowserContext(menu->browser_->profile())));
+ ~ZoomView() {
+ HostZoomMap::GetForBrowserContext(
+ menu_->browser_->profile())->RemoveZoomLevelChangedCallback(
+ zoom_callback_);
}
// Overridden from View.
@@ -613,15 +619,11 @@ class WrenchMenu::ZoomView : public WrenchMenuView,
}
}
- // Overridden from content::NotificationObserver.
- virtual void Observe(int type,
- const content::NotificationSource& source,
- const content::NotificationDetails& details) OVERRIDE {
- DCHECK_EQ(content::NOTIFICATION_ZOOM_LEVEL_CHANGED, type);
+ private:
+ void OnZoomLevelChanged(const std::string& host) {
UpdateZoomControls();
}
- private:
void UpdateZoomControls() {
bool enable_increment = false;
bool enable_decrement = false;
@@ -669,6 +671,7 @@ class WrenchMenu::ZoomView : public WrenchMenuView,
// Index of the fullscreen menu item in the model.
const int fullscreen_index_;
+ content::HostZoomMap::ZoomLevelChangedCallback zoom_callback_;
content::NotificationRegistrar registrar_;
// Button for incrementing the zoom.
diff --git a/chrome/browser/ui/zoom/zoom_controller.cc b/chrome/browser/ui/zoom/zoom_controller.cc
index d17864f..4b9c041 100644
--- a/chrome/browser/ui/zoom/zoom_controller.cc
+++ b/chrome/browser/ui/zoom/zoom_controller.cc
@@ -24,7 +24,10 @@ DEFINE_WEB_CONTENTS_USER_DATA_KEY(ZoomController);
ZoomController::ZoomController(content::WebContents* web_contents)
: content::WebContentsObserver(web_contents),
zoom_percent_(100),
- observer_(NULL) {
+ observer_(NULL),
+ browser_context_(web_contents->GetBrowserContext()),
+ zoom_callback_(base::Bind(&ZoomController::OnZoomLevelChanged,
+ base::Unretained(this))) {
Profile* profile =
Profile::FromBrowserContext(web_contents->GetBrowserContext());
default_zoom_level_.Init(prefs::kDefaultZoomLevel, profile->GetPrefs(),
@@ -32,15 +35,18 @@ ZoomController::ZoomController(content::WebContents* web_contents)
base::Unretained(this),
std::string()));
- content::HostZoomMap* zoom_map =
- content::HostZoomMap::GetForBrowserContext(profile);
- registrar_.Add(this, content::NOTIFICATION_ZOOM_LEVEL_CHANGED,
- content::Source<content::HostZoomMap>(zoom_map));
+ content::HostZoomMap::GetForBrowserContext(
+ browser_context_)->AddZoomLevelChangedCallback(
+ zoom_callback_);
UpdateState(std::string());
}
-ZoomController::~ZoomController() {}
+ZoomController::~ZoomController() {
+ content::HostZoomMap::GetForBrowserContext(
+ browser_context_)->RemoveZoomLevelChangedCallback(
+ zoom_callback_);
+}
bool ZoomController::IsAtDefaultZoom() const {
return content::ZoomValuesEqual(web_contents()->GetZoomLevel(),
@@ -61,11 +67,8 @@ void ZoomController::DidNavigateMainFrame(
UpdateState(std::string());
}
-void ZoomController::Observe(int type,
- const content::NotificationSource& source,
- const content::NotificationDetails& details) {
- DCHECK_EQ(content::NOTIFICATION_ZOOM_LEVEL_CHANGED, type);
- UpdateState(*content::Details<std::string>(details).ptr());
+void ZoomController::OnZoomLevelChanged(const std::string& host) {
+ UpdateState(host);
}
void ZoomController::UpdateState(const std::string& host) {
diff --git a/chrome/browser/ui/zoom/zoom_controller.h b/chrome/browser/ui/zoom/zoom_controller.h
index 1dd7809..2dda110 100644
--- a/chrome/browser/ui/zoom/zoom_controller.h
+++ b/chrome/browser/ui/zoom/zoom_controller.h
@@ -8,8 +8,7 @@
#include "base/basictypes.h"
#include "base/compiler_specific.h"
#include "base/prefs/public/pref_member.h"
-#include "content/public/browser/notification_observer.h"
-#include "content/public/browser/notification_registrar.h"
+#include "content/public/browser/host_zoom_map.h"
#include "content/public/browser/web_contents_observer.h"
#include "content/public/browser/web_contents_user_data.h"
@@ -20,8 +19,7 @@ class WebContents;
}
// Per-tab class to manage the Omnibox zoom icon.
-class ZoomController : public content::NotificationObserver,
- public content::WebContentsObserver,
+class ZoomController : public content::WebContentsObserver,
public content::WebContentsUserData<ZoomController> {
public:
virtual ~ZoomController();
@@ -41,16 +39,13 @@ class ZoomController : public content::NotificationObserver,
const content::LoadCommittedDetails& details,
const content::FrameNavigateParams& params) OVERRIDE;
- // content::NotificationObserver overrides:
- virtual void Observe(int type,
- const content::NotificationSource& source,
- const content::NotificationDetails& details) OVERRIDE;
-
private:
explicit ZoomController(content::WebContents* web_contents);
friend class content::WebContentsUserData<ZoomController>;
friend class ZoomControllerTest;
+ void OnZoomLevelChanged(const std::string& host);
+
// Updates the zoom icon and zoom percentage based on current values and
// notifies the observer if changes have occurred. |host| may be empty,
// meaning the change should apply to ~all sites. If it is not empty, the
@@ -60,14 +55,16 @@ class ZoomController : public content::NotificationObserver,
// The current zoom percentage.
int zoom_percent_;
- content::NotificationRegistrar registrar_;
-
// Used to access the default zoom level preference.
DoublePrefMember default_zoom_level_;
// Observer receiving notifications on state changes.
ZoomObserver* observer_;
+ content::BrowserContext* browser_context_;
+
+ content::HostZoomMap::ZoomLevelChangedCallback zoom_callback_;
+
DISALLOW_COPY_AND_ASSIGN(ZoomController);
};
diff --git a/chrome/browser/ui/zoom/zoom_controller_unittest.cc b/chrome/browser/ui/zoom/zoom_controller_unittest.cc
index cc5be54..f96cfb7 100644
--- a/chrome/browser/ui/zoom/zoom_controller_unittest.cc
+++ b/chrome/browser/ui/zoom/zoom_controller_unittest.cc
@@ -14,9 +14,6 @@
#include "content/public/browser/browser_thread.h"
#include "content/public/browser/host_zoom_map.h"
#include "content/public/browser/navigation_details.h"
-#include "content/public/browser/notification_details.h"
-#include "content/public/browser/notification_source.h"
-#include "content/public/browser/notification_types.h"
#include "content/public/common/frame_navigate_params.h"
#include "content/public/test/test_browser_thread.h"
#include "content/public/test/test_utils.h"
@@ -71,11 +68,5 @@ TEST_F(ZoomControllerTest, Observe) {
content::HostZoomMap::GetForBrowserContext(
web_contents()->GetBrowserContext());
- content::WindowedNotificationObserver notification_observer(
- content::NOTIFICATION_ZOOM_LEVEL_CHANGED,
- content::NotificationService::AllSources());
-
host_zoom_map->SetZoomLevel(std::string(), 110.0f);
-
- notification_observer.Wait();
}
diff --git a/content/browser/host_zoom_map_impl.cc b/content/browser/host_zoom_map_impl.cc
index 942d6f4..aa5a870 100644
--- a/content/browser/host_zoom_map_impl.cc
+++ b/content/browser/host_zoom_map_impl.cc
@@ -90,10 +90,8 @@ void HostZoomMapImpl::SetZoomLevel(const std::string& host, double level) {
}
}
- NotificationService::current()->Notify(
- NOTIFICATION_ZOOM_LEVEL_CHANGED,
- Source<HostZoomMap>(this),
- Details<const std::string>(&host));
+ for (size_t i = 0; i < zoom_level_changed_callbacks_.size(); i++)
+ zoom_level_changed_callbacks_[i].Run(host);
}
double HostZoomMapImpl::GetDefaultZoomLevel() const {
@@ -104,6 +102,22 @@ void HostZoomMapImpl::SetDefaultZoomLevel(double level) {
default_zoom_level_ = level;
}
+void HostZoomMapImpl::AddZoomLevelChangedCallback(
+ const ZoomLevelChangedCallback& callback) {
+ zoom_level_changed_callbacks_.push_back(callback);
+}
+
+void HostZoomMapImpl::RemoveZoomLevelChangedCallback(
+ const ZoomLevelChangedCallback& callback) {
+ for (size_t i = 0; i < zoom_level_changed_callbacks_.size(); i++) {
+ if (zoom_level_changed_callbacks_[i].Equals(callback)) {
+ zoom_level_changed_callbacks_.erase(
+ zoom_level_changed_callbacks_.begin() + i);
+ return;
+ }
+ }
+}
+
double HostZoomMapImpl::GetTemporaryZoomLevel(int render_process_id,
int render_view_id) const {
base::AutoLock auto_lock(lock_);
@@ -145,11 +159,8 @@ void HostZoomMapImpl::SetTemporaryZoomLevel(int render_process_id,
}
}
- std::string host;
- NotificationService::current()->Notify(
- NOTIFICATION_ZOOM_LEVEL_CHANGED,
- Source<HostZoomMap>(this),
- Details<const std::string>(&host));
+ for (size_t i = 0; i < zoom_level_changed_callbacks_.size(); i++)
+ zoom_level_changed_callbacks_[i].Run(std::string());
}
void HostZoomMapImpl::Observe(int type,
diff --git a/content/browser/host_zoom_map_impl.h b/content/browser/host_zoom_map_impl.h
index 7840188..4e6eff4 100644
--- a/content/browser/host_zoom_map_impl.h
+++ b/content/browser/host_zoom_map_impl.h
@@ -34,6 +34,10 @@ class CONTENT_EXPORT HostZoomMapImpl : public NON_EXPORTED_BASE(HostZoomMap),
virtual void SetZoomLevel(const std::string& host, double level) OVERRIDE;
virtual double GetDefaultZoomLevel() const OVERRIDE;
virtual void SetDefaultZoomLevel(double level) OVERRIDE;
+ virtual void AddZoomLevelChangedCallback(
+ const ZoomLevelChangedCallback& callback) OVERRIDE;
+ virtual void RemoveZoomLevelChangedCallback(
+ const ZoomLevelChangedCallback& callback) OVERRIDE;
// Returns the temporary zoom level that's only valid for the lifetime of
// the given WebContents (i.e. isn't saved and doesn't affect other
@@ -59,6 +63,9 @@ class CONTENT_EXPORT HostZoomMapImpl : public NON_EXPORTED_BASE(HostZoomMap),
private:
typedef std::map<std::string, double> HostZoomLevels;
+ // Callbacks called when zoom level changes.
+ std::vector<ZoomLevelChangedCallback> zoom_level_changed_callbacks_;
+
// Copy of the pref data, so that we can read it on the IO thread.
HostZoomLevels host_zoom_levels_;
double default_zoom_level_;
diff --git a/content/public/browser/host_zoom_map.h b/content/public/browser/host_zoom_map.h
index 1e32e79..c399f69 100644
--- a/content/public/browser/host_zoom_map.h
+++ b/content/public/browser/host_zoom_map.h
@@ -10,6 +10,7 @@
#include <vector>
#include "base/basictypes.h"
+#include "base/callback.h"
#include "content/common/content_export.h"
namespace content {
@@ -50,6 +51,14 @@ class HostZoomMap {
virtual double GetDefaultZoomLevel() const = 0;
virtual void SetDefaultZoomLevel(double level) = 0;;
+ typedef base::Callback<void(const std::string&)> ZoomLevelChangedCallback;
+
+ // Add and remove zoom level changed callbacks.
+ virtual void AddZoomLevelChangedCallback(
+ const ZoomLevelChangedCallback& callback) = 0;
+ virtual void RemoveZoomLevelChangedCallback(
+ const ZoomLevelChangedCallback& callback) = 0;
+
protected:
virtual ~HostZoomMap() {}
};
diff --git a/content/public/browser/notification_types.h b/content/public/browser/notification_types.h
index ced9dcf..4c3bd71 100644
--- a/content/public/browser/notification_types.h
+++ b/content/public/browser/notification_types.h
@@ -336,11 +336,6 @@ enum NotificationType {
// The source is a NavigationController.
NOTIFICATION_REPOST_WARNING_SHOWN,
- // Sent when the zoom level changes. The source is the HostZoomMap. The
- // details is a string of the hostname for which the zoom changed. In case
- // of a temporary zoom level change, the details is an empty string.
- NOTIFICATION_ZOOM_LEVEL_CHANGED,
-
// Custom notifications used by the embedder should start from here.
NOTIFICATION_CONTENT_END,
};