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

Side by Side Diff: chrome/renderer/extensions/chrome_v8_context.cc

Issue 11571014: Lazy load chrome.* APIs (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: apitest.js 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 | Annotate | Revision Log
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 "chrome/renderer/extensions/chrome_v8_context.h" 5 #include "chrome/renderer/extensions/chrome_v8_context.h"
6 6
7 #include "base/debug/trace_event.h" 7 #include "base/debug/trace_event.h"
8 #include "base/logging.h" 8 #include "base/logging.h"
9 #include "base/string_split.h" 9 #include "base/string_split.h"
10 #include "base/values.h" 10 #include "base/values.h"
(...skipping 21 matching lines...) Expand all
32 } // namespace 32 } // namespace
33 33
34 ChromeV8Context::ChromeV8Context(v8::Handle<v8::Context> v8_context, 34 ChromeV8Context::ChromeV8Context(v8::Handle<v8::Context> v8_context,
35 WebKit::WebFrame* web_frame, 35 WebKit::WebFrame* web_frame,
36 const Extension* extension, 36 const Extension* extension,
37 Feature::Context context_type) 37 Feature::Context context_type)
38 : v8_context_(v8::Persistent<v8::Context>::New(v8_context->GetIsolate(), 38 : v8_context_(v8::Persistent<v8::Context>::New(v8_context->GetIsolate(),
39 v8_context)), 39 v8_context)),
40 web_frame_(web_frame), 40 web_frame_(web_frame),
41 extension_(extension), 41 extension_(extension),
42 context_type_(context_type) { 42 context_type_(context_type),
43 available_extension_apis_initialized_(false) {
43 VLOG(1) << "Created context:\n" 44 VLOG(1) << "Created context:\n"
44 << " extension id: " << GetExtensionID() << "\n" 45 << " extension id: " << GetExtensionID() << "\n"
45 << " frame: " << web_frame_ << "\n" 46 << " frame: " << web_frame_ << "\n"
46 << " context type: " << GetContextTypeDescription(); 47 << " context type: " << GetContextTypeDescription();
47 } 48 }
48 49
49 ChromeV8Context::~ChromeV8Context() { 50 ChromeV8Context::~ChromeV8Context() {
50 VLOG(1) << "Destroyed context for extension\n" 51 VLOG(1) << "Destroyed context for extension\n"
51 << " extension id: " << GetExtensionID(); 52 << " extension id: " << GetExtensionID();
52 v8_context_.Dispose(v8_context_->GetIsolate()); 53 v8_context_.Dispose(v8_context_->GetIsolate());
53 } 54 }
54 55
55 std::string ChromeV8Context::GetExtensionID() { 56 std::string ChromeV8Context::GetExtensionID() {
56 return extension_ ? extension_->id() : ""; 57 return extension_ ? extension_->id() : "";
57 } 58 }
58 59
59 // static 60 // static
60 v8::Handle<v8::Value> ChromeV8Context::GetOrCreateChromeHidden( 61 v8::Handle<v8::Value> ChromeV8Context::GetOrCreateChromeHidden(
61 v8::Handle<v8::Context> context) { 62 v8::Handle<v8::Context> context) {
62 v8::Local<v8::Object> global = context->Global(); 63 v8::Local<v8::Object> global = context->Global();
63 v8::Local<v8::Value> hidden = global->GetHiddenValue( 64 v8::Local<v8::Value> hidden = global->GetHiddenValue(
64 v8::String::New(kChromeHidden)); 65 v8::String::New(kChromeHidden));
65 66
66 if (hidden.IsEmpty() || hidden->IsUndefined()) { 67 if (hidden.IsEmpty() || hidden->IsUndefined()) {
67 hidden = v8::Object::New(); 68 hidden = v8::Object::New();
68 global->SetHiddenValue(v8::String::New(kChromeHidden), hidden); 69 global->SetHiddenValue(v8::String::New(kChromeHidden), hidden);
69 70
70 #ifndef NDEBUG 71 #ifndef NDEBUG
71 // Tell schema_generated_bindings.js to validate callbacks and events 72 // Tell bindings.js to validate callbacks and events against their schema
72 // against their schema definitions. 73 // definitions.
73 v8::Local<v8::Object>::Cast(hidden)->Set( 74 v8::Local<v8::Object>::Cast(hidden)->Set(
74 v8::String::New(kValidateCallbacks), v8::True()); 75 v8::String::New(kValidateCallbacks), v8::True());
75 // Tell schema_generated_bindings.js to validate API for ambiguity. 76 // Tell bindings.js to validate API for ambiguity.
76 v8::Local<v8::Object>::Cast(hidden)->Set( 77 v8::Local<v8::Object>::Cast(hidden)->Set(
77 v8::String::New(kValidateAPI), v8::True()); 78 v8::String::New(kValidateAPI), v8::True());
78 #endif 79 #endif
79 } 80 }
80 81
81 DCHECK(hidden->IsObject()); 82 DCHECK(hidden->IsObject());
82 return v8::Local<v8::Object>::Cast(hidden); 83 return v8::Local<v8::Object>::Cast(hidden);
83 } 84 }
84 85
85 v8::Handle<v8::Value> ChromeV8Context::GetChromeHidden() const { 86 v8::Handle<v8::Value> ChromeV8Context::GetChromeHidden() const {
(...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after
136 v8::Object::New(), 137 v8::Object::New(),
137 argc, 138 argc,
138 argv); 139 argv);
139 if (result) 140 if (result)
140 *result = result_temp; 141 *result = result_temp;
141 142
142 return true; 143 return true;
143 } 144 }
144 145
145 const std::set<std::string>& ChromeV8Context::GetAvailableExtensionAPIs() { 146 const std::set<std::string>& ChromeV8Context::GetAvailableExtensionAPIs() {
146 if (!available_extension_apis_.get()) { 147 if (!available_extension_apis_initialized_) {
147 available_extension_apis_ = 148 available_extension_apis_ =
148 ExtensionAPI::GetSharedInstance()->GetAPIsForContext( 149 ExtensionAPI::GetSharedInstance()->GetAPIsForContext(
149 context_type_, 150 context_type_,
150 extension_, 151 extension_,
151 UserScriptSlave::GetDataSourceURLForFrame( 152 UserScriptSlave::GetDataSourceURLForFrame(web_frame_));
152 web_frame_)).Pass(); 153 available_extension_apis_initialized_ = true;
153 } 154 }
154 return *(available_extension_apis_.get()); 155 return available_extension_apis_;
155 } 156 }
156 157
157 void ChromeV8Context::DispatchOnLoadEvent(bool is_incognito_process, 158 void ChromeV8Context::DispatchOnLoadEvent(bool is_incognito_process,
158 int manifest_version) { 159 int manifest_version) {
159 v8::HandleScope handle_scope; 160 v8::HandleScope handle_scope;
160 v8::Handle<v8::Value> argv[] = { 161 v8::Handle<v8::Value> argv[] = {
161 v8::String::New(GetExtensionID().c_str()), 162 v8::String::New(GetExtensionID().c_str()),
162 v8::String::New(GetContextTypeDescription().c_str()), 163 v8::String::New(GetContextTypeDescription().c_str()),
163 v8::Boolean::New(is_incognito_process), 164 v8::Boolean::New(is_incognito_process),
164 v8::Integer::New(manifest_version), 165 v8::Integer::New(manifest_version),
(...skipping 12 matching lines...) Expand all
177 case Feature::BLESSED_EXTENSION_CONTEXT: return "BLESSED_EXTENSION"; 178 case Feature::BLESSED_EXTENSION_CONTEXT: return "BLESSED_EXTENSION";
178 case Feature::UNBLESSED_EXTENSION_CONTEXT: return "UNBLESSED_EXTENSION"; 179 case Feature::UNBLESSED_EXTENSION_CONTEXT: return "UNBLESSED_EXTENSION";
179 case Feature::CONTENT_SCRIPT_CONTEXT: return "CONTENT_SCRIPT"; 180 case Feature::CONTENT_SCRIPT_CONTEXT: return "CONTENT_SCRIPT";
180 case Feature::WEB_PAGE_CONTEXT: return "WEB_PAGE"; 181 case Feature::WEB_PAGE_CONTEXT: return "WEB_PAGE";
181 } 182 }
182 NOTREACHED(); 183 NOTREACHED();
183 return ""; 184 return "";
184 } 185 }
185 186
186 } // namespace extensions 187 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698