diff options
author | Simon Hausmann <simon.hausmann@digia.com> | 2012-11-22 09:09:45 +0100 |
---|---|---|
committer | Simon Hausmann <simon.hausmann@digia.com> | 2012-11-22 09:10:13 +0100 |
commit | 470286ecfe79d59df14944e5b5d34630fc739391 (patch) | |
tree | 43983212872e06cebefd2ae474418fa2908ca54c /Source/WebKit/chromium/src/WebFrameImpl.cpp | |
parent | 23037105e948c2065da5a937d3a2396b0ff45c1e (diff) | |
download | qtwebkit-470286ecfe79d59df14944e5b5d34630fc739391.tar.gz |
Imported WebKit commit e89504fa9195b2063b2530961d4b73dd08de3242 (http://svn.webkit.org/repository/webkit/trunk@135485)
Change-Id: I03774e5ac79721c13ffa30d152537a74d0b12e66
Reviewed-by: Simon Hausmann <simon.hausmann@digia.com>
Diffstat (limited to 'Source/WebKit/chromium/src/WebFrameImpl.cpp')
-rw-r--r-- | Source/WebKit/chromium/src/WebFrameImpl.cpp | 26 |
1 files changed, 4 insertions, 22 deletions
diff --git a/Source/WebKit/chromium/src/WebFrameImpl.cpp b/Source/WebKit/chromium/src/WebFrameImpl.cpp index 1936476f3..eacf9aba8 100644 --- a/Source/WebKit/chromium/src/WebFrameImpl.cpp +++ b/Source/WebKit/chromium/src/WebFrameImpl.cpp @@ -130,7 +130,6 @@ #include "RenderObject.h" #include "RenderTreeAsText.h" #include "RenderView.h" -#include "RenderWidget.h" #include "ResourceHandle.h" #include "ResourceRequest.h" #include "SchemeRegistry.h" @@ -304,23 +303,6 @@ static long long generateFrameIdentifier() return ++next; } -static WebPluginContainerImpl* pluginContainerFromNode(const WebNode& node) -{ - if (node.isNull()) - return 0; - - const Node* coreNode = node.constUnwrap<Node>(); - if (coreNode->hasTagName(HTMLNames::objectTag) || coreNode->hasTagName(HTMLNames::embedTag)) { - RenderObject* object = coreNode->renderer(); - if (object && object->isWidget()) { - Widget* widget = toRenderWidget(object)->widget(); - if (widget && widget->isPluginContainer()) - return static_cast<WebPluginContainerImpl*>(widget); - } - } - return 0; -} - WebPluginContainerImpl* WebFrameImpl::pluginContainerFromFrame(Frame* frame) { if (!frame) @@ -1202,7 +1184,7 @@ size_t WebFrameImpl::characterIndexForPoint(const WebPoint& webPoint) const IntPoint point = frame()->view()->windowToContents(webPoint); HitTestResult result = frame()->eventHandler()->hitTestResultAtPoint(point, false); - RefPtr<Range> range = frame()->rangeForPoint(result.roundedPoint()); + RefPtr<Range> range = frame()->rangeForPoint(result.roundedPointInInnerNodeFrame()); if (!range) return notFound; @@ -1232,7 +1214,7 @@ bool WebFrameImpl::executeCommand(const WebString& name, const WebNode& node) if (command == "Copy") { WebPluginContainerImpl* pluginContainer = pluginContainerFromFrame(frame()); if (!pluginContainer) - pluginContainer = pluginContainerFromNode(node); + pluginContainer = static_cast<WebPluginContainerImpl*>(node.pluginContainer()); if (pluginContainer) { pluginContainer->copy(); return true; @@ -1428,7 +1410,7 @@ int WebFrameImpl::printBegin(const WebPrintParams& printParams, const WebNode& c pluginContainer = pluginContainerFromFrame(frame()); } else { // We only support printing plugin nodes for now. - pluginContainer = pluginContainerFromNode(constrainToNode); + pluginContainer = static_cast<WebPluginContainerImpl*>(constrainToNode.pluginContainer()); } if (pluginContainer && pluginContainer->supportsPaginatedPrint()) @@ -1477,7 +1459,7 @@ void WebFrameImpl::printEnd() bool WebFrameImpl::isPrintScalingDisabledForPlugin(const WebNode& node) { - WebPluginContainerImpl* pluginContainer = node.isNull() ? pluginContainerFromFrame(frame()) : pluginContainerFromNode(node); + WebPluginContainerImpl* pluginContainer = node.isNull() ? pluginContainerFromFrame(frame()) : static_cast<WebPluginContainerImpl*>(node.pluginContainer()); if (!pluginContainer || !pluginContainer->supportsPaginatedPrint()) return false; |