diff options
author | weiliangc@chromium.org <weiliangc@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2014-05-07 15:39:41 +0000 |
---|---|---|
committer | weiliangc@chromium.org <weiliangc@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2014-05-07 15:39:41 +0000 |
commit | 9be1adc83cd60051957268b4aa6517cf2c23fbbb (patch) | |
tree | 7930ff16a9ead5412d0a5a10dd325e4b575a6c87 /cc/test/mock_quad_culler.cc | |
parent | af5e7996e4e5e60ea67512143a226aac952a695d (diff) | |
download | chromium_src-9be1adc83cd60051957268b4aa6517cf2c23fbbb.zip chromium_src-9be1adc83cd60051957268b4aa6517cf2c23fbbb.tar.gz chromium_src-9be1adc83cd60051957268b4aa6517cf2c23fbbb.tar.bz2 |
Create SharedQuadState on RenderPass
Instead of creating SharedQuadState on layers and pass ownership around,
create SharedQuadState on RenderPass and only pass the raw pointer to
layers. Also let QuadCuller hold pointer to RenderPass instead of two
points to DrawQuadList and SharedQuadStateList that is owned by
RenderPass.
BUG=344962
TEST=cc_unittests
Review URL: https://codereview.chromium.org/265823015
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@268785 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'cc/test/mock_quad_culler.cc')
-rw-r--r-- | cc/test/mock_quad_culler.cc | 24 |
1 files changed, 10 insertions, 14 deletions
diff --git a/cc/test/mock_quad_culler.cc b/cc/test/mock_quad_culler.cc index 773430f..ddb5913 100644 --- a/cc/test/mock_quad_culler.cc +++ b/cc/test/mock_quad_culler.cc @@ -9,23 +9,19 @@ namespace cc { -MockQuadCuller::MockQuadCuller() - : active_quad_list_(&quad_list_storage_), - active_shared_quad_state_list_(&shared_quad_state_storage_) {} +MockQuadCuller::MockQuadCuller() { + render_pass_storage_ = RenderPass::Create(); + active_render_pass_ = render_pass_storage_.get(); +} -MockQuadCuller::MockQuadCuller( - QuadList* external_quad_list, - SharedQuadStateList* external_shared_quad_state_list) - : active_quad_list_(external_quad_list), - active_shared_quad_state_list_(external_shared_quad_state_list) {} +MockQuadCuller::MockQuadCuller(RenderPass* external_render_pass) + : active_render_pass_(external_render_pass) { +} MockQuadCuller::~MockQuadCuller() {} -SharedQuadState* MockQuadCuller::UseSharedQuadState( - scoped_ptr<SharedQuadState> shared_quad_state) { - SharedQuadState* raw_ptr = shared_quad_state.get(); - active_shared_quad_state_list_->push_back(shared_quad_state.Pass()); - return raw_ptr; +SharedQuadState* MockQuadCuller::CreateSharedQuadState() { + return active_render_pass_->CreateAndAppendSharedQuadState(); } gfx::Rect MockQuadCuller::UnoccludedContentRect( @@ -63,7 +59,7 @@ gfx::Rect MockQuadCuller::UnoccludedContributingSurfaceContentRect( void MockQuadCuller::Append(scoped_ptr<DrawQuad> draw_quad) { DCHECK(!draw_quad->rect.IsEmpty()); DCHECK(!draw_quad->visible_rect.IsEmpty()); - active_quad_list_->push_back(draw_quad.Pass()); + active_render_pass_->quad_list.push_back(draw_quad.Pass()); } } // namespace cc |