xref: /aosp_15_r20/external/cronet/base/time/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_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