diff options
Diffstat (limited to 'cc/quads/render_pass.cc')
-rw-r--r-- | cc/quads/render_pass.cc | 39 |
1 files changed, 38 insertions, 1 deletions
diff --git a/cc/quads/render_pass.cc b/cc/quads/render_pass.cc index ef6308c..50d5028 100644 --- a/cc/quads/render_pass.cc +++ b/cc/quads/render_pass.cc @@ -4,12 +4,20 @@ #include "cc/quads/render_pass.h" +#include "base/values.h" +#include "cc/base/math_util.h" +#include "cc/debug/traced_value.h" #include "cc/output/copy_output_request.h" #include "cc/quads/draw_quad.h" #include "cc/quads/shared_quad_state.h" namespace cc { +void* RenderPass::Id::AsTracingId() const { + COMPILE_ASSERT(sizeof(size_t) <= sizeof(void*), size_t_bigger_than_pointer); + return reinterpret_cast<void*>(base::HashPair(layer_id, index)); +} + scoped_ptr<RenderPass> RenderPass::Create() { return make_scoped_ptr(new RenderPass); } @@ -19,7 +27,11 @@ RenderPass::RenderPass() has_transparent_background(true), has_occlusion_from_outside_target_surface(false) {} -RenderPass::~RenderPass() {} +RenderPass::~RenderPass() { + TRACE_EVENT_OBJECT_DELETED_WITH_ID( + TRACE_DISABLED_BY_DEFAULT("cc.debug.quads"), + "cc::RenderPass", id.AsTracingId()); +} scoped_ptr<RenderPass> RenderPass::Copy(Id new_id) const { scoped_ptr<RenderPass> copy_pass(Create()); @@ -69,4 +81,29 @@ void RenderPass::SetAll(Id id, DCHECK(shared_quad_state_list.empty()); } +scoped_ptr<base::Value> RenderPass::AsValue() const { + scoped_ptr<base::DictionaryValue> value(new base::DictionaryValue()); + value->Set("output_rect", MathUtil::AsValue(output_rect).release()); + value->Set("damage_rect", MathUtil::AsValue(damage_rect).release()); + value->SetBoolean("has_transparent_background", has_transparent_background); + value->SetBoolean("has_occlusion_from_outside_target_surface", + has_occlusion_from_outside_target_surface); + value->SetInteger("copy_requests", copy_requests.size()); + scoped_ptr<base::ListValue> shared_states_value(new base::ListValue()); + for (size_t i = 0; i < shared_quad_state_list.size(); ++i) { + shared_states_value->Append(shared_quad_state_list[i]->AsValue().release()); + } + value->Set("shared_quad_state_list", shared_states_value.release()); + scoped_ptr<base::ListValue> quad_list_value(new base::ListValue()); + for (size_t i = 0; i < quad_list.size(); ++i) { + quad_list_value->Append(quad_list[i]->AsValue().release()); + } + value->Set("quad_list", quad_list_value.release()); + + TracedValue::MakeDictIntoImplicitSnapshotWithCategory( + TRACE_DISABLED_BY_DEFAULT("cc.debug.quads"), + value.get(), "cc::RenderPass", id.AsTracingId()); + return value.PassAs<base::Value>(); +} + } // namespace cc |