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

Side by Side Diff: cc/test/fake_delegated_renderer_layer_impl.cc

Issue 1152473006: cc: Remove DrawQuad::IterateResoruces (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 6 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 unified diff | Download patch
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "cc/test/fake_delegated_renderer_layer_impl.h" 5 #include "cc/test/fake_delegated_renderer_layer_impl.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "cc/output/delegated_frame_data.h" 8 #include "cc/output/delegated_frame_data.h"
9 #include "cc/quads/draw_quad.h" 9 #include "cc/quads/draw_quad.h"
10 #include "cc/resources/returned_resource.h" 10 #include "cc/resources/returned_resource.h"
11 #include "cc/trees/layer_tree_impl.h" 11 #include "cc/trees/layer_tree_impl.h"
12 12
13 namespace cc { 13 namespace cc {
14 14
15 FakeDelegatedRendererLayerImpl::FakeDelegatedRendererLayerImpl( 15 FakeDelegatedRendererLayerImpl::FakeDelegatedRendererLayerImpl(
16 LayerTreeImpl* tree_impl, 16 LayerTreeImpl* tree_impl,
17 int id) 17 int id)
18 : DelegatedRendererLayerImpl(tree_impl, id) { 18 : DelegatedRendererLayerImpl(tree_impl, id) {
19 } 19 }
20 20
21 FakeDelegatedRendererLayerImpl::~FakeDelegatedRendererLayerImpl() {} 21 FakeDelegatedRendererLayerImpl::~FakeDelegatedRendererLayerImpl() {}
22 22
23 scoped_ptr<LayerImpl> FakeDelegatedRendererLayerImpl::CreateLayerImpl( 23 scoped_ptr<LayerImpl> FakeDelegatedRendererLayerImpl::CreateLayerImpl(
24 LayerTreeImpl* tree_impl) { 24 LayerTreeImpl* tree_impl) {
25 return FakeDelegatedRendererLayerImpl::Create(tree_impl, id()); 25 return FakeDelegatedRendererLayerImpl::Create(tree_impl, id());
26 } 26 }
27 27
28 static ResourceId AddResourceToFrame(ResourceProvider* resource_provider,
29 DelegatedFrameData* frame,
30 ResourceId resource_id) {
31 TransferableResource resource;
32 resource.id = resource_id;
33 resource.mailbox_holder.texture_target =
34 resource_provider->TargetForTesting(resource_id);
35 frame->resource_list.push_back(resource);
36 return resource_id;
37 }
38
39 ResourceProvider::ResourceIdSet FakeDelegatedRendererLayerImpl::Resources() 28 ResourceProvider::ResourceIdSet FakeDelegatedRendererLayerImpl::Resources()
40 const { 29 const {
41 return ResourcesForTesting(); 30 return ResourcesForTesting();
42 } 31 }
43 32
44 void NoopReturnCallback(const ReturnedResourceArray& returned, 33 void NoopReturnCallback(const ReturnedResourceArray& returned,
45 BlockingTaskRunner* main_thread_task_runner) { 34 BlockingTaskRunner* main_thread_task_runner) {
46 } 35 }
47 36
48 void FakeDelegatedRendererLayerImpl::SetFrameDataForRenderPasses( 37 void FakeDelegatedRendererLayerImpl::SetFrameDataForRenderPasses(
49 float device_scale_factor, 38 float device_scale_factor,
50 const RenderPassList& pass_list) { 39 const RenderPassList& pass_list) {
51 scoped_ptr<DelegatedFrameData> delegated_frame(new DelegatedFrameData); 40 scoped_ptr<DelegatedFrameData> delegated_frame(new DelegatedFrameData);
52 delegated_frame->device_scale_factor = device_scale_factor; 41 delegated_frame->device_scale_factor = device_scale_factor;
53 RenderPass::CopyAll(pass_list, &delegated_frame->render_pass_list); 42 RenderPass::CopyAll(pass_list, &delegated_frame->render_pass_list);
54 43
55 ResourceProvider* resource_provider = layer_tree_impl()->resource_provider(); 44 ResourceProvider* resource_provider = layer_tree_impl()->resource_provider();
56 45
57 DrawQuad::ResourceIteratorCallback add_resource_to_frame_callback =
58 base::Bind(&AddResourceToFrame, resource_provider, delegated_frame.get());
59 for (const auto& pass : delegated_frame->render_pass_list) { 46 for (const auto& pass : delegated_frame->render_pass_list) {
60 for (const auto& quad : pass->quad_list) 47 for (const auto& quad : pass->quad_list) {
61 quad->IterateResources(add_resource_to_frame_callback); 48 for (ResourceId resource_id : quad->resources) {
49 TransferableResource resource;
50 resource.id = resource_id;
51 resource.mailbox_holder.texture_target =
52 resource_provider->TargetForTesting(resource_id);
53 delegated_frame->resource_list.push_back(resource);
54 }
55 }
62 } 56 }
63 57
64 CreateChildIdIfNeeded(base::Bind(&NoopReturnCallback)); 58 CreateChildIdIfNeeded(base::Bind(&NoopReturnCallback));
65 SetFrameData(delegated_frame.get(), gfx::RectF()); 59 SetFrameData(delegated_frame.get(), gfx::RectF());
66 } 60 }
67
68 } // namespace cc 61 } // namespace cc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698