mirror of
https://bitbucket.org/chromiumembedded/cef
synced 2025-06-05 21:39:12 +02:00
- Add developer tools support (issue #127).
- Send title change notifications generated after page content is done loading. - Restore windows and bring to the front in BrowserWebViewDelegate::show(). git-svn-id: https://chromiumembedded.googlecode.com/svn/trunk@168 5089003a-bbd8-11dd-ad1f-f1f9622dbc98
This commit is contained in:
94
libcef/browser_devtools_client.cc
Normal file
94
libcef/browser_devtools_client.cc
Normal file
@@ -0,0 +1,94 @@
|
||||
// Copyright (c) 2010 The Chromium Authors. All rights reserved.
|
||||
// Use of this source code is governed by a BSD-style license that can be
|
||||
// found in the LICENSE file.
|
||||
|
||||
#include "third_party/WebKit/WebKit/chromium/public/WebDevToolsAgent.h"
|
||||
#include "third_party/WebKit/WebKit/chromium/public/WebDevToolsFrontend.h"
|
||||
#include "third_party/WebKit/WebKit/chromium/public/WebFrame.h"
|
||||
#include "third_party/WebKit/WebKit/chromium/public/WebString.h"
|
||||
#include "third_party/WebKit/WebKit/chromium/public/WebScriptSource.h"
|
||||
#include "third_party/WebKit/WebKit/chromium/public/WebView.h"
|
||||
|
||||
#undef LOG
|
||||
#include "browser_devtools_agent.h"
|
||||
#include "browser_devtools_callargs.h"
|
||||
#include "browser_devtools_client.h"
|
||||
#include "browser_impl.h"
|
||||
|
||||
#include "base/command_line.h"
|
||||
#include "base/message_loop.h"
|
||||
|
||||
using WebKit::WebDevToolsAgent;
|
||||
using WebKit::WebDevToolsFrontend;
|
||||
using WebKit::WebDevToolsMessageData;
|
||||
using WebKit::WebString;
|
||||
using WebKit::WebView;
|
||||
|
||||
BrowserDevToolsClient::BrowserDevToolsClient(CefBrowserImpl* browser,
|
||||
BrowserDevToolsAgent *agent)
|
||||
: ALLOW_THIS_IN_INITIALIZER_LIST(call_method_factory_(this)),
|
||||
browser_(browser),
|
||||
dev_tools_agent_(agent),
|
||||
web_view_(browser->GetWebView()) {
|
||||
web_tools_frontend_.reset(WebDevToolsFrontend::create(web_view_, this,
|
||||
WebString::fromUTF8("en-US")));
|
||||
dev_tools_agent_->attach(this);
|
||||
}
|
||||
|
||||
BrowserDevToolsClient::~BrowserDevToolsClient() {
|
||||
// It is a chance that page will be destroyed at detach step of
|
||||
// dev_tools_agent_ and we should clean pending requests a bit earlier.
|
||||
call_method_factory_.RevokeAll();
|
||||
if (dev_tools_agent_)
|
||||
dev_tools_agent_->detach();
|
||||
}
|
||||
|
||||
void BrowserDevToolsClient::sendFrontendLoaded() {
|
||||
if (dev_tools_agent_)
|
||||
dev_tools_agent_->frontendLoaded();
|
||||
}
|
||||
|
||||
void BrowserDevToolsClient::sendMessageToBackend(
|
||||
const WebString& data) {
|
||||
if (dev_tools_agent_)
|
||||
dev_tools_agent_->AsyncCall(BrowserDevToolsCallArgs(data));
|
||||
}
|
||||
|
||||
void BrowserDevToolsClient::sendDebuggerCommandToAgent(
|
||||
const WebString& command) {
|
||||
WebDevToolsAgent::executeDebuggerCommand(command, 1);
|
||||
}
|
||||
|
||||
void BrowserDevToolsClient::activateWindow() {
|
||||
NOTIMPLEMENTED();
|
||||
}
|
||||
|
||||
void BrowserDevToolsClient::closeWindow() {
|
||||
NOTIMPLEMENTED();
|
||||
}
|
||||
|
||||
void BrowserDevToolsClient::dockWindow() {
|
||||
NOTIMPLEMENTED();
|
||||
}
|
||||
|
||||
void BrowserDevToolsClient::undockWindow() {
|
||||
NOTIMPLEMENTED();
|
||||
}
|
||||
|
||||
void BrowserDevToolsClient::AsyncCall(const BrowserDevToolsCallArgs &args) {
|
||||
MessageLoop::current()->PostDelayedTask(FROM_HERE,
|
||||
call_method_factory_.NewRunnableMethod(&BrowserDevToolsClient::Call,
|
||||
args), 0);
|
||||
}
|
||||
|
||||
void BrowserDevToolsClient::Call(const BrowserDevToolsCallArgs &args) {
|
||||
web_tools_frontend_->dispatchOnInspectorFrontend(args.data_);
|
||||
if (BrowserDevToolsCallArgs::calls_count() == 1)
|
||||
all_messages_processed();
|
||||
}
|
||||
|
||||
void BrowserDevToolsClient::all_messages_processed() {
|
||||
web_view_->mainFrame()->executeScript(WebKit::WebScriptSource(
|
||||
WebString::fromUTF8("if (window.WebInspector && "
|
||||
"WebInspector.queuesAreEmpty) WebInspector.queuesAreEmpty();")));
|
||||
}
|
Reference in New Issue
Block a user