diff options
author | jamesr@chromium.org <jamesr@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2013-03-26 18:06:10 +0000 |
---|---|---|
committer | jamesr@chromium.org <jamesr@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2013-03-26 18:06:10 +0000 |
commit | adb08548d49107d17ccd2caea44c7fc8bc106680 (patch) | |
tree | b04645bbd04bbca91d41a4badad5528e2f29b9ad /cc | |
parent | ab3b99de93676e6b18a0b58d2de141694c2ab79a (diff) | |
download | chromium_src-adb08548d49107d17ccd2caea44c7fc8bc106680.zip chromium_src-adb08548d49107d17ccd2caea44c7fc8bc106680.tar.gz chromium_src-adb08548d49107d17ccd2caea44c7fc8bc106680.tar.bz2 |
This fixes all lint issues (except for false positives) in:
cc/base/
cc/debug/
cc/resources/
cc/quads/
BUG=144577
Review URL: https://codereview.chromium.org/13051003
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@190715 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'cc')
80 files changed, 1126 insertions, 946 deletions
diff --git a/cc/base/completion_event.h b/cc/base/completion_event.h index f7fa5b1..759ce9c 100644 --- a/cc/base/completion_event.h +++ b/cc/base/completion_event.h @@ -58,6 +58,6 @@ class CompletionEvent { #endif }; -} +} // namespace cc #endif // CC_BASE_COMPLETION_EVENT_H_ diff --git a/cc/base/hash_pair.h b/cc/base/hash_pair.h index e8602d2..5e0aa08 100644 --- a/cc/base/hash_pair.h +++ b/cc/base/hash_pair.h @@ -7,6 +7,9 @@ #ifndef CC_BASE_HASH_PAIR_H_ #define CC_BASE_HASH_PAIR_H_ +#include <utility> + +#include "base/basictypes.h" #include "base/hash_tables.h" #if defined(COMPILER_MSVC) @@ -30,7 +33,7 @@ #else #error define DEFINE_PAIR_HASH_FUNCTION_START for your compiler -#endif // COMPILER +#endif // COMPILER namespace BASE_HASH_NAMESPACE { @@ -61,22 +64,22 @@ namespace BASE_HASH_NAMESPACE { } \ DEFINE_PAIR_HASH_FUNCTION_END(); -DEFINE_32BIT_PAIR_HASH(short, short); -DEFINE_32BIT_PAIR_HASH(short, unsigned short); -DEFINE_32BIT_PAIR_HASH(short, int); -DEFINE_32BIT_PAIR_HASH(short, unsigned); -DEFINE_32BIT_PAIR_HASH(unsigned short, short); -DEFINE_32BIT_PAIR_HASH(unsigned short, unsigned short); -DEFINE_32BIT_PAIR_HASH(unsigned short, int); -DEFINE_32BIT_PAIR_HASH(unsigned short, unsigned); -DEFINE_32BIT_PAIR_HASH(int, short); -DEFINE_32BIT_PAIR_HASH(int, unsigned short); -DEFINE_32BIT_PAIR_HASH(int, int); -DEFINE_32BIT_PAIR_HASH(int, unsigned); -DEFINE_32BIT_PAIR_HASH(unsigned, short); -DEFINE_32BIT_PAIR_HASH(unsigned, unsigned short); -DEFINE_32BIT_PAIR_HASH(unsigned, int); -DEFINE_32BIT_PAIR_HASH(unsigned, unsigned); +DEFINE_32BIT_PAIR_HASH(int16, int16); +DEFINE_32BIT_PAIR_HASH(int16, uint16); +DEFINE_32BIT_PAIR_HASH(int16, int32); +DEFINE_32BIT_PAIR_HASH(int16, uint32); +DEFINE_32BIT_PAIR_HASH(uint16, int16); +DEFINE_32BIT_PAIR_HASH(uint16, uint16); +DEFINE_32BIT_PAIR_HASH(uint16, int32); +DEFINE_32BIT_PAIR_HASH(uint16, uint32); +DEFINE_32BIT_PAIR_HASH(int32, int16); +DEFINE_32BIT_PAIR_HASH(int32, uint16); +DEFINE_32BIT_PAIR_HASH(int32, int32); +DEFINE_32BIT_PAIR_HASH(int32, uint32); +DEFINE_32BIT_PAIR_HASH(uint32, int16); +DEFINE_32BIT_PAIR_HASH(uint32, uint16); +DEFINE_32BIT_PAIR_HASH(uint32, int32); +DEFINE_32BIT_PAIR_HASH(uint32, uint32); #undef DEFINE_32BIT_PAIR_HASH @@ -120,24 +123,24 @@ DEFINE_32BIT_PAIR_HASH(unsigned, unsigned); } \ DEFINE_PAIR_HASH_FUNCTION_END(); -DEFINE_64BIT_PAIR_HASH(short, int64); -DEFINE_64BIT_PAIR_HASH(short, uint64); -DEFINE_64BIT_PAIR_HASH(unsigned short, int64); -DEFINE_64BIT_PAIR_HASH(unsigned short, uint64); -DEFINE_64BIT_PAIR_HASH(int, int64); -DEFINE_64BIT_PAIR_HASH(int, uint64); -DEFINE_64BIT_PAIR_HASH(unsigned, int64); -DEFINE_64BIT_PAIR_HASH(unsigned, uint64); -DEFINE_64BIT_PAIR_HASH(int64, short); -DEFINE_64BIT_PAIR_HASH(int64, unsigned short); -DEFINE_64BIT_PAIR_HASH(int64, int); -DEFINE_64BIT_PAIR_HASH(int64, unsigned); +DEFINE_64BIT_PAIR_HASH(int16, int64); +DEFINE_64BIT_PAIR_HASH(int16, uint64); +DEFINE_64BIT_PAIR_HASH(uint16, int64); +DEFINE_64BIT_PAIR_HASH(uint16, uint64); +DEFINE_64BIT_PAIR_HASH(int32, int64); +DEFINE_64BIT_PAIR_HASH(int32, uint64); +DEFINE_64BIT_PAIR_HASH(uint32, int64); +DEFINE_64BIT_PAIR_HASH(uint32, uint64); +DEFINE_64BIT_PAIR_HASH(int64, int16); +DEFINE_64BIT_PAIR_HASH(int64, uint16); +DEFINE_64BIT_PAIR_HASH(int64, int32); +DEFINE_64BIT_PAIR_HASH(int64, uint32); DEFINE_64BIT_PAIR_HASH(int64, int64); DEFINE_64BIT_PAIR_HASH(int64, uint64); -DEFINE_64BIT_PAIR_HASH(uint64, short); -DEFINE_64BIT_PAIR_HASH(uint64, unsigned short); -DEFINE_64BIT_PAIR_HASH(uint64, int); -DEFINE_64BIT_PAIR_HASH(uint64, unsigned); +DEFINE_64BIT_PAIR_HASH(uint64, int16); +DEFINE_64BIT_PAIR_HASH(uint64, uint16); +DEFINE_64BIT_PAIR_HASH(uint64, int32); +DEFINE_64BIT_PAIR_HASH(uint64, uint32); DEFINE_64BIT_PAIR_HASH(uint64, int64); DEFINE_64BIT_PAIR_HASH(uint64, uint64); diff --git a/cc/base/hash_pair_unittest.cc b/cc/base/hash_pair_unittest.cc index 685e935..ad16761 100644 --- a/cc/base/hash_pair_unittest.cc +++ b/cc/base/hash_pair_unittest.cc @@ -22,46 +22,29 @@ class HashPairTest : public testing::Test { // Verify that a hash_map can be constructed for pairs of integers of various // sizes. TEST_F(HashPairTest, IntegerPairs) { - typedef std::pair<short, short> ShortShortPair; - typedef std::pair<short, int> ShortIntPair; - typedef std::pair<short, int32> ShortInt32Pair; - typedef std::pair<short, int64> ShortInt64Pair; + typedef std::pair<int16, int16> Int16Int16Pair; + typedef std::pair<int16, int32> Int16Int32Pair; + typedef std::pair<int16, int64> Int16Int64Pair; - INSERT_PAIR_TEST(ShortShortPair, 4, 6); - INSERT_PAIR_TEST(ShortIntPair, 7, (1 << 30) + 4342); - INSERT_PAIR_TEST(ShortInt32Pair, 9, (1 << 29) + 378128932); - INSERT_PAIR_TEST(ShortInt64Pair, 10, + INSERT_PAIR_TEST(Int16Int16Pair, 4, 6); + INSERT_PAIR_TEST(Int16Int32Pair, 9, (1 << 29) + 378128932); + INSERT_PAIR_TEST(Int16Int64Pair, 10, (GG_INT64_C(1) << 60) + GG_INT64_C(78931732321)); - typedef std::pair<int, short> IntShortPair; - typedef std::pair<int, int> IntIntPair; - typedef std::pair<int, int32> IntInt32Pair; - typedef std::pair<int, int64> IntInt64Pair; - - INSERT_PAIR_TEST(IntShortPair, 4, 6); - INSERT_PAIR_TEST(IntIntPair, 7, (1 << 30) + 4342); - INSERT_PAIR_TEST(IntInt32Pair, 9, (1 << 29) + 378128932); - INSERT_PAIR_TEST(IntInt64Pair, 10, - (GG_INT64_C(1) << 60) + GG_INT64_C(78931732321)); - - typedef std::pair<int32, short> Int32ShortPair; - typedef std::pair<int32, int> Int32IntPair; + typedef std::pair<int32, int16> Int32Int16Pair; typedef std::pair<int32, int32> Int32Int32Pair; typedef std::pair<int32, int64> Int32Int64Pair; - INSERT_PAIR_TEST(Int32ShortPair, 4, 6); - INSERT_PAIR_TEST(Int32IntPair, 7, (1 << 30) + 4342); + INSERT_PAIR_TEST(Int32Int16Pair, 4, 6); INSERT_PAIR_TEST(Int32Int32Pair, 9, (1 << 29) + 378128932); INSERT_PAIR_TEST(Int32Int64Pair, 10, (GG_INT64_C(1) << 60) + GG_INT64_C(78931732321)); - typedef std::pair<int64, short> Int64ShortPair; - typedef std::pair<int64, int> Int64IntPair; + typedef std::pair<int64, int16> Int64Int16Pair; typedef std::pair<int64, int32> Int64Int32Pair; typedef std::pair<int64, int64> Int64Int64Pair; - INSERT_PAIR_TEST(Int64ShortPair, 4, 6); - INSERT_PAIR_TEST(Int64IntPair, 7, (1 << 30) + 4342); + INSERT_PAIR_TEST(Int64Int16Pair, 4, 6); INSERT_PAIR_TEST(Int64Int32Pair, 9, (1 << 29) + 378128932); INSERT_PAIR_TEST(Int64Int64Pair, 10, (GG_INT64_C(1) << 60) + GG_INT64_C(78931732321)); diff --git a/cc/base/math_util.h b/cc/base/math_util.h index dc9110f..1736444 100644 --- a/cc/base/math_util.h +++ b/cc/base/math_util.h @@ -152,7 +152,6 @@ class CC_EXPORT MathUtil { // If the value is inf, returns max double/float representation. static scoped_ptr<base::Value> AsValueSafely(double value); static scoped_ptr<base::Value> AsValueSafely(float value); - }; } // namespace cc diff --git a/cc/base/region_unittest.cc b/cc/base/region_unittest.cc index 737ae27..20379ba 100644 --- a/cc/base/region_unittest.cc +++ b/cc/base/region_unittest.cc @@ -71,7 +71,7 @@ TEST(RegionTest, ContainsPoint) { TEST_BOTTOM_OF_RECT(r, 31, 40, 10, 10); r.Union(gfx::Rect(42, 40, 10, 10)); - + TEST_INSIDE_RECT(r, 42, 40, 10, 10); TEST_LEFT_OF_RECT(r, 42, 40, 10, 10); TEST_RIGHT_OF_RECT(r, 42, 40, 10, 10); diff --git a/cc/base/scoped_ptr_deque.h b/cc/base/scoped_ptr_deque.h index b1e9d0e..35289f1 100644 --- a/cc/base/scoped_ptr_deque.h +++ b/cc/base/scoped_ptr_deque.h @@ -5,7 +5,9 @@ #ifndef CC_BASE_SCOPED_PTR_DEQUE_H_ #define CC_BASE_SCOPED_PTR_DEQUE_H_ +#include <algorithm> #include <deque> + #include "base/basictypes.h" #include "base/logging.h" #include "base/memory/scoped_ptr.h" diff --git a/cc/base/scoped_ptr_hash_map.h b/cc/base/scoped_ptr_hash_map.h index 734fb8a..3a749a5 100644 --- a/cc/base/scoped_ptr_hash_map.h +++ b/cc/base/scoped_ptr_hash_map.h @@ -5,6 +5,9 @@ #ifndef CC_BASE_SCOPED_PTR_HASH_MAP_H_ #define CC_BASE_SCOPED_PTR_HASH_MAP_H_ +#include <algorithm> +#include <utility> + #include "base/basictypes.h" #include "base/hash_tables.h" #include "base/logging.h" @@ -14,11 +17,12 @@ namespace cc { // This type acts like a hash_map<K, scoped_ptr<V> >, based on top of -// std::hash_map. The ScopedPtrHashMap has ownership of all values in the data +// base::hash_map. The ScopedPtrHashMap has ownership of all values in the data // structure. template <typename Key, typename Value> class ScopedPtrHashMap { typedef base::hash_map<Key, Value*> Container; + public: typedef typename Container::iterator iterator; typedef typename Container::const_iterator const_iterator; diff --git a/cc/base/scoped_ptr_vector.h b/cc/base/scoped_ptr_vector.h index 1e69b16..01f4d3d 100644 --- a/cc/base/scoped_ptr_vector.h +++ b/cc/base/scoped_ptr_vector.h @@ -5,6 +5,9 @@ #ifndef CC_BASE_SCOPED_PTR_VECTOR_H_ #define CC_BASE_SCOPED_PTR_VECTOR_H_ +#include <algorithm> +#include <vector> + #include "base/basictypes.h" #include "base/logging.h" #include "base/memory/scoped_ptr.h" @@ -142,7 +145,7 @@ class ScopedPtrVector { template<class Compare> inline void sort(Compare comp) { - std::sort(data_.begin(), data_.end(), comp); + std::sort(data_.begin(), data_.end(), comp); } iterator begin() { return static_cast<iterator>(data_.begin()); } diff --git a/cc/base/tiling_data.cc b/cc/base/tiling_data.cc index f734b35..ba6aaa8 100644 --- a/cc/base/tiling_data.cc +++ b/cc/base/tiling_data.cc @@ -256,8 +256,10 @@ gfx::Vector2d TilingData::TextureOffset(int x_index, int y_index) const { } void TilingData::RecomputeNumTiles() { - num_tiles_x_ = ComputeNumTiles(max_texture_size_.width(), total_size_.width(), border_texels_); - num_tiles_y_ = ComputeNumTiles(max_texture_size_.height(), total_size_.height(), border_texels_); + num_tiles_x_ = ComputeNumTiles( + max_texture_size_.width(), total_size_.width(), border_texels_); + num_tiles_y_ = ComputeNumTiles( + max_texture_size_.height(), total_size_.height(), border_texels_); } TilingData::BaseIterator::BaseIterator(const TilingData* tiling_data) diff --git a/cc/base/tiling_data.h b/cc/base/tiling_data.h index fc71409e..3bf9809 100644 --- a/cc/base/tiling_data.h +++ b/cc/base/tiling_data.h @@ -5,6 +5,8 @@ #ifndef CC_BASE_TILING_DATA_H_ #define CC_BASE_TILING_DATA_H_ +#include <utility> + #include "base/basictypes.h" #include "base/logging.h" #include "cc/base/cc_export.h" @@ -74,7 +76,10 @@ class CC_EXPORT TilingData { protected: explicit BaseIterator(const TilingData* tiling_data); - void done() { index_x_ = -1; index_y_ = -1; } + void done() { + index_x_ = -1; + index_y_ = -1; + } const TilingData* tiling_data_; int index_x_; diff --git a/cc/base/tiling_data_unittest.cc b/cc/base/tiling_data_unittest.cc index f24dc6a..ea141ad 100644 --- a/cc/base/tiling_data_unittest.cc +++ b/cc/base/tiling_data_unittest.cc @@ -4,6 +4,8 @@ #include "cc/base/tiling_data.h" +#include <vector> + #include "cc/test/geometry_test_utils.h" #include "testing/gtest/include/gtest/gtest.h" diff --git a/cc/base/worker_pool.cc b/cc/base/worker_pool.cc index 469f67c6..d276529 100644 --- a/cc/base/worker_pool.cc +++ b/cc/base/worker_pool.cc @@ -4,6 +4,8 @@ #include "cc/base/worker_pool.h" +#include <algorithm> + #include "base/bind.h" #include "base/debug/trace_event.h" #include "base/stringprintf.h" @@ -344,10 +346,9 @@ void WorkerPool::Inner::OnIdleOnOriginThread() { void WorkerPool::Inner::Run() { #if defined(OS_ANDROID) // TODO(epenner): Move thread priorities to base. (crbug.com/170549) - int nice_value = 10; // Idle priority. + int nice_value = 10; // Idle priority. setpriority(PRIO_PROCESS, base::PlatformThread::CurrentId(), nice_value); #endif - { base::AutoLock lock(lock_); diff --git a/cc/base/worker_pool.h b/cc/base/worker_pool.h index af130f3..172165c 100644 --- a/cc/base/worker_pool.h +++ b/cc/base/worker_pool.h @@ -31,7 +31,7 @@ class WorkerPoolTask { void DidComplete(); protected: - WorkerPoolTask(const base::Closure& reply); + explicit WorkerPoolTask(const base::Closure& reply); const base::Closure reply_; }; diff --git a/cc/debug/debug_colors.cc b/cc/debug/debug_colors.cc index 462fca7..cc43480 100644 --- a/cc/debug/debug_colors.cc +++ b/cc/debug/debug_colors.cc @@ -15,110 +15,217 @@ static const float Scale(float width, const LayerTreeImpl* tree_impl) { // ======= Layer border colors ======= // Tiled content layers are orange. -SkColor DebugColors::TiledContentLayerBorderColor() { return SkColorSetARGB(128, 255, 128, 0); } -int DebugColors::TiledContentLayerBorderWidth(const LayerTreeImpl* tree_impl) { return Scale(2, tree_impl); } +SkColor DebugColors::TiledContentLayerBorderColor() { + return SkColorSetARGB(128, 255, 128, 0); +} +int DebugColors::TiledContentLayerBorderWidth(const LayerTreeImpl* tree_impl) { + return Scale(2, tree_impl); +} // Image layers are olive. -SkColor DebugColors::ImageLayerBorderColor() { return SkColorSetARGB(128, 128, 128, 0); } -int DebugColors::ImageLayerBorderWidth(const LayerTreeImpl* tree_impl) { return Scale(2, tree_impl); } +SkColor DebugColors::ImageLayerBorderColor() { + return SkColorSetARGB(128, 128, 128, 0); +} +int DebugColors::ImageLayerBorderWidth(const LayerTreeImpl* tree_impl) { + return Scale(2, tree_impl); +} // Non-tiled content layers area green. -SkColor DebugColors::ContentLayerBorderColor() { return SkColorSetARGB(128, 0, 128, 32); } -int DebugColors::ContentLayerBorderWidth(const LayerTreeImpl* tree_impl) { return Scale(2, tree_impl); } +SkColor DebugColors::ContentLayerBorderColor() { + return SkColorSetARGB(128, 0, 128, 32); +} +int DebugColors::ContentLayerBorderWidth(const LayerTreeImpl* tree_impl) { + return Scale(2, tree_impl); +} // Masking layers are pale blue and wide. -SkColor DebugColors::MaskingLayerBorderColor() { return SkColorSetARGB(48, 128, 255, 255); } -int DebugColors::MaskingLayerBorderWidth(const LayerTreeImpl* tree_impl) { return Scale(20, tree_impl); } +SkColor DebugColors::MaskingLayerBorderColor() { + return SkColorSetARGB(48, 128, 255, 255); +} +int DebugColors::MaskingLayerBorderWidth(const LayerTreeImpl* tree_impl) { + return Scale(20, tree_impl); +} // Other container layers are yellow. -SkColor DebugColors::ContainerLayerBorderColor() { return SkColorSetARGB(192, 255, 255, 0); } -int DebugColors::ContainerLayerBorderWidth(const LayerTreeImpl* tree_impl) { return Scale(2, tree_impl); } +SkColor DebugColors::ContainerLayerBorderColor() { + return SkColorSetARGB(192, 255, 255, 0); +} +int DebugColors::ContainerLayerBorderWidth(const LayerTreeImpl* tree_impl) { + return Scale(2, tree_impl); +} // Render surfaces are blue. -SkColor DebugColors::SurfaceBorderColor() { return SkColorSetARGB(100, 0, 0, 255); } -int DebugColors::SurfaceBorderWidth(const LayerTreeImpl* tree_impl) { return Scale(2, tree_impl); } +SkColor DebugColors::SurfaceBorderColor() { + return SkColorSetARGB(100, 0, 0, 255); +} +int DebugColors::SurfaceBorderWidth(const LayerTreeImpl* tree_impl) { + return Scale(2, tree_impl); +} // Replicas of render surfaces are purple. -SkColor DebugColors::SurfaceReplicaBorderColor() { return SkColorSetARGB(100, 160, 0, 255); } -int DebugColors::SurfaceReplicaBorderWidth(const LayerTreeImpl* tree_impl) { return Scale(2, tree_impl); } +SkColor DebugColors::SurfaceReplicaBorderColor() { + return SkColorSetARGB(100, 160, 0, 255); +} +int DebugColors::SurfaceReplicaBorderWidth(const LayerTreeImpl* tree_impl) { + return Scale(2, tree_impl); +} // ======= Tile colors ======= // High-res tile borders are cyan. -SkColor DebugColors::HighResTileBorderColor() { return SkColorSetARGB(100, 80, 200, 200); } -int DebugColors::HighResTileBorderWidth(const LayerTreeImpl* tree_impl) { return Scale(1, tree_impl); } +SkColor DebugColors::HighResTileBorderColor() { + return SkColorSetARGB(100, 80, 200, 200); +} +int DebugColors::HighResTileBorderWidth(const LayerTreeImpl* tree_impl) { + return Scale(1, tree_impl); +} // Low-res tile borders are purple. -SkColor DebugColors::LowResTileBorderColor() { return SkColorSetARGB(100, 212, 83, 192); } -int DebugColors::LowResTileBorderWidth(const LayerTreeImpl* tree_impl) { return Scale(2, tree_impl); } +SkColor DebugColors::LowResTileBorderColor() { + return SkColorSetARGB(100, 212, 83, 192); +} +int DebugColors::LowResTileBorderWidth(const LayerTreeImpl* tree_impl) { + return Scale(2, tree_impl); +} // Other high-resolution tile borders are yellow. -SkColor DebugColors::ExtraHighResTileBorderColor() { return SkColorSetARGB(100, 239, 231, 20); } -int DebugColors::ExtraHighResTileBorderWidth(const LayerTreeImpl* tree_impl) { return Scale(2, tree_impl); } +SkColor DebugColors::ExtraHighResTileBorderColor() { + return SkColorSetARGB(100, 239, 231, 20); +} +int DebugColors::ExtraHighResTileBorderWidth(const LayerTreeImpl* tree_impl) { + return Scale(2, tree_impl); +} // Other low-resolution tile borders are green. -SkColor DebugColors::ExtraLowResTileBorderColor() { return SkColorSetARGB(100, 93, 186, 18); } -int DebugColors::ExtraLowResTileBorderWidth(const LayerTreeImpl* tree_impl) { return Scale(2, tree_impl); } +SkColor DebugColors::ExtraLowResTileBorderColor() { + return SkColorSetARGB(100, 93, 186, 18); +} +int DebugColors::ExtraLowResTileBorderWidth(const LayerTreeImpl* tree_impl) { + return Scale(2, tree_impl); +} // Missing tile borders are red. -SkColor DebugColors::MissingTileBorderColor() { return SkColorSetARGB(100, 255, 0, 0); } -int DebugColors::MissingTileBorderWidth(const LayerTreeImpl* tree_impl) { return Scale(1, tree_impl); } +SkColor DebugColors::MissingTileBorderColor() { + return SkColorSetARGB(100, 255, 0, 0); +} +int DebugColors::MissingTileBorderWidth(const LayerTreeImpl* tree_impl) { + return Scale(1, tree_impl); +} // Culled tile borders are brown. -SkColor DebugColors::CulledTileBorderColor() { return SkColorSetARGB(120, 160, 100, 0); } -int DebugColors::CulledTileBorderWidth(const LayerTreeImpl* tree_impl) { return Scale(1, tree_impl); } +SkColor DebugColors::CulledTileBorderColor() { + return SkColorSetARGB(120, 160, 100, 0); +} +int DebugColors::CulledTileBorderWidth(const LayerTreeImpl* tree_impl) { + return Scale(1, tree_impl); +} // Solid color tile borders are grey. -SkColor DebugColors::SolidColorTileBorderColor() { return SkColorSetARGB(128, 128, 128, 128); } -int DebugColors::SolidColorTileBorderWidth(const LayerTreeImpl* tree_impl) { return Scale(1, tree_impl); } +SkColor DebugColors::SolidColorTileBorderColor() { + return SkColorSetARGB(128, 128, 128, 128); +} +int DebugColors::SolidColorTileBorderWidth(const LayerTreeImpl* tree_impl) { + return Scale(1, tree_impl); +} // ======= Checkerboard colors ======= // Non-debug checkerboards are grey. -SkColor DebugColors::DefaultCheckerboardColor() { return SkColorSetRGB(241, 241, 241); } +SkColor DebugColors::DefaultCheckerboardColor() { + return SkColorSetRGB(241, 241, 241); +} // Invalidated tiles get sky blue checkerboards. -SkColor DebugColors::InvalidatedTileCheckerboardColor() { return SkColorSetRGB(128, 200, 245); } +SkColor DebugColors::InvalidatedTileCheckerboardColor() { + return SkColorSetRGB(128, 200, 245); +} // Evicted tiles get pale red checkerboards. -SkColor DebugColors::EvictedTileCheckerboardColor() { return SkColorSetRGB(255, 200, 200); } +SkColor DebugColors::EvictedTileCheckerboardColor() { + return SkColorSetRGB(255, 200, 200); +} // ======= Debug rect colors ======= // Paint rects in red. -SkColor DebugColors::PaintRectBorderColor() { return SkColorSetARGB(255, 255, 0, 0); } -int DebugColors::PaintRectBorderWidth(const LayerTreeImpl* tree_impl) { return Scale(2, tree_impl); } -SkColor DebugColors::PaintRectFillColor() { return SkColorSetARGB(30, 255, 0, 0); } +SkColor DebugColors::PaintRectBorderColor() { + return SkColorSetARGB(255, 255, 0, 0); +} +int DebugColors::PaintRectBorderWidth(const LayerTreeImpl* tree_impl) { + return Scale(2, tree_impl); +} +SkColor DebugColors::PaintRectFillColor() { + return SkColorSetARGB(30, 255, 0, 0); +} // Property-changed rects in blue. -SkColor DebugColors::PropertyChangedRectBorderColor() { return SkColorSetARGB(255, 0, 0, 255); } -int DebugColors::PropertyChangedRectBorderWidth(const LayerTreeImpl* tree_impl) { return Scale(2, tree_impl); } -SkColor DebugColors::PropertyChangedRectFillColor() { return SkColorSetARGB(30, 0, 0, 255); } +SkColor DebugColors::PropertyChangedRectBorderColor() { + return SkColorSetARGB(255, 0, 0, 255); +} +int DebugColors::PropertyChangedRectBorderWidth( + const LayerTreeImpl* tree_impl) { + return Scale(2, tree_impl); +} +SkColor DebugColors::PropertyChangedRectFillColor() { + return SkColorSetARGB(30, 0, 0, 255); +} // Surface damage rects in yellow-orange. -SkColor DebugColors::SurfaceDamageRectBorderColor() { return SkColorSetARGB(255, 200, 100, 0); } -int DebugColors::SurfaceDamageRectBorderWidth(const LayerTreeImpl* tree_impl) { return Scale(2, tree_impl); } -SkColor DebugColors::SurfaceDamageRectFillColor() { return SkColorSetARGB(30, 200, 100, 0); } +SkColor DebugColors::SurfaceDamageRectBorderColor() { + return SkColorSetARGB(255, 200, 100, 0); +} +int DebugColors::SurfaceDamageRectBorderWidth(const LayerTreeImpl* tree_impl) { + return Scale(2, tree_impl); +} +SkColor DebugColors::SurfaceDamageRectFillColor() { + return SkColorSetARGB(30, 200, 100, 0); +} // Surface replica screen space rects in green. -SkColor DebugColors::ScreenSpaceLayerRectBorderColor() { return SkColorSetARGB(255, 100, 200, 0); } -int DebugColors::ScreenSpaceLayerRectBorderWidth(const LayerTreeImpl* tree_impl) { return Scale(2, tree_impl); } -SkColor DebugColors::ScreenSpaceLayerRectFillColor() { return SkColorSetARGB(30, 100, 200, 0); } +SkColor DebugColors::ScreenSpaceLayerRectBorderColor() { + return SkColorSetARGB(255, 100, 200, 0); +} +int DebugColors::ScreenSpaceLayerRectBorderWidth( + const LayerTreeImpl* tree_impl) { + return Scale(2, tree_impl); +} +SkColor DebugColors::ScreenSpaceLayerRectFillColor() { + return SkColorSetARGB(30, 100, 200, 0); +} // Layer screen space rects in purple. -SkColor DebugColors::ScreenSpaceSurfaceReplicaRectBorderColor() { return SkColorSetARGB(255, 100, 0, 200); } -int DebugColors::ScreenSpaceSurfaceReplicaRectBorderWidth(const LayerTreeImpl* tree_impl) { return Scale(2, tree_impl); } -SkColor DebugColors::ScreenSpaceSurfaceReplicaRectFillColor() { return SkColorSetARGB(10, 100, 0, 200); } +SkColor DebugColors::ScreenSpaceSurfaceReplicaRectBorderColor() { + return SkColorSetARGB(255, 100, 0, 200); +} +int DebugColors::ScreenSpaceSurfaceReplicaRectBorderWidth( + const LayerTreeImpl* tree_impl) { + return Scale(2, tree_impl); +} +SkColor DebugColors::ScreenSpaceSurfaceReplicaRectFillColor() { + return SkColorSetARGB(10, 100, 0, 200); +} // Occluding rects in pink. -SkColor DebugColors::OccludingRectBorderColor() { return SkColorSetARGB(255, 245, 136, 255); } -int DebugColors::OccludingRectBorderWidth(const LayerTreeImpl* tree_impl) { return Scale(2, tree_impl); } -SkColor DebugColors::OccludingRectFillColor() { return SkColorSetARGB(10, 245, 136, 255); } +SkColor DebugColors::OccludingRectBorderColor() { + return SkColorSetARGB(255, 245, 136, 255); +} +int DebugColors::OccludingRectBorderWidth(const LayerTreeImpl* tree_impl) { + return Scale(2, tree_impl); +} +SkColor DebugColors::OccludingRectFillColor() { + return SkColorSetARGB(10, 245, 136, 255); +} // Non-Occluding rects in a reddish color. -SkColor DebugColors::NonOccludingRectBorderColor() { return SkColorSetARGB(255, 200, 0, 100); } -int DebugColors::NonOccludingRectBorderWidth(const LayerTreeImpl* tree_impl) { return Scale(2, tree_impl); } -SkColor DebugColors::NonOccludingRectFillColor() { return SkColorSetARGB(10, 200, 0, 100); } +SkColor DebugColors::NonOccludingRectBorderColor() { + return SkColorSetARGB(255, 200, 0, 100); +} +int DebugColors::NonOccludingRectBorderWidth(const LayerTreeImpl* tree_impl) { + return Scale(2, tree_impl); +} +SkColor DebugColors::NonOccludingRectFillColor() { + return SkColorSetARGB(10, 200, 0, 100); +} // Non-Painted rects in cyan. SkColor DebugColors::NonPaintedFillColor() { return SK_ColorCYAN; } @@ -128,15 +235,25 @@ SkColor DebugColors::MissingPictureFillColor() { return SK_ColorMAGENTA; } // ======= HUD widget colors ======= -SkColor DebugColors::HUDBackgroundColor() { return SkColorSetARGB(215, 17, 17, 17); } -SkColor DebugColors::HUDSeparatorLineColor() { return SkColorSetARGB(255, 130, 130, 130); } -SkColor DebugColors::HUDIndicatorLineColor() { return SkColorSetARGB(255, 80, 80, 80); } +SkColor DebugColors::HUDBackgroundColor() { + return SkColorSetARGB(215, 17, 17, 17); +} +SkColor DebugColors::HUDSeparatorLineColor() { + return SkColorSetARGB(255, 130, 130, 130); +} +SkColor DebugColors::HUDIndicatorLineColor() { + return SkColorSetARGB(255, 80, 80, 80); +} SkColor DebugColors::PlatformLayerTreeTextColor() { return SK_ColorRED; } SkColor DebugColors::FPSDisplayTextAndGraphColor() { return SK_ColorRED; } -SkColor DebugColors::MemoryDisplayTextColor() { return SkColorSetARGB(255, 220, 220, 220); } +SkColor DebugColors::MemoryDisplayTextColor() { + return SkColorSetARGB(255, 220, 220, 220); +} // Paint time display in green (similar to paint times in the WebInspector) -SkColor DebugColors::PaintTimeDisplayTextAndGraphColor() { return SkColorSetRGB(75, 155, 55); } +SkColor DebugColors::PaintTimeDisplayTextAndGraphColor() { + return SkColorSetRGB(75, 155, 55); +} } // namespace cc diff --git a/cc/debug/debug_colors.h b/cc/debug/debug_colors.h index 4b9fe1a..ba5f8b6 100644 --- a/cc/debug/debug_colors.h +++ b/cc/debug/debug_colors.h @@ -77,7 +77,8 @@ class DebugColors { static SkColor ScreenSpaceLayerRectFillColor(); static SkColor ScreenSpaceSurfaceReplicaRectBorderColor(); - static int ScreenSpaceSurfaceReplicaRectBorderWidth(const LayerTreeImpl* tree_impl); + static int ScreenSpaceSurfaceReplicaRectBorderWidth( + const LayerTreeImpl* tree_impl); static SkColor ScreenSpaceSurfaceReplicaRectFillColor(); static SkColor OccludingRectBorderColor(); diff --git a/cc/debug/devtools_instrumentation.h b/cc/debug/devtools_instrumentation.h index cfdd7dc..4b21366 100644 --- a/cc/debug/devtools_instrumentation.h +++ b/cc/debug/devtools_instrumentation.h @@ -18,7 +18,7 @@ const char kRasterTask[] = "RasterTask"; } struct ScopedPaintLayer { - ScopedPaintLayer(int layer_id) { + explicit ScopedPaintLayer(int layer_id) { TRACE_EVENT_BEGIN1(internal::kCategory, internal::kPaintLayer, internal::kLayerId, layer_id); } @@ -30,7 +30,7 @@ struct ScopedPaintLayer { }; struct ScopedRasterTask { - ScopedRasterTask(int layer_id) { + explicit ScopedRasterTask(int layer_id) { TRACE_EVENT_BEGIN1(internal::kCategory, internal::kRasterTask, internal::kLayerId, layer_id); } @@ -43,7 +43,7 @@ struct ScopedRasterTask { struct ScopedLayerObjectTracker : public base::debug::TraceScopedTrackableObject<int> { - ScopedLayerObjectTracker(int layer_id) + explicit ScopedLayerObjectTracker(int layer_id) : base::debug::TraceScopedTrackableObject<int>( internal::kCategory, internal::kLayerId, diff --git a/cc/debug/fake_web_graphics_context_3d.h b/cc/debug/fake_web_graphics_context_3d.h index dc0ea99..a1ccc05 100644 --- a/cc/debug/fake_web_graphics_context_3d.h +++ b/cc/debug/fake_web_graphics_context_3d.h @@ -13,8 +13,8 @@ namespace cc { // WebGraphicsContext3D base class for use in unit tests. // All operations are no-ops (returning 0 if necessary). -class CC_EXPORT FakeWebGraphicsContext3D : - public NON_EXPORTED_BASE(WebKit::WebGraphicsContext3D) { +class CC_EXPORT FakeWebGraphicsContext3D + : public NON_EXPORTED_BASE(WebKit::WebGraphicsContext3D) { public: FakeWebGraphicsContext3D(); virtual ~FakeWebGraphicsContext3D(); diff --git a/cc/debug/frame_rate_counter.cc b/cc/debug/frame_rate_counter.cc index bcd31b0..8a829ff 100644 --- a/cc/debug/frame_rate_counter.cc +++ b/cc/debug/frame_rate_counter.cc @@ -4,6 +4,7 @@ #include "cc/debug/frame_rate_counter.h" +#include <algorithm> #include <limits> #include "base/metrics/histogram.h" diff --git a/cc/debug/overdraw_metrics.h b/cc/debug/overdraw_metrics.h index fcbd6ff..43bd19ba 100644 --- a/cc/debug/overdraw_metrics.h +++ b/cc/debug/overdraw_metrics.h @@ -21,7 +21,7 @@ class OverdrawMetrics { public: static scoped_ptr<OverdrawMetrics> Create(bool record_metrics_for_frame) { return make_scoped_ptr(new OverdrawMetrics(record_metrics_for_frame)); - } + } // These methods are used for saving metrics during update/commit. @@ -93,9 +93,9 @@ class OverdrawMetrics { // Count of tiles that were invalidated but not uploaded. int tiles_culled_for_upload_; // Count the number of bytes in contents textures. - unsigned long long contents_texture_use_bytes_; + uint64 contents_texture_use_bytes_; // Count the number of bytes in RenderSurfaceImpl textures. - unsigned long long render_surface_texture_use_bytes_; + uint64 render_surface_texture_use_bytes_; // These values are used for saving metrics during draw. diff --git a/cc/debug/rendering_stats_instrumentation.h b/cc/debug/rendering_stats_instrumentation.h index 63401c0..c3ec320 100644 --- a/cc/debug/rendering_stats_instrumentation.h +++ b/cc/debug/rendering_stats_instrumentation.h @@ -2,8 +2,8 @@ // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. -#ifndef CC_RENDERING_STATS_INSTRUMENTATION_H_ -#define CC_RENDERING_STATS_INSTRUMENTATION_H_ +#ifndef CC_DEBUG_RENDERING_STATS_INSTRUMENTATION_H_ +#define CC_DEBUG_RENDERING_STATS_INSTRUMENTATION_H_ #include "base/memory/scoped_ptr.h" #include "base/synchronization/lock.h" @@ -71,4 +71,4 @@ class CC_EXPORT RenderingStatsInstrumentation { } // namespace cc -#endif // CC_RENDERING_STATS_INSTRUMENTATION_H_ +#endif // CC_DEBUG_RENDERING_STATS_INSTRUMENTATION_H_ diff --git a/cc/debug/ring_buffer.h b/cc/debug/ring_buffer.h index d9bf3f6..74da2d9 100644 --- a/cc/debug/ring_buffer.h +++ b/cc/debug/ring_buffer.h @@ -9,7 +9,7 @@ namespace cc { -template<typename T, size_t size> +template<typename T, size_t kSize> class RingBuffer { public: explicit RingBuffer() @@ -17,7 +17,7 @@ class RingBuffer { } size_t BufferSize() const { - return size; + return kSize; } size_t CurrentIndex() const { @@ -60,7 +60,7 @@ class RingBuffer { Iterator& operator++() { index_++; - if (index_ == size) + if (index_ == kSize) out_of_range_ = true; return *this; } @@ -77,41 +77,41 @@ class RingBuffer { } private: - Iterator(const RingBuffer<T, size>& buffer, size_t index) + Iterator(const RingBuffer<T, kSize>& buffer, size_t index) : buffer_(buffer), index_(index), out_of_range_(false) { } - const RingBuffer<T, size>& buffer_; + const RingBuffer<T, kSize>& buffer_; size_t index_; bool out_of_range_; - friend class RingBuffer<T, size>; + friend class RingBuffer<T, kSize>; }; // Returns an Iterator pointing to the oldest value in the buffer. // Example usage (iterate from oldest to newest value): - // for (RingBuffer<T, size>::Iterator it = ring_buffer.Begin(); it; ++it) ... + // for (RingBuffer<T, kSize>::Iterator it = ring_buffer.Begin(); it; ++it) {} Iterator Begin() const { - if (current_index_ < size) - return Iterator(*this, size - current_index_); + if (current_index_ < kSize) + return Iterator(*this, kSize - current_index_); return Iterator(*this, 0); } // Returns an Iterator pointing to the newest value in the buffer. // Example usage (iterate backwards from newest to oldest value): - // for (RingBuffer<T, size>::Iterator it = ring_buffer.End(); it; --it) ... + // for (RingBuffer<T, kSize>::Iterator it = ring_buffer.End(); it; --it) {} Iterator End() const { - return Iterator(*this, size - 1); + return Iterator(*this, kSize - 1); } private: inline size_t BufferIndex(size_t n) const { - return (current_index_ + n) % size; + return (current_index_ + n) % kSize; } - T buffer_[size]; + T buffer_[kSize]; size_t current_index_; }; diff --git a/cc/layers/layer_unittest.cc b/cc/layers/layer_unittest.cc index 8a93c52..4184e0b 100644 --- a/cc/layers/layer_unittest.cc +++ b/cc/layers/layer_unittest.cc @@ -551,7 +551,7 @@ TEST_F(LayerTest, CheckPropertyChangeCausesCorrectBehavior) { gfx::Vector2d(10, 10))); EXPECT_SET_NEEDS_COMMIT(1, test_layer->SetShouldScrollOnMainThread(true)); EXPECT_SET_NEEDS_COMMIT(1, test_layer->SetNonFastScrollableRegion( - gfx::Rect(1, 1, 2, 2))); + Region(gfx::Rect(1, 1, 2, 2)))); EXPECT_SET_NEEDS_COMMIT(1, test_layer->SetHaveWheelEventHandlers(true)); EXPECT_SET_NEEDS_COMMIT(1, test_layer->SetTransform( gfx::Transform(0.0, 0.0, 0.0, 0.0, 0.0, 0.0))); diff --git a/cc/layers/picture_layer_impl.h b/cc/layers/picture_layer_impl.h index 4a85691..c94d275 100644 --- a/cc/layers/picture_layer_impl.h +++ b/cc/layers/picture_layer_impl.h @@ -5,6 +5,7 @@ #ifndef CC_LAYERS_PICTURE_LAYER_IMPL_H_ #define CC_LAYERS_PICTURE_LAYER_IMPL_H_ +#include "cc/base/cc_export.h" #include "cc/base/scoped_ptr_vector.h" #include "cc/layers/layer_impl.h" #include "cc/resources/picture_layer_tiling.h" @@ -18,8 +19,9 @@ namespace cc { struct AppendQuadsData; class QuadSink; -class CC_EXPORT PictureLayerImpl : public LayerImpl, - public PictureLayerTilingClient { +class CC_EXPORT PictureLayerImpl + : public LayerImpl, + NON_EXPORTED_BASE(public PictureLayerTilingClient) { public: static scoped_ptr<PictureLayerImpl> Create(LayerTreeImpl* tree_impl, int id) { return make_scoped_ptr(new PictureLayerImpl(tree_impl, id)); diff --git a/cc/quads/checkerboard_draw_quad.h b/cc/quads/checkerboard_draw_quad.h index 53d1c5e..b2ed876 100644 --- a/cc/quads/checkerboard_draw_quad.h +++ b/cc/quads/checkerboard_draw_quad.h @@ -33,10 +33,11 @@ class CC_EXPORT CheckerboardDrawQuad : public DrawQuad { OVERRIDE; static const CheckerboardDrawQuad* MaterialCast(const DrawQuad*); + private: CheckerboardDrawQuad(); }; -} +} // namespace cc #endif // CC_QUADS_CHECKERBOARD_DRAW_QUAD_H_ diff --git a/cc/quads/debug_border_draw_quad.h b/cc/quads/debug_border_draw_quad.h index 80484368..2f4b3ca 100644 --- a/cc/quads/debug_border_draw_quad.h +++ b/cc/quads/debug_border_draw_quad.h @@ -36,10 +36,11 @@ class CC_EXPORT DebugBorderDrawQuad : public DrawQuad { OVERRIDE; static const DebugBorderDrawQuad* MaterialCast(const DrawQuad*); + private: DebugBorderDrawQuad(); }; -} +} // namespace cc #endif // CC_QUADS_DEBUG_BORDER_DRAW_QUAD_H_ diff --git a/cc/quads/draw_quad.cc b/cc/quads/draw_quad.cc index 22271d6..0250481 100644 --- a/cc/quads/draw_quad.cc +++ b/cc/quads/draw_quad.cc @@ -16,12 +16,10 @@ #include "cc/quads/yuv_video_draw_quad.h" namespace { - template<typename T> T* TypedCopy(const cc::DrawQuad* other) { return new T(*T::MaterialCast(other)); } - -} +} // namespace namespace cc { diff --git a/cc/quads/draw_quad.h b/cc/quads/draw_quad.h index 2636a07..05924f1 100644 --- a/cc/quads/draw_quad.h +++ b/cc/quads/draw_quad.h @@ -114,6 +114,6 @@ class CC_EXPORT DrawQuad { bool needs_blending); }; -} +} // namespace cc #endif // CC_QUADS_DRAW_QUAD_H_ diff --git a/cc/quads/draw_quad_unittest.cc b/cc/quads/draw_quad_unittest.cc index 281da3b..3eefdc9 100644 --- a/cc/quads/draw_quad_unittest.cc +++ b/cc/quads/draw_quad_unittest.cc @@ -4,6 +4,8 @@ #include "cc/quads/draw_quad.h" +#include <algorithm> + #include "base/bind.h" #include "cc/base/math_util.h" #include "cc/quads/checkerboard_draw_quad.h" @@ -497,13 +499,13 @@ TEST(DrawQuadTest, ClipTextureDrawQuad) { shared_state->clip_rect = gfx::Rect(50, 70, 30, 20); // The original quad is 'ABCD', the clipped quad is 'abcd': - //40 50 90 - // B--:-------C 60 - // | b----c -|-70 - // | | | | - // | a----d -|-90 - // | | - // A----------D 120 + // 40 50 90 + // B--:-------C 60 + // | b----c -|-70 + // | | | | + // | a----d -|-90 + // | | + // A----------D 120 // UV and vertex opacity are stored per vertex on the parent rectangle 'ABCD'. // This is the UV value for vertex 'B'. diff --git a/cc/quads/io_surface_draw_quad.cc b/cc/quads/io_surface_draw_quad.cc index ac107c1..eb4aa20 100644 --- a/cc/quads/io_surface_draw_quad.cc +++ b/cc/quads/io_surface_draw_quad.cc @@ -26,7 +26,7 @@ void IOSurfaceDrawQuad::SetNew(const SharedQuadState* shared_quad_state, gfx::Rect visible_rect = rect; bool needs_blending = false; DrawQuad::SetAll(shared_quad_state, DrawQuad::IO_SURFACE_CONTENT, rect, - opaque_rect, visible_rect, needs_blending); + opaque_rect, visible_rect, needs_blending); this->io_surface_size = io_surface_size; this->io_surface_texture_id = io_surface_texture_id; this->orientation = orientation; diff --git a/cc/quads/io_surface_draw_quad.h b/cc/quads/io_surface_draw_quad.h index d0559e2..38dabf8 100644 --- a/cc/quads/io_surface_draw_quad.h +++ b/cc/quads/io_surface_draw_quad.h @@ -45,10 +45,11 @@ class CC_EXPORT IOSurfaceDrawQuad : public DrawQuad { OVERRIDE; static const IOSurfaceDrawQuad* MaterialCast(const DrawQuad*); + private: IOSurfaceDrawQuad(); }; -} +} // namespace cc #endif // CC_QUADS_IO_SURFACE_DRAW_QUAD_H_ diff --git a/cc/quads/render_pass.h b/cc/quads/render_pass.h index 154b02c5..bfd0d83 100644 --- a/cc/quads/render_pass.h +++ b/cc/quads/render_pass.h @@ -5,6 +5,7 @@ #ifndef CC_QUADS_RENDER_PASS_H_ #define CC_QUADS_RENDER_PASS_H_ +#include <utility> #include <vector> #include "base/basictypes.h" @@ -45,7 +46,7 @@ class CC_EXPORT RenderPass { int layer_id; int index; - Id(int layer_id, int index) : layer_id(layer_id), index(index) {} + Id(int layer_id, int index) : layer_id(layer_id), index(index) {} bool operator==(const Id& other) const { return layer_id == other.layer_id && index == other.index; @@ -105,7 +106,7 @@ class CC_EXPORT RenderPass { DISALLOW_COPY_AND_ASSIGN(RenderPass); }; -} // namespace cc +} // namespace cc namespace BASE_HASH_NAMESPACE { #if defined(COMPILER_MSVC) @@ -124,12 +125,12 @@ struct hash<cc::RenderPass::Id> { }; #else #error define a hash function for your compiler -#endif // COMPILER +#endif // COMPILER } namespace cc { typedef ScopedPtrVector<RenderPass> RenderPassList; typedef base::hash_map<RenderPass::Id, RenderPass*> RenderPassIdHashMap; -} // namespace cc +} // namespace cc #endif // CC_QUADS_RENDER_PASS_H_ diff --git a/cc/quads/render_pass_draw_quad.cc b/cc/quads/render_pass_draw_quad.cc index b4ec337..7ee1a88 100644 --- a/cc/quads/render_pass_draw_quad.cc +++ b/cc/quads/render_pass_draw_quad.cc @@ -40,8 +40,8 @@ void RenderPassDrawQuad::SetNew( const WebKit::WebFilterOperations& filters, skia::RefPtr<SkImageFilter> filter, const WebKit::WebFilterOperations& background_filters) { - DCHECK(render_pass_id.layer_id > 0); - DCHECK(render_pass_id.index >= 0); + DCHECK_GT(render_pass_id.layer_id, 0); + DCHECK_GE(render_pass_id.index, 0); gfx::Rect opaque_rect; gfx::Rect visible_rect = rect; @@ -66,8 +66,8 @@ void RenderPassDrawQuad::SetAll( const WebKit::WebFilterOperations& filters, skia::RefPtr<SkImageFilter> filter, const WebKit::WebFilterOperations& background_filters) { - DCHECK(render_pass_id.layer_id > 0); - DCHECK(render_pass_id.index >= 0); + DCHECK_GT(render_pass_id.layer_id, 0); + DCHECK_GE(render_pass_id.index, 0); DrawQuad::SetAll(shared_quad_state, DrawQuad::RENDER_PASS, rect, opaque_rect, visible_rect, needs_blending); @@ -88,7 +88,7 @@ void RenderPassDrawQuad::IterateResources( const RenderPassDrawQuad* RenderPassDrawQuad::MaterialCast( const DrawQuad* quad) { - DCHECK(quad->material == DrawQuad::RENDER_PASS); + DCHECK_EQ(quad->material, DrawQuad::RENDER_PASS); return static_cast<const RenderPassDrawQuad*>(quad); } diff --git a/cc/quads/render_pass_draw_quad.h b/cc/quads/render_pass_draw_quad.h index ca79755..303750f 100644 --- a/cc/quads/render_pass_draw_quad.h +++ b/cc/quads/render_pass_draw_quad.h @@ -74,6 +74,6 @@ class CC_EXPORT RenderPassDrawQuad : public DrawQuad { RenderPassDrawQuad(); }; -} +} // namespace cc #endif // CC_QUADS_RENDER_PASS_DRAW_QUAD_H_ diff --git a/cc/quads/render_pass_unittest.cc b/cc/quads/render_pass_unittest.cc index e487784..f2271b5 100644 --- a/cc/quads/render_pass_unittest.cc +++ b/cc/quads/render_pass_unittest.cc @@ -19,7 +19,8 @@ namespace cc { namespace { struct RenderPassSize { - // If you add a new field to this class, make sure to add it to the copy() tests. + // If you add a new field to this class, make sure to add it to the + // Copy() tests. RenderPass::Id id; QuadList quad_list; SharedQuadStateList shared_quad_state_list; diff --git a/cc/quads/shared_quad_state.h b/cc/quads/shared_quad_state.h index c7c1bc0..384fa81 100644 --- a/cc/quads/shared_quad_state.h +++ b/cc/quads/shared_quad_state.h @@ -39,6 +39,6 @@ class CC_EXPORT SharedQuadState { SharedQuadState(); }; -} +} // namespace cc #endif // CC_QUADS_SHARED_QUAD_STATE_H_ diff --git a/cc/quads/solid_color_draw_quad.h b/cc/quads/solid_color_draw_quad.h index a300063..690f816 100644 --- a/cc/quads/solid_color_draw_quad.h +++ b/cc/quads/solid_color_draw_quad.h @@ -33,10 +33,11 @@ class CC_EXPORT SolidColorDrawQuad : public DrawQuad { OVERRIDE; static const SolidColorDrawQuad* MaterialCast(const DrawQuad*); + private: SolidColorDrawQuad(); }; -} +} // namespace cc #endif // CC_QUADS_SOLID_COLOR_DRAW_QUAD_H_ diff --git a/cc/quads/stream_video_draw_quad.h b/cc/quads/stream_video_draw_quad.h index bfbcdf4..e6a46b4 100644 --- a/cc/quads/stream_video_draw_quad.h +++ b/cc/quads/stream_video_draw_quad.h @@ -37,10 +37,11 @@ class CC_EXPORT StreamVideoDrawQuad : public DrawQuad { OVERRIDE; static const StreamVideoDrawQuad* MaterialCast(const DrawQuad*); + private: StreamVideoDrawQuad(); }; -} +} // namespace cc #endif // CC_QUADS_STREAM_VIDEO_DRAW_QUAD_H_ diff --git a/cc/quads/texture_draw_quad.h b/cc/quads/texture_draw_quad.h index c888eca..0b35568 100644 --- a/cc/quads/texture_draw_quad.h +++ b/cc/quads/texture_draw_quad.h @@ -51,10 +51,11 @@ class CC_EXPORT TextureDrawQuad : public DrawQuad { static const TextureDrawQuad* MaterialCast(const DrawQuad*); bool PerformClipping(); + private: TextureDrawQuad(); }; -} +} // namespace cc #endif // CC_QUADS_TEXTURE_DRAW_QUAD_H_ diff --git a/cc/quads/tile_draw_quad.h b/cc/quads/tile_draw_quad.h index 74c3698..e39a281 100644 --- a/cc/quads/tile_draw_quad.h +++ b/cc/quads/tile_draw_quad.h @@ -45,10 +45,11 @@ class CC_EXPORT TileDrawQuad : public DrawQuad { OVERRIDE; static const TileDrawQuad* MaterialCast(const DrawQuad*); + private: TileDrawQuad(); }; -} +} // namespace cc #endif // CC_QUADS_TILE_DRAW_QUAD_H_ diff --git a/cc/quads/yuv_video_draw_quad.h b/cc/quads/yuv_video_draw_quad.h index dde1459..8885a5a 100644 --- a/cc/quads/yuv_video_draw_quad.h +++ b/cc/quads/yuv_video_draw_quad.h @@ -46,10 +46,11 @@ class CC_EXPORT YUVVideoDrawQuad : public DrawQuad { OVERRIDE; static const YUVVideoDrawQuad* MaterialCast(const DrawQuad*); + private: YUVVideoDrawQuad(); }; -} +} // namespace cc #endif // CC_QUADS_YUV_VIDEO_DRAW_QUAD_H_ diff --git a/cc/resources/caching_bitmap_content_layer_updater.cc b/cc/resources/caching_bitmap_content_layer_updater.cc index f6bb426..78f6097 100644 --- a/cc/resources/caching_bitmap_content_layer_updater.cc +++ b/cc/resources/caching_bitmap_content_layer_updater.cc @@ -2,7 +2,7 @@ // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. -#include "caching_bitmap_content_layer_updater.h" +#include "cc/resources/caching_bitmap_content_layer_updater.h" #include "base/logging.h" #include "cc/resources/layer_painter.h" @@ -38,7 +38,7 @@ void CachingBitmapContentLayerUpdater::PrepareToUpdate( const SkBitmap& new_bitmap = canvas_->getDevice()->accessBitmap(false); SkAutoLockPixels lock(new_bitmap); - DCHECK(new_bitmap.bytesPerPixel() > 0); + DCHECK_GT(new_bitmap.bytesPerPixel(), 0); pixels_did_change_ = new_bitmap.config() != cached_bitmap_.config() || new_bitmap.height() != cached_bitmap_.height() || new_bitmap.width() != cached_bitmap_.width() || diff --git a/cc/resources/image_layer_updater.cc b/cc/resources/image_layer_updater.cc index 4422bc4..378490d 100644 --- a/cc/resources/image_layer_updater.cc +++ b/cc/resources/image_layer_updater.cc @@ -57,4 +57,4 @@ void ImageLayerUpdater::UpdateTexture(ResourceUpdateQueue* queue, queue->AppendFullUpload(upload); } -} +} // namespace cc diff --git a/cc/resources/layer_quad.h b/cc/resources/layer_quad.h index 9c5a116..8098c20 100644 --- a/cc/resources/layer_quad.h +++ b/cc/resources/layer_quad.h @@ -73,16 +73,25 @@ class CC_EXPORT LayerQuad { const Edge& top, const Edge& right, const Edge& bottom); - LayerQuad(const gfx::QuadF& quad); + explicit LayerQuad(const gfx::QuadF& quad); Edge left() const { return left_; } Edge top() const { return top_; } Edge right() const { return right_; } Edge bottom() const { return bottom_; } - void InflateX(float dx) { left_.move_z(dx); right_.move_z(dx); } - void InflateY(float dy) { top_.move_z(dy); bottom_.move_z(dy); } - void Inflate(float d) { InflateX(d); InflateY(d); } + void InflateX(float dx) { + left_.move_z(dx); + right_.move_z(dx); + } + void InflateY(float dy) { + top_.move_z(dy); + bottom_.move_z(dy); + } + void Inflate(float d) { + InflateX(d); + InflateY(d); + } void InflateAntiAliasingDistance() { Inflate(kAntiAliasingInflateDistance); } @@ -100,6 +109,6 @@ class CC_EXPORT LayerQuad { DISALLOW_COPY_AND_ASSIGN(LayerQuad); }; -} +} // namespace cc #endif // CC_RESOURCES_LAYER_QUAD_H_ diff --git a/cc/resources/layer_tiling_data.cc b/cc/resources/layer_tiling_data.cc index eda05e3..0356985 100644 --- a/cc/resources/layer_tiling_data.cc +++ b/cc/resources/layer_tiling_data.cc @@ -4,6 +4,8 @@ #include "cc/resources/layer_tiling_data.h" +#include <vector> + #include "base/logging.h" namespace cc { diff --git a/cc/resources/layer_tiling_data.h b/cc/resources/layer_tiling_data.h index 255bbdc8..74cea06 100644 --- a/cc/resources/layer_tiling_data.h +++ b/cc/resources/layer_tiling_data.h @@ -5,6 +5,8 @@ #ifndef CC_RESOURCES_LAYER_TILING_DATA_H_ #define CC_RESOURCES_LAYER_TILING_DATA_H_ +#include <utility> + #include "base/basictypes.h" #include "base/memory/scoped_ptr.h" #include "cc/base/cc_export.h" diff --git a/cc/resources/managed_memory_policy.cc b/cc/resources/managed_memory_policy.cc index ab4c091..3571d7a 100644 --- a/cc/resources/managed_memory_policy.cc +++ b/cc/resources/managed_memory_policy.cc @@ -2,10 +2,10 @@ // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. -#include "managed_memory_policy.h" +#include "cc/resources/managed_memory_policy.h" #include "base/logging.h" -#include "priority_calculator.h" +#include "cc/resources/priority_calculator.h" namespace cc { diff --git a/cc/resources/managed_memory_policy.h b/cc/resources/managed_memory_policy.h index 5b0787a..dd8ac25 100644 --- a/cc/resources/managed_memory_policy.h +++ b/cc/resources/managed_memory_policy.h @@ -19,7 +19,7 @@ struct CC_EXPORT ManagedMemoryPolicy { CUTOFF_ALLOW_EVERYTHING, }; - ManagedMemoryPolicy(size_t bytes_limit_when_visible); + explicit ManagedMemoryPolicy(size_t bytes_limit_when_visible); ManagedMemoryPolicy(size_t bytes_limit_when_visible, PriorityCutoff priority_cutoff_when_visible, size_t bytes_limit_when_not_visible, diff --git a/cc/resources/managed_tile_state.cc b/cc/resources/managed_tile_state.cc index fe8b192..f428f95 100644 --- a/cc/resources/managed_tile_state.cc +++ b/cc/resources/managed_tile_state.cc @@ -4,6 +4,8 @@ #include "cc/resources/managed_tile_state.h" +#include <limits> + #include "cc/base/math_util.h" namespace cc { diff --git a/cc/resources/memory_history.cc b/cc/resources/memory_history.cc index 13b71c7..a2f8b6e 100644 --- a/cc/resources/memory_history.cc +++ b/cc/resources/memory_history.cc @@ -4,6 +4,8 @@ #include "cc/resources/memory_history.h" +#include <limits> + namespace cc { // static diff --git a/cc/resources/picture.cc b/cc/resources/picture.cc index 701d8ac..d3ddc53 100644 --- a/cc/resources/picture.cc +++ b/cc/resources/picture.cc @@ -30,8 +30,7 @@ class DisableLCDTextFilter : public SkDrawFilter { return true; } }; - -} +} // namespace namespace cc { @@ -169,7 +168,7 @@ void Picture::GatherPixelRefs(const gfx::Rect& layer_rect, } SkPixelRef** refs = reinterpret_cast<SkPixelRef**>(data); - for (unsigned int i = 0; i < pixel_refs->size() / sizeof(SkPixelRef*); ++i) { + for (size_t i = 0; i < pixel_refs->size() / sizeof(*refs); ++i) { if (*refs && (*refs)->getURI() && !strncmp( (*refs)->getURI(), kLabelLazyDecoded, 4)) { pixel_ref_list.push_back(static_cast<skia::LazyPixelRef*>(*refs)); diff --git a/cc/resources/picture.h b/cc/resources/picture.h index 3cb6791..8598fbf 100644 --- a/cc/resources/picture.h +++ b/cc/resources/picture.h @@ -60,7 +60,7 @@ class CC_EXPORT Picture std::list<skia::LazyPixelRef*>& pixel_ref_list); private: - Picture(gfx::Rect layer_rect); + explicit Picture(gfx::Rect layer_rect); // This constructor assumes SkPicture is already ref'd and transfers // ownership to this picture. Picture(const skia::RefPtr<SkPicture>&, diff --git a/cc/resources/picture_layer_tiling.cc b/cc/resources/picture_layer_tiling.cc index b1fa9a8..fd4ce83 100644 --- a/cc/resources/picture_layer_tiling.cc +++ b/cc/resources/picture_layer_tiling.cc @@ -4,6 +4,7 @@ #include "cc/resources/picture_layer_tiling.h" +#include <algorithm> #include <cmath> #include "base/debug/trace_event.h" @@ -131,7 +132,6 @@ void PictureLayerTiling::Invalidate(const Region& layer_invalidation) { for (Region::Iterator region_iter(layer_invalidation); region_iter.has_rect(); region_iter.next()) { - gfx::Rect layer_invalidation = region_iter.rect(); layer_invalidation.Intersect(gfx::Rect(layer_bounds_)); gfx::Rect rect = @@ -522,7 +522,7 @@ gfx::Rect PictureLayerTiling::ExpandRectEquallyToAreaBoundedBy( gfx::Rect bounding_rect) { DCHECK(!starting_rect.IsEmpty()); DCHECK(!bounding_rect.IsEmpty()); - DCHECK(target_area > 0); + DCHECK_GT(target_area, 0); gfx::Rect rect = IntersectRects(starting_rect, bounding_rect); if (rect.IsEmpty()) diff --git a/cc/resources/picture_layer_tiling.h b/cc/resources/picture_layer_tiling.h index 7a71fa8..bc61321 100644 --- a/cc/resources/picture_layer_tiling.h +++ b/cc/resources/picture_layer_tiling.h @@ -5,6 +5,9 @@ #ifndef CC_RESOURCES_PICTURE_LAYER_TILING_H_ #define CC_RESOURCES_PICTURE_LAYER_TILING_H_ +#include <utility> +#include <vector> + #include "base/basictypes.h" #include "base/hash_tables.h" #include "base/memory/scoped_ptr.h" @@ -31,6 +34,9 @@ class PictureLayerTilingClient { virtual gfx::Size CalculateTileSize( gfx::Size current_tile_size, gfx::Size content_bounds) = 0; + + protected: + virtual ~PictureLayerTilingClient() {} }; class CC_EXPORT PictureLayerTiling { @@ -145,7 +151,7 @@ class CC_EXPORT PictureLayerTiling { typedef std::pair<int, int> TileMapKey; typedef base::hash_map<TileMapKey, scoped_refptr<Tile> > TileMap; - PictureLayerTiling(float contents_scale); + explicit PictureLayerTiling(float contents_scale); Tile* TileAt(int, int) const; void CreateTilesFromContentRect(gfx::Rect layer_rect); void CreateTile(int i, int j); diff --git a/cc/resources/picture_layer_tiling_set.h b/cc/resources/picture_layer_tiling_set.h index 5e4d92f..901bb9b 100644 --- a/cc/resources/picture_layer_tiling_set.h +++ b/cc/resources/picture_layer_tiling_set.h @@ -29,7 +29,7 @@ class CC_EXPORT PictureLayerTilingSet { void SetLayerBounds(gfx::Size layer_bounds); gfx::Size LayerBounds() const; - void Invalidate(const Region& layer_invalidation); + void Invalidate(const Region& layer_invalidation); PictureLayerTiling* AddTiling(float contents_scale); size_t num_tilings() const { return tilings_.size(); } diff --git a/cc/resources/picture_layer_tiling_set_unittest.cc b/cc/resources/picture_layer_tiling_set_unittest.cc index cb38d1b..ce10998 100644 --- a/cc/resources/picture_layer_tiling_set_unittest.cc +++ b/cc/resources/picture_layer_tiling_set_unittest.cc @@ -4,6 +4,8 @@ #include "cc/resources/picture_layer_tiling_set.h" +#include <vector> + #include "cc/resources/resource_pool.h" #include "cc/resources/resource_provider.h" #include "cc/test/fake_output_surface.h" diff --git a/cc/resources/picture_layer_tiling_unittest.cc b/cc/resources/picture_layer_tiling_unittest.cc index fd69926..4f3c656 100644 --- a/cc/resources/picture_layer_tiling_unittest.cc +++ b/cc/resources/picture_layer_tiling_unittest.cc @@ -45,7 +45,6 @@ class PictureLayerTilingIteratorTest : public testing::Test { request_rect); iter; ++iter) { - // Geometry cannot overlap previous geometry at all gfx::Rect geometry = iter.geometry_rect(); EXPECT_TRUE(expect_rect.Contains(geometry)); diff --git a/cc/resources/picture_pile.cc b/cc/resources/picture_pile.cc index e57a103..85a2e9b 100644 --- a/cc/resources/picture_pile.cc +++ b/cc/resources/picture_pile.cc @@ -2,10 +2,12 @@ // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. +#include "cc/resources/picture_pile.h" + #include <algorithm> +#include <vector> #include "cc/base/region.h" -#include "cc/resources/picture_pile.h" #include "cc/resources/picture_pile_impl.h" namespace { @@ -112,7 +114,7 @@ void PicturePile::Update( class FullyContainedPredicate { public: - FullyContainedPredicate(gfx::Rect rect) : layer_rect_(rect) {} + explicit FullyContainedPredicate(gfx::Rect rect) : layer_rect_(rect) {} bool operator()(const scoped_refptr<Picture>& picture) { return layer_rect_.Contains(picture->LayerRect()); } diff --git a/cc/resources/picture_pile_base.cc b/cc/resources/picture_pile_base.cc index f650f1c..4bb99af 100644 --- a/cc/resources/picture_pile_base.cc +++ b/cc/resources/picture_pile_base.cc @@ -4,6 +4,9 @@ #include "cc/resources/picture_pile_base.h" +#include <algorithm> +#include <vector> + #include "base/logging.h" #include "third_party/skia/include/core/SkColor.h" #include "ui/gfx/rect_conversions.h" diff --git a/cc/resources/picture_pile_base.h b/cc/resources/picture_pile_base.h index 7014107..35b3f11 100644 --- a/cc/resources/picture_pile_base.h +++ b/cc/resources/picture_pile_base.h @@ -6,6 +6,7 @@ #define CC_RESOURCES_PICTURE_PILE_BASE_H_ #include <list> +#include <utility> #include "base/hash_tables.h" #include "base/memory/ref_counted.h" @@ -21,7 +22,7 @@ namespace cc { class CC_EXPORT PicturePileBase : public base::RefCounted<PicturePileBase> { public: PicturePileBase(); - PicturePileBase(const PicturePileBase* other); + explicit PicturePileBase(const PicturePileBase* other); PicturePileBase(const PicturePileBase* other, unsigned thread_index); void Resize(gfx::Size size); diff --git a/cc/resources/picture_pile_impl.cc b/cc/resources/picture_pile_impl.cc index 76e6d56..4e425e5 100644 --- a/cc/resources/picture_pile_impl.cc +++ b/cc/resources/picture_pile_impl.cc @@ -249,8 +249,8 @@ void PicturePileImpl::AnalyzeInRect(const gfx::Rect& content_rect, canvas.consumeLazyPixelRefs(&analysis->lazy_pixel_refs); } -PicturePileImpl::Analysis::Analysis() : - is_solid_color(false), +PicturePileImpl::Analysis::Analysis() + : is_solid_color(false), is_transparent(false), is_cheap_to_raster(false) { } diff --git a/cc/resources/picture_pile_impl.h b/cc/resources/picture_pile_impl.h index 6584d7f..34364bd 100644 --- a/cc/resources/picture_pile_impl.h +++ b/cc/resources/picture_pile_impl.h @@ -7,6 +7,7 @@ #include <list> #include <map> +#include <vector> #include "cc/base/cc_export.h" #include "cc/resources/picture_pile_base.h" @@ -62,7 +63,7 @@ class CC_EXPORT PicturePileImpl : public PicturePileBase { protected: friend class PicturePile; - PicturePileImpl(bool enable_lcd_text); + explicit PicturePileImpl(bool enable_lcd_text); PicturePileImpl(const PicturePileBase* other, bool enable_lcd_text); virtual ~PicturePileImpl(); diff --git a/cc/resources/prioritized_resource_manager.cc b/cc/resources/prioritized_resource_manager.cc index 2c406df..9659a4f 100644 --- a/cc/resources/prioritized_resource_manager.cc +++ b/cc/resources/prioritized_resource_manager.cc @@ -416,7 +416,6 @@ void PrioritizedResourceManager::RegisterTexture(PrioritizedResource* texture) { texture->set_manager_internal(this); textures_.insert(texture); - } void PrioritizedResourceManager::UnregisterTexture( diff --git a/cc/resources/prioritized_resource_manager.h b/cc/resources/prioritized_resource_manager.h index b1f013d..51571fe 100644 --- a/cc/resources/prioritized_resource_manager.h +++ b/cc/resources/prioritized_resource_manager.h @@ -47,7 +47,7 @@ class CC_EXPORT PrioritizedResourceManager { typedef std::list<PrioritizedResource::Backing*> BackingList; - // TODO (epenner): (http://crbug.com/137094) This 64MB default is a straggler + // TODO(epenner): (http://crbug.com/137094) This 64MB default is a straggler // from the old texture manager and is just to give us a default memory // allocation before we get a callback from the GPU memory manager. We // should probaby either: @@ -171,7 +171,7 @@ class CC_EXPORT PrioritizedResourceManager { return a < b; } - PrioritizedResourceManager(const Proxy* proxy); + explicit PrioritizedResourceManager(const Proxy* proxy); bool EvictBackingsToReduceMemory(size_t limit_bytes, int priority_cutoff, diff --git a/cc/resources/prioritized_resource_unittest.cc b/cc/resources/prioritized_resource_unittest.cc index 98e4985..58a938d 100644 --- a/cc/resources/prioritized_resource_unittest.cc +++ b/cc/resources/prioritized_resource_unittest.cc @@ -16,773 +16,776 @@ namespace cc { class PrioritizedResourceTest : public testing::Test { public: - PrioritizedResourceTest() - : proxy_(scoped_ptr<Thread>(NULL)), - texture_size_(256, 256), - texture_format_(GL_RGBA), - output_surface_(CreateFakeOutputSurface()) { - DebugScopedSetImplThread impl_thread(&proxy_); - resource_provider_ = cc::ResourceProvider::Create(output_surface_.get()); - } - - virtual ~PrioritizedResourceTest() { - DebugScopedSetImplThread impl_thread(&proxy_); - resource_provider_.reset(); - } - - size_t TexturesMemorySize(size_t texture_count) { - return Resource::MemorySizeBytes(texture_size_, texture_format_) * - texture_count; - } - - scoped_ptr<PrioritizedResourceManager> CreateManager(size_t max_textures) { - scoped_ptr<PrioritizedResourceManager> manager = - PrioritizedResourceManager::Create(&proxy_); - manager->SetMaxMemoryLimitBytes(TexturesMemorySize(max_textures)); - return manager.Pass(); - } - - bool ValidateTexture(scoped_ptr<PrioritizedResource>& texture, - bool request_late) { - ResourceManagerAssertInvariants(texture->resource_manager()); - if (request_late) - texture->RequestLate(); - ResourceManagerAssertInvariants(texture->resource_manager()); - DebugScopedSetImplThreadAndMainThreadBlocked - impl_thread_and_main_thread_blocked(&proxy_); - bool success = texture->can_acquire_backing_texture(); - if (success) - texture->AcquireBackingTexture(ResourceProvider()); - return success; - } - - void PrioritizeTexturesAndBackings( - PrioritizedResourceManager* resource_manager) { - resource_manager->PrioritizeTextures(); - ResourceManagerUpdateBackingsPriorities(resource_manager); - } - - void ResourceManagerUpdateBackingsPriorities( - PrioritizedResourceManager* resource_manager) { - DebugScopedSetImplThreadAndMainThreadBlocked - impl_thread_and_main_thread_blocked(&proxy_); - resource_manager->PushTexturePrioritiesToBackings(); - } - - cc::ResourceProvider* ResourceProvider() { return resource_provider_.get(); } - - void ResourceManagerAssertInvariants( - PrioritizedResourceManager* resource_manager) { + PrioritizedResourceTest() + : proxy_(scoped_ptr<Thread>(NULL)), + texture_size_(256, 256), + texture_format_(GL_RGBA), + output_surface_(CreateFakeOutputSurface()) { + DebugScopedSetImplThread impl_thread(&proxy_); + resource_provider_ = cc::ResourceProvider::Create(output_surface_.get()); + } + + virtual ~PrioritizedResourceTest() { + DebugScopedSetImplThread impl_thread(&proxy_); + resource_provider_.reset(); + } + + size_t TexturesMemorySize(size_t texture_count) { + return Resource::MemorySizeBytes(texture_size_, texture_format_) * + texture_count; + } + + scoped_ptr<PrioritizedResourceManager> CreateManager(size_t max_textures) { + scoped_ptr<PrioritizedResourceManager> manager = + PrioritizedResourceManager::Create(&proxy_); + manager->SetMaxMemoryLimitBytes(TexturesMemorySize(max_textures)); + return manager.Pass(); + } + + bool ValidateTexture(PrioritizedResource* texture, + bool request_late) { + ResourceManagerAssertInvariants(texture->resource_manager()); + if (request_late) + texture->RequestLate(); + ResourceManagerAssertInvariants(texture->resource_manager()); + DebugScopedSetImplThreadAndMainThreadBlocked + impl_thread_and_main_thread_blocked(&proxy_); + bool success = texture->can_acquire_backing_texture(); + if (success) + texture->AcquireBackingTexture(ResourceProvider()); + return success; + } + + void PrioritizeTexturesAndBackings( + PrioritizedResourceManager* resource_manager) { + resource_manager->PrioritizeTextures(); + ResourceManagerUpdateBackingsPriorities(resource_manager); + } + + void ResourceManagerUpdateBackingsPriorities( + PrioritizedResourceManager* resource_manager) { + DebugScopedSetImplThreadAndMainThreadBlocked + impl_thread_and_main_thread_blocked(&proxy_); + resource_manager->PushTexturePrioritiesToBackings(); + } + + cc::ResourceProvider* ResourceProvider() { return resource_provider_.get(); } + + void ResourceManagerAssertInvariants( + PrioritizedResourceManager* resource_manager) { #ifndef NDEBUG - DebugScopedSetImplThreadAndMainThreadBlocked - impl_thread_and_main_thread_blocked(&proxy_); - resource_manager->AssertInvariants(); + DebugScopedSetImplThreadAndMainThreadBlocked + impl_thread_and_main_thread_blocked(&proxy_); + resource_manager->AssertInvariants(); #endif - } + } - bool TextureBackingIsAbovePriorityCutoff(PrioritizedResource* texture) { - return texture->backing()-> - was_above_priority_cutoff_at_last_priority_update(); - } + bool TextureBackingIsAbovePriorityCutoff(PrioritizedResource* texture) { + return texture->backing()-> + was_above_priority_cutoff_at_last_priority_update(); + } - size_t EvictedBackingCount(PrioritizedResourceManager* resource_manager) { - return resource_manager->evicted_backings_.size(); - } + size_t EvictedBackingCount(PrioritizedResourceManager* resource_manager) { + return resource_manager->evicted_backings_.size(); + } protected: - FakeProxy proxy_; - const gfx::Size texture_size_; - const GLenum texture_format_; - scoped_ptr<OutputSurface> output_surface_; - scoped_ptr<cc::ResourceProvider> resource_provider_; + FakeProxy proxy_; + const gfx::Size texture_size_; + const GLenum texture_format_; + scoped_ptr<OutputSurface> output_surface_; + scoped_ptr<cc::ResourceProvider> resource_provider_; }; namespace { TEST_F(PrioritizedResourceTest, RequestTextureExceedingMaxLimit) { - const size_t max_textures = 8; - scoped_ptr<PrioritizedResourceManager> resource_manager = - CreateManager(max_textures); - - // Create textures for double our memory limit. - scoped_ptr<PrioritizedResource> textures[max_textures * 2]; - - for (size_t i = 0; i < max_textures * 2; ++i) - textures[i] = - resource_manager->CreateTexture(texture_size_, texture_format_); - - // Set decreasing priorities - for (size_t i = 0; i < max_textures * 2; ++i) - textures[i]->set_request_priority(100 + i); - - // Only lower half should be available. - PrioritizeTexturesAndBackings(resource_manager.get()); - EXPECT_TRUE(ValidateTexture(textures[0], false)); - EXPECT_TRUE(ValidateTexture(textures[7], false)); - EXPECT_FALSE(ValidateTexture(textures[8], false)); - EXPECT_FALSE(ValidateTexture(textures[15], false)); - - // Set increasing priorities - for (size_t i = 0; i < max_textures * 2; ++i) - textures[i]->set_request_priority(100 - i); - - // Only upper half should be available. - PrioritizeTexturesAndBackings(resource_manager.get()); - EXPECT_FALSE(ValidateTexture(textures[0], false)); - EXPECT_FALSE(ValidateTexture(textures[7], false)); - EXPECT_TRUE(ValidateTexture(textures[8], false)); - EXPECT_TRUE(ValidateTexture(textures[15], false)); - - EXPECT_EQ(TexturesMemorySize(max_textures), - resource_manager->MemoryAboveCutoffBytes()); - EXPECT_LE(resource_manager->MemoryUseBytes(), - resource_manager->MemoryAboveCutoffBytes()); + const size_t kMaxTextures = 8; + scoped_ptr<PrioritizedResourceManager> resource_manager = + CreateManager(kMaxTextures); - DebugScopedSetImplThreadAndMainThreadBlocked - impl_thread_and_main_thread_blocked(&proxy_); - resource_manager->ClearAllMemory(ResourceProvider()); + // Create textures for double our memory limit. + scoped_ptr<PrioritizedResource> textures[kMaxTextures * 2]; + + for (size_t i = 0; i < kMaxTextures * 2; ++i) + textures[i] = + resource_manager->CreateTexture(texture_size_, texture_format_); + + // Set decreasing priorities + for (size_t i = 0; i < kMaxTextures * 2; ++i) + textures[i]->set_request_priority(100 + i); + + // Only lower half should be available. + PrioritizeTexturesAndBackings(resource_manager.get()); + EXPECT_TRUE(ValidateTexture(textures[0].get(), false)); + EXPECT_TRUE(ValidateTexture(textures[7].get(), false)); + EXPECT_FALSE(ValidateTexture(textures[8].get(), false)); + EXPECT_FALSE(ValidateTexture(textures[15].get(), false)); + + // Set increasing priorities + for (size_t i = 0; i < kMaxTextures * 2; ++i) + textures[i]->set_request_priority(100 - i); + + // Only upper half should be available. + PrioritizeTexturesAndBackings(resource_manager.get()); + EXPECT_FALSE(ValidateTexture(textures[0].get(), false)); + EXPECT_FALSE(ValidateTexture(textures[7].get(), false)); + EXPECT_TRUE(ValidateTexture(textures[8].get(), false)); + EXPECT_TRUE(ValidateTexture(textures[15].get(), false)); + + EXPECT_EQ(TexturesMemorySize(kMaxTextures), + resource_manager->MemoryAboveCutoffBytes()); + EXPECT_LE(resource_manager->MemoryUseBytes(), + resource_manager->MemoryAboveCutoffBytes()); + + DebugScopedSetImplThreadAndMainThreadBlocked + impl_thread_and_main_thread_blocked(&proxy_); + resource_manager->ClearAllMemory(ResourceProvider()); } TEST_F(PrioritizedResourceTest, ChangeMemoryLimits) { - const size_t max_textures = 8; - scoped_ptr<PrioritizedResourceManager> resource_manager = - CreateManager(max_textures); - scoped_ptr<PrioritizedResource> textures[max_textures]; - - for (size_t i = 0; i < max_textures; ++i) - textures[i] = - resource_manager->CreateTexture(texture_size_, texture_format_); - for (size_t i = 0; i < max_textures; ++i) - textures[i]->set_request_priority(100 + i); - - // Set max limit to 8 textures - resource_manager->SetMaxMemoryLimitBytes(TexturesMemorySize(8)); - PrioritizeTexturesAndBackings(resource_manager.get()); - for (size_t i = 0; i < max_textures; ++i) - ValidateTexture(textures[i], false); { - DebugScopedSetImplThreadAndMainThreadBlocked - impl_thread_and_main_thread_blocked(&proxy_); - resource_manager->ReduceMemory(ResourceProvider()); - } - - EXPECT_EQ(TexturesMemorySize(8), - resource_manager->MemoryAboveCutoffBytes()); - EXPECT_LE(resource_manager->MemoryUseBytes(), - resource_manager->MemoryAboveCutoffBytes()); - - // Set max limit to 5 textures - resource_manager->SetMaxMemoryLimitBytes(TexturesMemorySize(5)); - PrioritizeTexturesAndBackings(resource_manager.get()); - for (size_t i = 0; i < max_textures; ++i) - EXPECT_EQ(ValidateTexture(textures[i], false), i < 5); { - DebugScopedSetImplThreadAndMainThreadBlocked - impl_thread_and_main_thread_blocked(&proxy_); - resource_manager->ReduceMemory(ResourceProvider()); - } - - EXPECT_EQ(TexturesMemorySize(5), - resource_manager->MemoryAboveCutoffBytes()); - EXPECT_LE(resource_manager->MemoryUseBytes(), - resource_manager->MemoryAboveCutoffBytes()); - - // Set max limit to 4 textures - resource_manager->SetMaxMemoryLimitBytes(TexturesMemorySize(4)); - PrioritizeTexturesAndBackings(resource_manager.get()); - for (size_t i = 0; i < max_textures; ++i) - EXPECT_EQ(ValidateTexture(textures[i], false), i < 4); { - DebugScopedSetImplThreadAndMainThreadBlocked - impl_thread_and_main_thread_blocked(&proxy_); - resource_manager->ReduceMemory(ResourceProvider()); - } - - EXPECT_EQ(TexturesMemorySize(4), - resource_manager->MemoryAboveCutoffBytes()); - EXPECT_LE(resource_manager->MemoryUseBytes(), - resource_manager->MemoryAboveCutoffBytes()); + const size_t kMaxTextures = 8; + scoped_ptr<PrioritizedResourceManager> resource_manager = + CreateManager(kMaxTextures); + scoped_ptr<PrioritizedResource> textures[kMaxTextures]; + for (size_t i = 0; i < kMaxTextures; ++i) { + textures[i] = + resource_manager->CreateTexture(texture_size_, texture_format_); + } + for (size_t i = 0; i < kMaxTextures; ++i) + textures[i]->set_request_priority(100 + i); + + // Set max limit to 8 textures + resource_manager->SetMaxMemoryLimitBytes(TexturesMemorySize(8)); + PrioritizeTexturesAndBackings(resource_manager.get()); + for (size_t i = 0; i < kMaxTextures; ++i) + ValidateTexture(textures[i].get(), false); + { DebugScopedSetImplThreadAndMainThreadBlocked impl_thread_and_main_thread_blocked(&proxy_); - resource_manager->ClearAllMemory(ResourceProvider()); + resource_manager->ReduceMemory(ResourceProvider()); + } + + EXPECT_EQ(TexturesMemorySize(8), resource_manager->MemoryAboveCutoffBytes()); + EXPECT_LE(resource_manager->MemoryUseBytes(), + resource_manager->MemoryAboveCutoffBytes()); + + // Set max limit to 5 textures + resource_manager->SetMaxMemoryLimitBytes(TexturesMemorySize(5)); + PrioritizeTexturesAndBackings(resource_manager.get()); + for (size_t i = 0; i < kMaxTextures; ++i) + EXPECT_EQ(ValidateTexture(textures[i].get(), false), i < 5); + { + DebugScopedSetImplThreadAndMainThreadBlocked + impl_thread_and_main_thread_blocked(&proxy_); + resource_manager->ReduceMemory(ResourceProvider()); + } + + EXPECT_EQ(TexturesMemorySize(5), resource_manager->MemoryAboveCutoffBytes()); + EXPECT_LE(resource_manager->MemoryUseBytes(), + resource_manager->MemoryAboveCutoffBytes()); + + // Set max limit to 4 textures + resource_manager->SetMaxMemoryLimitBytes(TexturesMemorySize(4)); + PrioritizeTexturesAndBackings(resource_manager.get()); + for (size_t i = 0; i < kMaxTextures; ++i) + EXPECT_EQ(ValidateTexture(textures[i].get(), false), i < 4); + { + DebugScopedSetImplThreadAndMainThreadBlocked + impl_thread_and_main_thread_blocked(&proxy_); + resource_manager->ReduceMemory(ResourceProvider()); + } + + EXPECT_EQ(TexturesMemorySize(4), resource_manager->MemoryAboveCutoffBytes()); + EXPECT_LE(resource_manager->MemoryUseBytes(), + resource_manager->MemoryAboveCutoffBytes()); + + DebugScopedSetImplThreadAndMainThreadBlocked + impl_thread_and_main_thread_blocked(&proxy_); + resource_manager->ClearAllMemory(ResourceProvider()); } TEST_F(PrioritizedResourceTest, ChangePriorityCutoff) { - const size_t max_textures = 8; - scoped_ptr<PrioritizedResourceManager> resource_manager = - CreateManager(max_textures); - scoped_ptr<PrioritizedResource> textures[max_textures]; - - for (size_t i = 0; i < max_textures; ++i) - textures[i] = - resource_manager->CreateTexture(texture_size_, texture_format_); - for (size_t i = 0; i < max_textures; ++i) - textures[i]->set_request_priority(100 + i); - - // Set the cutoff to drop two textures. Try to request_late on all textures, - // and make sure that request_late doesn't work on a texture with equal - // priority to the cutoff. - resource_manager->SetMaxMemoryLimitBytes(TexturesMemorySize(8)); - resource_manager->SetExternalPriorityCutoff(106); - PrioritizeTexturesAndBackings(resource_manager.get()); - for (size_t i = 0; i < max_textures; ++i) - EXPECT_EQ(ValidateTexture(textures[i], true), i < 6); { - DebugScopedSetImplThreadAndMainThreadBlocked - impl_thread_and_main_thread_blocked(&proxy_); - resource_manager->ReduceMemory(ResourceProvider()); - } - EXPECT_EQ(TexturesMemorySize(6), - resource_manager->MemoryAboveCutoffBytes()); - EXPECT_LE(resource_manager->MemoryUseBytes(), - resource_manager->MemoryAboveCutoffBytes()); - - // Set the cutoff to drop two more textures. - resource_manager->SetExternalPriorityCutoff(104); - PrioritizeTexturesAndBackings(resource_manager.get()); - for (size_t i = 0; i < max_textures; ++i) - EXPECT_EQ(ValidateTexture(textures[i], false), i < 4); { - DebugScopedSetImplThreadAndMainThreadBlocked - impl_thread_and_main_thread_blocked(&proxy_); - resource_manager->ReduceMemory(ResourceProvider()); - } - EXPECT_EQ(TexturesMemorySize(4), - resource_manager->MemoryAboveCutoffBytes()); - - // Do a one-time eviction for one more texture based on priority cutoff - PrioritizedResourceManager::BackingList evicted_backings; - resource_manager->UnlinkAndClearEvictedBackings(); { - DebugScopedSetImplThreadAndMainThreadBlocked - impl_thread_and_main_thread_blocked(&proxy_); - resource_manager->ReduceMemoryOnImplThread( - TexturesMemorySize(8), 104, ResourceProvider()); - EXPECT_EQ(0, EvictedBackingCount(resource_manager.get())); - resource_manager->ReduceMemoryOnImplThread( - TexturesMemorySize(8), 103, ResourceProvider()); - EXPECT_EQ(1, EvictedBackingCount(resource_manager.get())); - } - resource_manager->UnlinkAndClearEvictedBackings(); - EXPECT_EQ(TexturesMemorySize(3), resource_manager->MemoryUseBytes()); - - // Re-allocate the the texture after the one-time drop. - PrioritizeTexturesAndBackings(resource_manager.get()); - for (size_t i = 0; i < max_textures; ++i) - EXPECT_EQ(ValidateTexture(textures[i], false), i < 4); { - DebugScopedSetImplThreadAndMainThreadBlocked - impl_thread_and_main_thread_blocked(&proxy_); - resource_manager->ReduceMemory(ResourceProvider()); - } - EXPECT_EQ(TexturesMemorySize(4), - resource_manager->MemoryAboveCutoffBytes()); + const size_t kMaxTextures = 8; + scoped_ptr<PrioritizedResourceManager> resource_manager = + CreateManager(kMaxTextures); + scoped_ptr<PrioritizedResource> textures[kMaxTextures]; + for (size_t i = 0; i < kMaxTextures; ++i) { + textures[i] = + resource_manager->CreateTexture(texture_size_, texture_format_); + } + for (size_t i = 0; i < kMaxTextures; ++i) + textures[i]->set_request_priority(100 + i); + + // Set the cutoff to drop two textures. Try to request_late on all textures, + // and make sure that request_late doesn't work on a texture with equal + // priority to the cutoff. + resource_manager->SetMaxMemoryLimitBytes(TexturesMemorySize(8)); + resource_manager->SetExternalPriorityCutoff(106); + PrioritizeTexturesAndBackings(resource_manager.get()); + for (size_t i = 0; i < kMaxTextures; ++i) + EXPECT_EQ(ValidateTexture(textures[i].get(), true), i < 6); + { DebugScopedSetImplThreadAndMainThreadBlocked impl_thread_and_main_thread_blocked(&proxy_); - resource_manager->ClearAllMemory(ResourceProvider()); + resource_manager->ReduceMemory(ResourceProvider()); + } + EXPECT_EQ(TexturesMemorySize(6), resource_manager->MemoryAboveCutoffBytes()); + EXPECT_LE(resource_manager->MemoryUseBytes(), + resource_manager->MemoryAboveCutoffBytes()); + + // Set the cutoff to drop two more textures. + resource_manager->SetExternalPriorityCutoff(104); + PrioritizeTexturesAndBackings(resource_manager.get()); + for (size_t i = 0; i < kMaxTextures; ++i) + EXPECT_EQ(ValidateTexture(textures[i].get(), false), i < 4); + { + DebugScopedSetImplThreadAndMainThreadBlocked + impl_thread_and_main_thread_blocked(&proxy_); + resource_manager->ReduceMemory(ResourceProvider()); + } + EXPECT_EQ(TexturesMemorySize(4), resource_manager->MemoryAboveCutoffBytes()); + + // Do a one-time eviction for one more texture based on priority cutoff + PrioritizedResourceManager::BackingList evicted_backings; + resource_manager->UnlinkAndClearEvictedBackings(); + { + DebugScopedSetImplThreadAndMainThreadBlocked + impl_thread_and_main_thread_blocked(&proxy_); + resource_manager->ReduceMemoryOnImplThread( + TexturesMemorySize(8), 104, ResourceProvider()); + EXPECT_EQ(0, EvictedBackingCount(resource_manager.get())); + resource_manager->ReduceMemoryOnImplThread( + TexturesMemorySize(8), 103, ResourceProvider()); + EXPECT_EQ(1, EvictedBackingCount(resource_manager.get())); + } + resource_manager->UnlinkAndClearEvictedBackings(); + EXPECT_EQ(TexturesMemorySize(3), resource_manager->MemoryUseBytes()); + + // Re-allocate the the texture after the one-time drop. + PrioritizeTexturesAndBackings(resource_manager.get()); + for (size_t i = 0; i < kMaxTextures; ++i) + EXPECT_EQ(ValidateTexture(textures[i].get(), false), i < 4); + { + DebugScopedSetImplThreadAndMainThreadBlocked + impl_thread_and_main_thread_blocked(&proxy_); + resource_manager->ReduceMemory(ResourceProvider()); + } + EXPECT_EQ(TexturesMemorySize(4), resource_manager->MemoryAboveCutoffBytes()); + + DebugScopedSetImplThreadAndMainThreadBlocked + impl_thread_and_main_thread_blocked(&proxy_); + resource_manager->ClearAllMemory(ResourceProvider()); } TEST_F(PrioritizedResourceTest, ResourceManagerPartialUpdateTextures) { - const size_t max_textures = 4; - const size_t num_textures = 4; - scoped_ptr<PrioritizedResourceManager> resource_manager = - CreateManager(max_textures); - scoped_ptr<PrioritizedResource> textures[num_textures]; - scoped_ptr<PrioritizedResource> more_textures[num_textures]; - - for (size_t i = 0; i < num_textures; ++i) { - textures[i] = - resource_manager->CreateTexture(texture_size_, texture_format_); - more_textures[i] = - resource_manager->CreateTexture(texture_size_, texture_format_); - } - - for (size_t i = 0; i < num_textures; ++i) - textures[i]->set_request_priority(200 + i); - PrioritizeTexturesAndBackings(resource_manager.get()); - - // Allocate textures which are currently high priority. - EXPECT_TRUE(ValidateTexture(textures[0], false)); - EXPECT_TRUE(ValidateTexture(textures[1], false)); - EXPECT_TRUE(ValidateTexture(textures[2], false)); - EXPECT_TRUE(ValidateTexture(textures[3], false)); - - EXPECT_TRUE(textures[0]->have_backing_texture()); - EXPECT_TRUE(textures[1]->have_backing_texture()); - EXPECT_TRUE(textures[2]->have_backing_texture()); - EXPECT_TRUE(textures[3]->have_backing_texture()); - - for (size_t i = 0; i < num_textures; ++i) - more_textures[i]->set_request_priority(100 + i); - PrioritizeTexturesAndBackings(resource_manager.get()); - - // Textures are now below cutoff. - EXPECT_FALSE(ValidateTexture(textures[0], false)); - EXPECT_FALSE(ValidateTexture(textures[1], false)); - EXPECT_FALSE(ValidateTexture(textures[2], false)); - EXPECT_FALSE(ValidateTexture(textures[3], false)); - - // But they are still valid to use. - EXPECT_TRUE(textures[0]->have_backing_texture()); - EXPECT_TRUE(textures[1]->have_backing_texture()); - EXPECT_TRUE(textures[2]->have_backing_texture()); - EXPECT_TRUE(textures[3]->have_backing_texture()); - - // Higher priority textures are finally needed. - EXPECT_TRUE(ValidateTexture(more_textures[0], false)); - EXPECT_TRUE(ValidateTexture(more_textures[1], false)); - EXPECT_TRUE(ValidateTexture(more_textures[2], false)); - EXPECT_TRUE(ValidateTexture(more_textures[3], false)); - - // Lower priority have been fully evicted. - EXPECT_FALSE(textures[0]->have_backing_texture()); - EXPECT_FALSE(textures[1]->have_backing_texture()); - EXPECT_FALSE(textures[2]->have_backing_texture()); - EXPECT_FALSE(textures[3]->have_backing_texture()); - - DebugScopedSetImplThreadAndMainThreadBlocked - impl_thread_and_main_thread_blocked(&proxy_); - resource_manager->ClearAllMemory(ResourceProvider()); + const size_t kMaxTextures = 4; + const size_t kNumTextures = 4; + scoped_ptr<PrioritizedResourceManager> resource_manager = + CreateManager(kMaxTextures); + scoped_ptr<PrioritizedResource> textures[kNumTextures]; + scoped_ptr<PrioritizedResource> more_textures[kNumTextures]; + + for (size_t i = 0; i < kNumTextures; ++i) { + textures[i] = + resource_manager->CreateTexture(texture_size_, texture_format_); + more_textures[i] = + resource_manager->CreateTexture(texture_size_, texture_format_); + } + + for (size_t i = 0; i < kNumTextures; ++i) + textures[i]->set_request_priority(200 + i); + PrioritizeTexturesAndBackings(resource_manager.get()); + + // Allocate textures which are currently high priority. + EXPECT_TRUE(ValidateTexture(textures[0].get(), false)); + EXPECT_TRUE(ValidateTexture(textures[1].get(), false)); + EXPECT_TRUE(ValidateTexture(textures[2].get(), false)); + EXPECT_TRUE(ValidateTexture(textures[3].get(), false)); + + EXPECT_TRUE(textures[0]->have_backing_texture()); + EXPECT_TRUE(textures[1]->have_backing_texture()); + EXPECT_TRUE(textures[2]->have_backing_texture()); + EXPECT_TRUE(textures[3]->have_backing_texture()); + + for (size_t i = 0; i < kNumTextures; ++i) + more_textures[i]->set_request_priority(100 + i); + PrioritizeTexturesAndBackings(resource_manager.get()); + + // Textures are now below cutoff. + EXPECT_FALSE(ValidateTexture(textures[0].get(), false)); + EXPECT_FALSE(ValidateTexture(textures[1].get(), false)); + EXPECT_FALSE(ValidateTexture(textures[2].get(), false)); + EXPECT_FALSE(ValidateTexture(textures[3].get(), false)); + + // But they are still valid to use. + EXPECT_TRUE(textures[0]->have_backing_texture()); + EXPECT_TRUE(textures[1]->have_backing_texture()); + EXPECT_TRUE(textures[2]->have_backing_texture()); + EXPECT_TRUE(textures[3]->have_backing_texture()); + + // Higher priority textures are finally needed. + EXPECT_TRUE(ValidateTexture(more_textures[0].get(), false)); + EXPECT_TRUE(ValidateTexture(more_textures[1].get(), false)); + EXPECT_TRUE(ValidateTexture(more_textures[2].get(), false)); + EXPECT_TRUE(ValidateTexture(more_textures[3].get(), false)); + + // Lower priority have been fully evicted. + EXPECT_FALSE(textures[0]->have_backing_texture()); + EXPECT_FALSE(textures[1]->have_backing_texture()); + EXPECT_FALSE(textures[2]->have_backing_texture()); + EXPECT_FALSE(textures[3]->have_backing_texture()); + + DebugScopedSetImplThreadAndMainThreadBlocked + impl_thread_and_main_thread_blocked(&proxy_); + resource_manager->ClearAllMemory(ResourceProvider()); } TEST_F(PrioritizedResourceTest, ResourceManagerPrioritiesAreEqual) { - const size_t max_textures = 16; - scoped_ptr<PrioritizedResourceManager> resource_manager = - CreateManager(max_textures); - scoped_ptr<PrioritizedResource> textures[max_textures]; - - for (size_t i = 0; i < max_textures; ++i) - textures[i] = - resource_manager->CreateTexture(texture_size_, texture_format_); - - // All 16 textures have the same priority except 2 higher priority. - for (size_t i = 0; i < max_textures; ++i) - textures[i]->set_request_priority(100); - textures[0]->set_request_priority(99); - textures[1]->set_request_priority(99); - - // Set max limit to 8 textures - resource_manager->SetMaxMemoryLimitBytes(TexturesMemorySize(8)); - PrioritizeTexturesAndBackings(resource_manager.get()); - - // The two high priority textures should be available, others should not. - for (size_t i = 0; i < 2; ++i) - EXPECT_TRUE(ValidateTexture(textures[i], false)); - for (size_t i = 2; i < max_textures; ++i) - EXPECT_FALSE(ValidateTexture(textures[i], false)); - EXPECT_EQ(TexturesMemorySize(2), - resource_manager->MemoryAboveCutoffBytes()); - EXPECT_LE(resource_manager->MemoryUseBytes(), - resource_manager->MemoryAboveCutoffBytes()); - - // Manually reserving textures should only succeed on the higher priority - // textures, and on remaining textures up to the memory limit. - for (size_t i = 0; i < 8; i++) - EXPECT_TRUE(ValidateTexture(textures[i], true)); - for (size_t i = 9; i < max_textures; i++) - EXPECT_FALSE(ValidateTexture(textures[i], true)); - EXPECT_EQ(TexturesMemorySize(8), - resource_manager->MemoryAboveCutoffBytes()); - EXPECT_LE(resource_manager->MemoryUseBytes(), - resource_manager->MemoryAboveCutoffBytes()); + const size_t kMaxTextures = 16; + scoped_ptr<PrioritizedResourceManager> resource_manager = + CreateManager(kMaxTextures); + scoped_ptr<PrioritizedResource> textures[kMaxTextures]; - DebugScopedSetImplThreadAndMainThreadBlocked - impl_thread_and_main_thread_blocked(&proxy_); - resource_manager->ClearAllMemory(ResourceProvider()); + for (size_t i = 0; i < kMaxTextures; ++i) { + textures[i] = + resource_manager->CreateTexture(texture_size_, texture_format_); + } + + // All 16 textures have the same priority except 2 higher priority. + for (size_t i = 0; i < kMaxTextures; ++i) + textures[i]->set_request_priority(100); + textures[0]->set_request_priority(99); + textures[1]->set_request_priority(99); + + // Set max limit to 8 textures + resource_manager->SetMaxMemoryLimitBytes(TexturesMemorySize(8)); + PrioritizeTexturesAndBackings(resource_manager.get()); + + // The two high priority textures should be available, others should not. + for (size_t i = 0; i < 2; ++i) + EXPECT_TRUE(ValidateTexture(textures[i].get(), false)); + for (size_t i = 2; i < kMaxTextures; ++i) + EXPECT_FALSE(ValidateTexture(textures[i].get(), false)); + EXPECT_EQ(TexturesMemorySize(2), resource_manager->MemoryAboveCutoffBytes()); + EXPECT_LE(resource_manager->MemoryUseBytes(), + resource_manager->MemoryAboveCutoffBytes()); + + // Manually reserving textures should only succeed on the higher priority + // textures, and on remaining textures up to the memory limit. + for (size_t i = 0; i < 8; i++) + EXPECT_TRUE(ValidateTexture(textures[i].get(), true)); + for (size_t i = 9; i < kMaxTextures; i++) + EXPECT_FALSE(ValidateTexture(textures[i].get(), true)); + EXPECT_EQ(TexturesMemorySize(8), resource_manager->MemoryAboveCutoffBytes()); + EXPECT_LE(resource_manager->MemoryUseBytes(), + resource_manager->MemoryAboveCutoffBytes()); + + DebugScopedSetImplThreadAndMainThreadBlocked + impl_thread_and_main_thread_blocked(&proxy_); + resource_manager->ClearAllMemory(ResourceProvider()); } TEST_F(PrioritizedResourceTest, ResourceManagerDestroyedFirst) { - scoped_ptr<PrioritizedResourceManager> resource_manager = CreateManager(1); - scoped_ptr<PrioritizedResource> texture = - resource_manager->CreateTexture(texture_size_, texture_format_); + scoped_ptr<PrioritizedResourceManager> resource_manager = CreateManager(1); + scoped_ptr<PrioritizedResource> texture = + resource_manager->CreateTexture(texture_size_, texture_format_); - // Texture is initially invalid, but it will become available. - EXPECT_FALSE(texture->have_backing_texture()); + // Texture is initially invalid, but it will become available. + EXPECT_FALSE(texture->have_backing_texture()); - texture->set_request_priority(100); - PrioritizeTexturesAndBackings(resource_manager.get()); + texture->set_request_priority(100); + PrioritizeTexturesAndBackings(resource_manager.get()); - EXPECT_TRUE(ValidateTexture(texture, false)); - EXPECT_TRUE(texture->can_acquire_backing_texture()); - EXPECT_TRUE(texture->have_backing_texture()); { - DebugScopedSetImplThreadAndMainThreadBlocked - impl_thread_and_main_thread_blocked(&proxy_); - resource_manager->ClearAllMemory(ResourceProvider()); - } - resource_manager.reset(); + EXPECT_TRUE(ValidateTexture(texture.get(), false)); + EXPECT_TRUE(texture->can_acquire_backing_texture()); + EXPECT_TRUE(texture->have_backing_texture()); + { + DebugScopedSetImplThreadAndMainThreadBlocked + impl_thread_and_main_thread_blocked(&proxy_); + resource_manager->ClearAllMemory(ResourceProvider()); + } + resource_manager.reset(); - EXPECT_FALSE(texture->can_acquire_backing_texture()); - EXPECT_FALSE(texture->have_backing_texture()); + EXPECT_FALSE(texture->can_acquire_backing_texture()); + EXPECT_FALSE(texture->have_backing_texture()); } TEST_F(PrioritizedResourceTest, TextureMovedToNewManager) { - scoped_ptr<PrioritizedResourceManager> resource_manager_one = - CreateManager(1); - scoped_ptr<PrioritizedResourceManager> resource_manager_two = - CreateManager(1); - scoped_ptr<PrioritizedResource> texture = - resource_manager_one->CreateTexture(texture_size_, texture_format_); + scoped_ptr<PrioritizedResourceManager> resource_manager_one = + CreateManager(1); + scoped_ptr<PrioritizedResourceManager> resource_manager_two = + CreateManager(1); + scoped_ptr<PrioritizedResource> texture = + resource_manager_one->CreateTexture(texture_size_, texture_format_); - // Texture is initially invalid, but it will become available. - EXPECT_FALSE(texture->have_backing_texture()); + // Texture is initially invalid, but it will become available. + EXPECT_FALSE(texture->have_backing_texture()); - texture->set_request_priority(100); - PrioritizeTexturesAndBackings(resource_manager_one.get()); + texture->set_request_priority(100); + PrioritizeTexturesAndBackings(resource_manager_one.get()); - EXPECT_TRUE(ValidateTexture(texture, false)); - EXPECT_TRUE(texture->can_acquire_backing_texture()); - EXPECT_TRUE(texture->have_backing_texture()); + EXPECT_TRUE(ValidateTexture(texture.get(), false)); + EXPECT_TRUE(texture->can_acquire_backing_texture()); + EXPECT_TRUE(texture->have_backing_texture()); - texture->SetTextureManager(0); { - DebugScopedSetImplThreadAndMainThreadBlocked - impl_thread_and_main_thread_blocked(&proxy_); - resource_manager_one->ClearAllMemory(ResourceProvider()); - } - resource_manager_one.reset(); + texture->SetTextureManager(NULL); + { + DebugScopedSetImplThreadAndMainThreadBlocked + impl_thread_and_main_thread_blocked(&proxy_); + resource_manager_one->ClearAllMemory(ResourceProvider()); + } + resource_manager_one.reset(); - EXPECT_FALSE(texture->can_acquire_backing_texture()); - EXPECT_FALSE(texture->have_backing_texture()); + EXPECT_FALSE(texture->can_acquire_backing_texture()); + EXPECT_FALSE(texture->have_backing_texture()); - texture->SetTextureManager(resource_manager_two.get()); + texture->SetTextureManager(resource_manager_two.get()); - PrioritizeTexturesAndBackings(resource_manager_two.get()); + PrioritizeTexturesAndBackings(resource_manager_two.get()); - EXPECT_TRUE(ValidateTexture(texture, false)); - EXPECT_TRUE(texture->can_acquire_backing_texture()); - EXPECT_TRUE(texture->have_backing_texture()); + EXPECT_TRUE(ValidateTexture(texture.get(), false)); + EXPECT_TRUE(texture->can_acquire_backing_texture()); + EXPECT_TRUE(texture->have_backing_texture()); - DebugScopedSetImplThreadAndMainThreadBlocked - impl_thread_and_main_thread_blocked(&proxy_); - resource_manager_two->ClearAllMemory(ResourceProvider()); + DebugScopedSetImplThreadAndMainThreadBlocked + impl_thread_and_main_thread_blocked(&proxy_); + resource_manager_two->ClearAllMemory(ResourceProvider()); } TEST_F(PrioritizedResourceTest, RenderSurfacesReduceMemoryAvailableOutsideRootSurface) { - const size_t max_textures = 8; - scoped_ptr<PrioritizedResourceManager> resource_manager = - CreateManager(max_textures); - - // Half of the memory is taken by surfaces (with high priority place-holder) - scoped_ptr<PrioritizedResource> render_surface_place_holder = + const size_t kMaxTextures = 8; + scoped_ptr<PrioritizedResourceManager> resource_manager = + CreateManager(kMaxTextures); + + // Half of the memory is taken by surfaces (with high priority place-holder) + scoped_ptr<PrioritizedResource> render_surface_place_holder = + resource_manager->CreateTexture(texture_size_, texture_format_); + render_surface_place_holder->SetToSelfManagedMemoryPlaceholder( + TexturesMemorySize(4)); + render_surface_place_holder->set_request_priority( + PriorityCalculator::RenderSurfacePriority()); + + // Create textures to fill our memory limit. + scoped_ptr<PrioritizedResource> textures[kMaxTextures]; + + for (size_t i = 0; i < kMaxTextures; ++i) { + textures[i] = resource_manager->CreateTexture(texture_size_, texture_format_); - render_surface_place_holder->SetToSelfManagedMemoryPlaceholder( - TexturesMemorySize(4)); - render_surface_place_holder->set_request_priority( - PriorityCalculator::RenderSurfacePriority()); - - // Create textures to fill our memory limit. - scoped_ptr<PrioritizedResource> textures[max_textures]; - - for (size_t i = 0; i < max_textures; ++i) - textures[i] = - resource_manager->CreateTexture(texture_size_, texture_format_); - - // Set decreasing non-visible priorities outside root surface. - for (size_t i = 0; i < max_textures; ++i) - textures[i]->set_request_priority(100 + i); - - // Only lower half should be available. - PrioritizeTexturesAndBackings(resource_manager.get()); - EXPECT_TRUE(ValidateTexture(textures[0], false)); - EXPECT_TRUE(ValidateTexture(textures[3], false)); - EXPECT_FALSE(ValidateTexture(textures[4], false)); - EXPECT_FALSE(ValidateTexture(textures[7], false)); - - // Set increasing non-visible priorities outside root surface. - for (size_t i = 0; i < max_textures; ++i) - textures[i]->set_request_priority(100 - i); - - // Only upper half should be available. - PrioritizeTexturesAndBackings(resource_manager.get()); - EXPECT_FALSE(ValidateTexture(textures[0], false)); - EXPECT_FALSE(ValidateTexture(textures[3], false)); - EXPECT_TRUE(ValidateTexture(textures[4], false)); - EXPECT_TRUE(ValidateTexture(textures[7], false)); - - EXPECT_EQ(TexturesMemorySize(4), - resource_manager->MemoryAboveCutoffBytes()); - EXPECT_EQ(TexturesMemorySize(4), - resource_manager->MemoryForSelfManagedTextures()); - EXPECT_LE(resource_manager->MemoryUseBytes(), - resource_manager->MemoryAboveCutoffBytes()); - - DebugScopedSetImplThreadAndMainThreadBlocked - impl_thread_and_main_thread_blocked(&proxy_); - resource_manager->ClearAllMemory(ResourceProvider()); + } + + // Set decreasing non-visible priorities outside root surface. + for (size_t i = 0; i < kMaxTextures; ++i) + textures[i]->set_request_priority(100 + i); + + // Only lower half should be available. + PrioritizeTexturesAndBackings(resource_manager.get()); + EXPECT_TRUE(ValidateTexture(textures[0].get(), false)); + EXPECT_TRUE(ValidateTexture(textures[3].get(), false)); + EXPECT_FALSE(ValidateTexture(textures[4].get(), false)); + EXPECT_FALSE(ValidateTexture(textures[7].get(), false)); + + // Set increasing non-visible priorities outside root surface. + for (size_t i = 0; i < kMaxTextures; ++i) + textures[i]->set_request_priority(100 - i); + + // Only upper half should be available. + PrioritizeTexturesAndBackings(resource_manager.get()); + EXPECT_FALSE(ValidateTexture(textures[0].get(), false)); + EXPECT_FALSE(ValidateTexture(textures[3].get(), false)); + EXPECT_TRUE(ValidateTexture(textures[4].get(), false)); + EXPECT_TRUE(ValidateTexture(textures[7].get(), false)); + + EXPECT_EQ(TexturesMemorySize(4), resource_manager->MemoryAboveCutoffBytes()); + EXPECT_EQ(TexturesMemorySize(4), + resource_manager->MemoryForSelfManagedTextures()); + EXPECT_LE(resource_manager->MemoryUseBytes(), + resource_manager->MemoryAboveCutoffBytes()); + + DebugScopedSetImplThreadAndMainThreadBlocked + impl_thread_and_main_thread_blocked(&proxy_); + resource_manager->ClearAllMemory(ResourceProvider()); } TEST_F(PrioritizedResourceTest, RenderSurfacesReduceMemoryAvailableForRequestLate) { - const size_t max_textures = 8; - scoped_ptr<PrioritizedResourceManager> resource_manager = - CreateManager(max_textures); - - // Half of the memory is taken by surfaces (with high priority place-holder) - scoped_ptr<PrioritizedResource> render_surface_place_holder = + const size_t kMaxTextures = 8; + scoped_ptr<PrioritizedResourceManager> resource_manager = + CreateManager(kMaxTextures); + + // Half of the memory is taken by surfaces (with high priority place-holder) + scoped_ptr<PrioritizedResource> render_surface_place_holder = + resource_manager->CreateTexture(texture_size_, texture_format_); + render_surface_place_holder->SetToSelfManagedMemoryPlaceholder( + TexturesMemorySize(4)); + render_surface_place_holder->set_request_priority( + PriorityCalculator::RenderSurfacePriority()); + + // Create textures to fill our memory limit. + scoped_ptr<PrioritizedResource> textures[kMaxTextures]; + + for (size_t i = 0; i < kMaxTextures; ++i) { + textures[i] = resource_manager->CreateTexture(texture_size_, texture_format_); - render_surface_place_holder->SetToSelfManagedMemoryPlaceholder( - TexturesMemorySize(4)); - render_surface_place_holder->set_request_priority( - PriorityCalculator::RenderSurfacePriority()); - - // Create textures to fill our memory limit. - scoped_ptr<PrioritizedResource> textures[max_textures]; - - for (size_t i = 0; i < max_textures; ++i) - textures[i] = - resource_manager->CreateTexture(texture_size_, texture_format_); - - // Set equal priorities. - for (size_t i = 0; i < max_textures; ++i) - textures[i]->set_request_priority(100); - - // The first four to be requested late will be available. - PrioritizeTexturesAndBackings(resource_manager.get()); - for (unsigned i = 0; i < max_textures; ++i) - EXPECT_FALSE(ValidateTexture(textures[i], false)); - for (unsigned i = 0; i < max_textures; i += 2) - EXPECT_TRUE(ValidateTexture(textures[i], true)); - for (unsigned i = 1; i < max_textures; i += 2) - EXPECT_FALSE(ValidateTexture(textures[i], true)); - - EXPECT_EQ(TexturesMemorySize(4), - resource_manager->MemoryAboveCutoffBytes()); - EXPECT_EQ(TexturesMemorySize(4), - resource_manager->MemoryForSelfManagedTextures()); - EXPECT_LE(resource_manager->MemoryUseBytes(), - resource_manager->MemoryAboveCutoffBytes()); - - DebugScopedSetImplThreadAndMainThreadBlocked - impl_thread_and_main_thread_blocked(&proxy_); - resource_manager->ClearAllMemory(ResourceProvider()); + } + + // Set equal priorities. + for (size_t i = 0; i < kMaxTextures; ++i) + textures[i]->set_request_priority(100); + + // The first four to be requested late will be available. + PrioritizeTexturesAndBackings(resource_manager.get()); + for (unsigned i = 0; i < kMaxTextures; ++i) + EXPECT_FALSE(ValidateTexture(textures[i].get(), false)); + for (unsigned i = 0; i < kMaxTextures; i += 2) + EXPECT_TRUE(ValidateTexture(textures[i].get(), true)); + for (unsigned i = 1; i < kMaxTextures; i += 2) + EXPECT_FALSE(ValidateTexture(textures[i].get(), true)); + + EXPECT_EQ(TexturesMemorySize(4), resource_manager->MemoryAboveCutoffBytes()); + EXPECT_EQ(TexturesMemorySize(4), + resource_manager->MemoryForSelfManagedTextures()); + EXPECT_LE(resource_manager->MemoryUseBytes(), + resource_manager->MemoryAboveCutoffBytes()); + + DebugScopedSetImplThreadAndMainThreadBlocked + impl_thread_and_main_thread_blocked(&proxy_); + resource_manager->ClearAllMemory(ResourceProvider()); } TEST_F(PrioritizedResourceTest, WhenRenderSurfaceNotAvailableTexturesAlsoNotAvailable) { - const size_t max_textures = 8; - scoped_ptr<PrioritizedResourceManager> resource_manager = - CreateManager(max_textures); - - // Half of the memory is taken by surfaces (with high priority place-holder) - scoped_ptr<PrioritizedResource> render_surface_place_holder = + const size_t kMaxTextures = 8; + scoped_ptr<PrioritizedResourceManager> resource_manager = + CreateManager(kMaxTextures); + + // Half of the memory is taken by surfaces (with high priority place-holder) + scoped_ptr<PrioritizedResource> render_surface_place_holder = + resource_manager->CreateTexture(texture_size_, texture_format_); + render_surface_place_holder->SetToSelfManagedMemoryPlaceholder( + TexturesMemorySize(4)); + render_surface_place_holder->set_request_priority( + PriorityCalculator::RenderSurfacePriority()); + + // Create textures to fill our memory limit. + scoped_ptr<PrioritizedResource> textures[kMaxTextures]; + + for (size_t i = 0; i < kMaxTextures; ++i) + textures[i] = resource_manager->CreateTexture(texture_size_, texture_format_); - render_surface_place_holder->SetToSelfManagedMemoryPlaceholder( - TexturesMemorySize(4)); - render_surface_place_holder->set_request_priority( - PriorityCalculator::RenderSurfacePriority()); - - // Create textures to fill our memory limit. - scoped_ptr<PrioritizedResource> textures[max_textures]; - - for (size_t i = 0; i < max_textures; ++i) - textures[i] = - resource_manager->CreateTexture(texture_size_, texture_format_); - - // Set 6 visible textures in the root surface, and 2 in a child surface. - for (size_t i = 0; i < 6; ++i) - textures[i]-> - set_request_priority(PriorityCalculator::VisiblePriority(true)); - for (size_t i = 6; i < 8; ++i) - textures[i]-> - set_request_priority(PriorityCalculator::VisiblePriority(false)); - - PrioritizeTexturesAndBackings(resource_manager.get()); - - // Unable to request_late textures in the child surface. - EXPECT_FALSE(ValidateTexture(textures[6], true)); - EXPECT_FALSE(ValidateTexture(textures[7], true)); - - // Root surface textures are valid. - for (size_t i = 0; i < 6; ++i) - EXPECT_TRUE(ValidateTexture(textures[i], false)); - - EXPECT_EQ(TexturesMemorySize(6), - resource_manager->MemoryAboveCutoffBytes()); - EXPECT_EQ(TexturesMemorySize(2), - resource_manager->MemoryForSelfManagedTextures()); - EXPECT_LE(resource_manager->MemoryUseBytes(), - resource_manager->MemoryAboveCutoffBytes()); - DebugScopedSetImplThreadAndMainThreadBlocked - impl_thread_and_main_thread_blocked(&proxy_); - resource_manager->ClearAllMemory(ResourceProvider()); + // Set 6 visible textures in the root surface, and 2 in a child surface. + for (size_t i = 0; i < 6; ++i) { + textures[i]-> + set_request_priority(PriorityCalculator::VisiblePriority(true)); + } + for (size_t i = 6; i < 8; ++i) { + textures[i]-> + set_request_priority(PriorityCalculator::VisiblePriority(false)); + } + + PrioritizeTexturesAndBackings(resource_manager.get()); + + // Unable to request_late textures in the child surface. + EXPECT_FALSE(ValidateTexture(textures[6].get(), true)); + EXPECT_FALSE(ValidateTexture(textures[7].get(), true)); + + // Root surface textures are valid. + for (size_t i = 0; i < 6; ++i) + EXPECT_TRUE(ValidateTexture(textures[i].get(), false)); + + EXPECT_EQ(TexturesMemorySize(6), resource_manager->MemoryAboveCutoffBytes()); + EXPECT_EQ(TexturesMemorySize(2), + resource_manager->MemoryForSelfManagedTextures()); + EXPECT_LE(resource_manager->MemoryUseBytes(), + resource_manager->MemoryAboveCutoffBytes()); + + DebugScopedSetImplThreadAndMainThreadBlocked + impl_thread_and_main_thread_blocked(&proxy_); + resource_manager->ClearAllMemory(ResourceProvider()); } TEST_F(PrioritizedResourceTest, RequestLateBackingsSorting) { - const size_t max_textures = 8; - scoped_ptr<PrioritizedResourceManager> resource_manager = - CreateManager(max_textures); - resource_manager->SetMaxMemoryLimitBytes(TexturesMemorySize(max_textures)); - - // Create textures to fill our memory limit. - scoped_ptr<PrioritizedResource> textures[max_textures]; - for (size_t i = 0; i < max_textures; ++i) - textures[i] = - resource_manager->CreateTexture(texture_size_, texture_format_); - - // Set equal priorities, and allocate backings for all textures. - for (size_t i = 0; i < max_textures; ++i) - textures[i]->set_request_priority(100); - PrioritizeTexturesAndBackings(resource_manager.get()); - for (unsigned i = 0; i < max_textures; ++i) - EXPECT_TRUE(ValidateTexture(textures[i], false)); - - // Drop the memory limit and prioritize (none will be above the threshold, - // but they still have backings because ReduceMemory hasn't been called). - resource_manager->SetMaxMemoryLimitBytes( - TexturesMemorySize(max_textures / 2)); - PrioritizeTexturesAndBackings(resource_manager.get()); - - // Push half of them back over the limit. - for (size_t i = 0; i < max_textures; i += 2) - EXPECT_TRUE(textures[i]->RequestLate()); - - // Push the priorities to the backings array and sort the backings array - ResourceManagerUpdateBackingsPriorities(resource_manager.get()); - - // Assert that the backings list be sorted with the below-limit backings - // before the above-limit backings. - ResourceManagerAssertInvariants(resource_manager.get()); - - // Make sure that we have backings for all of the textures. - for (size_t i = 0; i < max_textures; ++i) - EXPECT_TRUE(textures[i]->have_backing_texture()); - - // Make sure that only the request_late textures are above the priority - // cutoff - for (size_t i = 0; i < max_textures; i += 2) - EXPECT_TRUE(TextureBackingIsAbovePriorityCutoff(textures[i].get())); - for (size_t i = 1; i < max_textures; i += 2) - EXPECT_FALSE(TextureBackingIsAbovePriorityCutoff(textures[i].get())); + const size_t kMaxTextures = 8; + scoped_ptr<PrioritizedResourceManager> resource_manager = + CreateManager(kMaxTextures); + resource_manager->SetMaxMemoryLimitBytes(TexturesMemorySize(kMaxTextures)); + + // Create textures to fill our memory limit. + scoped_ptr<PrioritizedResource> textures[kMaxTextures]; + for (size_t i = 0; i < kMaxTextures; ++i) + textures[i] = + resource_manager->CreateTexture(texture_size_, texture_format_); - DebugScopedSetImplThreadAndMainThreadBlocked - impl_thread_and_main_thread_blocked(&proxy_); - resource_manager->ClearAllMemory(ResourceProvider()); + // Set equal priorities, and allocate backings for all textures. + for (size_t i = 0; i < kMaxTextures; ++i) + textures[i]->set_request_priority(100); + PrioritizeTexturesAndBackings(resource_manager.get()); + for (unsigned i = 0; i < kMaxTextures; ++i) + EXPECT_TRUE(ValidateTexture(textures[i].get(), false)); + + // Drop the memory limit and prioritize (none will be above the threshold, + // but they still have backings because ReduceMemory hasn't been called). + resource_manager->SetMaxMemoryLimitBytes( + TexturesMemorySize(kMaxTextures / 2)); + PrioritizeTexturesAndBackings(resource_manager.get()); + + // Push half of them back over the limit. + for (size_t i = 0; i < kMaxTextures; i += 2) + EXPECT_TRUE(textures[i]->RequestLate()); + + // Push the priorities to the backings array and sort the backings array + ResourceManagerUpdateBackingsPriorities(resource_manager.get()); + + // Assert that the backings list be sorted with the below-limit backings + // before the above-limit backings. + ResourceManagerAssertInvariants(resource_manager.get()); + + // Make sure that we have backings for all of the textures. + for (size_t i = 0; i < kMaxTextures; ++i) + EXPECT_TRUE(textures[i]->have_backing_texture()); + + // Make sure that only the request_late textures are above the priority + // cutoff + for (size_t i = 0; i < kMaxTextures; i += 2) + EXPECT_TRUE(TextureBackingIsAbovePriorityCutoff(textures[i].get())); + for (size_t i = 1; i < kMaxTextures; i += 2) + EXPECT_FALSE(TextureBackingIsAbovePriorityCutoff(textures[i].get())); + + DebugScopedSetImplThreadAndMainThreadBlocked + impl_thread_and_main_thread_blocked(&proxy_); + resource_manager->ClearAllMemory(ResourceProvider()); } TEST_F(PrioritizedResourceTest, ClearUploadsToEvictedResources) { - const size_t max_textures = 4; - scoped_ptr<PrioritizedResourceManager> resource_manager = - CreateManager(max_textures); - resource_manager->SetMaxMemoryLimitBytes(TexturesMemorySize(max_textures)); - - // Create textures to fill our memory limit. - scoped_ptr<PrioritizedResource> textures[max_textures]; - - for (size_t i = 0; i < max_textures; ++i) - textures[i] = - resource_manager->CreateTexture(texture_size_, texture_format_); - - // Set equal priorities, and allocate backings for all textures. - for (size_t i = 0; i < max_textures; ++i) - textures[i]->set_request_priority(100); - PrioritizeTexturesAndBackings(resource_manager.get()); - for (unsigned i = 0; i < max_textures; ++i) - EXPECT_TRUE(ValidateTexture(textures[i], false)); - - ResourceUpdateQueue queue; - DebugScopedSetImplThreadAndMainThreadBlocked - impl_thread_and_main_thread_blocked(&proxy_); - for (size_t i = 0; i < max_textures; ++i) { - const ResourceUpdate upload = ResourceUpdate::Create( - textures[i].get(), NULL, gfx::Rect(), gfx::Rect(), gfx::Vector2d()); - queue.AppendFullUpload(upload); - } + const size_t kMaxTextures = 4; + scoped_ptr<PrioritizedResourceManager> resource_manager = + CreateManager(kMaxTextures); + resource_manager->SetMaxMemoryLimitBytes(TexturesMemorySize(kMaxTextures)); - // Make sure that we have backings for all of the textures. - for (size_t i = 0; i < max_textures; ++i) - EXPECT_TRUE(textures[i]->have_backing_texture()); + // Create textures to fill our memory limit. + scoped_ptr<PrioritizedResource> textures[kMaxTextures]; - queue.ClearUploadsToEvictedResources(); - EXPECT_EQ(4, queue.FullUploadSize()); - - resource_manager->ReduceMemoryOnImplThread( - TexturesMemorySize(1), - PriorityCalculator::AllowEverythingCutoff(), - ResourceProvider()); - queue.ClearUploadsToEvictedResources(); - EXPECT_EQ(1, queue.FullUploadSize()); + for (size_t i = 0; i < kMaxTextures; ++i) + textures[i] = + resource_manager->CreateTexture(texture_size_, texture_format_); - resource_manager->ReduceMemoryOnImplThread( - 0, PriorityCalculator::AllowEverythingCutoff(), ResourceProvider()); - queue.ClearUploadsToEvictedResources(); - EXPECT_EQ(0, queue.FullUploadSize()); + // Set equal priorities, and allocate backings for all textures. + for (size_t i = 0; i < kMaxTextures; ++i) + textures[i]->set_request_priority(100); + PrioritizeTexturesAndBackings(resource_manager.get()); + for (unsigned i = 0; i < kMaxTextures; ++i) + EXPECT_TRUE(ValidateTexture(textures[i].get(), false)); + + ResourceUpdateQueue queue; + DebugScopedSetImplThreadAndMainThreadBlocked + impl_thread_and_main_thread_blocked(&proxy_); + for (size_t i = 0; i < kMaxTextures; ++i) { + const ResourceUpdate upload = ResourceUpdate::Create( + textures[i].get(), NULL, gfx::Rect(), gfx::Rect(), gfx::Vector2d()); + queue.AppendFullUpload(upload); + } + + // Make sure that we have backings for all of the textures. + for (size_t i = 0; i < kMaxTextures; ++i) + EXPECT_TRUE(textures[i]->have_backing_texture()); + + queue.ClearUploadsToEvictedResources(); + EXPECT_EQ(4, queue.FullUploadSize()); + + resource_manager->ReduceMemoryOnImplThread( + TexturesMemorySize(1), + PriorityCalculator::AllowEverythingCutoff(), + ResourceProvider()); + queue.ClearUploadsToEvictedResources(); + EXPECT_EQ(1, queue.FullUploadSize()); + + resource_manager->ReduceMemoryOnImplThread( + 0, PriorityCalculator::AllowEverythingCutoff(), ResourceProvider()); + queue.ClearUploadsToEvictedResources(); + EXPECT_EQ(0, queue.FullUploadSize()); } TEST_F(PrioritizedResourceTest, UsageStatistics) { - const size_t max_textures = 5; - scoped_ptr<PrioritizedResourceManager> resource_manager = - CreateManager(max_textures); - scoped_ptr<PrioritizedResource> textures[max_textures]; - - for (size_t i = 0; i < max_textures; ++i) - textures[i] = - resource_manager->CreateTexture(texture_size_, texture_format_); - - textures[0]->set_request_priority( - PriorityCalculator::AllowVisibleOnlyCutoff() - 1); - textures[1]-> - set_request_priority(PriorityCalculator::AllowVisibleOnlyCutoff()); - textures[2]->set_request_priority( - PriorityCalculator::AllowVisibleAndNearbyCutoff() - 1); - textures[3]->set_request_priority( - PriorityCalculator::AllowVisibleAndNearbyCutoff()); - textures[4]->set_request_priority( - PriorityCalculator::AllowVisibleAndNearbyCutoff() + 1); - - // Set max limit to 2 textures. - resource_manager->SetMaxMemoryLimitBytes(TexturesMemorySize(2)); - PrioritizeTexturesAndBackings(resource_manager.get()); - - // The first two textures should be available, others should not. - for (size_t i = 0; i < 2; ++i) - EXPECT_TRUE(ValidateTexture(textures[i], false)); - for (size_t i = 2; i < max_textures; ++i) - EXPECT_FALSE(ValidateTexture(textures[i], false)); - - // Validate the statistics. - { - DebugScopedSetImplThread impl_thread(&proxy_); - EXPECT_EQ(TexturesMemorySize(2), resource_manager->MemoryUseBytes()); - EXPECT_EQ(TexturesMemorySize(1), - resource_manager->MemoryVisibleBytes()); - EXPECT_EQ(TexturesMemorySize(3), - resource_manager->MemoryVisibleAndNearbyBytes()); - } - - // Re-prioritize the textures, but do not push the values to backings. - textures[0]->set_request_priority( - PriorityCalculator::AllowVisibleOnlyCutoff() - 1); - textures[1]->set_request_priority( - PriorityCalculator::AllowVisibleOnlyCutoff() - 1); - textures[2]->set_request_priority( - PriorityCalculator::AllowVisibleOnlyCutoff() - 1); - textures[3]->set_request_priority( - PriorityCalculator::AllowVisibleAndNearbyCutoff() - 1); - textures[4]->set_request_priority( - PriorityCalculator::AllowVisibleAndNearbyCutoff()); - resource_manager->PrioritizeTextures(); - - // Verify that we still see the old values. - { - DebugScopedSetImplThread impl_thread (& proxy_); - EXPECT_EQ(TexturesMemorySize(2), resource_manager->MemoryUseBytes()); - EXPECT_EQ(TexturesMemorySize(1), - resource_manager->MemoryVisibleBytes()); - EXPECT_EQ(TexturesMemorySize(3), - resource_manager->MemoryVisibleAndNearbyBytes()); - } - - // Push priorities to backings, and verify we see the new values. - { - DebugScopedSetImplThreadAndMainThreadBlocked - impl_thread_and_main_thread_blocked (& proxy_); - resource_manager->PushTexturePrioritiesToBackings(); - EXPECT_EQ(TexturesMemorySize(2), resource_manager->MemoryUseBytes()); - EXPECT_EQ(TexturesMemorySize(3), - resource_manager->MemoryVisibleBytes()); - EXPECT_EQ(TexturesMemorySize(4), - resource_manager->MemoryVisibleAndNearbyBytes()); - } + const size_t kMaxTextures = 5; + scoped_ptr<PrioritizedResourceManager> resource_manager = + CreateManager(kMaxTextures); + scoped_ptr<PrioritizedResource> textures[kMaxTextures]; + for (size_t i = 0; i < kMaxTextures; ++i) { + textures[i] = + resource_manager->CreateTexture(texture_size_, texture_format_); + } + + textures[0]-> + set_request_priority(PriorityCalculator::AllowVisibleOnlyCutoff() - 1); + textures[1]-> + set_request_priority(PriorityCalculator::AllowVisibleOnlyCutoff()); + textures[2]->set_request_priority( + PriorityCalculator::AllowVisibleAndNearbyCutoff() - 1); + textures[3]-> + set_request_priority(PriorityCalculator::AllowVisibleAndNearbyCutoff()); + textures[4]->set_request_priority( + PriorityCalculator::AllowVisibleAndNearbyCutoff() + 1); + + // Set max limit to 2 textures. + resource_manager->SetMaxMemoryLimitBytes(TexturesMemorySize(2)); + PrioritizeTexturesAndBackings(resource_manager.get()); + + // The first two textures should be available, others should not. + for (size_t i = 0; i < 2; ++i) + EXPECT_TRUE(ValidateTexture(textures[i].get(), false)); + for (size_t i = 2; i < kMaxTextures; ++i) + EXPECT_FALSE(ValidateTexture(textures[i].get(), false)); + + // Validate the statistics. + { + DebugScopedSetImplThread impl_thread(&proxy_); + EXPECT_EQ(TexturesMemorySize(2), resource_manager->MemoryUseBytes()); + EXPECT_EQ(TexturesMemorySize(1), resource_manager->MemoryVisibleBytes()); + EXPECT_EQ(TexturesMemorySize(3), + resource_manager->MemoryVisibleAndNearbyBytes()); + } + + // Re-prioritize the textures, but do not push the values to backings. + textures[0]-> + set_request_priority(PriorityCalculator::AllowVisibleOnlyCutoff() - 1); + textures[1]-> + set_request_priority(PriorityCalculator::AllowVisibleOnlyCutoff() - 1); + textures[2]-> + set_request_priority(PriorityCalculator::AllowVisibleOnlyCutoff() - 1); + textures[3]->set_request_priority( + PriorityCalculator::AllowVisibleAndNearbyCutoff() - 1); + textures[4]-> + set_request_priority(PriorityCalculator::AllowVisibleAndNearbyCutoff()); + resource_manager->PrioritizeTextures(); + + // Verify that we still see the old values. + { + DebugScopedSetImplThread impl_thread(&proxy_); + EXPECT_EQ(TexturesMemorySize(2), resource_manager->MemoryUseBytes()); + EXPECT_EQ(TexturesMemorySize(1), resource_manager->MemoryVisibleBytes()); + EXPECT_EQ(TexturesMemorySize(3), + resource_manager->MemoryVisibleAndNearbyBytes()); + } + + // Push priorities to backings, and verify we see the new values. + { DebugScopedSetImplThreadAndMainThreadBlocked - impl_thread_and_main_thread_blocked (& proxy_); - resource_manager->ClearAllMemory(ResourceProvider()); + impl_thread_and_main_thread_blocked(&proxy_); + resource_manager->PushTexturePrioritiesToBackings(); + EXPECT_EQ(TexturesMemorySize(2), resource_manager->MemoryUseBytes()); + EXPECT_EQ(TexturesMemorySize(3), resource_manager->MemoryVisibleBytes()); + EXPECT_EQ(TexturesMemorySize(4), + resource_manager->MemoryVisibleAndNearbyBytes()); + } + + DebugScopedSetImplThreadAndMainThreadBlocked + impl_thread_and_main_thread_blocked(&proxy_); + resource_manager->ClearAllMemory(ResourceProvider()); } } // namespace diff --git a/cc/resources/priority_calculator.cc b/cc/resources/priority_calculator.cc index aaeb6bb..bb9908d 100644 --- a/cc/resources/priority_calculator.cc +++ b/cc/resources/priority_calculator.cc @@ -4,6 +4,8 @@ #include "cc/resources/priority_calculator.h" +#include <algorithm> + #include "ui/gfx/rect.h" namespace cc { diff --git a/cc/resources/priority_calculator.h b/cc/resources/priority_calculator.h index 6ab54bd..2c940d8 100644 --- a/cc/resources/priority_calculator.h +++ b/cc/resources/priority_calculator.h @@ -36,6 +36,6 @@ class CC_EXPORT PriorityCalculator { static int AllowEverythingCutoff(); }; -} +} // namespace cc #endif // CC_RESOURCES_PRIORITY_CALCULATOR_H_ diff --git a/cc/resources/resource_pool.h b/cc/resources/resource_pool.h index f3ef9bb..f8f52ac 100644 --- a/cc/resources/resource_pool.h +++ b/cc/resources/resource_pool.h @@ -36,7 +36,7 @@ class CC_EXPORT ResourcePool { virtual ~ResourcePool(); - ResourceProvider* resource_provider() { return resource_provider_; }; + ResourceProvider* resource_provider() { return resource_provider_; } scoped_ptr<ResourcePool::Resource> AcquireResource( const gfx::Size&, GLenum format); @@ -45,7 +45,7 @@ class CC_EXPORT ResourcePool { void SetMaxMemoryUsageBytes(size_t max_memory_usage_bytes); protected: - ResourcePool(ResourceProvider* resource_provider); + explicit ResourcePool(ResourceProvider* resource_provider); private: ResourceProvider* resource_provider_; diff --git a/cc/resources/resource_provider.cc b/cc/resources/resource_provider.cc index d987251..e2b01e4 100644 --- a/cc/resources/resource_provider.cc +++ b/cc/resources/resource_provider.cc @@ -470,7 +470,7 @@ void ResourceProvider::UnlockForRead(ResourceId id) { ResourceMap::iterator it = resources_.find(id); CHECK(it != resources_.end()); Resource* resource = &it->second; - DCHECK(resource->lock_for_read_count > 0); + DCHECK_GT(resource->lock_for_read_count, 0); DCHECK(!resource->exported); resource->lock_for_read_count--; } @@ -1187,7 +1187,7 @@ void ResourceProvider::LazyAllocate(Resource* resource) { storage_format, size.width(), size.height())); - } else + } else { GLC(context3d, context3d->texImage2D(GL_TEXTURE_2D, 0, format, @@ -1197,6 +1197,7 @@ void ResourceProvider::LazyAllocate(Resource* resource) { format, GL_UNSIGNED_BYTE, NULL)); + } } void ResourceProvider::EnableReadLockFences(ResourceProvider::ResourceId id, diff --git a/cc/resources/resource_provider.h b/cc/resources/resource_provider.h index acd404f..e5001a0 100644 --- a/cc/resources/resource_provider.h +++ b/cc/resources/resource_provider.h @@ -395,6 +395,6 @@ class CC_EXPORT ResourceProvider { DISALLOW_COPY_AND_ASSIGN(ResourceProvider); }; -} +} // namespace cc #endif // CC_RESOURCES_RESOURCE_PROVIDER_H_ diff --git a/cc/resources/resource_provider_unittest.cc b/cc/resources/resource_provider_unittest.cc index cb431ab..6a5ea23 100644 --- a/cc/resources/resource_provider_unittest.cc +++ b/cc/resources/resource_provider_unittest.cc @@ -4,6 +4,8 @@ #include "cc/resources/resource_provider.h" +#include <algorithm> + #include "base/bind.h" #include "base/logging.h" #include "cc/base/scoped_ptr_deque.h" @@ -19,13 +21,17 @@ #include "third_party/khronos/GLES2/gl2ext.h" #include "ui/gfx/rect.h" -using namespace WebKit; - using testing::Mock; using testing::NiceMock; using testing::Return; using testing::StrictMock; using testing::_; +using WebKit::WGC3Dbyte; +using WebKit::WGC3Denum; +using WebKit::WGC3Dint; +using WebKit::WGC3Dsizei; +using WebKit::WGC3Duint; +using WebKit::WebGLId; namespace cc { namespace { @@ -323,8 +329,8 @@ class ResourceProviderContext : public TestWebGraphicsContext3D { PendingProduceTextureList pending_produce_textures_; }; -class ResourceProviderTest : - public testing::TestWithParam<ResourceProvider::ResourceType> { +class ResourceProviderTest + : public testing::TestWithParam<ResourceProvider::ResourceType> { public: ResourceProviderTest() : shared_data_(ContextSharedData::Create()), diff --git a/cc/resources/resource_update.h b/cc/resources/resource_update.h index caf63d9..c531bf7 100644 --- a/cc/resources/resource_update.h +++ b/cc/resources/resource_update.h @@ -39,6 +39,6 @@ struct CC_EXPORT ResourceUpdate { gfx::Vector2d dest_offset; }; -} +} // namespace cc #endif // CC_RESOURCES_RESOURCE_UPDATE_H_ diff --git a/cc/resources/resource_update_controller_unittest.cc b/cc/resources/resource_update_controller_unittest.cc index bb6114b..c4a8ee75 100644 --- a/cc/resources/resource_update_controller_unittest.cc +++ b/cc/resources/resource_update_controller_unittest.cc @@ -14,8 +14,13 @@ #include "testing/gtest/include/gtest/gtest.h" #include "third_party/khronos/GLES2/gl2ext.h" -using namespace WebKit; using testing::Test; +using WebKit::WGC3Denum; +using WebKit::WGC3Dint; +using WebKit::WGC3Duint; +using WebKit::WGC3Dsizei; +using WebKit::WebGLId; +using WebKit::WebString; namespace cc { namespace { @@ -27,7 +32,7 @@ class ResourceUpdateControllerTest; class WebGraphicsContext3DForUploadTest : public TestWebGraphicsContext3D { public: - WebGraphicsContext3DForUploadTest(ResourceUpdateControllerTest* test) + explicit WebGraphicsContext3DForUploadTest(ResourceUpdateControllerTest* test) : test_(test), support_shallow_flush_(true) {} @@ -320,8 +325,8 @@ TEST_F(ResourceUpdateControllerTest, ManyFullManyPartialUploads) { << "Last upload wasn't followed by a flush."; } -class FakeResourceUpdateControllerClient : - public cc::ResourceUpdateControllerClient { +class FakeResourceUpdateControllerClient + : public cc::ResourceUpdateControllerClient { public: FakeResourceUpdateControllerClient() { Reset(); } void Reset() { ready_to_finalize_called_ = false; } diff --git a/cc/resources/resource_update_queue.h b/cc/resources/resource_update_queue.h index 45a983a..9ed3266 100644 --- a/cc/resources/resource_update_queue.h +++ b/cc/resources/resource_update_queue.h @@ -43,6 +43,6 @@ class CC_EXPORT ResourceUpdateQueue { DISALLOW_COPY_AND_ASSIGN(ResourceUpdateQueue); }; -} +} // namespace cc #endif // CC_RESOURCES_RESOURCE_UPDATE_QUEUE_H_ diff --git a/cc/resources/scoped_resource.h b/cc/resources/scoped_resource.h index f6151b6..576b1f8 100644 --- a/cc/resources/scoped_resource.h +++ b/cc/resources/scoped_resource.h @@ -31,7 +31,7 @@ class CC_EXPORT ScopedResource : public Resource { void Leak(); protected: - explicit ScopedResource(ResourceProvider*); + explicit ScopedResource(ResourceProvider* provider); private: ResourceProvider* resource_provider_; @@ -43,6 +43,6 @@ class CC_EXPORT ScopedResource : public Resource { DISALLOW_COPY_AND_ASSIGN(ScopedResource); }; -} +} // namespace cc #endif // CC_RESOURCES_SCOPED_RESOURCE_H_ diff --git a/cc/resources/scoped_resource_unittest.cc b/cc/resources/scoped_resource_unittest.cc index b1c2a62..a9a087e 100644 --- a/cc/resources/scoped_resource_unittest.cc +++ b/cc/resources/scoped_resource_unittest.cc @@ -10,8 +10,6 @@ #include "testing/gtest/include/gtest/gtest.h" #include "third_party/khronos/GLES2/gl2.h" -using namespace WebKit; - namespace cc { namespace { diff --git a/cc/resources/tile.h b/cc/resources/tile.h index 904eb0b..40acb5b 100644 --- a/cc/resources/tile.h +++ b/cc/resources/tile.h @@ -63,8 +63,8 @@ class CC_EXPORT Tile : public base::RefCounted<Tile> { int layer_id() const { return layer_id_; } void set_picture_pile(scoped_refptr<PicturePileImpl> pile) { - DCHECK(pile->CanRaster(contents_scale_, content_rect_)); - picture_pile_ = pile; + DCHECK(pile->CanRaster(contents_scale_, content_rect_)); + picture_pile_ = pile; } private: diff --git a/cc/resources/tile_manager.cc b/cc/resources/tile_manager.cc index dce46b4..3b569ec 100644 --- a/cc/resources/tile_manager.cc +++ b/cc/resources/tile_manager.cc @@ -5,6 +5,7 @@ #include "cc/resources/tile_manager.h" #include <algorithm> +#include <string> #include "base/bind.h" #include "base/debug/trace_event.h" @@ -646,8 +647,8 @@ void TileManager::DispatchMoreTasks() { // need to process those tiles first before we start to handle the tiles // in the need_to_be_rasterized queue. Note that solid/transparent tiles // will not be put into the decoding list. - for(TileList::iterator it = tiles_with_image_decoding_tasks_.begin(); - it != tiles_with_image_decoding_tasks_.end(); ) { + for (TileList::iterator it = tiles_with_image_decoding_tasks_.begin(); + it != tiles_with_image_decoding_tasks_.end(); ) { ManagedTileState& managed_tile_state = (*it)->managed_state(); DispatchImageDecodeTasksForTile(*it); if (managed_tile_state.pending_pixel_refs.empty()) { @@ -1051,7 +1052,7 @@ void TileManager::RecordSolidColorPredictorResults( if (SkColorGetA(current_color) != 0) is_transparent = false; - if(!is_actually_solid && !is_transparent) + if (!is_actually_solid && !is_transparent) break; } diff --git a/cc/resources/tile_manager.h b/cc/resources/tile_manager.h index 83223b2..105d2d6 100644 --- a/cc/resources/tile_manager.h +++ b/cc/resources/tile_manager.h @@ -38,10 +38,10 @@ class CC_EXPORT TileManagerClient { // Tile manager classifying tiles into a few basic // bins: enum TileManagerBin { - NOW_BIN = 0, // Needed ASAP. - SOON_BIN = 1, // Impl-side version of prepainting. - EVENTUALLY_BIN = 2, // Nice to have, if we've got memory and time. - NEVER_BIN = 3, // Dont bother. + NOW_BIN = 0, // Needed ASAP. + SOON_BIN = 1, // Impl-side version of prepainting. + EVENTUALLY_BIN = 2, // Nice to have, if we've got memory and time. + NEVER_BIN = 3, // Dont bother. NUM_BINS = 4 // Be sure to update TileManagerBinAsValue when adding new fields. }; @@ -120,7 +120,6 @@ class CC_EXPORT TileManager : public WorkerPoolClient { } private: - // Data that is passed to raster tasks. struct RasterTaskMetadata { bool prediction_benchmarking; diff --git a/cc/resources/tile_priority.cc b/cc/resources/tile_priority.cc index e25b61e..d1c3fbf 100644 --- a/cc/resources/tile_priority.cc +++ b/cc/resources/tile_priority.cc @@ -30,24 +30,24 @@ bool Range::IsEmpty() { return start_ >= end_; } -inline void IntersectNegativeHalfplane(Range& out, float previous, +inline void IntersectNegativeHalfplane(Range* out, float previous, float current, float target, float time_delta) { float time_per_dist = time_delta / (current - previous); float t = (target - current) * time_per_dist; if (time_per_dist > 0.0f) - out.start_ = std::max(out.start_, t); + out->start_ = std::max(out->start_, t); else - out.end_ = std::min(out.end_, t); + out->end_ = std::min(out->end_, t); } -inline void IntersectPositiveHalfplane(Range& out, float previous, +inline void IntersectPositiveHalfplane(Range* out, float previous, float current, float target, float time_delta) { float time_per_dist = time_delta / (current - previous); float t = (target - current) * time_per_dist; if (time_per_dist < 0.0f) - out.start_ = std::max(out.start_, t); + out->start_ = std::max(out->start_, t); else - out.end_ = std::min(out.end_, t); + out->end_ = std::min(out->end_, t); } } // namespace @@ -132,16 +132,16 @@ float TilePriority::TimeForBoundsToIntersect(const gfx::RectF& previous_bounds, // each other during that period of time. Range range(0.0f, kMaxTimeToVisibleInSeconds); IntersectPositiveHalfplane( - range, previous_bounds.x(), current_bounds.x(), + &range, previous_bounds.x(), current_bounds.x(), target_bounds.right(), time_delta); IntersectNegativeHalfplane( - range, previous_bounds.right(), current_bounds.right(), + &range, previous_bounds.right(), current_bounds.right(), target_bounds.x(), time_delta); IntersectPositiveHalfplane( - range, previous_bounds.y(), current_bounds.y(), + &range, previous_bounds.y(), current_bounds.y(), target_bounds.bottom(), time_delta); IntersectNegativeHalfplane( - range, previous_bounds.bottom(), current_bounds.bottom(), + &range, previous_bounds.bottom(), current_bounds.bottom(), target_bounds.y(), time_delta); return range.IsEmpty() ? kMaxTimeToVisibleInSeconds : range.start_; } diff --git a/cc/resources/tile_priority.h b/cc/resources/tile_priority.h index a9558ef..d14f311 100644 --- a/cc/resources/tile_priority.h +++ b/cc/resources/tile_priority.h @@ -5,6 +5,7 @@ #ifndef CC_RESOURCES_TILE_PRIORITY_H_ #define CC_RESOURCES_TILE_PRIORITY_H_ +#include <algorithm> #include <limits> #include "base/memory/ref_counted.h" @@ -151,13 +152,13 @@ enum TileMemoryLimitPolicy { ALLOW_NOTHING, // You might be made visible, but you're not being interacted with. - ALLOW_ABSOLUTE_MINIMUM, // Tall. + ALLOW_ABSOLUTE_MINIMUM, // Tall. // You're being interacted with, but we're low on memory. - ALLOW_PREPAINT_ONLY, // Grande. + ALLOW_PREPAINT_ONLY, // Grande. // You're the only thing in town. Go crazy. - ALLOW_ANYTHING, // Venti. + ALLOW_ANYTHING, // Venti. // Be sure to update TreePriorityAsValue when adding new fields. }; |