1*6777b538SAndroid Build Coastguard Worker // Copyright 2012 The Chromium Authors 2*6777b538SAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be 3*6777b538SAndroid Build Coastguard Worker // found in the LICENSE file. 4*6777b538SAndroid Build Coastguard Worker 5*6777b538SAndroid Build Coastguard Worker #ifndef BASE_TIME_CLOCK_H_ 6*6777b538SAndroid Build Coastguard Worker #define BASE_TIME_CLOCK_H_ 7*6777b538SAndroid Build Coastguard Worker 8*6777b538SAndroid Build Coastguard Worker #include "base/base_export.h" 9*6777b538SAndroid Build Coastguard Worker #include "base/time/time.h" 10*6777b538SAndroid Build Coastguard Worker 11*6777b538SAndroid Build Coastguard Worker namespace base { 12*6777b538SAndroid Build Coastguard Worker 13*6777b538SAndroid Build Coastguard Worker // A Clock is an interface for objects that vend Times. It is 14*6777b538SAndroid Build Coastguard Worker // intended to be able to test the behavior of classes with respect to 15*6777b538SAndroid Build Coastguard Worker // time. 16*6777b538SAndroid Build Coastguard Worker // 17*6777b538SAndroid Build Coastguard Worker // See DefaultClock (base/time/default_clock.h) for the default 18*6777b538SAndroid Build Coastguard Worker // implementation that simply uses Time::Now(). 19*6777b538SAndroid Build Coastguard Worker // 20*6777b538SAndroid Build Coastguard Worker // (An implementation that uses Time::SystemTime() should be added as 21*6777b538SAndroid Build Coastguard Worker // needed.) 22*6777b538SAndroid Build Coastguard Worker // 23*6777b538SAndroid Build Coastguard Worker // See SimpleTestClock (base/test/simple_test_clock.h) for a simple 24*6777b538SAndroid Build Coastguard Worker // test implementation. 25*6777b538SAndroid Build Coastguard Worker // 26*6777b538SAndroid Build Coastguard Worker // See TickClock (base/time/tick_clock.h) for the equivalent interface for 27*6777b538SAndroid Build Coastguard Worker // TimeTicks. 28*6777b538SAndroid Build Coastguard Worker class BASE_EXPORT Clock { 29*6777b538SAndroid Build Coastguard Worker public: 30*6777b538SAndroid Build Coastguard Worker virtual ~Clock(); 31*6777b538SAndroid Build Coastguard Worker 32*6777b538SAndroid Build Coastguard Worker // Now() must be safe to call from any thread. The caller cannot 33*6777b538SAndroid Build Coastguard Worker // make any ordering assumptions about the returned Time. For 34*6777b538SAndroid Build Coastguard Worker // example, the system clock may change to an earlier time. 35*6777b538SAndroid Build Coastguard Worker virtual Time Now() const = 0; 36*6777b538SAndroid Build Coastguard Worker }; 37*6777b538SAndroid Build Coastguard Worker 38*6777b538SAndroid Build Coastguard Worker } // namespace base 39*6777b538SAndroid Build Coastguard Worker 40*6777b538SAndroid Build Coastguard Worker #endif // BASE_TIME_CLOCK_H_ 41