xref: /aosp_15_r20/external/grpc-grpc/include/grpcpp/support/time.h (revision cc02d7e222339f7a4f6ba5f422e6413f4bd931f2)
1*cc02d7e2SAndroid Build Coastguard Worker //
2*cc02d7e2SAndroid Build Coastguard Worker //
3*cc02d7e2SAndroid Build Coastguard Worker // Copyright 2015 gRPC authors.
4*cc02d7e2SAndroid Build Coastguard Worker //
5*cc02d7e2SAndroid Build Coastguard Worker // Licensed under the Apache License, Version 2.0 (the "License");
6*cc02d7e2SAndroid Build Coastguard Worker // you may not use this file except in compliance with the License.
7*cc02d7e2SAndroid Build Coastguard Worker // You may obtain a copy of the License at
8*cc02d7e2SAndroid Build Coastguard Worker //
9*cc02d7e2SAndroid Build Coastguard Worker //     http://www.apache.org/licenses/LICENSE-2.0
10*cc02d7e2SAndroid Build Coastguard Worker //
11*cc02d7e2SAndroid Build Coastguard Worker // Unless required by applicable law or agreed to in writing, software
12*cc02d7e2SAndroid Build Coastguard Worker // distributed under the License is distributed on an "AS IS" BASIS,
13*cc02d7e2SAndroid Build Coastguard Worker // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14*cc02d7e2SAndroid Build Coastguard Worker // See the License for the specific language governing permissions and
15*cc02d7e2SAndroid Build Coastguard Worker // limitations under the License.
16*cc02d7e2SAndroid Build Coastguard Worker //
17*cc02d7e2SAndroid Build Coastguard Worker //
18*cc02d7e2SAndroid Build Coastguard Worker 
19*cc02d7e2SAndroid Build Coastguard Worker #ifndef GRPCPP_SUPPORT_TIME_H
20*cc02d7e2SAndroid Build Coastguard Worker #define GRPCPP_SUPPORT_TIME_H
21*cc02d7e2SAndroid Build Coastguard Worker 
22*cc02d7e2SAndroid Build Coastguard Worker #include <chrono>
23*cc02d7e2SAndroid Build Coastguard Worker 
24*cc02d7e2SAndroid Build Coastguard Worker #include <grpc/impl/grpc_types.h>
25*cc02d7e2SAndroid Build Coastguard Worker #include <grpcpp/support/config.h>
26*cc02d7e2SAndroid Build Coastguard Worker 
27*cc02d7e2SAndroid Build Coastguard Worker namespace grpc {
28*cc02d7e2SAndroid Build Coastguard Worker 
29*cc02d7e2SAndroid Build Coastguard Worker /// If you are trying to use CompletionQueue::AsyncNext with a time class that
30*cc02d7e2SAndroid Build Coastguard Worker /// isn't either gpr_timespec or std::chrono::system_clock::time_point, you
31*cc02d7e2SAndroid Build Coastguard Worker /// will most likely be looking at this comment as your compiler will have
32*cc02d7e2SAndroid Build Coastguard Worker /// fired an error below. In order to fix this issue, you have two potential
33*cc02d7e2SAndroid Build Coastguard Worker /// solutions:
34*cc02d7e2SAndroid Build Coastguard Worker 
35*cc02d7e2SAndroid Build Coastguard Worker ///   1. Use gpr_timespec or std::chrono::system_clock::time_point instead
36*cc02d7e2SAndroid Build Coastguard Worker ///   2. Specialize the TimePoint class with whichever time class that you
37*cc02d7e2SAndroid Build Coastguard Worker ///      want to use here. See below for two examples of how to do this.
38*cc02d7e2SAndroid Build Coastguard Worker ///
39*cc02d7e2SAndroid Build Coastguard Worker template <typename T>
40*cc02d7e2SAndroid Build Coastguard Worker class TimePoint {
41*cc02d7e2SAndroid Build Coastguard Worker  public:
42*cc02d7e2SAndroid Build Coastguard Worker   // If you see the error with methods below, you may need either
43*cc02d7e2SAndroid Build Coastguard Worker   // i) using the existing types having a conversion class such as
44*cc02d7e2SAndroid Build Coastguard Worker   // gpr_timespec and std::chrono::system_clock::time_point or
45*cc02d7e2SAndroid Build Coastguard Worker   // ii) writing a new TimePoint<YourType> to address your case.
46*cc02d7e2SAndroid Build Coastguard Worker   TimePoint(const T& /*time*/) = delete;
47*cc02d7e2SAndroid Build Coastguard Worker   gpr_timespec raw_time() = delete;
48*cc02d7e2SAndroid Build Coastguard Worker };
49*cc02d7e2SAndroid Build Coastguard Worker 
50*cc02d7e2SAndroid Build Coastguard Worker template <>
51*cc02d7e2SAndroid Build Coastguard Worker class TimePoint<gpr_timespec> {
52*cc02d7e2SAndroid Build Coastguard Worker  public:
53*cc02d7e2SAndroid Build Coastguard Worker   // NOLINTNEXTLINE(google-explicit-constructor)
TimePoint(const gpr_timespec & time)54*cc02d7e2SAndroid Build Coastguard Worker   TimePoint(const gpr_timespec& time) : time_(time) {}
raw_time()55*cc02d7e2SAndroid Build Coastguard Worker   gpr_timespec raw_time() { return time_; }
56*cc02d7e2SAndroid Build Coastguard Worker 
57*cc02d7e2SAndroid Build Coastguard Worker  private:
58*cc02d7e2SAndroid Build Coastguard Worker   gpr_timespec time_;
59*cc02d7e2SAndroid Build Coastguard Worker };
60*cc02d7e2SAndroid Build Coastguard Worker 
61*cc02d7e2SAndroid Build Coastguard Worker }  // namespace grpc
62*cc02d7e2SAndroid Build Coastguard Worker 
63*cc02d7e2SAndroid Build Coastguard Worker namespace grpc {
64*cc02d7e2SAndroid Build Coastguard Worker 
65*cc02d7e2SAndroid Build Coastguard Worker // from and to should be absolute time.
66*cc02d7e2SAndroid Build Coastguard Worker void Timepoint2Timespec(const std::chrono::system_clock::time_point& from,
67*cc02d7e2SAndroid Build Coastguard Worker                         gpr_timespec* to);
68*cc02d7e2SAndroid Build Coastguard Worker void TimepointHR2Timespec(
69*cc02d7e2SAndroid Build Coastguard Worker     const std::chrono::high_resolution_clock::time_point& from,
70*cc02d7e2SAndroid Build Coastguard Worker     gpr_timespec* to);
71*cc02d7e2SAndroid Build Coastguard Worker 
72*cc02d7e2SAndroid Build Coastguard Worker std::chrono::system_clock::time_point Timespec2Timepoint(gpr_timespec t);
73*cc02d7e2SAndroid Build Coastguard Worker 
74*cc02d7e2SAndroid Build Coastguard Worker template <>
75*cc02d7e2SAndroid Build Coastguard Worker class TimePoint<std::chrono::system_clock::time_point> {
76*cc02d7e2SAndroid Build Coastguard Worker  public:
77*cc02d7e2SAndroid Build Coastguard Worker   // NOLINTNEXTLINE(google-explicit-constructor)
TimePoint(const std::chrono::system_clock::time_point & time)78*cc02d7e2SAndroid Build Coastguard Worker   TimePoint(const std::chrono::system_clock::time_point& time) {
79*cc02d7e2SAndroid Build Coastguard Worker     Timepoint2Timespec(time, &time_);
80*cc02d7e2SAndroid Build Coastguard Worker   }
raw_time()81*cc02d7e2SAndroid Build Coastguard Worker   gpr_timespec raw_time() const { return time_; }
82*cc02d7e2SAndroid Build Coastguard Worker 
83*cc02d7e2SAndroid Build Coastguard Worker  private:
84*cc02d7e2SAndroid Build Coastguard Worker   gpr_timespec time_;
85*cc02d7e2SAndroid Build Coastguard Worker };
86*cc02d7e2SAndroid Build Coastguard Worker 
87*cc02d7e2SAndroid Build Coastguard Worker }  // namespace grpc
88*cc02d7e2SAndroid Build Coastguard Worker 
89*cc02d7e2SAndroid Build Coastguard Worker #endif  // GRPCPP_SUPPORT_TIME_H
90