OLD | NEW |
---|---|
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 "content/browser/webui/web_ui.h" | 5 #include "content/browser/webui/web_ui.h" |
6 | 6 |
7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
8 #include "base/json/json_writer.h" | 8 #include "base/json/json_writer.h" |
9 #include "base/stl_util.h" | 9 #include "base/stl_util.h" |
10 #include "base/utf_string_conversions.h" | 10 #include "base/utf_string_conversions.h" |
(...skipping 23 matching lines...) Expand all Loading... | |
34 if (i > 0) | 34 if (i > 0) |
35 parameters += char16(','); | 35 parameters += char16(','); |
36 | 36 |
37 base::JSONWriter::Write(arg_list[i], false, &json); | 37 base::JSONWriter::Write(arg_list[i], false, &json); |
38 parameters += UTF8ToUTF16(json); | 38 parameters += UTF8ToUTF16(json); |
39 } | 39 } |
40 return ASCIIToUTF16(function_name) + | 40 return ASCIIToUTF16(function_name) + |
41 char16('(') + parameters + char16(')') + char16(';'); | 41 char16('(') + parameters + char16(')') + char16(';'); |
42 } | 42 } |
43 | 43 |
44 WebUI::WebUI(WebContents* contents, | 44 WebUI::WebUI(WebContents* contents) |
45 WebUIController* controller) | 45 : focus_location_bar_by_default_(false), |
46 : hide_favicon_(false), | |
47 focus_location_bar_by_default_(false), | |
48 should_hide_url_(false), | 46 should_hide_url_(false), |
49 link_transition_type_(content::PAGE_TRANSITION_LINK), | 47 link_transition_type_(content::PAGE_TRANSITION_LINK), |
50 bindings_(content::BINDINGS_POLICY_WEB_UI), | 48 bindings_(content::BINDINGS_POLICY_WEB_UI), |
51 register_callback_overwrites_(false), | 49 register_callback_overwrites_(false), |
52 web_contents_(contents), | 50 web_contents_(contents) { |
53 controller_(controller) { | |
54 DCHECK(contents); | 51 DCHECK(contents); |
55 AddMessageHandler(new GenericHandler()); | 52 AddMessageHandler(new GenericHandler()); |
56 } | 53 } |
57 | 54 |
58 WebUI::~WebUI() { | 55 WebUI::~WebUI() { |
56 // Delete the controller first, since it may also be keeping a pointer to some | |
57 // of the handlers and can call them at destruction. | |
58 controller_.reset(); | |
59 STLDeleteContainerPointers(handlers_.begin(), handlers_.end()); | 59 STLDeleteContainerPointers(handlers_.begin(), handlers_.end()); |
60 } | 60 } |
61 | 61 |
62 // WebUI, public: ------------------------------------------------------------- | 62 // WebUI, public: ------------------------------------------------------------- |
63 | 63 |
64 const WebUI::TypeID WebUI::kNoWebUI = NULL; | 64 const WebUI::TypeID WebUI::kNoWebUI = NULL; |
65 | 65 |
66 bool WebUI::OnMessageReceived(const IPC::Message& message) { | 66 bool WebUI::OnMessageReceived(const IPC::Message& message) { |
67 bool handled = true; | 67 bool handled = true; |
68 IPC_BEGIN_MESSAGE_MAP(WebUI, message) | 68 IPC_BEGIN_MESSAGE_MAP(WebUI, message) |
(...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
108 #endif // defined(TOOLKIT_VIEWS) | 108 #endif // defined(TOOLKIT_VIEWS) |
109 | 109 |
110 // Let the WebUI know that we're looking for UI that's optimized for touch | 110 // Let the WebUI know that we're looking for UI that's optimized for touch |
111 // input. | 111 // input. |
112 // TODO(rbyers) Figure out the right model for enabling touch-optimized UI | 112 // TODO(rbyers) Figure out the right model for enabling touch-optimized UI |
113 // (http://crbug.com/105380). | 113 // (http://crbug.com/105380). |
114 if (CommandLine::ForCurrentProcess()->HasSwitch(switches::kTouchOptimizedUI)) | 114 if (CommandLine::ForCurrentProcess()->HasSwitch(switches::kTouchOptimizedUI)) |
115 render_view_host->SetWebUIProperty("touchOptimized", "true"); | 115 render_view_host->SetWebUIProperty("touchOptimized", "true"); |
116 } | 116 } |
117 | 117 |
118 WebContents* WebUI::GetWebContents() const { | |
119 return web_contents_; | |
120 } | |
121 | |
122 bool WebUI::ShouldHideFavicon() const { | |
123 return hide_favicon_; | |
124 } | |
125 | |
126 void WebUI::HideFavicon() { | |
127 hide_favicon_ = true; | |
128 } | |
129 | |
130 bool WebUI::ShouldFocusLocationBarByDefault() const { | |
131 return focus_location_bar_by_default_; | |
132 } | |
133 | |
134 void WebUI::FocusLocationBarByDefault() { | |
135 focus_location_bar_by_default_ = true; | |
136 } | |
137 | |
138 bool WebUI::ShouldHideURL() const { | |
139 return should_hide_url_; | |
140 } | |
141 | |
142 void WebUI::HideURL() { | |
143 should_hide_url_ = true; | |
144 } | |
145 | |
146 const string16& WebUI::GetOverriddenTitle() const { | |
147 return overridden_title_; | |
148 } | |
149 | |
150 void WebUI::OverrideTitle(const string16& title) { | |
151 overridden_title_ = title; | |
152 } | |
153 | |
154 content::PageTransition WebUI::GetLinkTransitionType() const { | |
155 return link_transition_type_; | |
156 } | |
157 | |
158 void WebUI::SetLinkTransitionType(content::PageTransition type) { | |
159 link_transition_type_ = type; | |
160 } | |
161 | |
162 int WebUI::GetBindings() const { | |
163 return bindings_; | |
164 } | |
165 | |
166 void WebUI::SetBindings(int bindings) { | |
167 bindings_ = bindings; | |
168 } | |
169 | |
170 void WebUI::SetFrameXPath(const std::string& xpath) { | |
171 frame_xpath_ = xpath; | |
172 } | |
173 | |
174 WebUIController* WebUI::GetController() const { | |
175 return controller_.get(); | |
176 } | |
177 | |
178 void WebUI::SetController(WebUIController* controller) { | |
179 controller_.reset(controller); | |
Jói
2012/01/17 17:34:05
There might be a bug here w.r.t. the ownership mod
jam
2012/01/17 17:38:35
scoped_ptr::reset() does that :)
| |
180 } | |
181 | |
118 void WebUI::CallJavascriptFunction(const std::string& function_name) { | 182 void WebUI::CallJavascriptFunction(const std::string& function_name) { |
119 DCHECK(IsStringASCII(function_name)); | 183 DCHECK(IsStringASCII(function_name)); |
120 string16 javascript = ASCIIToUTF16(function_name + "();"); | 184 string16 javascript = ASCIIToUTF16(function_name + "();"); |
121 ExecuteJavascript(javascript); | 185 ExecuteJavascript(javascript); |
122 } | 186 } |
123 | 187 |
124 void WebUI::CallJavascriptFunction(const std::string& function_name, | 188 void WebUI::CallJavascriptFunction(const std::string& function_name, |
125 const Value& arg) { | 189 const Value& arg) { |
126 DCHECK(IsStringASCII(function_name)); | 190 DCHECK(IsStringASCII(function_name)); |
127 std::vector<const Value*> args; | 191 std::vector<const Value*> args; |
(...skipping 60 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
188 DCHECK(!handler->web_ui()); | 252 DCHECK(!handler->web_ui()); |
189 handler->set_web_ui(this); | 253 handler->set_web_ui(this); |
190 handler->RegisterMessages(); | 254 handler->RegisterMessages(); |
191 handlers_.push_back(handler); | 255 handlers_.push_back(handler); |
192 } | 256 } |
193 | 257 |
194 void WebUI::ExecuteJavascript(const string16& javascript) { | 258 void WebUI::ExecuteJavascript(const string16& javascript) { |
195 web_contents_->GetRenderViewHost()->ExecuteJavascriptInWebFrame( | 259 web_contents_->GetRenderViewHost()->ExecuteJavascriptInWebFrame( |
196 ASCIIToUTF16(frame_xpath_), javascript); | 260 ASCIIToUTF16(frame_xpath_), javascript); |
197 } | 261 } |
OLD | NEW |