Clone of chromium aad1ce808763f59c7a3753e08f1500a104ecc6fd refs/remotes/origin/HEAD
diff --git a/cc/trees/proxy.h b/cc/trees/proxy.h
new file mode 100644
index 0000000..feeab43
--- /dev/null
+++ b/cc/trees/proxy.h
@@ -0,0 +1,162 @@
+// Copyright 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.
+
+#ifndef CC_TREES_PROXY_H_
+#define CC_TREES_PROXY_H_
+
+#include <string>
+
+#include "base/basictypes.h"
+#include "base/logging.h"
+#include "base/memory/ref_counted.h"
+#include "base/memory/scoped_ptr.h"
+#include "base/threading/platform_thread.h"
+#include "base/time/time.h"
+#include "base/values.h"
+#include "cc/base/cc_export.h"
+
+namespace base {
+namespace debug {
+class TracedValue;
+}
+class SingleThreadTaskRunner;
+}
+
+namespace gfx {
+class Rect;
+class Vector2d;
+}
+
+namespace cc {
+class BlockingTaskRunner;
+class LayerTreeDebugState;
+class OutputSurface;
+struct RendererCapabilities;
+
+// Abstract class responsible for proxying commands from the main-thread side of
+// the compositor over to the compositor implementation.
+class CC_EXPORT Proxy {
+ public:
+  base::SingleThreadTaskRunner* MainThreadTaskRunner() const;
+  bool HasImplThread() const;
+  base::SingleThreadTaskRunner* ImplThreadTaskRunner() const;
+
+  // Debug hooks.
+  bool IsMainThread() const;
+  bool IsImplThread() const;
+  bool IsMainThreadBlocked() const;
+#if DCHECK_IS_ON
+  void SetMainThreadBlocked(bool is_main_thread_blocked);
+  void SetCurrentThreadIsImplThread(bool is_impl_thread);
+#endif
+
+  virtual ~Proxy();
+
+  virtual void FinishAllRendering() = 0;
+
+  virtual bool IsStarted() const = 0;
+
+  // Will call LayerTreeHost::OnCreateAndInitializeOutputSurfaceAttempted
+  // with the result of this function.
+  virtual void SetOutputSurface(scoped_ptr<OutputSurface> output_surface) = 0;
+
+  // Indicates that the compositing surface associated with our context is
+  // ready to use.
+  virtual void SetLayerTreeHostClientReady() = 0;
+
+  virtual void SetVisible(bool visible) = 0;
+
+  virtual const RendererCapabilities& GetRendererCapabilities() const = 0;
+
+  virtual void SetNeedsAnimate() = 0;
+  virtual void SetNeedsUpdateLayers() = 0;
+  virtual void SetNeedsCommit() = 0;
+  virtual void SetNeedsRedraw(const gfx::Rect& damage_rect) = 0;
+  virtual void SetNextCommitWaitsForActivation() = 0;
+
+  virtual void NotifyInputThrottledUntilCommit() = 0;
+
+  // Defers commits until it is reset. It is only supported when in threaded
+  // mode. It's an error to make a sync call like CompositeAndReadback while
+  // commits are deferred.
+  virtual void SetDeferCommits(bool defer_commits) = 0;
+
+  virtual void MainThreadHasStoppedFlinging() = 0;
+
+  virtual bool CommitRequested() const = 0;
+  virtual bool BeginMainFrameRequested() const = 0;
+
+  // Must be called before using the proxy.
+  virtual void Start() = 0;
+  virtual void Stop() = 0;   // Must be called before deleting the proxy.
+
+  // Forces 3D commands on all contexts to wait for all previous SwapBuffers
+  // to finish before executing in the GPU process.
+  virtual void ForceSerializeOnSwapBuffers() = 0;
+
+  // Maximum number of sub-region texture updates supported for each commit.
+  virtual size_t MaxPartialTextureUpdates() const = 0;
+
+  virtual bool SupportsImplScrolling() const = 0;
+
+  virtual void AsValueInto(base::debug::TracedValue* value) const = 0;
+
+  virtual void SetDebugState(const LayerTreeDebugState& debug_state) = 0;
+
+  // Testing hooks
+  virtual bool MainFrameWillHappenForTesting() = 0;
+
+  BlockingTaskRunner* blocking_main_thread_task_runner() const {
+    return blocking_main_thread_task_runner_.get();
+  }
+
+ protected:
+  Proxy(scoped_refptr<base::SingleThreadTaskRunner> main_task_runner,
+        scoped_refptr<base::SingleThreadTaskRunner> impl_task_runner);
+  friend class DebugScopedSetImplThread;
+  friend class DebugScopedSetMainThread;
+  friend class DebugScopedSetMainThreadBlocked;
+
+ private:
+  scoped_refptr<base::SingleThreadTaskRunner> main_task_runner_;
+  scoped_refptr<base::SingleThreadTaskRunner> impl_task_runner_;
+  scoped_ptr<BlockingTaskRunner> blocking_main_thread_task_runner_;
+
+#if DCHECK_IS_ON
+  const base::PlatformThreadId main_thread_id_;
+  bool impl_thread_is_overridden_;
+  bool is_main_thread_blocked_;
+#endif
+
+  DISALLOW_COPY_AND_ASSIGN(Proxy);
+};
+
+#if DCHECK_IS_ON
+class DebugScopedSetMainThreadBlocked {
+ public:
+  explicit DebugScopedSetMainThreadBlocked(Proxy* proxy) : proxy_(proxy) {
+    DCHECK(!proxy_->IsMainThreadBlocked());
+    proxy_->SetMainThreadBlocked(true);
+  }
+  ~DebugScopedSetMainThreadBlocked() {
+    DCHECK(proxy_->IsMainThreadBlocked());
+    proxy_->SetMainThreadBlocked(false);
+  }
+ private:
+  Proxy* proxy_;
+  DISALLOW_COPY_AND_ASSIGN(DebugScopedSetMainThreadBlocked);
+};
+#else
+class DebugScopedSetMainThreadBlocked {
+ public:
+  explicit DebugScopedSetMainThreadBlocked(Proxy* proxy) {}
+  ~DebugScopedSetMainThreadBlocked() {}
+ private:
+  DISALLOW_COPY_AND_ASSIGN(DebugScopedSetMainThreadBlocked);
+};
+#endif
+
+}  // namespace cc
+
+#endif  // CC_TREES_PROXY_H_