Chromium Code Reviews| Index: third_party/WebKit/Source/core/layout/LayoutPart.cpp |
| diff --git a/third_party/WebKit/Source/core/layout/LayoutPart.cpp b/third_party/WebKit/Source/core/layout/LayoutPart.cpp |
| index 9078c43ead331db2c248178d7033e6bdbb811f39..8e8745c8e0f807848d38e254d6bf0143a0a7d8d9 100644 |
| --- a/third_party/WebKit/Source/core/layout/LayoutPart.cpp |
| +++ b/third_party/WebKit/Source/core/layout/LayoutPart.cpp |
| @@ -28,6 +28,7 @@ |
| #include "core/frame/FrameView.h" |
| #include "core/frame/LocalFrame.h" |
| #include "core/html/HTMLFrameElementBase.h" |
| +#include "core/html/HTMLPlugInElement.h" |
| #include "core/layout/HitTestResult.h" |
| #include "core/layout/LayoutAnalyzer.h" |
| #include "core/layout/LayoutView.h" |
| @@ -98,6 +99,13 @@ FrameViewBase* LayoutPart::frameViewBase() const { |
| return nullptr; |
| } |
| +PluginView* LayoutPart::plugin() const { |
| + // Plugins are stored in their DOM node. |
| + return node() && isHTMLPlugInElement(node()) |
| + ? toHTMLPlugInElement(node())->plugin() |
| + : nullptr; |
| +} |
| + |
| PaintLayerType LayoutPart::layerTypeRequired() const { |
| PaintLayerType type = LayoutReplaced::layerTypeRequired(); |
| if (type != NoPaintLayer) |
| @@ -110,8 +118,8 @@ bool LayoutPart::requiresAcceleratedCompositing() const { |
| // a plugin LayoutObject and the plugin has a layer, then we need a layer. |
| // Second, if this is a LayoutObject with a contentDocument and that document |
| // needs a layer, then we need a layer. |
| - if (frameViewBase() && frameViewBase()->isPluginView() && |
| - toPluginView(frameViewBase())->platformLayer()) |
| + PluginView* pluginView = plugin(); |
| + if (pluginView && pluginView->platformLayer()) |
| return true; |
| if (!node() || !node()->isFrameOwnerElement()) |
| @@ -247,6 +255,7 @@ void LayoutPart::styleDidChange(StyleDifference diff, |
| if (frameViewBase && frameViewBase->isFrameView()) |
| toFrameView(frameViewBase)->recalculateCustomScrollbarStyle(); |
| + // TODO(joelhockey): Does this need separate code for plugins? |
|
haraken
2017/03/22 15:32:33
I guess yes.
Can you add CHECK(!(node() && isHTML
joelhockey
2017/03/27 06:42:21
Thanks, that is a helpful approach. It showed tha
|
| if (style()->visibility() != EVisibility::kVisible) { |
| frameViewBase->hide(); |
|
haraken
2017/03/22 15:32:33
One way to handle both the FrameViewBase case and
joelhockey
2017/03/27 06:42:21
This function will be ok to take FrameViewBase as
haraken
2017/03/28 07:39:41
However, you're planning to remove the inheritance
joelhockey
2017/03/28 22:56:23
Yes, I will remove the inheritance from FrameView
haraken
2017/03/29 11:04:46
Sounds like a nice plan.
|
| } else { |
| @@ -272,7 +281,7 @@ void LayoutPart::paintContents(const PaintInfo& paintInfo, |
| CursorDirective LayoutPart::getCursor(const LayoutPoint& point, |
| Cursor& cursor) const { |
| - if (frameViewBase() && frameViewBase()->isPluginView()) { |
| + if (plugin()) { |
| // A plugin is responsible for setting the cursor when the pointer is over |
| // it. |
| return DoNotSetCursor; |
| @@ -301,6 +310,7 @@ void LayoutPart::updateOnWidgetChange() { |
| if (!needsLayout()) |
| updateGeometryInternal(); |
| + // TODO(joelhockey): Does this need special handling for plugin? |
|
dcheng
2017/03/23 07:21:42
I think this also needs to be handled: the main su
joelhockey
2017/03/27 06:42:21
Thanks. I just noticed how the impl forwards the
|
| if (style()->visibility() != EVisibility::kVisible) { |
| frameViewBase->hide(); |
| } else { |
| @@ -319,6 +329,7 @@ void LayoutPart::updateGeometry() { |
| LayoutRect newFrame = replacedContentRect(); |
| DCHECK(newFrame.size() == roundedIntSize(newFrame.size())); |
| + // TODO(joelhockey): Does this need special handling for plugin? |
| bool boundsWillChange = |
| LayoutSize(frameViewBase->frameRect().size()) != newFrame.size(); |
| @@ -372,6 +383,7 @@ void LayoutPart::updateGeometryInternal() { |
| // Why is the protector needed? |
| RefPtr<LayoutPart> protector(this); |
| + // TODO(joelhockey): Does this need special handling for plugin? |
| frameViewBase->setFrameRect(frameRect); |
| } |