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

Side by Side Diff: third_party/WebKit/Source/platform/Timer.h

Issue 2191533003: Refactor Timer classes in preparation for landing FrameTimers. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 4 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
OLDNEW
1 /* 1 /*
2 * Copyright (C) 2006 Apple Computer, Inc. All rights reserved. 2 * Copyright (C) 2006 Apple Computer, Inc. All rights reserved.
3 * 3 *
4 * Redistribution and use in source and binary forms, with or without 4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions 5 * modification, are permitted provided that the following conditions
6 * are met: 6 * are met:
7 * 1. Redistributions of source code must retain the above copyright 7 * 1. Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer. 8 * notice, this list of conditions and the following disclaimer.
9 * 2. Redistributions in binary form must reproduce the above copyright 9 * 2. Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the 10 * notice, this list of conditions and the following disclaimer in the
(...skipping 26 matching lines...) Expand all
37 #include "wtf/Threading.h" 37 #include "wtf/Threading.h"
38 #include "wtf/Vector.h" 38 #include "wtf/Vector.h"
39 39
40 namespace blink { 40 namespace blink {
41 41
42 // Time intervals are all in seconds. 42 // Time intervals are all in seconds.
43 43
44 class PLATFORM_EXPORT TimerBase { 44 class PLATFORM_EXPORT TimerBase {
45 WTF_MAKE_NONCOPYABLE(TimerBase); 45 WTF_MAKE_NONCOPYABLE(TimerBase);
46 public: 46 public:
47 TimerBase();
dcheng 2016/07/28 13:09:51 This was only used by three subclasses: Suspendabl
haraken 2016/07/28 14:44:46 I believe that SuspendableTImer was intentionally
haraken 2016/07/28 17:38:15 So, ignore this comment.
dcheng 2016/07/29 02:23:18 !!! I made a mistake. I changed SuspendableTimer t
48 explicit TimerBase(WebTaskRunner*); 47 explicit TimerBase(WebTaskRunner*);
49 virtual ~TimerBase(); 48 virtual ~TimerBase();
50 49
51 void start(double nextFireInterval, double repeatInterval, const WebTraceLoc ation&); 50 void start(double nextFireInterval, double repeatInterval, const WebTraceLoc ation&);
52 51
53 void startRepeating(double repeatInterval, const WebTraceLocation& caller) 52 void startRepeating(double repeatInterval, const WebTraceLocation& caller)
54 { 53 {
55 start(repeatInterval, repeatInterval, caller); 54 start(repeatInterval, repeatInterval, caller);
56 } 55 }
57 void startOneShot(double interval, const WebTraceLocation& caller) 56 void startOneShot(double interval, const WebTraceLocation& caller)
(...skipping 12 matching lines...) Expand all
70 double now = timerMonotonicallyIncreasingTime(); 69 double now = timerMonotonicallyIncreasingTime();
71 setNextFireTime(now, std::max(m_nextFireTime - now + delta, 0.0)); 70 setNextFireTime(now, std::max(m_nextFireTime - now + delta, 0.0));
72 m_repeatInterval += delta; 71 m_repeatInterval += delta;
73 } 72 }
74 73
75 struct PLATFORM_EXPORT Comparator { 74 struct PLATFORM_EXPORT Comparator {
76 bool operator()(const TimerBase* a, const TimerBase* b) const; 75 bool operator()(const TimerBase* a, const TimerBase* b) const;
77 }; 76 };
78 77
79 protected: 78 protected:
80 static WebTaskRunner* UnthrottledWebTaskRunner(); 79 static WebTaskRunner* getTimerTaskRunner();
80 static WebTaskRunner* getDefaultTaskRunner();
81 81
82 private: 82 private:
83 virtual void fired() = 0; 83 virtual void fired() = 0;
84 84
85 virtual WebTaskRunner* timerTaskRunner() const; 85 virtual WebTaskRunner* timerTaskRunner() const;
86 86
87 NO_LAZY_SWEEP_SANITIZE_ADDRESS 87 NO_LAZY_SWEEP_SANITIZE_ADDRESS
88 virtual bool canFire() const { return true; } 88 virtual bool canFire() const { return true; }
89 89
90 double timerMonotonicallyIncreasingTime() const; 90 double timerMonotonicallyIncreasingTime() const;
(...skipping 57 matching lines...) Expand 10 before | Expand all | Expand 10 after
148 template<typename T> 148 template<typename T>
149 class TimerIsObjectAliveTrait<T, true> { 149 class TimerIsObjectAliveTrait<T, true> {
150 public: 150 public:
151 static bool isHeapObjectAlive(T* objectPointer) 151 static bool isHeapObjectAlive(T* objectPointer)
152 { 152 {
153 return !ThreadHeap::willObjectBeLazilySwept(objectPointer); 153 return !ThreadHeap::willObjectBeLazilySwept(objectPointer);
154 } 154 }
155 }; 155 };
156 156
157 template <typename TimerFiredClass> 157 template <typename TimerFiredClass>
158 class Timer : public TimerBase { 158 class TaskRunnerTimer : public TimerBase {
159 public: 159 public:
160 using TimerFiredFunction = void (TimerFiredClass::*)(Timer<TimerFiredClass>* ); 160 using TimerFiredFunction = void (TimerFiredClass::*)(TimerBase*);
161 161
162 // TODO(dcheng): Consider removing this overload once all timers are using t he 162 TaskRunnerTimer(WebTaskRunner* webTaskRunner, TimerFiredClass* o, TimerFired Function f)
163 // appropriate task runner. https://crbug.com/624694
164 Timer(TimerFiredClass* o, TimerFiredFunction f)
165 : m_object(o), m_function(f)
166 {
167 }
168
169 Timer(TimerFiredClass* o, TimerFiredFunction f, WebTaskRunner* webTaskRunner )
170 : TimerBase(webTaskRunner), m_object(o), m_function(f) 163 : TimerBase(webTaskRunner), m_object(o), m_function(f)
171 { 164 {
172 } 165 }
173 166
174 ~Timer() override { } 167 ~TaskRunnerTimer() override { }
175 168
176 protected: 169 protected:
177 void fired() override 170 void fired() override
178 { 171 {
179 (m_object->*m_function)(this); 172 (m_object->*m_function)(this);
180 } 173 }
181 174
182 NO_LAZY_SWEEP_SANITIZE_ADDRESS 175 NO_LAZY_SWEEP_SANITIZE_ADDRESS
183 bool canFire() const override 176 bool canFire() const override
184 { 177 {
185 // Oilpan: if a timer fires while Oilpan heaps are being lazily 178 // Oilpan: if a timer fires while Oilpan heaps are being lazily
186 // swept, it is not safe to proceed if the object is about to 179 // swept, it is not safe to proceed if the object is about to
187 // be swept (and this timer will be stopped while doing so.) 180 // be swept (and this timer will be stopped while doing so.)
188 return TimerIsObjectAliveTrait<TimerFiredClass>::isHeapObjectAlive(m_obj ect); 181 return TimerIsObjectAliveTrait<TimerFiredClass>::isHeapObjectAlive(m_obj ect);
189 } 182 }
190 183
191 private: 184 private:
192 // FIXME: Oilpan: TimerBase should be moved to the heap and m_object should be traced. 185 // FIXME: Oilpan: TimerBase should be moved to the heap and m_object should be traced.
193 // This raw pointer is safe as long as Timer<X> is held by the X itself (Tha t's the case 186 // This raw pointer is safe as long as Timer<X> is held by the X itself (Tha t's the case
194 // in the current code base). 187 // in the current code base).
195 GC_PLUGIN_IGNORE("363031") 188 GC_PLUGIN_IGNORE("363031")
196 TimerFiredClass* m_object; 189 TimerFiredClass* m_object;
197 TimerFiredFunction m_function; 190 TimerFiredFunction m_function;
198 }; 191 };
199 192
193 // TODO(dcheng): Consider removing this overload once all timers are using the
194 // appropriate task runner. https://crbug.com/624694
195 template <typename TimerFiredClass>
196 class Timer : public TaskRunnerTimer<TimerFiredClass> {
197 public:
198 using TimerFiredFunction = typename TaskRunnerTimer<TimerFiredClass>::TimerF iredFunction;
dcheng 2016/07/28 13:09:51 I switched these to using type aliases, because it
199
200 ~Timer() override { }
201
202 Timer(TimerFiredClass* timerFiredClass, TimerFiredFunction timerFiredFunctio n)
203 : TaskRunnerTimer<TimerFiredClass>(TimerBase::getTimerTaskRunner(), time rFiredClass, timerFiredFunction)
204 {
205 }
206 };
207
208
200 // This subclass of Timer posts its tasks on the current thread's default task r unner. 209 // This subclass of Timer posts its tasks on the current thread's default task r unner.
201 // Tasks posted on there are not throttled when the tab is in the background. 210 // Tasks posted on there are not throttled when the tab is in the background.
202 template <typename TimerFiredClass> 211 template <typename TimerFiredClass>
203 class UnthrottledTimer : public Timer<TimerFiredClass> { 212 class UnthrottledThreadTimer : public TaskRunnerTimer<TimerFiredClass> {
204 public: 213 public:
205 using TimerFiredFunction = void (TimerFiredClass::*)(Timer<TimerFiredClass>* ); 214 using TimerFiredFunction = typename TaskRunnerTimer<TimerFiredClass>::TimerF iredFunction;
206 215
207 ~UnthrottledTimer() override { } 216 ~UnthrottledThreadTimer() override { }
208 217
209 UnthrottledTimer(TimerFiredClass* timerFiredClass, TimerFiredFunction timerF iredFunction) 218 UnthrottledThreadTimer(TimerFiredClass* timerFiredClass, TimerFiredFunction timerFiredFunction)
210 : Timer<TimerFiredClass>(timerFiredClass, timerFiredFunction, TimerBase: :UnthrottledWebTaskRunner()) 219 : TaskRunnerTimer<TimerFiredClass>(TimerBase::getDefaultTaskRunner(), ti merFiredClass, timerFiredFunction)
211 { 220 {
212 } 221 }
213 }; 222 };
214 223
215 NO_LAZY_SWEEP_SANITIZE_ADDRESS 224 NO_LAZY_SWEEP_SANITIZE_ADDRESS
216 inline bool TimerBase::isActive() const 225 inline bool TimerBase::isActive() const
217 { 226 {
218 ASSERT(m_thread == currentThread()); 227 ASSERT(m_thread == currentThread());
219 return m_cancellableTimerTask; 228 return m_cancellableTimerTask;
220 } 229 }
221 230
222 } // namespace blink 231 } // namespace blink
223 232
224 #endif // Timer_h 233 #endif // Timer_h
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698