// Copyright (c) 2012 The Chromium Embedded Framework Authors. // Portions copyright (c) 2011 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. // MSVC++ requires this to be set before any other includes to get M_PI. // Otherwise there will be compile errors in wtf/MathExtras.h. #define _USE_MATH_DEFINES // Defines required to access Blink internals (unwrap WebNode). #undef BLINK_IMPLEMENTATION #define BLINK_IMPLEMENTATION 1 #undef INSIDE_BLINK #define INSIDE_BLINK 1 #include "libcef/renderer/webkit_glue.h" #include "base/compiler_specific.h" MSVC_PUSH_WARNING_LEVEL(0); #include "third_party/WebKit/public/platform/WebString.h" #include "third_party/WebKit/public/web/WebDocument.h" #include "third_party/WebKit/public/web/WebElement.h" #include "third_party/WebKit/public/web/WebNode.h" #include "third_party/WebKit/public/web/WebViewClient.h" #include "third_party/WebKit/Source/bindings/core/v8/ScriptController.h" #include "third_party/WebKit/Source/bindings/core/v8/ScriptSourceCode.h" #include "third_party/WebKit/Source/bindings/core/v8/V8Binding.h" #include "third_party/WebKit/Source/core/dom/Document.h" #include "third_party/WebKit/Source/core/dom/Element.h" #include "third_party/WebKit/Source/core/dom/Node.h" #include "third_party/WebKit/Source/core/editing/serializers/Serialization.h" #include "third_party/WebKit/Source/core/frame/LocalFrame.h" #include "third_party/WebKit/Source/core/frame/Settings.h" #include "third_party/WebKit/Source/platform/weborigin/SchemeRegistry.h" #include "third_party/WebKit/Source/web/WebLocalFrameImpl.h" #include "third_party/WebKit/Source/web/WebViewImpl.h" MSVC_POP_WARNING(); #undef LOG #include "base/logging.h" #include "content/renderer/render_frame_impl.h" namespace webkit_glue { const int64_t kInvalidFrameId = -1; bool CanGoBack(blink::WebView* view) { if (!view) return false; blink::WebViewImpl* impl = reinterpret_cast(view); return (impl->Client()->HistoryBackListCount() > 0); } bool CanGoForward(blink::WebView* view) { if (!view) return false; blink::WebViewImpl* impl = reinterpret_cast(view); return (impl->Client()->HistoryForwardListCount() > 0); } void GoBack(blink::WebView* view) { if (!view) return; blink::WebViewImpl* impl = reinterpret_cast(view); if (impl->Client()->HistoryBackListCount() > 0) impl->Client()->NavigateBackForwardSoon(-1); } void GoForward(blink::WebView* view) { if (!view) return; blink::WebViewImpl* impl = reinterpret_cast(view); if (impl->Client()->HistoryForwardListCount() > 0) impl->Client()->NavigateBackForwardSoon(1); } std::string DumpDocumentText(blink::WebFrame* frame) { // We use the document element's text instead of the body text here because // not all documents have a body, such as XML documents. blink::WebElement document_element = frame->GetDocument().DocumentElement(); if (document_element.IsNull()) return std::string(); blink::Element* web_element = document_element.Unwrap(); return blink::WebString(web_element->innerText()).Utf8(); } cef_dom_node_type_t GetNodeType(const blink::WebNode& node) { const blink::Node* web_node = node.ConstUnwrap(); switch (web_node->getNodeType()) { case blink::Node::kElementNode: return DOM_NODE_TYPE_ELEMENT; case blink::Node::kAttributeNode: return DOM_NODE_TYPE_ATTRIBUTE; case blink::Node::kTextNode: return DOM_NODE_TYPE_TEXT; case blink::Node::kCdataSectionNode: return DOM_NODE_TYPE_CDATA_SECTION; case blink::Node::kProcessingInstructionNode: return DOM_NODE_TYPE_PROCESSING_INSTRUCTIONS; case blink::Node::kCommentNode: return DOM_NODE_TYPE_COMMENT; case blink::Node::kDocumentNode: return DOM_NODE_TYPE_DOCUMENT; case blink::Node::kDocumentTypeNode: return DOM_NODE_TYPE_DOCUMENT_TYPE; case blink::Node::kDocumentFragmentNode: return DOM_NODE_TYPE_DOCUMENT_FRAGMENT; } return DOM_NODE_TYPE_UNSUPPORTED; } blink::WebString GetNodeName(const blink::WebNode& node) { const blink::Node* web_node = node.ConstUnwrap(); return web_node->nodeName(); } blink::WebString CreateNodeMarkup(const blink::WebNode& node) { const blink::Node* web_node = node.ConstUnwrap(); return blink::CreateMarkup(web_node); } bool SetNodeValue(blink::WebNode& node, const blink::WebString& value) { blink::Node* web_node = node.Unwrap(); web_node->setNodeValue(value); return true; } int64_t GetIdentifier(blink::WebFrame* frame) { // Each WebFrame will have an associated RenderFrame. The RenderFrame // routing IDs are unique within a given renderer process. content::RenderFrame* render_frame = content::RenderFrame::FromWebFrame(frame); DCHECK(render_frame); if (render_frame) return render_frame->GetRoutingID(); return kInvalidFrameId; } std::string GetUniqueName(blink::WebFrame* frame) { content::RenderFrameImpl* render_frame = content::RenderFrameImpl::FromWebFrame(frame); DCHECK(render_frame); if (render_frame) return render_frame->unique_name(); return std::string(); } v8::MaybeLocal CallV8Function(v8::Local context, v8::Local function, v8::Local receiver, int argc, v8::Local args[], v8::Isolate* isolate) { v8::MaybeLocal func_rv; // Execute the function call using the V8ScriptRunner so that inspector // instrumentation works. blink::LocalFrame* frame = blink::ToLocalFrameIfNotDetached(context); DCHECK(frame); if (frame && frame->GetDocument()->CanExecuteScripts(blink::kAboutToExecuteScript)) { func_rv = blink::V8ScriptRunner::CallFunction( function, frame->GetDocument(), receiver, argc, args, isolate); } return func_rv; } bool IsTextControlElement(const blink::WebElement& element) { const blink::Element* web_element = element.ConstUnwrap(); return web_element->IsTextControl(); } v8::MaybeLocal ExecuteV8ScriptAndReturnValue( const blink::WebString& source, const blink::WebString& source_url, int start_line, v8::Local context, v8::Isolate* isolate, v8::TryCatch& tryCatch, blink::AccessControlStatus accessControlStatus) { // Based on ScriptController::executeScriptAndReturnValue DCHECK(isolate); if (start_line < 1) start_line = 1; const blink::KURL kurl = source_url.IsEmpty() ? blink::KURL() : blink::KURL(blink::kParsedURLString, source_url); const blink::ScriptSourceCode ssc = blink::ScriptSourceCode(source, kurl, WTF::TextPosition(WTF::OrdinalNumber::FromOneBasedInt(start_line), WTF::OrdinalNumber::FromZeroBasedInt(0))); v8::MaybeLocal result; blink::LocalFrame* frame = blink::ToLocalFrameIfNotDetached(context); DCHECK(frame); if (frame) { blink::V8CacheOptions v8CacheOptions(blink::kV8CacheOptionsDefault); if (frame && frame->GetSettings()) v8CacheOptions = frame->GetSettings()->GetV8CacheOptions(); v8::Local script; if (!blink::V8Call(blink::V8ScriptRunner::CompileScript(ssc, isolate, accessControlStatus, v8CacheOptions), script, tryCatch)) { return result; } result = blink::V8ScriptRunner::RunCompiledScript(isolate, script, blink::ToExecutionContext(context)); } return result; } bool IsScriptForbidden() { return blink::ScriptForbiddenScope::IsScriptForbidden(); } void RegisterURLSchemeAsLocal(const blink::WebString& scheme) { blink::SchemeRegistry::RegisterURLSchemeAsLocal(scheme); } void RegisterURLSchemeAsSecure(const blink::WebString& scheme) { blink::SchemeRegistry::RegisterURLSchemeAsSecure(scheme); } void RegisterURLSchemeAsCORSEnabled(const blink::WebString& scheme) { blink::SchemeRegistry::RegisterURLSchemeAsCORSEnabled(scheme); } } // webkit_glue