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

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

Issue 1801853002: Transfer LayerImpl ownership to LayerTreeImpl (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: rebaaase. Created 4 years, 9 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_layer_tree_host.h" 5 #include "cc/test/fake_layer_tree_host.h"
6 6
7 #include "cc/layers/layer.h" 7 #include "cc/layers/layer.h"
8 #include "cc/test/fake_image_serialization_processor.h" 8 #include "cc/test/fake_image_serialization_processor.h"
9 #include "cc/test/test_task_graph_runner.h" 9 #include "cc/test/test_task_graph_runner.h"
10 10
(...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after
74 74
75 const RendererCapabilities& FakeLayerTreeHost::GetRendererCapabilities() const { 75 const RendererCapabilities& FakeLayerTreeHost::GetRendererCapabilities() const {
76 if (renderer_capabilities_set) 76 if (renderer_capabilities_set)
77 return renderer_capabilities; 77 return renderer_capabilities;
78 return LayerTreeHost::GetRendererCapabilities(); 78 return LayerTreeHost::GetRendererCapabilities();
79 } 79 }
80 80
81 void FakeLayerTreeHost::SetNeedsCommit() { needs_commit_ = true; } 81 void FakeLayerTreeHost::SetNeedsCommit() { needs_commit_ = true; }
82 82
83 LayerImpl* FakeLayerTreeHost::CommitAndCreateLayerImplTree() { 83 LayerImpl* FakeLayerTreeHost::CommitAndCreateLayerImplTree() {
84 scoped_ptr<LayerImpl> old_root_layer_impl = active_tree()->DetachLayerTree(); 84 TreeSynchronizer::SynchronizeTrees(root_layer(), active_tree());
85 85 LayerImpl* layer_impl = active_tree()->root_layer();
86 scoped_ptr<LayerImpl> layer_impl = TreeSynchronizer::SynchronizeTrees(
87 root_layer(), std::move(old_root_layer_impl), active_tree());
88 active_tree()->SetPropertyTrees(*property_trees()); 86 active_tree()->SetPropertyTrees(*property_trees());
89 TreeSynchronizer::PushProperties(root_layer(), layer_impl.get()); 87 TreeSynchronizer::PushProperties(root_layer(), layer_impl);
90
91 active_tree()->SetRootLayer(std::move(layer_impl));
92 active_tree()->UpdatePropertyTreeScrollOffset(property_trees()); 88 active_tree()->UpdatePropertyTreeScrollOffset(property_trees());
93 89
94 if (page_scale_layer() && inner_viewport_scroll_layer()) { 90 if (page_scale_layer() && inner_viewport_scroll_layer()) {
95 active_tree()->SetViewportLayersFromIds( 91 active_tree()->SetViewportLayersFromIds(
96 overscroll_elasticity_layer() ? overscroll_elasticity_layer()->id() 92 overscroll_elasticity_layer() ? overscroll_elasticity_layer()->id()
97 : Layer::INVALID_ID, 93 : Layer::INVALID_ID,
98 page_scale_layer()->id(), inner_viewport_scroll_layer()->id(), 94 page_scale_layer()->id(), inner_viewport_scroll_layer()->id(),
99 outer_viewport_scroll_layer() ? outer_viewport_scroll_layer()->id() 95 outer_viewport_scroll_layer() ? outer_viewport_scroll_layer()->id()
100 : Layer::INVALID_ID); 96 : Layer::INVALID_ID);
101 } 97 }
102 98
103 active_tree()->UpdatePropertyTreesForBoundsDelta(); 99 active_tree()->UpdatePropertyTreesForBoundsDelta();
104 return active_tree()->root_layer(); 100 return active_tree()->root_layer();
105 } 101 }
106 102
107 LayerImpl* FakeLayerTreeHost::CommitAndCreatePendingTree() { 103 LayerImpl* FakeLayerTreeHost::CommitAndCreatePendingTree() {
108 scoped_ptr<LayerImpl> old_root_layer_impl = pending_tree()->DetachLayerTree(); 104 TreeSynchronizer::SynchronizeTrees(root_layer(), pending_tree());
105 LayerImpl* layer_impl = pending_tree()->root_layer();
106 pending_tree()->SetPropertyTrees(*property_trees());
107 TreeSynchronizer::PushProperties(root_layer(), layer_impl);
109 108
110 scoped_ptr<LayerImpl> layer_impl = TreeSynchronizer::SynchronizeTrees(
111 root_layer(), std::move(old_root_layer_impl), pending_tree());
112 pending_tree()->SetPropertyTrees(*property_trees());
113 TreeSynchronizer::PushProperties(root_layer(), layer_impl.get());
114
115 pending_tree()->SetRootLayer(std::move(layer_impl));
116 pending_tree()->UpdatePropertyTreeScrollOffset(property_trees()); 109 pending_tree()->UpdatePropertyTreeScrollOffset(property_trees());
117 return pending_tree()->root_layer(); 110 return pending_tree()->root_layer();
118 } 111 }
119 112
120 } // namespace cc 113 } // namespace cc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698