- add sources.
[platform/framework/web/crosswalk.git] / src / cc / scheduler / delay_based_time_source.h
1 // Copyright 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #ifndef CC_SCHEDULER_DELAY_BASED_TIME_SOURCE_H_
6 #define CC_SCHEDULER_DELAY_BASED_TIME_SOURCE_H_
7
8 #include "base/memory/weak_ptr.h"
9 #include "cc/base/cc_export.h"
10 #include "cc/scheduler/time_source.h"
11
12 namespace base { class SingleThreadTaskRunner; }
13
14 namespace cc {
15
16 // This timer implements a time source that achieves the specified interval
17 // in face of millisecond-precision delayed callbacks and random queueing
18 // delays. DelayBasedTimeSource uses base::TimeTicks::Now as its timebase.
19 class CC_EXPORT DelayBasedTimeSource : public TimeSource {
20  public:
21   static scoped_refptr<DelayBasedTimeSource> Create(
22       base::TimeDelta interval, base::SingleThreadTaskRunner* task_runner);
23
24   virtual void SetClient(TimeSourceClient* client) OVERRIDE;
25
26   // TimeSource implementation
27   virtual void SetTimebaseAndInterval(base::TimeTicks timebase,
28                                       base::TimeDelta interval) OVERRIDE;
29
30   virtual base::TimeTicks SetActive(bool active) OVERRIDE;
31   virtual bool Active() const OVERRIDE;
32
33   // Get the last and next tick times. nextTimeTime() returns null when
34   // inactive.
35   virtual base::TimeTicks LastTickTime() OVERRIDE;
36   virtual base::TimeTicks NextTickTime() OVERRIDE;
37
38   // Virtual for testing.
39   virtual base::TimeTicks Now() const;
40
41  protected:
42   DelayBasedTimeSource(base::TimeDelta interval,
43                        base::SingleThreadTaskRunner* task_runner);
44   virtual ~DelayBasedTimeSource();
45
46   base::TimeTicks NextTickTarget(base::TimeTicks now);
47   void PostNextTickTask(base::TimeTicks now);
48   void OnTimerFired();
49
50   struct Parameters {
51     Parameters(base::TimeDelta interval, base::TimeTicks tick_target)
52         : interval(interval), tick_target(tick_target) {}
53     base::TimeDelta interval;
54     base::TimeTicks tick_target;
55   };
56
57   TimeSourceClient* client_;
58   base::TimeTicks last_tick_time_;
59
60   // current_parameters_ should only be written by PostNextTickTask.
61   // next_parameters_ will take effect on the next call to PostNextTickTask.
62   // Maintaining a pending set of parameters allows NextTickTime() to always
63   // reflect the actual time we expect OnTimerFired to be called.
64   Parameters current_parameters_;
65   Parameters next_parameters_;
66
67   bool active_;
68
69   base::SingleThreadTaskRunner* task_runner_;
70   base::WeakPtrFactory<DelayBasedTimeSource> weak_factory_;
71
72  private:
73   DISALLOW_COPY_AND_ASSIGN(DelayBasedTimeSource);
74 };
75
76 // DelayBasedTimeSource uses base::TimeTicks::HighResNow as its timebase.
77 class DelayBasedTimeSourceHighRes : public DelayBasedTimeSource {
78  public:
79   static scoped_refptr<DelayBasedTimeSourceHighRes> Create(
80         base::TimeDelta interval, base::SingleThreadTaskRunner* task_runner);
81
82   virtual base::TimeTicks Now() const OVERRIDE;
83
84  protected:
85   DelayBasedTimeSourceHighRes(base::TimeDelta interval,
86                               base::SingleThreadTaskRunner* task_runner);
87   virtual ~DelayBasedTimeSourceHighRes();
88
89  private:
90   DISALLOW_COPY_AND_ASSIGN(DelayBasedTimeSourceHighRes);
91 };
92
93 }  // namespace cc
94
95 #endif  // CC_SCHEDULER_DELAY_BASED_TIME_SOURCE_H_