Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 "chrome/renderer/extensions/dispatcher.h" | 5 #include "chrome/renderer/extensions/dispatcher.h" |
| 6 | 6 |
| 7 #include "base/callback.h" | 7 #include "base/callback.h" |
| 8 #include "base/command_line.h" | 8 #include "base/command_line.h" |
| 9 #include "base/memory/scoped_ptr.h" | 9 #include "base/memory/scoped_ptr.h" |
| 10 #include "base/string_piece.h" | 10 #include "base/string_piece.h" |
| (...skipping 932 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 943 BackgroundInfo::HasLazyBackgroundPage(extension)); | 943 BackgroundInfo::HasLazyBackgroundPage(extension)); |
| 944 module_system->RegisterNativeHandler("process", | 944 module_system->RegisterNativeHandler("process", |
| 945 scoped_ptr<NativeHandler>(new ProcessInfoNativeHandler( | 945 scoped_ptr<NativeHandler>(new ProcessInfoNativeHandler( |
| 946 this, v8_context, context->GetExtensionID(), | 946 this, v8_context, context->GetExtensionID(), |
| 947 context->GetContextTypeDescription(), | 947 context->GetContextTypeDescription(), |
| 948 ChromeRenderProcessObserver::is_incognito_process(), | 948 ChromeRenderProcessObserver::is_incognito_process(), |
| 949 manifest_version, send_request_disabled))); | 949 manifest_version, send_request_disabled))); |
| 950 | 950 |
| 951 GetOrCreateChrome(v8_context); | 951 GetOrCreateChrome(v8_context); |
| 952 | 952 |
| 953 // Loading JavaScript is expensive, so only run the full API bindings | 953 if (extension && !extension->is_platform_app()) |
|
not at google - send to devlin
2013/03/22 18:13:48
I'm happy every time I see this!
| |
| 954 // generation mechanisms in extension pages (NOT all web pages). | 954 module_system->Require("miscellaneous_bindings"); |
| 955 switch (context_type) { | 955 module_system->Require("json"); // see paranoid comment in json.js |
|
not at google - send to devlin
2013/03/22 18:13:48
hm, this might end up being a problem. maybe. I ju
cduvall
2013/03/22 20:26:45
Done.
| |
| 956 case Feature::UNSPECIFIED_CONTEXT: | 956 RegisterSchemaGeneratedBindings(module_system.get(), |
| 957 case Feature::WEB_PAGE_CONTEXT: | 957 context, |
| 958 // TODO(kalman): see comment below about ExtensionAPI. | 958 v8_context); |
| 959 InstallBindings(module_system.get(), v8_context, "app"); | 959 InstallBindings(module_system.get(), v8_context, "app"); |
| 960 InstallBindings(module_system.get(), v8_context, "webstore"); | 960 InstallBindings(module_system.get(), v8_context, "webstore"); |
|
not at google - send to devlin
2013/03/22 18:13:48
with this patch these two lines might actually be
cduvall
2013/03/22 20:26:45
Done.
| |
| 961 break; | |
| 962 case Feature::BLESSED_EXTENSION_CONTEXT: | |
| 963 case Feature::UNBLESSED_EXTENSION_CONTEXT: | |
| 964 case Feature::CONTENT_SCRIPT_CONTEXT: { | |
| 965 if (extension && !extension->is_platform_app()) | |
| 966 module_system->Require("miscellaneous_bindings"); | |
| 967 module_system->Require("json"); // see paranoid comment in json.js | |
| 968 | |
| 969 // TODO(kalman): move this code back out of the switch and execute it | |
| 970 // regardless of |context_type|. ExtensionAPI knows how to return the | |
| 971 // correct APIs, however, until it doesn't have a 2MB overhead we can't | |
| 972 // load it in every process. | |
| 973 RegisterSchemaGeneratedBindings(module_system.get(), | |
| 974 context, | |
| 975 v8_context); | |
| 976 break; | |
| 977 } | |
| 978 } | |
| 979 | 961 |
| 980 bool is_within_platform_app = IsWithinPlatformApp(frame); | 962 bool is_within_platform_app = IsWithinPlatformApp(frame); |
| 981 // Inject custom JS into the platform app context. | 963 // Inject custom JS into the platform app context. |
| 982 if (is_within_platform_app) | 964 if (is_within_platform_app) |
| 983 module_system->Require("platformApp"); | 965 module_system->Require("platformApp"); |
| 984 | 966 |
| 985 // Only platform apps support the <webview> tag, because the "webView" and | 967 // Only platform apps support the <webview> tag, because the "webView" and |
| 986 // "denyWebView" modules will affect the performance of DOM modifications | 968 // "denyWebView" modules will affect the performance of DOM modifications |
| 987 // (http://crbug.com/196453). | 969 // (http://crbug.com/196453). |
| 988 if (context_type == Feature::BLESSED_EXTENSION_CONTEXT && | 970 if (context_type == Feature::BLESSED_EXTENSION_CONTEXT && |
| (...skipping 337 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1326 std::string error_msg = base::StringPrintf(kMessage, function_name.c_str()); | 1308 std::string error_msg = base::StringPrintf(kMessage, function_name.c_str()); |
| 1327 v8::ThrowException( | 1309 v8::ThrowException( |
| 1328 v8::Exception::Error(v8::String::New(error_msg.c_str()))); | 1310 v8::Exception::Error(v8::String::New(error_msg.c_str()))); |
| 1329 return false; | 1311 return false; |
| 1330 } | 1312 } |
| 1331 | 1313 |
| 1332 return true; | 1314 return true; |
| 1333 } | 1315 } |
| 1334 | 1316 |
| 1335 } // namespace extensions | 1317 } // namespace extensions |
| OLD | NEW |