ACE 8.0.1
|
Adapts an ACE timer queue to be driven asynchronously using signals. More...
#include <Timer_Queue_Adapters.h>
Public Types | |
typedef TQ | TIMER_QUEUE |
![]() | |
enum | { LO_PRIORITY = 0 , HI_PRIORITY = 10 , NULL_MASK = 0 , READ_MASK = (1 << 0) , WRITE_MASK = (1 << 1) , EXCEPT_MASK = (1 << 2) , ACCEPT_MASK = (1 << 3) , CONNECT_MASK = (1 << 4) , TIMER_MASK = (1 << 5) , QOS_MASK = (1 << 6) , GROUP_QOS_MASK = (1 << 7) , SIGNAL_MASK = (1 << 8) , ALL_EVENTS_MASK , RWE_MASK , DONT_CALL = (1 << 9) } |
enum | { ACE_EVENT_HANDLER_NOT_RESUMED = -1 , ACE_REACTOR_RESUMES_HANDLER = 0 , ACE_APPLICATION_RESUMES_HANDLER } |
typedef long | Reference_Count |
Reference count type. | |
Private Member Functions | |
virtual int | schedule_ualarm () |
Perform the logic to compute the new ualarm(2) setting. | |
virtual int | handle_signal (int signum, siginfo_t *, ucontext_t *) |
Called back by SIGALRM handler. | |
Private Attributes | |
ACE_Sig_Handler | sig_handler_ |
TQ | timer_queue_ |
ACE_Sig_Set | mask_ |
Mask of signals to be blocked when we're servicing SIGALRM . | |
Additional Inherited Members | |
![]() | |
static ACE_THR_FUNC_RETURN | read_adapter (void *event_handler) |
static int | register_stdin_handler (ACE_Event_Handler *eh, ACE_Reactor *reactor, ACE_Thread_Manager *thr_mgr, int flags=THR_DETACHED) |
static int | remove_stdin_handler (ACE_Reactor *reactor, ACE_Thread_Manager *thr_mgr) |
Performs the inverse of the register_stdin_handler() method. | |
![]() | |
typedef std::atomic< Reference_Count > | Atomic_Reference_Count |
Typedef for implementation of reference counting. | |
![]() | |
ACE_Event_Handler (ACE_Reactor *=nullptr, int priority=ACE_Event_Handler::LO_PRIORITY) | |
Force ACE_Event_Handler to be an abstract base class. | |
![]() | |
Atomic_Reference_Count | reference_count_ |
Reference count. | |
Adapts an ACE timer queue to be driven asynchronously using signals.
This implementation uses the ACE_OS::ualarm call, to generate the SIGARLM signal that is caught by this class.
typedef TQ ACE_Async_Timer_Queue_Adapter< TQ, TYPE >::TIMER_QUEUE |
ACE_Async_Timer_Queue_Adapter< TQ, TYPE >::ACE_Async_Timer_Queue_Adapter | ( | ACE_Sig_Set * | mask = 0 | ) |
Constructor.
Register the SIGALRM handler. If mask == 0 then block all signals when SIGALRM
is run. Otherwise, just block the signals indicated in mask.
int ACE_Async_Timer_Queue_Adapter< TQ, TYPE >::cancel | ( | long | timer_id, |
const void ** | act = 0 ) |
Cancel the timer_id and pass back the act if an address is passed in.
Dispatch all timers with expiry time at or before the current time. Returns the number of timers expired.
|
privatevirtual |
Called back by SIGALRM
handler.
Reimplemented from ACE_Event_Handler.
long ACE_Async_Timer_Queue_Adapter< TQ, TYPE >::schedule | ( | TYPE | type, |
const void * | act, | ||
const ACE_Time_Value & | future_time, | ||
const ACE_Time_Value & | interval = ACE_Time_Value::zero ) |
Schedule the timer according to the semantics of the ACE_Timer_List. This timer gets dispatched via a signal, rather than by a user calling expire(). Note that interval timers are not implemented yet.
|
privatevirtual |
Perform the logic to compute the new ualarm(2) setting.
Return a reference to the underlying timer queue.
|
private |
Mask of signals to be blocked when we're servicing SIGALRM
.
|
private |
Handler for the SIGALRM
signal, so that we can access our state without requiring any global variables.
|
private |
Implementation of the timer queue (e.g., ACE_Timer_List, ACE_Timer_Heap, etc.).