Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "extensions/renderer/dispatcher.h" | 5 #include "extensions/renderer/dispatcher.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/callback.h" | 8 #include "base/callback.h" |
| 9 #include "base/command_line.h" | 9 #include "base/command_line.h" |
| 10 #include "base/debug/alias.h" | 10 #include "base/debug/alias.h" |
| (...skipping 14 matching lines...) Expand all Loading... | |
| 25 #include "extensions/common/extension.h" | 25 #include "extensions/common/extension.h" |
| 26 #include "extensions/common/extension_api.h" | 26 #include "extensions/common/extension_api.h" |
| 27 #include "extensions/common/extension_messages.h" | 27 #include "extensions/common/extension_messages.h" |
| 28 #include "extensions/common/extension_urls.h" | 28 #include "extensions/common/extension_urls.h" |
| 29 #include "extensions/common/features/feature.h" | 29 #include "extensions/common/features/feature.h" |
| 30 #include "extensions/common/features/feature_provider.h" | 30 #include "extensions/common/features/feature_provider.h" |
| 31 #include "extensions/common/manifest.h" | 31 #include "extensions/common/manifest.h" |
| 32 #include "extensions/common/manifest_constants.h" | 32 #include "extensions/common/manifest_constants.h" |
| 33 #include "extensions/common/manifest_handlers/background_info.h" | 33 #include "extensions/common/manifest_handlers/background_info.h" |
| 34 #include "extensions/common/manifest_handlers/externally_connectable.h" | 34 #include "extensions/common/manifest_handlers/externally_connectable.h" |
| 35 #include "extensions/common/manifest_handlers/options_page_info.h" | |
| 35 #include "extensions/common/manifest_handlers/sandboxed_page_info.h" | 36 #include "extensions/common/manifest_handlers/sandboxed_page_info.h" |
| 36 #include "extensions/common/message_bundle.h" | 37 #include "extensions/common/message_bundle.h" |
| 37 #include "extensions/common/permissions/permission_set.h" | 38 #include "extensions/common/permissions/permission_set.h" |
| 38 #include "extensions/common/permissions/permissions_data.h" | 39 #include "extensions/common/permissions/permissions_data.h" |
| 39 #include "extensions/common/switches.h" | 40 #include "extensions/common/switches.h" |
| 40 #include "extensions/common/view_type.h" | 41 #include "extensions/common/view_type.h" |
| 41 #include "extensions/renderer/api_activity_logger.h" | 42 #include "extensions/renderer/api_activity_logger.h" |
| 42 #include "extensions/renderer/api_definitions_natives.h" | 43 #include "extensions/renderer/api_definitions_natives.h" |
| 43 #include "extensions/renderer/app_runtime_custom_bindings.h" | 44 #include "extensions/renderer/app_runtime_custom_bindings.h" |
| 44 #include "extensions/renderer/binding_generating_native_handler.h" | 45 #include "extensions/renderer/binding_generating_native_handler.h" |
| (...skipping 280 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 325 script_context_set_.Remove(context); | 326 script_context_set_.Remove(context); |
| 326 VLOG(1) << "Num tracked contexts: " << script_context_set_.size(); | 327 VLOG(1) << "Num tracked contexts: " << script_context_set_.size(); |
| 327 } | 328 } |
| 328 | 329 |
| 329 void Dispatcher::DidCreateDocumentElement(blink::WebFrame* frame) { | 330 void Dispatcher::DidCreateDocumentElement(blink::WebFrame* frame) { |
| 330 // Note: use GetEffectiveDocumentURL not just frame->document()->url() | 331 // Note: use GetEffectiveDocumentURL not just frame->document()->url() |
| 331 // so that this also injects the stylesheet on about:blank frames that | 332 // so that this also injects the stylesheet on about:blank frames that |
| 332 // are hosted in the extension process. | 333 // are hosted in the extension process. |
| 333 GURL effective_document_url = ScriptContext::GetEffectiveDocumentURL( | 334 GURL effective_document_url = ScriptContext::GetEffectiveDocumentURL( |
| 334 frame, frame->document().url(), true /* match_about_blank */); | 335 frame, frame->document().url(), true /* match_about_blank */); |
| 336 | |
| 335 const Extension* extension = | 337 const Extension* extension = |
| 336 extensions_.GetExtensionOrAppByURL(effective_document_url); | 338 extensions_.GetExtensionOrAppByURL(effective_document_url); |
| 337 | 339 |
| 338 if (extension && | 340 if (extension && |
| 339 (extension->is_extension() || extension->is_platform_app())) { | 341 (extension->is_extension() || extension->is_platform_app())) { |
| 340 int resource_id = | 342 int resource_id = extension->is_platform_app() ? IDR_PLATFORM_APP_CSS |
| 341 extension->is_platform_app() ? IDR_PLATFORM_APP_CSS : IDR_EXTENSION_CSS; | 343 : IDR_EXTENSION_FONTS_CSS; |
| 342 std::string stylesheet = ResourceBundle::GetSharedInstance() | 344 std::string stylesheet = ResourceBundle::GetSharedInstance() |
| 343 .GetRawDataResource(resource_id) | 345 .GetRawDataResource(resource_id) |
| 344 .as_string(); | 346 .as_string(); |
| 345 ReplaceFirstSubstringAfterOffset( | 347 ReplaceFirstSubstringAfterOffset( |
| 346 &stylesheet, 0, "$FONTFAMILY", system_font_family_); | 348 &stylesheet, 0, "$FONTFAMILY", system_font_family_); |
| 347 ReplaceFirstSubstringAfterOffset( | 349 ReplaceFirstSubstringAfterOffset( |
| 348 &stylesheet, 0, "$FONTSIZE", system_font_size_); | 350 &stylesheet, 0, "$FONTSIZE", system_font_size_); |
| 349 | 351 |
| 350 // Blink doesn't let us define an additional user agent stylesheet, so | 352 // Blink doesn't let us define an additional user agent stylesheet, so |
| 351 // we insert the default platform app or extension stylesheet into all | 353 // we insert the default platform app or extension stylesheet into all |
| 352 // documents that are loaded in each app or extension. | 354 // documents that are loaded in each app or extension. |
| 353 frame->document().insertStyleSheet(WebString::fromUTF8(stylesheet)); | 355 frame->document().insertStyleSheet(WebString::fromUTF8(stylesheet)); |
| 354 } | 356 } |
| 357 | |
| 358 if (extension && extension->is_extension() && | |
| 359 OptionsPageInfo::ShouldUseChromeStyle(extension) && | |
| 360 effective_document_url == OptionsPageInfo::GetOptionsPage(extension)) { | |
|
Devlin
2014/09/04 21:27:37
Is this data copied over to the renderer process?
ericzeng
2014/09/04 22:30:30
I don't know either. Which data in particular?
Devlin
2014/09/04 22:39:19
The extension's manifest data for whether or not i
ericzeng
2014/09/04 23:48:58
I'm pretty sure that it is - the IPC call when ext
Yoyo Zhou
2014/09/05 16:24:35
Yes, the renderer ought to have all the manifest d
| |
| 361 frame->document().insertStyleSheet( | |
| 362 WebString::fromUTF8(ResourceBundle::GetSharedInstance() | |
| 363 .GetRawDataResource(IDR_EXTENSION_CSS) | |
|
Devlin
2014/09/04 21:27:37
Naively looking at this, it seems that you inject
ericzeng
2014/09/04 22:30:30
I think the conditional above should catch it - it
Devlin
2014/09/04 22:39:19
D'oh. Don't know why I missed that.
| |
| 364 .as_string())); | |
| 365 } | |
| 355 content_watcher_->DidCreateDocumentElement(frame); | 366 content_watcher_->DidCreateDocumentElement(frame); |
| 356 } | 367 } |
| 357 | 368 |
| 358 void Dispatcher::DidMatchCSS( | 369 void Dispatcher::DidMatchCSS( |
| 359 blink::WebFrame* frame, | 370 blink::WebFrame* frame, |
| 360 const blink::WebVector<blink::WebString>& newly_matching_selectors, | 371 const blink::WebVector<blink::WebString>& newly_matching_selectors, |
| 361 const blink::WebVector<blink::WebString>& stopped_matching_selectors) { | 372 const blink::WebVector<blink::WebString>& stopped_matching_selectors) { |
| 362 content_watcher_->DidMatchCSS( | 373 content_watcher_->DidMatchCSS( |
| 363 frame, newly_matching_selectors, stopped_matching_selectors); | 374 frame, newly_matching_selectors, stopped_matching_selectors); |
| 364 } | 375 } |
| (...skipping 935 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1300 return v8::Handle<v8::Object>(); | 1311 return v8::Handle<v8::Object>(); |
| 1301 | 1312 |
| 1302 if (bind_name) | 1313 if (bind_name) |
| 1303 *bind_name = split.back(); | 1314 *bind_name = split.back(); |
| 1304 | 1315 |
| 1305 return bind_object.IsEmpty() ? AsObjectOrEmpty(GetOrCreateChrome(context)) | 1316 return bind_object.IsEmpty() ? AsObjectOrEmpty(GetOrCreateChrome(context)) |
| 1306 : bind_object; | 1317 : bind_object; |
| 1307 } | 1318 } |
| 1308 | 1319 |
| 1309 } // namespace extensions | 1320 } // namespace extensions |
| OLD | NEW |