diff options
author | pfeldman@chromium.org <pfeldman@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-05-08 11:47:53 +0000 |
---|---|---|
committer | pfeldman@chromium.org <pfeldman@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-05-08 11:47:53 +0000 |
commit | 6f45d5f57decad87b06a63239d77657ed458e361 (patch) | |
tree | 43f2690aef005299ab1dbe81dbe149d18f8b2471 /webkit/glue | |
parent | 7e8e6b672b783c9f9ca3bf302a3a0ea6704c34e1 (diff) | |
download | chromium_src-6f45d5f57decad87b06a63239d77657ed458e361.zip chromium_src-6f45d5f57decad87b06a63239d77657ed458e361.tar.gz chromium_src-6f45d5f57decad87b06a63239d77657ed458e361.tar.bz2 |
DevTools: Move client js bindings to per-instance basis.
Review URL: http://codereview.chromium.org/113146
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@15634 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'webkit/glue')
-rw-r--r-- | webkit/glue/webdevtoolsclient_impl.cc | 104 | ||||
-rw-r--r-- | webkit/glue/webdevtoolsclient_impl.h | 12 |
2 files changed, 44 insertions, 72 deletions
diff --git a/webkit/glue/webdevtoolsclient_impl.cc b/webkit/glue/webdevtoolsclient_impl.cc index 4f654f4..f9d4052 100644 --- a/webkit/glue/webdevtoolsclient_impl.cc +++ b/webkit/glue/webdevtoolsclient_impl.cc @@ -79,61 +79,6 @@ class RemoteDebuggerCommandExecutor : public CppBoundClass { } // namespace // static -HashMap<WebCore::Page*, WebDevToolsClientImpl*> - WebDevToolsClientImpl::page_to_client_; - -// static -v8::Persistent<v8::FunctionTemplate> - WebDevToolsClientImpl::host_template_; - -// static -void WebDevToolsClientImpl::InitBoundObject() { - if (!host_template_.IsEmpty()) { - return; - } - v8::HandleScope scope; - v8::Local<v8::FunctionTemplate> local_template = - v8::FunctionTemplate::New(V8Proxy::CheckNewLegal); - host_template_ = v8::Persistent<v8::FunctionTemplate>::New(local_template); - - v8::Local<v8::Signature> default_signature = - v8::Signature::New(host_template_); - v8::Local<v8::ObjectTemplate> proto = host_template_->PrototypeTemplate(); - InitProtoFunction(proto, - "addSourceToFrame", - WebDevToolsClientImpl::JsAddSourceToFrame, - default_signature); - InitProtoFunction(proto, - "loaded", - WebDevToolsClientImpl::JsLoaded, - default_signature); - InitProtoFunction(proto, - "search", - WebCore::V8Custom::v8InspectorControllerSearchCallback, - default_signature); - InitProtoFunction(proto, - "activateWindow", - WebDevToolsClientImpl::JsActivateWindow, - default_signature); - host_template_->SetClassName(v8::String::New("DevToolsHost")); -} - -// static -void WebDevToolsClientImpl::InitProtoFunction( - v8::Handle<v8::ObjectTemplate> proto, - const char* name, - v8::InvocationCallback callback, - v8::Handle<v8::Signature> signature) { - proto->Set( - v8::String::New(name), - v8::FunctionTemplate::New( - callback, - v8::Handle<v8::Value>(), - signature), - static_cast<v8::PropertyAttribute>(v8::DontDelete)); -} - -// static WebDevToolsClient* WebDevToolsClient::Create( WebView* view, WebDevToolsClientDelegate* delegate) { @@ -145,8 +90,7 @@ WebDevToolsClientImpl::WebDevToolsClientImpl( WebDevToolsClientDelegate* delegate) : web_view_impl_(web_view_impl), delegate_(delegate), - loaded_(false), - page_(NULL) { + loaded_(false) { WebFrameImpl* frame = web_view_impl_->main_frame(); // Debugger commands should be sent using special method. @@ -158,8 +102,6 @@ WebDevToolsClientImpl::WebDevToolsClientImpl( net_agent_obj_.set(new JsNetAgentBoundObj(this, frame, L"RemoteNetAgent")); tools_agent_obj_.set( new JsToolsAgentBoundObj(this, frame, L"RemoteToolsAgent")); - page_ = web_view_impl_->page(); - page_to_client_.set(page_, this); WebDevToolsClientImpl::InitBoundObject(); v8::HandleScope scope; @@ -174,7 +116,40 @@ WebDevToolsClientImpl::WebDevToolsClientImpl( } WebDevToolsClientImpl::~WebDevToolsClientImpl() { - page_to_client_.remove(page_); + host_template_.Dispose(); + v8_this_.Dispose(); +} + +void WebDevToolsClientImpl::InitBoundObject() { + v8::HandleScope scope; + v8::Local<v8::FunctionTemplate> local_template = + v8::FunctionTemplate::New(V8Proxy::CheckNewLegal); + host_template_ = v8::Persistent<v8::FunctionTemplate>::New(local_template); + v8_this_ = v8::Persistent<v8::External>::New(v8::External::New(this)); + + InitProtoFunction("addSourceToFrame", + WebDevToolsClientImpl::JsAddSourceToFrame); + InitProtoFunction("loaded", + WebDevToolsClientImpl::JsLoaded); + InitProtoFunction("search", + WebCore::V8Custom::v8InspectorControllerSearchCallback); + InitProtoFunction("activateWindow", + WebDevToolsClientImpl::JsActivateWindow); + host_template_->SetClassName(v8::String::New("DevToolsHost")); +} + +void WebDevToolsClientImpl::InitProtoFunction( + const char* name, + v8::InvocationCallback callback) { + v8::Local<v8::Signature> signature = v8::Signature::New(host_template_); + v8::Local<v8::ObjectTemplate> proto = host_template_->PrototypeTemplate(); + proto->Set( + v8::String::New(name), + v8::FunctionTemplate::New( + callback, + v8_this_, + signature), + static_cast<v8::PropertyAttribute>(v8::DontDelete)); } void WebDevToolsClientImpl::DispatchMessageFromAgent( @@ -231,11 +206,12 @@ v8::Handle<v8::Value> WebDevToolsClientImpl::JsAddSourceToFrame( // static v8::Handle<v8::Value> WebDevToolsClientImpl::JsLoaded( const v8::Arguments& args) { - Page* page = V8Proxy::retrieveActiveFrame()->page(); - WebDevToolsClientImpl* client = page_to_client_.get(page); + WebDevToolsClientImpl* client = static_cast<WebDevToolsClientImpl*>( + v8::External::Cast(*args.Data())->Value()); client->loaded_ = true; // Grant the devtools page the ability to have source view iframes. + Page* page = V8Proxy::retrieveActiveFrame()->page(); SecurityOrigin* origin = page->mainFrame()->domWindow()->securityOrigin(); origin->grantUniversalAccess(); @@ -252,8 +228,8 @@ v8::Handle<v8::Value> WebDevToolsClientImpl::JsLoaded( // static v8::Handle<v8::Value> WebDevToolsClientImpl::JsActivateWindow( const v8::Arguments& args) { - Page* page = V8Proxy::retrieveActiveFrame()->page(); - WebDevToolsClientImpl* client = page_to_client_.get(page); + WebDevToolsClientImpl* client = static_cast<WebDevToolsClientImpl*>( + v8::External::Cast(*args.Data())->Value()); client->delegate_->ActivateWindow(); return v8::Undefined(); } diff --git a/webkit/glue/webdevtoolsclient_impl.h b/webkit/glue/webdevtoolsclient_impl.h index 8e250cb..6a9e1ce 100644 --- a/webkit/glue/webdevtoolsclient_impl.h +++ b/webkit/glue/webdevtoolsclient_impl.h @@ -43,17 +43,12 @@ class WebDevToolsClientImpl : public WebDevToolsClient, virtual void DispatchMessageFromAgent(const std::string& raw_msg); private: - static void InitProtoFunction(v8::Handle<v8::ObjectTemplate> proto, - const char* name, - v8::InvocationCallback callback, - v8::Handle<v8::Signature> signature); static v8::Handle<v8::Value> JsAddSourceToFrame(const v8::Arguments& args); static v8::Handle<v8::Value> JsLoaded(const v8::Arguments& args); static v8::Handle<v8::Value> JsActivateWindow(const v8::Arguments& args); - static v8::Persistent<v8::FunctionTemplate> host_template_; - static HashMap<WebCore::Page*, WebDevToolsClientImpl*> page_to_client_; - static void InitBoundObject(); + void InitBoundObject(); + void InitProtoFunction(const char* name, v8::InvocationCallback callback); WebViewImpl* web_view_impl_; WebDevToolsClientDelegate* delegate_; @@ -64,7 +59,8 @@ class WebDevToolsClientImpl : public WebDevToolsClient, OwnPtr<JsToolsAgentBoundObj> tools_agent_obj_; bool loaded_; Vector<std::string> pending_incoming_messages_; - WebCore::Page* page_; + v8::Persistent<v8::FunctionTemplate> host_template_; + v8::Persistent<v8::External> v8_this_; DISALLOW_COPY_AND_ASSIGN(WebDevToolsClientImpl); }; |