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

Side by Side Diff: cc/resources/direct_raster_worker_pool.h

Issue 228173002: cc: Separate RasterWorkerPool interface from implementation details. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: address review feedback Created 6 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « cc/cc.gyp ('k') | cc/resources/direct_raster_worker_pool.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef CC_RESOURCES_DIRECT_RASTER_WORKER_POOL_H_ 5 #ifndef CC_RESOURCES_DIRECT_RASTER_WORKER_POOL_H_
6 #define CC_RESOURCES_DIRECT_RASTER_WORKER_POOL_H_ 6 #define CC_RESOURCES_DIRECT_RASTER_WORKER_POOL_H_
7 7
8 #include "base/memory/weak_ptr.h" 8 #include "base/memory/weak_ptr.h"
9 #include "cc/resources/raster_worker_pool.h" 9 #include "cc/resources/raster_worker_pool.h"
10 #include "cc/resources/rasterizer.h"
10 11
11 namespace cc { 12 namespace cc {
12 class ContextProvider; 13 class ContextProvider;
13 class ResourceProvider; 14 class ResourceProvider;
14 15
15 class CC_EXPORT DirectRasterWorkerPool : public RasterWorkerPool, 16 class CC_EXPORT DirectRasterWorkerPool : public RasterWorkerPool,
16 public internal::WorkerPoolTaskClient { 17 public Rasterizer,
18 public internal::RasterizerTaskClient {
17 public: 19 public:
18 virtual ~DirectRasterWorkerPool(); 20 virtual ~DirectRasterWorkerPool();
19 21
20 static scoped_ptr<DirectRasterWorkerPool> Create( 22 static scoped_ptr<RasterWorkerPool> Create(
21 base::SequencedTaskRunner* task_runner, 23 base::SequencedTaskRunner* task_runner,
22 ResourceProvider* resource_provider, 24 ResourceProvider* resource_provider,
23 ContextProvider* context_provider); 25 ContextProvider* context_provider);
24 26
25 // Overridden from RasterWorkerPool: 27 // Overridden from RasterWorkerPool:
26 virtual void SetClient(RasterWorkerPoolClient* client) OVERRIDE; 28 virtual Rasterizer* AsRasterizer() OVERRIDE;
29
30 // Overridden from Rasterizer:
31 virtual void SetClient(RasterizerClient* client) OVERRIDE;
27 virtual void Shutdown() OVERRIDE {} 32 virtual void Shutdown() OVERRIDE {}
28 virtual void ScheduleTasks(RasterTaskQueue* queue) OVERRIDE; 33 virtual void ScheduleTasks(RasterTaskQueue* queue) OVERRIDE;
29 virtual unsigned GetResourceTarget() const OVERRIDE; 34 virtual unsigned GetResourceTarget() const OVERRIDE;
30 virtual ResourceFormat GetResourceFormat() const OVERRIDE; 35 virtual ResourceFormat GetResourceFormat() const OVERRIDE;
31 virtual void CheckForCompletedTasks() OVERRIDE; 36 virtual void CheckForCompletedTasks() OVERRIDE;
32 37
33 // Overridden from internal::WorkerPoolTaskClient: 38 // Overridden from internal::RasterizerTaskClient:
34 virtual SkCanvas* AcquireCanvasForRaster(internal::WorkerPoolTask* task, 39 virtual SkCanvas* AcquireCanvasForRaster(internal::RasterTask* task) OVERRIDE;
35 const Resource* resource) OVERRIDE; 40 virtual void ReleaseCanvasForRaster(internal::RasterTask* task) OVERRIDE;
36 virtual void ReleaseCanvasForRaster(internal::WorkerPoolTask* task,
37 const Resource* resource) OVERRIDE;
38 41
39 protected: 42 private:
40 DirectRasterWorkerPool(base::SequencedTaskRunner* task_runner, 43 DirectRasterWorkerPool(base::SequencedTaskRunner* task_runner,
41 ResourceProvider* resource_provider, 44 ResourceProvider* resource_provider,
42 ContextProvider* context_provider); 45 ContextProvider* context_provider);
43 46
44 private:
45 void OnRasterFinished(); 47 void OnRasterFinished();
46 void OnRasterRequiredForActivationFinished(); 48 void OnRasterRequiredForActivationFinished();
47 void ScheduleRunTasksOnOriginThread(); 49 void ScheduleRunTasksOnOriginThread();
48 void RunTasksOnOriginThread(); 50 void RunTasksOnOriginThread();
49 void RunTaskOnOriginThread(internal::WorkerPoolTask* task); 51 void RunTaskOnOriginThread(internal::RasterizerTask* task);
50 52
51 scoped_refptr<base::SequencedTaskRunner> task_runner_; 53 scoped_refptr<base::SequencedTaskRunner> task_runner_;
52 RasterWorkerPoolClient* client_; 54 RasterizerClient* client_;
53 ResourceProvider* resource_provider_; 55 ResourceProvider* resource_provider_;
54 ContextProvider* context_provider_; 56 ContextProvider* context_provider_;
55 57
56 bool run_tasks_on_origin_thread_pending_; 58 bool run_tasks_on_origin_thread_pending_;
57 59
58 RasterTaskQueue raster_tasks_; 60 RasterTaskQueue raster_tasks_;
59 61
60 bool raster_tasks_pending_; 62 bool raster_tasks_pending_;
61 bool raster_tasks_required_for_activation_pending_; 63 bool raster_tasks_required_for_activation_pending_;
62 64
63 base::WeakPtrFactory<DirectRasterWorkerPool> 65 base::WeakPtrFactory<DirectRasterWorkerPool>
64 raster_finished_weak_ptr_factory_; 66 raster_finished_weak_ptr_factory_;
65 67
66 scoped_refptr<internal::WorkerPoolTask> raster_finished_task_; 68 scoped_refptr<internal::RasterizerTask> raster_finished_task_;
67 scoped_refptr<internal::WorkerPoolTask> 69 scoped_refptr<internal::RasterizerTask>
68 raster_required_for_activation_finished_task_; 70 raster_required_for_activation_finished_task_;
69 71
70 internal::WorkerPoolTask::Vector completed_tasks_; 72 internal::RasterizerTask::Vector completed_tasks_;
71 73
72 base::WeakPtrFactory<DirectRasterWorkerPool> weak_ptr_factory_; 74 base::WeakPtrFactory<DirectRasterWorkerPool> weak_ptr_factory_;
73 75
74 DISALLOW_COPY_AND_ASSIGN(DirectRasterWorkerPool); 76 DISALLOW_COPY_AND_ASSIGN(DirectRasterWorkerPool);
75 }; 77 };
76 78
77 } // namespace cc 79 } // namespace cc
78 80
79 #endif // CC_RESOURCES_DIRECT_RASTER_WORKER_POOL_H_ 81 #endif // CC_RESOURCES_DIRECT_RASTER_WORKER_POOL_H_
OLDNEW
« no previous file with comments | « cc/cc.gyp ('k') | cc/resources/direct_raster_worker_pool.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698