Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(351)

Unified Diff: services/gfx/compositor/graph/resource_def.h

Issue 1552963002: Initial checkin of the new Mozart compositor. (Closed) Base URL: git@github.com:domokit/mojo.git@moz-11
Patch Set: Created 4 years, 12 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: services/gfx/compositor/graph/resource_def.h
diff --git a/services/gfx/compositor/graph/resource_def.h b/services/gfx/compositor/graph/resource_def.h
new file mode 100644
index 0000000000000000000000000000000000000000..4f38b05b2e2e4f377ded9b88adb8cddf9bc5c6a9
--- /dev/null
+++ b/services/gfx/compositor/graph/resource_def.h
@@ -0,0 +1,71 @@
+// Copyright 2015 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 SERVICES_GFX_COMPOSITOR_GRAPH_RESOURCE_DEF_H_
+#define SERVICES_GFX_COMPOSITOR_GRAPH_RESOURCE_DEF_H_
+
+#include <memory>
+
+#include "base/macros.h"
+#include "mojo/services/gfx/composition/interfaces/resources.mojom.h"
+#include "services/gfx/compositor/render/render_image.h"
+
+namespace compositor {
+
+class SceneDef;
+
+// Abstract scene graph resource definition.
+class ResourceDef {
+ public:
+ enum class Type { kScene, kImage };
+
+ ResourceDef() = default;
+ virtual ~ResourceDef() = default;
+
+ // Gets the resource type.
+ virtual Type type() const = 0;
+
+ private:
+ DISALLOW_COPY_AND_ASSIGN(ResourceDef);
+};
+
+// Reference to another scene expressed as a resource definition.
+// The pointer may be null if the referenced scene has become unavailable.
+class SceneResourceDef : public ResourceDef {
+ public:
+ explicit SceneResourceDef(SceneDef* referenced_scene);
+ ~SceneResourceDef() override;
+
+ Type type() const override;
+
+ // The referenced scene, may be null if unavailable.
+ SceneDef* referenced_scene() { return referenced_scene_; }
+ void clear_referenced_scene() { referenced_scene_ = nullptr; }
+
+ private:
+ SceneDef* referenced_scene_;
abarth 2016/01/10 22:55:36 What is the lifetime relationship between this obj
jeffbrown 2016/01/16 03:28:32 I'm using bare pointers because I can guarantee th
+
+ DISALLOW_COPY_AND_ASSIGN(SceneResourceDef);
+};
+
+// Reference to an image expressed as a resource definition.
+class ImageResourceDef : public ResourceDef {
+ public:
+ explicit ImageResourceDef(const std::shared_ptr<RenderImage>& image);
+ ~ImageResourceDef() override;
+
+ Type type() const override;
+
+ // The referenced image, may be null if unavailable.
+ const std::shared_ptr<RenderImage>& image() { return image_; }
+
+ private:
+ std::shared_ptr<RenderImage> image_;
abarth 2016/01/10 22:55:36 I think I raised this before, but shared_ptr is no
jeffbrown 2016/01/16 03:28:32 I am actually using weak_ptr semantics here. It's
+
+ DISALLOW_COPY_AND_ASSIGN(ImageResourceDef);
+};
+
+} // namespace compositor
+
+#endif // SERVICES_GFX_COMPOSITOR_GRAPH_RESOURCE_DEF_H_

Powered by Google App Engine
This is Rietveld 408576698