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

Side by Side Diff: cc/surfaces/surface_resource_holder.cc

Issue 2802023002: Remove SurfaceFactory And SurfaceFactoryClient (Closed)
Patch Set: Merge unit tests Created 3 years, 8 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 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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/surfaces/surface_resource_holder.h" 5 #include "cc/surfaces/surface_resource_holder.h"
6 6
7 #include "cc/surfaces/surface_resource_holder_client.h" 7 #include "cc/surfaces/surface_resource_holder_client.h"
8 namespace cc { 8 namespace cc {
9
10 SurfaceResourceHolder::SurfaceResourceHolder( 9 SurfaceResourceHolder::SurfaceResourceHolder(
11 SurfaceResourceHolderClient* client) 10 SurfaceResourceHolderClient* client)
12 : client_(client) {} 11 : client_(client) {}
13 12
14 SurfaceResourceHolder::~SurfaceResourceHolder() { 13 SurfaceResourceHolder::~SurfaceResourceHolder() {}
15 }
16 14
17 SurfaceResourceHolder::ResourceRefs::ResourceRefs() 15 SurfaceResourceHolder::ResourceRefs::ResourceRefs()
18 : refs_received_from_child(0), refs_holding_resource_alive(0) { 16 : refs_received_from_child(0), refs_holding_resource_alive(0) {}
19 }
20 17
21 void SurfaceResourceHolder::Reset() { 18 void SurfaceResourceHolder::Reset() {
22 resource_id_info_map_.clear(); 19 resource_id_info_map_.clear();
23 } 20 }
24 21
25 void SurfaceResourceHolder::ReceiveFromChild( 22 void SurfaceResourceHolder::ReceiveFromChild(
26 const TransferableResourceArray& resources) { 23 const TransferableResourceArray& resources) {
27 for (TransferableResourceArray::const_iterator it = resources.begin(); 24 for (TransferableResourceArray::const_iterator it = resources.begin();
Fady Samuel 2017/04/26 00:44:14 for (const auto& resource : resources) { ... }
Alex Z. 2017/04/27 22:10:01 const auto& doesn't work since we have ++it. I cha
28 it != resources.end(); 25 it != resources.end(); ++it) {
29 ++it) {
30 ResourceRefs& ref = resource_id_info_map_[it->id]; 26 ResourceRefs& ref = resource_id_info_map_[it->id];
31 ref.refs_holding_resource_alive++; 27 ref.refs_holding_resource_alive++;
32 ref.refs_received_from_child++; 28 ref.refs_received_from_child++;
33 } 29 }
34 } 30 }
35 31
36 void SurfaceResourceHolder::RefResources( 32 void SurfaceResourceHolder::RefResources(
37 const TransferableResourceArray& resources) { 33 const TransferableResourceArray& resources) {
38 for (TransferableResourceArray::const_iterator it = resources.begin(); 34 for (TransferableResourceArray::const_iterator it = resources.begin();
39 it != resources.end(); 35 it != resources.end();
(...skipping 27 matching lines...) Expand all
67 returned.count = ref.refs_received_from_child; 63 returned.count = ref.refs_received_from_child;
68 resources_available_to_return.push_back(returned); 64 resources_available_to_return.push_back(returned);
69 resource_id_info_map_.erase(count_it); 65 resource_id_info_map_.erase(count_it);
70 } 66 }
71 } 67 }
72 68
73 client_->ReturnResources(resources_available_to_return); 69 client_->ReturnResources(resources_available_to_return);
74 } 70 }
75 71
76 } // namespace cc 72 } // namespace cc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698