/* -*- C++ -*- */ // $Id$ #include "ace/Reactor.h" template ACE_INLINE int ACE_Select_Reactor_T::resume_handler (ACE_Event_Handler *h) { ACE_TRACE ("ACE_Select_Reactor_T::resume_handler"); return this->resume_handler (h->get_handle ()); } template ACE_INLINE int ACE_Select_Reactor_T::resume_handler (const ACE_Handle_Set &handles) { ACE_TRACE ("ACE_Select_Reactor_T::resume_handler"); ACE_Handle_Set_Iterator handle_iter (handles); ACE_HANDLE h; ACE_MT (ACE_GUARD_RETURN (ACE_SELECT_REACTOR_TOKEN, ace_mon, this->token_, -1)); while ((h = handle_iter ()) != ACE_INVALID_HANDLE) if (this->resume_i (h) == -1) return -1; return 0; } template ACE_INLINE int ACE_Select_Reactor_T::suspend_handler (ACE_Event_Handler *h) { ACE_TRACE ("ACE_Select_Reactor_T::suspend_handler"); return this->suspend_handler (h->get_handle ()); } template ACE_INLINE int ACE_Select_Reactor_T::suspend_handler (const ACE_Handle_Set &handles) { ACE_TRACE ("ACE_Select_Reactor_T::suspend_handler"); ACE_Handle_Set_Iterator handle_iter (handles); ACE_HANDLE h; ACE_MT (ACE_GUARD_RETURN (ACE_SELECT_REACTOR_TOKEN, ace_mon, this->token_, -1)); while ((h = handle_iter ()) != ACE_INVALID_HANDLE) if (this->suspend_i (h) == -1) return -1; return 0; } template ACE_INLINE int ACE_Select_Reactor_T::register_handler (int signum, ACE_Event_Handler *new_sh, ACE_Sig_Action *new_disp, ACE_Event_Handler **old_sh, ACE_Sig_Action *old_disp) { ACE_TRACE ("ACE_Select_Reactor_T::register_handler"); return this->signal_handler_->register_handler (signum, new_sh, new_disp, old_sh, old_disp); } #if defined (ACE_WIN32) template ACE_INLINE int ACE_Select_Reactor_T::register_handler (ACE_Event_Handler *event_handler, ACE_HANDLE event_handle) { // Don't have an implementation for this yet... ACE_UNUSED_ARG (event_handler); ACE_UNUSED_ARG (event_handle); ACE_NOTSUP_RETURN (-1); } #endif /* ACE_WIN32 */ template ACE_INLINE int ACE_Select_Reactor_T::register_handler (ACE_HANDLE event_handle, ACE_HANDLE io_handle, ACE_Event_Handler *event_handler, ACE_Reactor_Mask mask) { // Don't have an implementation for this yet... ACE_UNUSED_ARG (event_handle); ACE_UNUSED_ARG (io_handle); ACE_UNUSED_ARG (event_handler); ACE_UNUSED_ARG (mask); ACE_NOTSUP_RETURN (-1); } template ACE_INLINE int ACE_Select_Reactor_T::handler (int signum, ACE_Event_Handler **handler) { ACE_TRACE ("ACE_Select_Reactor_T::handler"); return this->handler_i (signum, handler); } template ACE_INLINE int ACE_Select_Reactor_T::remove_handler (int signum, ACE_Sig_Action *new_disp, ACE_Sig_Action *old_disp, int sigkey) { ACE_TRACE ("ACE_Select_Reactor_T::remove_handler"); return this->signal_handler_->remove_handler (signum, new_disp, old_disp, sigkey); } template ACE_INLINE int ACE_Select_Reactor_T::uses_event_associations (void) { // Since the Select_Reactor does not do any event associations, this // function always return 0. return 0; } // = The remaining methods in this file must be called with locks // held. Note the queue handles its own locking. template ACE_INLINE int ACE_Select_Reactor_T::cancel_timer (ACE_Event_Handler *handler, int dont_call_handle_close) { ACE_TRACE ("ACE_Select_Reactor_T::cancel_timer"); return this->timer_queue_ != 0 && this->timer_queue_->cancel (handler, dont_call_handle_close); } template ACE_INLINE int ACE_Select_Reactor_T::cancel_timer (long timer_id, const void **arg, int dont_call_handle_close) { ACE_TRACE ("ACE_Select_Reactor_T::cancel_timer"); return this->timer_queue_->cancel (timer_id, arg, dont_call_handle_close); } // Performs operations on the "ready" bits. template ACE_INLINE int ACE_Select_Reactor_T::ready_ops (ACE_Event_Handler *handler, ACE_Reactor_Mask mask, int ops) { ACE_TRACE ("ACE_Select_Reactor_T::ready_ops"); return this->ready_ops (handler->get_handle (), mask, ops); } // Performs operations on the "dispatch" masks. template ACE_INLINE int ACE_Select_Reactor_T::mask_ops (ACE_Event_Handler *handler, ACE_Reactor_Mask mask, int ops) { ACE_TRACE ("ACE_Select_Reactor_T::mask_ops"); return this->mask_ops (handler->get_handle (), mask, ops); } template ACE_INLINE int ACE_Select_Reactor_T::schedule_wakeup (ACE_Event_Handler *eh, ACE_Reactor_Mask mask) { ACE_TRACE ("ACE_Select_Reactor_T::schedule_wakeup"); return this->mask_ops (eh->get_handle (), mask, ACE_Reactor::ADD_MASK); } template ACE_INLINE int ACE_Select_Reactor_T::cancel_wakeup (ACE_Event_Handler *eh, ACE_Reactor_Mask mask) { ACE_TRACE ("ACE_Select_Reactor_T::cancel_wakeup"); return this->mask_ops (eh->get_handle (), mask, ACE_Reactor::CLR_MASK); } template ACE_INLINE int ACE_Select_Reactor_T::schedule_wakeup (ACE_HANDLE handle, ACE_Reactor_Mask mask) { ACE_TRACE ("ACE_Select_Reactor_T::schedule_wakeup"); return this->mask_ops (handle, mask, ACE_Reactor::ADD_MASK); } template ACE_INLINE int ACE_Select_Reactor_T::cancel_wakeup (ACE_HANDLE handle, ACE_Reactor_Mask mask) { ACE_TRACE ("ACE_Select_Reactor_T::cancel_wakeup"); return this->mask_ops (handle, mask, ACE_Reactor::CLR_MASK); } template ACE_INLINE ACE_Lock & ACE_Select_Reactor_T::lock (void) { ACE_TRACE ("ACE_Select_Reactor_T::lock"); return this->lock_adapter_; } template ACE_INLINE void ACE_Select_Reactor_T::wakeup_all_threads (void) { // Send a notification, but don't block if there's no one to receive // it. this->notify (0, ACE_Event_Handler::NULL_MASK, (ACE_Time_Value *) &ACE_Time_Value::zero); } template ACE_INLINE int ACE_Select_Reactor_T::alertable_handle_events (ACE_Time_Value *max_wait_time) { return this->handle_events (max_wait_time); } template ACE_INLINE int ACE_Select_Reactor_T::alertable_handle_events (ACE_Time_Value &max_wait_time) { return this->handle_events (max_wait_time); } template ACE_INLINE size_t ACE_Select_Reactor_T::size (void) { return this->handler_rep_.size (); }