chrono.hpp 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. // posix/chrono.cpp --------------------------------------------------------------//
  2. // Copyright Beman Dawes 2008
  3. // Copyright Vicente J. Botet Escriba 2009
  4. // Distributed under the Boost Software License, Version 1.0.
  5. // See http://www.boost.org/LICENSE_1_0.txt
  6. //----------------------------------------------------------------------------//
  7. // POSIX //
  8. //----------------------------------------------------------------------------//
  9. #include <time.h> // for clock_gettime
  10. #include <boost/assert.hpp>
  11. namespace boost
  12. {
  13. namespace chrono
  14. {
  15. system_clock::time_point system_clock::now() BOOST_NOEXCEPT
  16. {
  17. timespec ts;
  18. if ( ::clock_gettime( CLOCK_REALTIME, &ts ) )
  19. {
  20. BOOST_ASSERT(0 && "Boost::Chrono - Internal Error");
  21. }
  22. return time_point(duration(
  23. static_cast<system_clock::rep>( ts.tv_sec ) * 1000000000 + ts.tv_nsec));
  24. }
  25. #if !defined BOOST_CHRONO_DONT_PROVIDE_HYBRID_ERROR_HANDLING
  26. system_clock::time_point system_clock::now(system::error_code & ec)
  27. {
  28. timespec ts;
  29. if ( ::clock_gettime( CLOCK_REALTIME, &ts ) )
  30. {
  31. if (BOOST_CHRONO_IS_THROWS(ec))
  32. {
  33. boost::throw_exception(
  34. system::system_error(
  35. errno,
  36. BOOST_CHRONO_SYSTEM_CATEGORY,
  37. "chrono::system_clock" ));
  38. }
  39. else
  40. {
  41. ec.assign( errno, BOOST_CHRONO_SYSTEM_CATEGORY );
  42. return time_point();
  43. }
  44. }
  45. if (!BOOST_CHRONO_IS_THROWS(ec))
  46. {
  47. ec.clear();
  48. }
  49. return time_point(duration(
  50. static_cast<system_clock::rep>( ts.tv_sec ) * 1000000000 + ts.tv_nsec));
  51. }
  52. #endif
  53. std::time_t system_clock::to_time_t(const system_clock::time_point& t) BOOST_NOEXCEPT
  54. {
  55. return static_cast<std::time_t>( t.time_since_epoch().count() / 1000000000 );
  56. }
  57. system_clock::time_point system_clock::from_time_t(std::time_t t) BOOST_NOEXCEPT
  58. {
  59. return time_point(duration(static_cast<system_clock::rep>(t) * 1000000000));
  60. }
  61. #ifdef BOOST_CHRONO_HAS_CLOCK_STEADY
  62. steady_clock::time_point steady_clock::now() BOOST_NOEXCEPT
  63. {
  64. timespec ts;
  65. if ( ::clock_gettime( CLOCK_MONOTONIC, &ts ) )
  66. {
  67. BOOST_ASSERT(0 && "Boost::Chrono - Internal Error");
  68. }
  69. return time_point(duration(
  70. static_cast<steady_clock::rep>( ts.tv_sec ) * 1000000000 + ts.tv_nsec));
  71. }
  72. #if !defined BOOST_CHRONO_DONT_PROVIDE_HYBRID_ERROR_HANDLING
  73. steady_clock::time_point steady_clock::now(system::error_code & ec)
  74. {
  75. timespec ts;
  76. if ( ::clock_gettime( CLOCK_MONOTONIC, &ts ) )
  77. {
  78. if (BOOST_CHRONO_IS_THROWS(ec))
  79. {
  80. boost::throw_exception(
  81. system::system_error(
  82. errno,
  83. BOOST_CHRONO_SYSTEM_CATEGORY,
  84. "chrono::steady_clock" ));
  85. }
  86. else
  87. {
  88. ec.assign( errno, BOOST_CHRONO_SYSTEM_CATEGORY );
  89. return time_point();
  90. }
  91. }
  92. if (!BOOST_CHRONO_IS_THROWS(ec))
  93. {
  94. ec.clear();
  95. }
  96. return time_point(duration(
  97. static_cast<steady_clock::rep>( ts.tv_sec ) * 1000000000 + ts.tv_nsec));
  98. }
  99. #endif
  100. #endif
  101. } // namespace chrono
  102. } // namespace boost