diff options
Diffstat (limited to 'include/llvm/Support/TimeValue.h')
| -rw-r--r-- | include/llvm/Support/TimeValue.h | 24 | 
1 files changed, 15 insertions, 9 deletions
| diff --git a/include/llvm/Support/TimeValue.h b/include/llvm/Support/TimeValue.h index e780b50c6039..4b48b849f20d 100644 --- a/include/llvm/Support/TimeValue.h +++ b/include/llvm/Support/TimeValue.h @@ -11,12 +11,12 @@  //  //===----------------------------------------------------------------------===// +#ifndef LLVM_SUPPORT_TIMEVALUE_H +#define LLVM_SUPPORT_TIMEVALUE_H +  #include "llvm/Support/DataTypes.h"  #include <string> -#ifndef LLVM_SYSTEM_TIMEVALUE_H -#define LLVM_SYSTEM_TIMEVALUE_H -  namespace llvm {  namespace sys {    /// This class is used where a precise fixed point in time is required. The @@ -82,6 +82,9 @@ namespace sys {    /// @name Constructors    /// @{    public: +    /// \brief Default construct a time value, initializing to ZeroTime. +    TimeValue() : seconds_(0), nanos_(0) {} +      /// Caller provides the exact value in seconds and nanoseconds. The      /// \p nanos argument defaults to zero for convenience.      /// @brief Explicit constructor @@ -237,7 +240,7 @@ namespace sys {      /// Posix, correcting for the difference in Posix zero time.      /// @brief Convert to unix time (100 nanoseconds since 12:00:00a Jan 1,1970)      uint64_t toPosixTime() const { -      uint64_t result = seconds_ - PosixZeroTime.seconds_; +      uint64_t result = seconds_ - PosixZeroTimeSeconds;        result += nanos_ / NANOSECONDS_PER_POSIX_TICK;        return result;      } @@ -245,14 +248,14 @@ namespace sys {      /// Converts the TimeValue into the corresponding number of seconds      /// since the epoch (00:00:00 Jan 1,1970).      uint64_t toEpochTime() const { -      return seconds_ - PosixZeroTime.seconds_; +      return seconds_ - PosixZeroTimeSeconds;      }      /// Converts the TimeValue into the corresponding number of "ticks" for      /// Win32 platforms, correcting for the difference in Win32 zero time.      /// @brief Convert to windows time (seconds since 12:00:00a Jan 1, 1601)      uint64_t toWin32Time() const { -      uint64_t result = seconds_ - Win32ZeroTime.seconds_; +      uint64_t result = seconds_ - Win32ZeroTimeSeconds;        result += nanos_ / NANOSECONDS_PER_WIN32_TICK;        return result;      } @@ -261,7 +264,7 @@ namespace sys {      /// correction for the Posix zero time.      /// @brief Convert to timespec time (ala POSIX.1b)      void getTimespecTime( uint64_t& seconds, uint32_t& nanos ) const { -      seconds = seconds_ - PosixZeroTime.seconds_; +      seconds = seconds_ - PosixZeroTimeSeconds;        nanos = nanos_;      } @@ -328,7 +331,7 @@ namespace sys {      /// TimeValue and assigns that value to \p this.      /// @brief Convert seconds form PosixTime to TimeValue      void fromEpochTime( SecondsType seconds ) { -      seconds_ = seconds + PosixZeroTime.seconds_; +      seconds_ = seconds + PosixZeroTimeSeconds;        nanos_ = 0;        this->normalize();      } @@ -337,7 +340,7 @@ namespace sys {      /// corresponding TimeValue and assigns that value to \p this.      /// @brief Convert seconds form Windows FILETIME to TimeValue      void fromWin32Time( uint64_t win32Time ) { -      this->seconds_ = win32Time / 10000000 + Win32ZeroTime.seconds_; +      this->seconds_ = win32Time / 10000000 + Win32ZeroTimeSeconds;        this->nanos_ = NanoSecondsType(win32Time  % 10000000) * 100;      } @@ -357,6 +360,9 @@ namespace sys {      /// Store the values as a <timeval>.      SecondsType      seconds_;///< Stores the seconds part of the TimeVal      NanoSecondsType  nanos_;  ///< Stores the nanoseconds part of the TimeVal + +    static const SecondsType PosixZeroTimeSeconds; +    static const SecondsType Win32ZeroTimeSeconds;    /// @}    }; | 
