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

Side by Side Diff: content/browser/host_zoom_map_impl.cc

Issue 11866004: Add scheme to HostZoomMap (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: Fix alignment, add comment Created 7 years, 10 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 <cmath> 5 #include <cmath>
6 6
7 #include "content/browser/host_zoom_map_impl.h" 7 #include "content/browser/host_zoom_map_impl.h"
8 8
9 #include "base/string_piece.h" 9 #include "base/string_piece.h"
10 #include "base/utf_string_conversions.h" 10 #include "base/utf_string_conversions.h"
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after
47 47
48 void HostZoomMapImpl::CopyFrom(HostZoomMap* copy_interface) { 48 void HostZoomMapImpl::CopyFrom(HostZoomMap* copy_interface) {
49 // This can only be called on the UI thread to avoid deadlocks, otherwise 49 // This can only be called on the UI thread to avoid deadlocks, otherwise
50 // UI: a.CopyFrom(b); 50 // UI: a.CopyFrom(b);
51 // IO: b.CopyFrom(a); 51 // IO: b.CopyFrom(a);
52 // can deadlock. 52 // can deadlock.
53 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 53 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
54 HostZoomMapImpl* copy = static_cast<HostZoomMapImpl*>(copy_interface); 54 HostZoomMapImpl* copy = static_cast<HostZoomMapImpl*>(copy_interface);
55 base::AutoLock auto_lock(lock_); 55 base::AutoLock auto_lock(lock_);
56 base::AutoLock copy_auto_lock(copy->lock_); 56 base::AutoLock copy_auto_lock(copy->lock_);
57 for (HostZoomLevels::const_iterator i(copy->host_zoom_levels_.begin()); 57 host_zoom_levels_.
58 i != copy->host_zoom_levels_.end(); ++i) { 58 insert(copy->host_zoom_levels_.begin(), copy->host_zoom_levels_.end());
59 host_zoom_levels_[i->first] = i->second; 59 for (SchemeHostZoomLevels::const_iterator i(copy->
60 scheme_host_zoom_levels_.begin());
61 i != copy->scheme_host_zoom_levels_.end(); ++i) {
62 scheme_host_zoom_levels_[i->first] = HostZoomLevels();
63 scheme_host_zoom_levels_[i->first].
64 insert(i->second.begin(), i->second.end());
60 } 65 }
61 default_zoom_level_ = copy->default_zoom_level_; 66 default_zoom_level_ = copy->default_zoom_level_;
62 } 67 }
63 68
64 double HostZoomMapImpl::GetZoomLevel(const std::string& host) const { 69 double HostZoomMapImpl::GetZoomLevelForHost(const std::string& host) const {
65 base::AutoLock auto_lock(lock_); 70 base::AutoLock auto_lock(lock_);
66 HostZoomLevels::const_iterator i(host_zoom_levels_.find(host)); 71 HostZoomLevels::const_iterator i(host_zoom_levels_.find(host));
67 return (i == host_zoom_levels_.end()) ? default_zoom_level_ : i->second; 72 return (i == host_zoom_levels_.end()) ? default_zoom_level_ : i->second;
68 } 73 }
69 74
70 void HostZoomMapImpl::SetZoomLevel(const std::string& host, double level) { 75 double HostZoomMapImpl::GetZoomLevelForHostAndScheme(
76 const std::string& scheme,
77 const std::string& host) const {
78 {
79 base::AutoLock auto_lock(lock_);
80 SchemeHostZoomLevels::const_iterator scheme_iterator(
81 scheme_host_zoom_levels_.find(scheme));
82 if (scheme_iterator != scheme_host_zoom_levels_.end()) {
83 HostZoomLevels::const_iterator i(scheme_iterator->second.find(host));
84 if (i != scheme_iterator->second.end())
85 return i->second;
86 }
87 }
88 return GetZoomLevelForHost(host);
89 }
90
91 void HostZoomMapImpl::SetZoomLevelForHost(const std::string& host,
92 double level) {
71 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 93 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
72 94
73 { 95 {
74 base::AutoLock auto_lock(lock_); 96 base::AutoLock auto_lock(lock_);
75 97
76 if (ZoomValuesEqual(level, default_zoom_level_)) 98 if (ZoomValuesEqual(level, default_zoom_level_))
77 host_zoom_levels_.erase(host); 99 host_zoom_levels_.erase(host);
78 else 100 else
79 host_zoom_levels_[host] = level; 101 host_zoom_levels_[host] = level;
80 } 102 }
81 103
82 // Notify renderers from this browser context. 104 // Notify renderers from this browser context.
83 for (RenderProcessHost::iterator i(RenderProcessHost::AllHostsIterator()); 105 for (RenderProcessHost::iterator i(RenderProcessHost::AllHostsIterator());
84 !i.IsAtEnd(); i.Advance()) { 106 !i.IsAtEnd(); i.Advance()) {
85 RenderProcessHost* render_process_host = i.GetCurrentValue(); 107 RenderProcessHost* render_process_host = i.GetCurrentValue();
86 if (HostZoomMap::GetForBrowserContext( 108 if (HostZoomMap::GetForBrowserContext(
87 render_process_host->GetBrowserContext()) == this) { 109 render_process_host->GetBrowserContext()) == this) {
88 render_process_host->Send( 110 render_process_host->Send(
89 new ViewMsg_SetZoomLevelForCurrentURL(host, level)); 111 new ViewMsg_SetZoomLevelForCurrentURL(std::string(), host, level));
90 } 112 }
91 } 113 }
92 114
115 for (size_t i = 0; i < zoom_level_changed_callbacks_.size(); i++)
116 zoom_level_changed_callbacks_[i].Run(host);
117 }
118
119 void HostZoomMapImpl::SetZoomLevelForHostAndScheme(const std::string& scheme,
120 const std::string& host,
121 double level) {
122 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
123 {
124 base::AutoLock auto_lock(lock_);
125 scheme_host_zoom_levels_[scheme][host] = level;
126 }
127
128 // Notify renderers from this browser context.
129 for (RenderProcessHost::iterator i(RenderProcessHost::AllHostsIterator());
130 !i.IsAtEnd(); i.Advance()) {
131 RenderProcessHost* render_process_host = i.GetCurrentValue();
132 if (HostZoomMap::GetForBrowserContext(
133 render_process_host->GetBrowserContext()) == this) {
134 render_process_host->Send(
135 new ViewMsg_SetZoomLevelForCurrentURL(scheme, host, level));
136 }
137 }
138
93 for (size_t i = 0; i < zoom_level_changed_callbacks_.size(); i++) 139 for (size_t i = 0; i < zoom_level_changed_callbacks_.size(); i++)
94 zoom_level_changed_callbacks_[i].Run(host); 140 zoom_level_changed_callbacks_[i].Run(host);
95 } 141 }
96 142
97 double HostZoomMapImpl::GetDefaultZoomLevel() const { 143 double HostZoomMapImpl::GetDefaultZoomLevel() const {
98 return default_zoom_level_; 144 return default_zoom_level_;
99 } 145 }
100 146
101 void HostZoomMapImpl::SetDefaultZoomLevel(double level) { 147 void HostZoomMapImpl::SetDefaultZoomLevel(double level) {
102 default_zoom_level_ = level; 148 default_zoom_level_ = level;
(...skipping 81 matching lines...) Expand 10 before | Expand all | Expand 10 after
184 } 230 }
185 default: 231 default:
186 NOTREACHED() << "Unexpected preference observed."; 232 NOTREACHED() << "Unexpected preference observed.";
187 } 233 }
188 } 234 }
189 235
190 HostZoomMapImpl::~HostZoomMapImpl() { 236 HostZoomMapImpl::~HostZoomMapImpl() {
191 } 237 }
192 238
193 } // namespace content 239 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698