OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 // Time represents an absolute point in coordinated universal time (UTC), | 5 // Time represents an absolute point in coordinated universal time (UTC), |
6 // internally represented as microseconds (s/1,000,000) since the Windows epoch | 6 // internally represented as microseconds (s/1,000,000) since the Windows epoch |
7 // (1601-01-01 00:00:00 UTC). System-dependent clock interface routines are | 7 // (1601-01-01 00:00:00 UTC). System-dependent clock interface routines are |
8 // defined in time_PLATFORM.cc. Note that values for Time may skew and jump | 8 // defined in time_PLATFORM.cc. Note that values for Time may skew and jump |
9 // around as the operating system makes adjustments to synchronize (e.g., with | 9 // around as the operating system makes adjustments to synchronize (e.g., with |
10 // NTP servers). Thus, client code that uses the Time class must account for | 10 // NTP servers). Thus, client code that uses the Time class must account for |
(...skipping 111 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
122 | 122 |
123 // Converts an integer value representing TimeDelta to a class. This is used | 123 // Converts an integer value representing TimeDelta to a class. This is used |
124 // when deserializing a |TimeDelta| structure, using a value known to be | 124 // when deserializing a |TimeDelta| structure, using a value known to be |
125 // compatible. It is not provided as a constructor because the integer type | 125 // compatible. It is not provided as a constructor because the integer type |
126 // may be unclear from the perspective of a caller. | 126 // may be unclear from the perspective of a caller. |
127 static TimeDelta FromInternalValue(int64_t delta) { return TimeDelta(delta); } | 127 static TimeDelta FromInternalValue(int64_t delta) { return TimeDelta(delta); } |
128 | 128 |
129 // Returns the maximum time delta, which should be greater than any reasonable | 129 // Returns the maximum time delta, which should be greater than any reasonable |
130 // time delta we might compare it to. Adding or subtracting the maximum time | 130 // time delta we might compare it to. Adding or subtracting the maximum time |
131 // delta to a time or another time delta has an undefined result. | 131 // delta to a time or another time delta has an undefined result. |
132 static TimeDelta Max(); | 132 static constexpr TimeDelta Max(); |
133 | 133 |
134 // Returns the internal numeric value of the TimeDelta object. Please don't | 134 // Returns the internal numeric value of the TimeDelta object. Please don't |
135 // use this and do arithmetic on it, as it is more error prone than using the | 135 // use this and do arithmetic on it, as it is more error prone than using the |
136 // provided operators. | 136 // provided operators. |
137 // For serializing, use FromInternalValue to reconstitute. | 137 // For serializing, use FromInternalValue to reconstitute. |
138 int64_t ToInternalValue() const { return delta_; } | 138 int64_t ToInternalValue() const { return delta_; } |
139 | 139 |
140 // Returns the magnitude (absolute value) of this TimeDelta. | 140 // Returns the magnitude (absolute value) of this TimeDelta. |
141 TimeDelta magnitude() const { | 141 TimeDelta magnitude() const { |
142 // Some toolchains provide an incomplete C++11 implementation and lack an | 142 // Some toolchains provide an incomplete C++11 implementation and lack an |
(...skipping 519 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
662 constexpr TimeDelta TimeDelta::FromMillisecondsD(double ms) { | 662 constexpr TimeDelta TimeDelta::FromMillisecondsD(double ms) { |
663 return FromDouble(ms * Time::kMicrosecondsPerMillisecond); | 663 return FromDouble(ms * Time::kMicrosecondsPerMillisecond); |
664 } | 664 } |
665 | 665 |
666 // static | 666 // static |
667 constexpr TimeDelta TimeDelta::FromMicroseconds(int64_t us) { | 667 constexpr TimeDelta TimeDelta::FromMicroseconds(int64_t us) { |
668 return TimeDelta(us); | 668 return TimeDelta(us); |
669 } | 669 } |
670 | 670 |
671 // static | 671 // static |
| 672 constexpr TimeDelta TimeDelta::Max() { |
| 673 return TimeDelta(std::numeric_limits<int64_t>::max()); |
| 674 } |
| 675 |
| 676 // static |
672 constexpr TimeDelta TimeDelta::FromDouble(double value) { | 677 constexpr TimeDelta TimeDelta::FromDouble(double value) { |
673 // TODO(crbug.com/612601): Use saturated_cast<int64_t>(value) once we sort out | 678 // TODO(crbug.com/612601): Use saturated_cast<int64_t>(value) once we sort out |
674 // the Min() behavior. | 679 // the Min() behavior. |
675 return value > std::numeric_limits<int64_t>::max() | 680 return value > std::numeric_limits<int64_t>::max() |
676 ? Max() | 681 ? Max() |
677 : value < -std::numeric_limits<int64_t>::max() | 682 : value < -std::numeric_limits<int64_t>::max() |
678 ? -Max() | 683 ? -Max() |
679 : TimeDelta(static_cast<int64_t>(value)); | 684 : TimeDelta(static_cast<int64_t>(value)); |
680 } | 685 } |
681 | 686 |
(...skipping 167 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
849 static void WaitUntilInitializedWin(); | 854 static void WaitUntilInitializedWin(); |
850 #endif | 855 #endif |
851 }; | 856 }; |
852 | 857 |
853 // For logging use only. | 858 // For logging use only. |
854 BASE_EXPORT std::ostream& operator<<(std::ostream& os, ThreadTicks time_ticks); | 859 BASE_EXPORT std::ostream& operator<<(std::ostream& os, ThreadTicks time_ticks); |
855 | 860 |
856 } // namespace base | 861 } // namespace base |
857 | 862 |
858 #endif // BASE_TIME_TIME_H_ | 863 #endif // BASE_TIME_TIME_H_ |
OLD | NEW |