| Index: cc/resources/eviction_tile_priority_queue.h
|
| diff --git a/cc/resources/eviction_tile_priority_queue.h b/cc/resources/eviction_tile_priority_queue.h
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..060d120c6fc31dedd319d0d90e72bdafea92e107
|
| --- /dev/null
|
| +++ b/cc/resources/eviction_tile_priority_queue.h
|
| @@ -0,0 +1,74 @@
|
| +// Copyright 2014 The Chromium Authors. All rights reserved.
|
| +// Use of this source code is governed by a BSD-style license that can be
|
| +// found in the LICENSE file.
|
| +
|
| +#ifndef CC_RESOURCES_EVICTION_TILE_PRIORITY_QUEUE_H_
|
| +#define CC_RESOURCES_EVICTION_TILE_PRIORITY_QUEUE_H_
|
| +
|
| +#include <utility>
|
| +#include <vector>
|
| +
|
| +#include "cc/base/cc_export.h"
|
| +#include "cc/layers/picture_layer_impl.h"
|
| +#include "cc/resources/tile_priority.h"
|
| +#include "cc/resources/tile_priority_queue.h"
|
| +
|
| +namespace cc {
|
| +
|
| +class CC_EXPORT EvictionTilePriorityQueue : public TilePriorityQueue {
|
| + public:
|
| + EvictionTilePriorityQueue();
|
| + virtual ~EvictionTilePriorityQueue();
|
| +
|
| + void Reset();
|
| + void BuildQueue(const std::vector<PictureLayerImpl*>& layers,
|
| + TreePriority tree_priority);
|
| +
|
| + // TilePriorityQueue overrides.
|
| + virtual void Pop() OVERRIDE;
|
| + virtual bool IsEmpty() OVERRIDE;
|
| + virtual Tile* Top() OVERRIDE;
|
| +
|
| + private:
|
| + struct PairedPictureLayerQueue {
|
| + PairedPictureLayerQueue();
|
| + ~PairedPictureLayerQueue();
|
| +
|
| + Tile* PeekTile(TreePriority tree_priority);
|
| + void PopTile(TreePriority tree_priority);
|
| +
|
| + PictureLayerImpl::LayerEvictionTileIterator* NextTileIterator(
|
| + TreePriority tree_priority);
|
| +
|
| + PictureLayerImpl::LayerEvictionTileIterator active_iterator;
|
| + PictureLayerImpl::LayerEvictionTileIterator pending_iterator;
|
| +
|
| + std::vector<Tile*> returned_shared_tiles;
|
| + };
|
| +
|
| + class EvictionOrderComparator {
|
| + public:
|
| + explicit EvictionOrderComparator(TreePriority tree_priority);
|
| +
|
| + bool operator()(PairedPictureLayerQueue* a,
|
| + PairedPictureLayerQueue* b) const;
|
| +
|
| + private:
|
| + TreePriority tree_priority_;
|
| + };
|
| +
|
| + void Initialize();
|
| +
|
| + std::vector<PairedPictureLayerQueue> paired_queues_;
|
| + std::vector<PairedPictureLayerQueue*> queue_heap_;
|
| + std::vector<PairedPictureLayer> paired_picture_layers_;
|
| + TreePriority tree_priority_;
|
| + EvictionOrderComparator comparator_;
|
| + bool initialized_;
|
| +
|
| + DISALLOW_COPY_AND_ASSIGN(EvictionTilePriorityQueue);
|
| +};
|
| +
|
| +} // namespace cc
|
| +
|
| +#endif // CC_RESOURCES_EVICTION_TILE_PRIORITY_QUEUE_H_
|
|
|