OLD | NEW |
1 // Copyright 2012 The Chromium Authors. All rights reserved. | 1 // Copyright 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "cc/test/fake_tile_manager.h" | 5 #include "cc/test/fake_tile_manager.h" |
6 | 6 |
7 #include <stddef.h> | 7 #include <stddef.h> |
8 #include <stdint.h> | 8 #include <stdint.h> |
9 | 9 |
10 #include <deque> | 10 #include <deque> |
11 #include <limits> | 11 #include <limits> |
12 | 12 |
13 #include "base/lazy_instance.h" | 13 #include "base/lazy_instance.h" |
14 #include "base/thread_task_runner_handle.h" | 14 #include "base/thread_task_runner_handle.h" |
15 #include "cc/raster/raster_buffer.h" | 15 #include "cc/raster/raster_buffer.h" |
16 #include "cc/raster/tile_task_runner.h" | 16 #include "cc/raster/tile_task_runner.h" |
17 | 17 |
18 namespace cc { | 18 namespace cc { |
19 | 19 |
20 namespace { | 20 namespace { |
21 | 21 |
22 class FakeTileTaskRunnerImpl : public TileTaskRunner, public TileTaskClient { | 22 class FakeTileTaskRunnerImpl : public TileTaskRunner, |
| 23 public DependencyTaskClient { |
23 public: | 24 public: |
24 // Overridden from TileTaskRunner: | 25 // Overridden from TileTaskRunner: |
25 void Shutdown() override {} | 26 void Shutdown() override {} |
26 void ScheduleTasks(TaskGraph* graph) override { | 27 void ScheduleTasks(TaskGraph* graph) override { |
27 for (const auto& node : graph->nodes) { | 28 for (const auto& node : graph->nodes) { |
28 RasterTask* task = static_cast<RasterTask*>(node.task); | 29 DependencyTask* task = node.task; |
29 | 30 |
30 task->WillSchedule(); | 31 task->WillSchedule(); |
31 task->ScheduleOnOriginThread(this); | 32 task->ScheduleOnOriginThread(this); |
32 task->DidSchedule(); | 33 task->DidSchedule(); |
33 | 34 |
34 completed_tasks_.push_back(task); | 35 completed_tasks_.push_back(task); |
35 } | 36 } |
36 } | 37 } |
37 void CheckForCompletedTasks() override { | 38 void CheckForCompletedTasks() override { |
38 for (RasterTask::Vector::iterator it = completed_tasks_.begin(); | 39 for (DependencyTask::Vector::iterator it = completed_tasks_.begin(); |
39 it != completed_tasks_.end(); | 40 it != completed_tasks_.end(); ++it) { |
40 ++it) { | 41 DependencyTask* task = it->get(); |
41 RasterTask* task = it->get(); | |
42 | 42 |
43 task->WillComplete(); | 43 task->WillComplete(); |
44 task->CompleteOnOriginThread(this); | 44 task->CompleteOnOriginThread(this); |
45 task->DidComplete(); | 45 task->DidComplete(); |
46 } | 46 } |
47 completed_tasks_.clear(); | 47 completed_tasks_.clear(); |
48 } | 48 } |
49 ResourceFormat GetResourceFormat(bool must_support_alpha) const override { | 49 ResourceFormat GetResourceFormat(bool must_support_alpha) const override { |
50 return RGBA_8888; | 50 return RGBA_8888; |
51 } | 51 } |
52 bool GetResourceRequiresSwizzle(bool must_support_alpha) const override { | 52 bool GetResourceRequiresSwizzle(bool must_support_alpha) const override { |
53 return ResourceFormatRequiresSwizzle(GetResourceFormat(must_support_alpha)); | 53 return ResourceFormatRequiresSwizzle(GetResourceFormat(must_support_alpha)); |
54 } | 54 } |
55 | 55 |
56 // Overridden from TileTaskClient: | 56 // Overridden from DependencyTaskClient: |
57 scoped_ptr<RasterBuffer> AcquireBufferForRaster( | 57 scoped_ptr<RasterBuffer> AcquireBufferForRaster( |
58 const Resource* resource, | 58 const Resource* resource, |
59 uint64_t resource_content_id, | 59 uint64_t resource_content_id, |
60 uint64_t previous_content_id) override { | 60 uint64_t previous_content_id) override { |
61 return nullptr; | 61 return nullptr; |
62 } | 62 } |
63 void ReleaseBufferForRaster(scoped_ptr<RasterBuffer> buffer) override {} | 63 void ReleaseBufferForRaster(scoped_ptr<RasterBuffer> buffer) override {} |
64 | 64 |
65 private: | 65 private: |
66 RasterTask::Vector completed_tasks_; | 66 DependencyTask::Vector completed_tasks_; |
67 }; | 67 }; |
68 base::LazyInstance<FakeTileTaskRunnerImpl> g_fake_tile_task_runner = | 68 base::LazyInstance<FakeTileTaskRunnerImpl> g_fake_tile_task_runner = |
69 LAZY_INSTANCE_INITIALIZER; | 69 LAZY_INSTANCE_INITIALIZER; |
70 | 70 |
71 } // namespace | 71 } // namespace |
72 | 72 |
73 FakeTileManager::FakeTileManager(TileManagerClient* client) | 73 FakeTileManager::FakeTileManager(TileManagerClient* client) |
74 : TileManager(client, | 74 : TileManager(client, |
75 base::ThreadTaskRunnerHandle::Get(), | 75 base::ThreadTaskRunnerHandle::Get(), |
76 std::numeric_limits<size_t>::max(), | 76 std::numeric_limits<size_t>::max(), |
(...skipping 23 matching lines...) Expand all Loading... |
100 } | 100 } |
101 | 101 |
102 void FakeTileManager::Release(Tile* tile) { | 102 void FakeTileManager::Release(Tile* tile) { |
103 TileManager::Release(tile); | 103 TileManager::Release(tile); |
104 | 104 |
105 FreeResourcesForReleasedTiles(); | 105 FreeResourcesForReleasedTiles(); |
106 CleanUpReleasedTiles(); | 106 CleanUpReleasedTiles(); |
107 } | 107 } |
108 | 108 |
109 } // namespace cc | 109 } // namespace cc |
OLD | NEW |