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 110 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
121 | 121 |
122 // Converts an integer value representing TimeDelta to a class. This is used | 122 // Converts an integer value representing TimeDelta to a class. This is used |
123 // when deserializing a |TimeDelta| structure, using a value known to be | 123 // when deserializing a |TimeDelta| structure, using a value known to be |
124 // compatible. It is not provided as a constructor because the integer type | 124 // compatible. It is not provided as a constructor because the integer type |
125 // may be unclear from the perspective of a caller. | 125 // may be unclear from the perspective of a caller. |
126 static TimeDelta FromInternalValue(int64_t delta) { return TimeDelta(delta); } | 126 static TimeDelta FromInternalValue(int64_t delta) { return TimeDelta(delta); } |
127 | 127 |
128 // Returns the maximum time delta, which should be greater than any reasonable | 128 // Returns the maximum time delta, which should be greater than any reasonable |
129 // time delta we might compare it to. Adding or subtracting the maximum time | 129 // time delta we might compare it to. Adding or subtracting the maximum time |
130 // delta to a time or another time delta has an undefined result. | 130 // delta to a time or another time delta has an undefined result. |
131 static TimeDelta Max(); | 131 static constexpr TimeDelta Max(); |
132 | 132 |
133 // Returns the internal numeric value of the TimeDelta object. Please don't | 133 // Returns the internal numeric value of the TimeDelta object. Please don't |
134 // use this and do arithmetic on it, as it is more error prone than using the | 134 // use this and do arithmetic on it, as it is more error prone than using the |
135 // provided operators. | 135 // provided operators. |
136 // For serializing, use FromInternalValue to reconstitute. | 136 // For serializing, use FromInternalValue to reconstitute. |
137 int64_t ToInternalValue() const { return delta_; } | 137 int64_t ToInternalValue() const { return delta_; } |
138 | 138 |
139 // Returns the magnitude (absolute value) of this TimeDelta. | 139 // Returns the magnitude (absolute value) of this TimeDelta. |
140 TimeDelta magnitude() const { | 140 TimeDelta magnitude() const { |
141 // Some toolchains provide an incomplete C++11 implementation and lack an | 141 // Some toolchains provide an incomplete C++11 implementation and lack an |
(...skipping 508 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
650 constexpr TimeDelta TimeDelta::FromMillisecondsD(double ms) { | 650 constexpr TimeDelta TimeDelta::FromMillisecondsD(double ms) { |
651 return FromDouble(ms * Time::kMicrosecondsPerMillisecond); | 651 return FromDouble(ms * Time::kMicrosecondsPerMillisecond); |
652 } | 652 } |
653 | 653 |
654 // static | 654 // static |
655 constexpr TimeDelta TimeDelta::FromMicroseconds(int64_t us) { | 655 constexpr TimeDelta TimeDelta::FromMicroseconds(int64_t us) { |
656 return TimeDelta(us); | 656 return TimeDelta(us); |
657 } | 657 } |
658 | 658 |
659 // static | 659 // static |
| 660 constexpr TimeDelta TimeDelta::Max() { |
| 661 return TimeDelta(std::numeric_limits<int64_t>::max()); |
| 662 } |
| 663 |
| 664 // static |
660 constexpr TimeDelta TimeDelta::FromDouble(double value) { | 665 constexpr TimeDelta TimeDelta::FromDouble(double value) { |
661 // TODO(crbug.com/612601): Use saturated_cast<int64_t>(value) once we sort out | 666 // TODO(crbug.com/612601): Use saturated_cast<int64_t>(value) once we sort out |
662 // the Min() behavior. | 667 // the Min() behavior. |
663 return value > std::numeric_limits<int64_t>::max() | 668 return value > std::numeric_limits<int64_t>::max() |
664 ? Max() | 669 ? Max() |
665 : value < -std::numeric_limits<int64_t>::max() | 670 : value < -std::numeric_limits<int64_t>::max() |
666 ? -Max() | 671 ? -Max() |
667 : TimeDelta(static_cast<int64_t>(value)); | 672 : TimeDelta(static_cast<int64_t>(value)); |
668 } | 673 } |
669 | 674 |
(...skipping 163 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
833 static void WaitUntilInitializedWin(); | 838 static void WaitUntilInitializedWin(); |
834 #endif | 839 #endif |
835 }; | 840 }; |
836 | 841 |
837 // For logging use only. | 842 // For logging use only. |
838 BASE_EXPORT std::ostream& operator<<(std::ostream& os, ThreadTicks time_ticks); | 843 BASE_EXPORT std::ostream& operator<<(std::ostream& os, ThreadTicks time_ticks); |
839 | 844 |
840 } // namespace base | 845 } // namespace base |
841 | 846 |
842 #endif // BASE_TIME_TIME_H_ | 847 #endif // BASE_TIME_TIME_H_ |
OLD | NEW |