Shorten string
[chromium-blink-merge.git] / cc / resources / prioritized_tile_set.h
blob2d4693efe3621bc433848492f52b2c715fdcfdaf
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
3 // found in the LICENSE file.
5 #ifndef CC_RESOURCES_PRIORITIZED_TILE_SET_H_
6 #define CC_RESOURCES_PRIORITIZED_TILE_SET_H_
8 #include <vector>
10 #include "cc/base/cc_export.h"
11 #include "cc/resources/managed_tile_state.h"
13 namespace cc {
14 class Tile;
16 class CC_EXPORT PrioritizedTileSet {
17 public:
18 PrioritizedTileSet();
19 ~PrioritizedTileSet();
21 void InsertTile(Tile* tile, ManagedTileBin bin);
22 void Clear();
23 bool IsEmpty();
25 class CC_EXPORT Iterator {
26 public:
27 Iterator(PrioritizedTileSet* set, bool use_priority_ordering);
29 ~Iterator();
31 void DisablePriorityOrdering();
33 Iterator& operator++();
34 Tile* operator->() { return *(*this); }
35 Tile* operator*();
36 operator bool() const {
37 return iterator_ != tile_set_->tiles_[current_bin_].end();
40 private:
41 void AdvanceList();
43 PrioritizedTileSet* tile_set_;
44 ManagedTileBin current_bin_;
45 std::vector<Tile*>::iterator iterator_;
46 bool use_priority_ordering_;
49 private:
50 friend class Iterator;
52 void SortBinIfNeeded(ManagedTileBin bin);
54 std::vector<Tile*> tiles_[NUM_BINS];
55 bool bin_sorted_[NUM_BINS];
58 } // namespace cc
60 #endif // CC_RESOURCES_PRIORITIZED_TILE_SET_H_