summaryrefslogtreecommitdiffstats
path: root/Source/WebCore/rendering/RenderPart.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'Source/WebCore/rendering/RenderPart.cpp')
-rw-r--r--Source/WebCore/rendering/RenderPart.cpp34
1 files changed, 33 insertions, 1 deletions
diff --git a/Source/WebCore/rendering/RenderPart.cpp b/Source/WebCore/rendering/RenderPart.cpp
index 3262961..59b9795 100644
--- a/Source/WebCore/rendering/RenderPart.cpp
+++ b/Source/WebCore/rendering/RenderPart.cpp
@@ -24,10 +24,11 @@
#include "config.h"
#include "RenderPart.h"
-#include "RenderView.h"
#include "Frame.h"
#include "FrameView.h"
#include "HTMLFrameElementBase.h"
+#include "PluginViewBase.h"
+#include "RenderView.h"
namespace WebCore {
@@ -58,4 +59,35 @@ void RenderPart::viewCleared()
{
}
+#if USE(ACCELERATED_COMPOSITING)
+bool RenderPart::requiresLayer() const
+{
+ if (RenderWidget::requiresLayer())
+ return true;
+
+ return requiresAcceleratedCompositing();
+}
+
+bool RenderPart::requiresAcceleratedCompositing() const
+{
+ // There are two general cases in which we can return true. First, if this is a plugin
+ // renderer and the plugin has a layer, then we need a layer. Second, if this is
+ // a renderer with a contentDocument and that document needs a layer, then we need
+ // a layer.
+ if (widget() && widget()->isPluginViewBase() && static_cast<PluginViewBase*>(widget())->platformLayer())
+ return true;
+
+ if (!node() || !node()->isFrameOwnerElement())
+ return false;
+
+ HTMLFrameOwnerElement* element = static_cast<HTMLFrameOwnerElement*>(node());
+ if (Document* contentDocument = element->contentDocument()) {
+ if (RenderView* view = contentDocument->renderView())
+ return view->usesCompositing();
+ }
+
+ return false;
+}
+#endif
+
}