xref: /aosp_15_r20/external/cronet/base/time/tick_clock.h (revision 6777b5387eb2ff775bb5750e3f5d96f37fb7352b)
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