Index: content/public/browser/android/synchronous_compositor.h |
diff --git a/content/public/browser/android/synchronous_compositor.h b/content/public/browser/android/synchronous_compositor.h |
index 476b86dce8310bb235402a50a67bab4137f8fca5..9a43cc184909958879af11bca11d4c1714937f2e 100644 |
--- a/content/public/browser/android/synchronous_compositor.h |
+++ b/content/public/browser/android/synchronous_compositor.h |
@@ -5,9 +5,12 @@ |
#ifndef CONTENT_PUBLIC_BROWSER_ANDROID_SYNCHRONOUS_COMPOSITOR_H_ |
#define CONTENT_PUBLIC_BROWSER_ANDROID_SYNCHRONOUS_COMPOSITOR_H_ |
+#include "base/callback.h" |
#include "base/memory/ref_counted.h" |
+#include "cc/blink/context_provider_web_context.h" |
#include "content/common/content_export.h" |
#include "gpu/command_buffer/service/in_process_command_buffer.h" |
+#include "third_party/WebKit/public/platform/WebGraphicsContext3D.h" |
#include "ui/gfx/geometry/rect.h" |
#include "ui/gfx/geometry/size.h" |
@@ -20,7 +23,7 @@ class CompositorFrameAck; |
namespace gfx { |
class Transform; |
-}; |
+} |
namespace gpu { |
class GLInProcessContext; |
@@ -36,11 +39,25 @@ class WebContents; |
// kEnableSyncrhonousRendererCompositor flag is specified. |
class CONTENT_EXPORT SynchronousCompositor { |
public: |
+ struct CONTENT_EXPORT ContextHolder { |
+ ContextHolder(); |
+ ~ContextHolder(); |
+ |
+ scoped_refptr<cc_blink::ContextProviderWebContext> context_provider; |
+ gpu::GLInProcessContext* context; |
+ }; |
+ |
// Must be called once per WebContents instance. Will create the compositor |
// instance as needed, but only if |client| is non-nullptr. |
static void SetClientForWebContents(WebContents* contents, |
SynchronousCompositorClient* client); |
+ typedef base::Callback<ContextHolder( |
+ bool /* need_share_group_with_parent */, |
+ const blink::WebGraphicsContext3D::Attributes& /* attributes */, |
+ bool /* is_offscreen */)> CreateContextCallback; |
+ static void SetCreateContextCallback(CreateContextCallback callback); |
+ |
static void SetGpuService( |
scoped_refptr<gpu::InProcessCommandBuffer::Service> service); |