Index: cc/surfaces/surface_reference_base.cc |
diff --git a/cc/surfaces/surface_reference_base.cc b/cc/surfaces/surface_reference_base.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..ad3ed1ef2ddc6b4433125b551629deeec9eae4db |
--- /dev/null |
+++ b/cc/surfaces/surface_reference_base.cc |
@@ -0,0 +1,31 @@ |
+// Copyright 2016 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. |
+ |
+#include "cc/surfaces/surface_reference_base.h" |
+ |
+#include "cc/surfaces/surface_reference_factory.h" |
+ |
+namespace cc { |
+ |
+SurfaceReferenceBase::SurfaceReferenceBase( |
+ scoped_refptr<const SurfaceReferenceFactory> factory) |
+ : factory_(std::move(factory)) {} |
+ |
+SurfaceReferenceBase::~SurfaceReferenceBase() { |
+ DCHECK(!factory_) << "Destroy must be called before destruction"; |
+} |
+ |
+void SurfaceReferenceBase::Destroy() { |
+ DCHECK(factory_) << "Destroy can only be called once"; |
+ factory_->DestroyReference(this); |
+ factory_ = nullptr; |
+} |
+ |
+void SurfaceReferenceBase::Destroy(CompositorFrameMetadata* metadata) { |
Fady Samuel
2016/12/16 12:24:09
Get rid of this?
Saman Sami
2016/12/16 16:14:35
Done.
|
+ DCHECK(factory_) << "Destroy can only be called once"; |
+ factory_->DestroyReference(this, metadata); |
+ factory_ = nullptr; |
+} |
+ |
+} // namespace cc |