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 
8 #ifndef BOOST_WINAPI_WAITABLE_TIMER_HPP_INCLUDED_
9 #define BOOST_WINAPI_WAITABLE_TIMER_HPP_INCLUDED_
10 
11 #include <boost/winapi/basic_types.hpp>
12 
13 #ifdef BOOST_HAS_PRAGMA_ONCE
14 #pragma once
15 #endif
16 
17 #if BOOST_WINAPI_PARTITION_APP_SYSTEM
18 
19 #if !defined( BOOST_USE_WINDOWS_H )
20 extern "C" {
21 typedef boost::winapi::VOID_
22 (BOOST_WINAPI_WINAPI_CC *PTIMERAPCROUTINE)(
23     boost::winapi::LPVOID_ lpArgToCompletionRoutine,
24     boost::winapi::DWORD_ dwTimerLowValue,
25     boost::winapi::DWORD_ dwTimerHighValue);
26 
27 #if !defined( BOOST_NO_ANSI_APIS )
28 BOOST_SYMBOL_IMPORT boost::winapi::HANDLE_ BOOST_WINAPI_WINAPI_CC
29 CreateWaitableTimerA(
30     ::_SECURITY_ATTRIBUTES* lpTimerAttributes,
31     boost::winapi::BOOL_ bManualReset,
32     boost::winapi::LPCSTR_ lpTimerName);
33 
34 BOOST_SYMBOL_IMPORT boost::winapi::HANDLE_ BOOST_WINAPI_WINAPI_CC
35 OpenWaitableTimerA(
36     boost::winapi::DWORD_ dwDesiredAccess,
37     boost::winapi::BOOL_ bInheritHandle,
38     boost::winapi::LPCSTR_ lpTimerName);
39 #endif
40 
41 BOOST_SYMBOL_IMPORT boost::winapi::HANDLE_ BOOST_WINAPI_WINAPI_CC
42 CreateWaitableTimerW(
43     ::_SECURITY_ATTRIBUTES* lpTimerAttributes,
44     boost::winapi::BOOL_ bManualReset,
45     boost::winapi::LPCWSTR_ lpTimerName);
46 
47 BOOST_SYMBOL_IMPORT boost::winapi::HANDLE_ BOOST_WINAPI_WINAPI_CC
48 OpenWaitableTimerW(
49     boost::winapi::DWORD_ dwDesiredAccess,
50     boost::winapi::BOOL_ bInheritHandle,
51     boost::winapi::LPCWSTR_ lpTimerName);
52 
53 BOOST_SYMBOL_IMPORT boost::winapi::BOOL_ BOOST_WINAPI_WINAPI_CC
54 SetWaitableTimer(
55     boost::winapi::HANDLE_ hTimer,
56     const ::_LARGE_INTEGER* lpDueTime,
57     boost::winapi::LONG_ lPeriod,
58     PTIMERAPCROUTINE pfnCompletionRoutine,
59     boost::winapi::LPVOID_ lpArgToCompletionRoutine,
60     boost::winapi::BOOL_ fResume);
61 
62 BOOST_SYMBOL_IMPORT boost::winapi::BOOL_ BOOST_WINAPI_WINAPI_CC
63 CancelWaitableTimer(boost::winapi::HANDLE_ hTimer);
64 } // extern "C"
65 #endif
66 
67 namespace boost {
68 namespace winapi {
69 
70 typedef ::PTIMERAPCROUTINE PTIMERAPCROUTINE_;
71 
72 #if !defined( BOOST_NO_ANSI_APIS )
73 using ::OpenWaitableTimerA;
74 #endif
75 using ::OpenWaitableTimerW;
76 using ::CancelWaitableTimer;
77 
78 #if defined( BOOST_USE_WINDOWS_H )
79 
80 BOOST_CONSTEXPR_OR_CONST DWORD_ TIMER_ALL_ACCESS_ = TIMER_ALL_ACCESS;
81 BOOST_CONSTEXPR_OR_CONST DWORD_ TIMER_MODIFY_STATE_ = TIMER_MODIFY_STATE;
82 BOOST_CONSTEXPR_OR_CONST DWORD_ TIMER_QUERY_STATE_ = TIMER_QUERY_STATE;
83 
84 #else // defined( BOOST_USE_WINDOWS_H )
85 
86 BOOST_CONSTEXPR_OR_CONST DWORD_ TIMER_ALL_ACCESS_ = 0x001F0003;
87 BOOST_CONSTEXPR_OR_CONST DWORD_ TIMER_MODIFY_STATE_ = 0x00000002;
88 BOOST_CONSTEXPR_OR_CONST DWORD_ TIMER_QUERY_STATE_ = 0x00000001;
89 
90 #endif // defined( BOOST_USE_WINDOWS_H )
91 
92 BOOST_CONSTEXPR_OR_CONST DWORD_ timer_all_access = TIMER_ALL_ACCESS_;
93 BOOST_CONSTEXPR_OR_CONST DWORD_ timer_modify_state = TIMER_MODIFY_STATE_;
94 BOOST_CONSTEXPR_OR_CONST DWORD_ timer_query_state = TIMER_QUERY_STATE_;
95 
96 
97 #if !defined( BOOST_NO_ANSI_APIS )
CreateWaitableTimerA(PSECURITY_ATTRIBUTES_ lpTimerAttributes,BOOL_ bManualReset,LPCSTR_ lpTimerName)98 BOOST_FORCEINLINE HANDLE_ CreateWaitableTimerA(PSECURITY_ATTRIBUTES_ lpTimerAttributes, BOOL_ bManualReset, LPCSTR_ lpTimerName)
99 {
100     return ::CreateWaitableTimerA(reinterpret_cast< ::_SECURITY_ATTRIBUTES* >(lpTimerAttributes), bManualReset, lpTimerName);
101 }
102 #endif
103 
CreateWaitableTimerW(PSECURITY_ATTRIBUTES_ lpTimerAttributes,BOOL_ bManualReset,LPCWSTR_ lpTimerName)104 BOOST_FORCEINLINE HANDLE_ CreateWaitableTimerW(PSECURITY_ATTRIBUTES_ lpTimerAttributes, BOOL_ bManualReset, LPCWSTR_ lpTimerName)
105 {
106     return ::CreateWaitableTimerW(reinterpret_cast< ::_SECURITY_ATTRIBUTES* >(lpTimerAttributes), bManualReset, lpTimerName);
107 }
108 
SetWaitableTimer(HANDLE_ hTimer,const LARGE_INTEGER_ * lpDueTime,LONG_ lPeriod,PTIMERAPCROUTINE_ pfnCompletionRoutine,LPVOID_ lpArgToCompletionRoutine,BOOL_ fResume)109 BOOST_FORCEINLINE BOOL_ SetWaitableTimer(
110     HANDLE_ hTimer,
111     const LARGE_INTEGER_* lpDueTime,
112     LONG_ lPeriod,
113     PTIMERAPCROUTINE_ pfnCompletionRoutine,
114     LPVOID_ lpArgToCompletionRoutine,
115     BOOL_ fResume)
116 {
117     return ::SetWaitableTimer(hTimer, reinterpret_cast< const ::_LARGE_INTEGER* >(lpDueTime), lPeriod, pfnCompletionRoutine, lpArgToCompletionRoutine, fResume);
118 }
119 
120 #if !defined( BOOST_NO_ANSI_APIS )
create_waitable_timer(PSECURITY_ATTRIBUTES_ lpTimerAttributes,BOOL_ bManualReset,LPCSTR_ lpTimerName)121 BOOST_FORCEINLINE HANDLE_ create_waitable_timer(PSECURITY_ATTRIBUTES_ lpTimerAttributes, BOOL_ bManualReset, LPCSTR_ lpTimerName)
122 {
123     return ::CreateWaitableTimerA(reinterpret_cast< ::_SECURITY_ATTRIBUTES* >(lpTimerAttributes), bManualReset, lpTimerName);
124 }
125 #endif
126 
create_waitable_timer(PSECURITY_ATTRIBUTES_ lpTimerAttributes,BOOL_ bManualReset,LPCWSTR_ lpTimerName)127 BOOST_FORCEINLINE HANDLE_ create_waitable_timer(PSECURITY_ATTRIBUTES_ lpTimerAttributes, BOOL_ bManualReset, LPCWSTR_ lpTimerName)
128 {
129     return ::CreateWaitableTimerW(reinterpret_cast< ::_SECURITY_ATTRIBUTES* >(lpTimerAttributes), bManualReset, lpTimerName);
130 }
131 
create_anonymous_waitable_timer(PSECURITY_ATTRIBUTES_ lpTimerAttributes,BOOL_ bManualReset)132 BOOST_FORCEINLINE HANDLE_ create_anonymous_waitable_timer(PSECURITY_ATTRIBUTES_ lpTimerAttributes, BOOL_ bManualReset)
133 {
134 #ifdef BOOST_NO_ANSI_APIS
135     return ::CreateWaitableTimerW(reinterpret_cast< ::_SECURITY_ATTRIBUTES* >(lpTimerAttributes), bManualReset, 0);
136 #else
137     return ::CreateWaitableTimerA(reinterpret_cast< ::_SECURITY_ATTRIBUTES* >(lpTimerAttributes), bManualReset, 0);
138 #endif
139 }
140 
141 }
142 }
143 
144 #endif // BOOST_WINAPI_PARTITION_APP_SYSTEM
145 #endif // BOOST_WINAPI_WAITABLE_TIMER_HPP_INCLUDED_
146