xref: /aosp_15_r20/external/federated-compute/fcp/base/simulated_clock.h (revision 14675a029014e728ec732f129a32e299b2da0601)
1*14675a02SAndroid Build Coastguard Worker /*
2*14675a02SAndroid Build Coastguard Worker  * Copyright 2020 Google LLC
3*14675a02SAndroid Build Coastguard Worker  *
4*14675a02SAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*14675a02SAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*14675a02SAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*14675a02SAndroid Build Coastguard Worker  *
8*14675a02SAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*14675a02SAndroid Build Coastguard Worker  *
10*14675a02SAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*14675a02SAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*14675a02SAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*14675a02SAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*14675a02SAndroid Build Coastguard Worker  * limitations under the License.
15*14675a02SAndroid Build Coastguard Worker  */
16*14675a02SAndroid Build Coastguard Worker 
17*14675a02SAndroid Build Coastguard Worker #ifndef FCP_BASE_SIMULATED_CLOCK_H_
18*14675a02SAndroid Build Coastguard Worker #define FCP_BASE_SIMULATED_CLOCK_H_
19*14675a02SAndroid Build Coastguard Worker 
20*14675a02SAndroid Build Coastguard Worker #include "fcp/base/clock.h"
21*14675a02SAndroid Build Coastguard Worker 
22*14675a02SAndroid Build Coastguard Worker namespace fcp {
23*14675a02SAndroid Build Coastguard Worker 
24*14675a02SAndroid Build Coastguard Worker /*
25*14675a02SAndroid Build Coastguard Worker  * A simulated clock is a concrete Clock implementation that does not "tick"
26*14675a02SAndroid Build Coastguard Worker  * on its own.  Time is advanced by explicit calls to the AdvanceTime() or
27*14675a02SAndroid Build Coastguard Worker  * SetTime() functions.
28*14675a02SAndroid Build Coastguard Worker  */
29*14675a02SAndroid Build Coastguard Worker class SimulatedClock : public Clock {
30*14675a02SAndroid Build Coastguard Worker  public:
31*14675a02SAndroid Build Coastguard Worker   // Construct SimulatedClock with a specific initial time.
SimulatedClock(absl::Time t)32*14675a02SAndroid Build Coastguard Worker   explicit SimulatedClock(absl::Time t) : now_(t) {}
33*14675a02SAndroid Build Coastguard Worker 
34*14675a02SAndroid Build Coastguard Worker   // Construct SimulatedClock with default initial time (1970-01-01 00:00:00)
SimulatedClock()35*14675a02SAndroid Build Coastguard Worker   SimulatedClock() : SimulatedClock(absl::UnixEpoch()) {}
36*14675a02SAndroid Build Coastguard Worker 
37*14675a02SAndroid Build Coastguard Worker   // Returns the simulated time.
38*14675a02SAndroid Build Coastguard Worker   absl::Time Now() override;
39*14675a02SAndroid Build Coastguard Worker 
40*14675a02SAndroid Build Coastguard Worker   // Sleeps until the specified duration has elapsed according to this clock.
41*14675a02SAndroid Build Coastguard Worker   void Sleep(absl::Duration d) override;
42*14675a02SAndroid Build Coastguard Worker 
43*14675a02SAndroid Build Coastguard Worker   // Sets the simulated time. Wakes up any waiters whose deadlines have now
44*14675a02SAndroid Build Coastguard Worker   // expired.
45*14675a02SAndroid Build Coastguard Worker   void SetTime(absl::Time t);
46*14675a02SAndroid Build Coastguard Worker 
47*14675a02SAndroid Build Coastguard Worker   // Advances the simulated time. Wakes up any waiters whose deadlines have now
48*14675a02SAndroid Build Coastguard Worker   // expired.
49*14675a02SAndroid Build Coastguard Worker   void AdvanceTime(absl::Duration d);
50*14675a02SAndroid Build Coastguard Worker 
51*14675a02SAndroid Build Coastguard Worker  private:
52*14675a02SAndroid Build Coastguard Worker   // Returns the simulated time (called internally from the base class).
53*14675a02SAndroid Build Coastguard Worker   absl::Time NowLocked() override;
54*14675a02SAndroid Build Coastguard Worker 
55*14675a02SAndroid Build Coastguard Worker   // No specific scheduling is needed for SimulatedClock.
ScheduleWakeup(absl::Time wakeup_time)56*14675a02SAndroid Build Coastguard Worker   void ScheduleWakeup(absl::Time wakeup_time) override {}
57*14675a02SAndroid Build Coastguard Worker 
58*14675a02SAndroid Build Coastguard Worker   absl::Time now_ ABSL_GUARDED_BY(mutex());
59*14675a02SAndroid Build Coastguard Worker };
60*14675a02SAndroid Build Coastguard Worker 
61*14675a02SAndroid Build Coastguard Worker }  // namespace fcp
62*14675a02SAndroid Build Coastguard Worker 
63*14675a02SAndroid Build Coastguard Worker #endif  // FCP_BASE_SIMULATED_CLOCK_H_
64