waitable_timer.hpp 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. /*
  2. * Copyright 2013 Andrey Semashev
  3. *
  4. * Distributed under the Boost Software License, Version 1.0.
  5. * See http://www.boost.org/LICENSE_1_0.txt
  6. */
  7. #ifndef BOOST_WINAPI_WAITABLE_TIMER_HPP_INCLUDED_
  8. #define BOOST_WINAPI_WAITABLE_TIMER_HPP_INCLUDED_
  9. #include <boost/winapi/basic_types.hpp>
  10. #ifdef BOOST_HAS_PRAGMA_ONCE
  11. #pragma once
  12. #endif
  13. #if BOOST_WINAPI_PARTITION_APP_SYSTEM
  14. #if !defined( BOOST_USE_WINDOWS_H )
  15. extern "C" {
  16. typedef boost::winapi::VOID_
  17. (BOOST_WINAPI_WINAPI_CC *PTIMERAPCROUTINE)(
  18. boost::winapi::LPVOID_ lpArgToCompletionRoutine,
  19. boost::winapi::DWORD_ dwTimerLowValue,
  20. boost::winapi::DWORD_ dwTimerHighValue);
  21. #if !defined( BOOST_NO_ANSI_APIS )
  22. BOOST_SYMBOL_IMPORT boost::winapi::HANDLE_ BOOST_WINAPI_WINAPI_CC
  23. CreateWaitableTimerA(
  24. ::_SECURITY_ATTRIBUTES* lpTimerAttributes,
  25. boost::winapi::BOOL_ bManualReset,
  26. boost::winapi::LPCSTR_ lpTimerName);
  27. BOOST_SYMBOL_IMPORT boost::winapi::HANDLE_ BOOST_WINAPI_WINAPI_CC
  28. OpenWaitableTimerA(
  29. boost::winapi::DWORD_ dwDesiredAccess,
  30. boost::winapi::BOOL_ bInheritHandle,
  31. boost::winapi::LPCSTR_ lpTimerName);
  32. #endif
  33. BOOST_SYMBOL_IMPORT boost::winapi::HANDLE_ BOOST_WINAPI_WINAPI_CC
  34. CreateWaitableTimerW(
  35. ::_SECURITY_ATTRIBUTES* lpTimerAttributes,
  36. boost::winapi::BOOL_ bManualReset,
  37. boost::winapi::LPCWSTR_ lpTimerName);
  38. BOOST_SYMBOL_IMPORT boost::winapi::HANDLE_ BOOST_WINAPI_WINAPI_CC
  39. OpenWaitableTimerW(
  40. boost::winapi::DWORD_ dwDesiredAccess,
  41. boost::winapi::BOOL_ bInheritHandle,
  42. boost::winapi::LPCWSTR_ lpTimerName);
  43. BOOST_SYMBOL_IMPORT boost::winapi::BOOL_ BOOST_WINAPI_WINAPI_CC
  44. SetWaitableTimer(
  45. boost::winapi::HANDLE_ hTimer,
  46. const ::_LARGE_INTEGER* lpDueTime,
  47. boost::winapi::LONG_ lPeriod,
  48. PTIMERAPCROUTINE pfnCompletionRoutine,
  49. boost::winapi::LPVOID_ lpArgToCompletionRoutine,
  50. boost::winapi::BOOL_ fResume);
  51. BOOST_SYMBOL_IMPORT boost::winapi::BOOL_ BOOST_WINAPI_WINAPI_CC
  52. CancelWaitableTimer(boost::winapi::HANDLE_ hTimer);
  53. } // extern "C"
  54. #endif
  55. namespace boost {
  56. namespace winapi {
  57. typedef ::PTIMERAPCROUTINE PTIMERAPCROUTINE_;
  58. #if !defined( BOOST_NO_ANSI_APIS )
  59. using ::OpenWaitableTimerA;
  60. #endif
  61. using ::OpenWaitableTimerW;
  62. using ::CancelWaitableTimer;
  63. #if defined( BOOST_USE_WINDOWS_H )
  64. BOOST_CONSTEXPR_OR_CONST DWORD_ TIMER_ALL_ACCESS_ = TIMER_ALL_ACCESS;
  65. BOOST_CONSTEXPR_OR_CONST DWORD_ TIMER_MODIFY_STATE_ = TIMER_MODIFY_STATE;
  66. BOOST_CONSTEXPR_OR_CONST DWORD_ TIMER_QUERY_STATE_ = TIMER_QUERY_STATE;
  67. #else // defined( BOOST_USE_WINDOWS_H )
  68. BOOST_CONSTEXPR_OR_CONST DWORD_ TIMER_ALL_ACCESS_ = 0x001F0003;
  69. BOOST_CONSTEXPR_OR_CONST DWORD_ TIMER_MODIFY_STATE_ = 0x00000002;
  70. BOOST_CONSTEXPR_OR_CONST DWORD_ TIMER_QUERY_STATE_ = 0x00000001;
  71. #endif // defined( BOOST_USE_WINDOWS_H )
  72. BOOST_CONSTEXPR_OR_CONST DWORD_ timer_all_access = TIMER_ALL_ACCESS_;
  73. BOOST_CONSTEXPR_OR_CONST DWORD_ timer_modify_state = TIMER_MODIFY_STATE_;
  74. BOOST_CONSTEXPR_OR_CONST DWORD_ timer_query_state = TIMER_QUERY_STATE_;
  75. #if !defined( BOOST_NO_ANSI_APIS )
  76. BOOST_FORCEINLINE HANDLE_ CreateWaitableTimerA(PSECURITY_ATTRIBUTES_ lpTimerAttributes, BOOL_ bManualReset, LPCSTR_ lpTimerName)
  77. {
  78. return ::CreateWaitableTimerA(reinterpret_cast< ::_SECURITY_ATTRIBUTES* >(lpTimerAttributes), bManualReset, lpTimerName);
  79. }
  80. #endif
  81. BOOST_FORCEINLINE HANDLE_ CreateWaitableTimerW(PSECURITY_ATTRIBUTES_ lpTimerAttributes, BOOL_ bManualReset, LPCWSTR_ lpTimerName)
  82. {
  83. return ::CreateWaitableTimerW(reinterpret_cast< ::_SECURITY_ATTRIBUTES* >(lpTimerAttributes), bManualReset, lpTimerName);
  84. }
  85. BOOST_FORCEINLINE BOOL_ SetWaitableTimer(
  86. HANDLE_ hTimer,
  87. const LARGE_INTEGER_* lpDueTime,
  88. LONG_ lPeriod,
  89. PTIMERAPCROUTINE_ pfnCompletionRoutine,
  90. LPVOID_ lpArgToCompletionRoutine,
  91. BOOL_ fResume)
  92. {
  93. return ::SetWaitableTimer(hTimer, reinterpret_cast< const ::_LARGE_INTEGER* >(lpDueTime), lPeriod, pfnCompletionRoutine, lpArgToCompletionRoutine, fResume);
  94. }
  95. #if !defined( BOOST_NO_ANSI_APIS )
  96. BOOST_FORCEINLINE HANDLE_ create_waitable_timer(PSECURITY_ATTRIBUTES_ lpTimerAttributes, BOOL_ bManualReset, LPCSTR_ lpTimerName)
  97. {
  98. return ::CreateWaitableTimerA(reinterpret_cast< ::_SECURITY_ATTRIBUTES* >(lpTimerAttributes), bManualReset, lpTimerName);
  99. }
  100. #endif
  101. BOOST_FORCEINLINE HANDLE_ create_waitable_timer(PSECURITY_ATTRIBUTES_ lpTimerAttributes, BOOL_ bManualReset, LPCWSTR_ lpTimerName)
  102. {
  103. return ::CreateWaitableTimerW(reinterpret_cast< ::_SECURITY_ATTRIBUTES* >(lpTimerAttributes), bManualReset, lpTimerName);
  104. }
  105. BOOST_FORCEINLINE HANDLE_ create_anonymous_waitable_timer(PSECURITY_ATTRIBUTES_ lpTimerAttributes, BOOL_ bManualReset)
  106. {
  107. #ifdef BOOST_NO_ANSI_APIS
  108. return ::CreateWaitableTimerW(reinterpret_cast< ::_SECURITY_ATTRIBUTES* >(lpTimerAttributes), bManualReset, 0);
  109. #else
  110. return ::CreateWaitableTimerA(reinterpret_cast< ::_SECURITY_ATTRIBUTES* >(lpTimerAttributes), bManualReset, 0);
  111. #endif
  112. }
  113. }
  114. }
  115. #endif // BOOST_WINAPI_PARTITION_APP_SYSTEM
  116. #endif // BOOST_WINAPI_WAITABLE_TIMER_HPP_INCLUDED_