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_TICK_CLOCK_H_ 6*6777b538SAndroid Build Coastguard Worker #define BASE_TIME_TICK_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 TickClock is an interface for objects that vend TimeTicks. 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 // non-decreasing time. 16*6777b538SAndroid Build Coastguard Worker // 17*6777b538SAndroid Build Coastguard Worker // Note: Overriding Time/TimeTicks altogether via 18*6777b538SAndroid Build Coastguard Worker // TaskEnvironment::TimeSource::MOCK_TIME is now the preferred way of overriding 19*6777b538SAndroid Build Coastguard Worker // time in unit tests. As such, there shouldn't be many new use cases for 20*6777b538SAndroid Build Coastguard Worker // TickClock/DefaultTickClock anymore. 21*6777b538SAndroid Build Coastguard Worker // 22*6777b538SAndroid Build Coastguard Worker // See DefaultTickClock (base/time/default_tick_clock.h) for the default 23*6777b538SAndroid Build Coastguard Worker // implementation that simply uses TimeTicks::Now(). 24*6777b538SAndroid Build Coastguard Worker // 25*6777b538SAndroid Build Coastguard Worker // (Other implementations that use TimeTicks::NowFromSystemTime() should 26*6777b538SAndroid Build Coastguard Worker // be added as needed.) 27*6777b538SAndroid Build Coastguard Worker // 28*6777b538SAndroid Build Coastguard Worker // See SimpleTestTickClock (base/test/simple_test_tick_clock.h) for a 29*6777b538SAndroid Build Coastguard Worker // simple test implementation. 30*6777b538SAndroid Build Coastguard Worker // 31*6777b538SAndroid Build Coastguard Worker // See Clock (base/time/clock.h) for the equivalent interface for Times. 32*6777b538SAndroid Build Coastguard Worker class BASE_EXPORT TickClock { 33*6777b538SAndroid Build Coastguard Worker public: 34*6777b538SAndroid Build Coastguard Worker virtual ~TickClock(); 35*6777b538SAndroid Build Coastguard Worker 36*6777b538SAndroid Build Coastguard Worker // NowTicks() must be safe to call from any thread. The caller may 37*6777b538SAndroid Build Coastguard Worker // assume that NowTicks() is monotonic (but not strictly monotonic). 38*6777b538SAndroid Build Coastguard Worker // In other words, the returned TimeTicks will never decrease with 39*6777b538SAndroid Build Coastguard Worker // time, although they might "stand still". 40*6777b538SAndroid Build Coastguard Worker virtual TimeTicks NowTicks() const = 0; 41*6777b538SAndroid Build Coastguard Worker }; 42*6777b538SAndroid Build Coastguard Worker 43*6777b538SAndroid Build Coastguard Worker } // namespace base 44*6777b538SAndroid Build Coastguard Worker 45*6777b538SAndroid Build Coastguard Worker #endif // BASE_TIME_TICK_CLOCK_H_ 46