ACE 8.0.3
|
#include <Single_Input_Reactor.h>
Private Attributes | |
ACE_Event_Handler_var | event_handler_ |
Additional Inherited Members | |
![]() | |
ACE_ALLOC_HOOK_DECLARE | |
Declare the dynamic allocation hooks. | |
ACE_Single_Input_Reactor is a reactor implementation with extremely limited functionality.
It is designed for use by TAO in cases where there is only a single input to de-multiplex so select() is not needed. The single event handler which is registered will be treated as always ready for input. Other event types (write, exception) are not supported. Handling events with a timeout is not supported. Notification is not supported.
When used by TAO, this reactor is suitable for running on a dedicated thread which will only handle the acceptor's socket (see -ORBConcurrency thread-per-connection).
|
overridevirtual |
Implements ACE_Reactor_Impl.
|
overridevirtual |
Implements ACE_Reactor_Impl.
|
overridevirtual |
Cancel all Event_Handlers that match the address of event_handler. Returns number of handlers cancelled.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Cancel the single Event_Handler that matches the timer_id value (which was returned from the schedule method). If arg is non-NULL then it will be set to point to the `‘magic cookie’' argument passed in when the Event_Handler was registered. This makes it possible to free up the memory and avoid memory leaks. Returns 1 if cancellation succeeded and 0 if the timer_id wasn't found.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Clear masks_to_be_cleared from the event_handler's entry.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Clear masks_to_be_cleared from the handle's entry.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Close down and release all resources.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Returns 0, if the size of the current message has been put in size Returns -1, if not. ACE_HANDLE allows the reactor to check if the caller is valid.
Implements ACE_Reactor_Impl.
Control whether the Reactor will handle any more incoming events or not. If do_stop == 1, the Reactor will be disabled. By default, a reactor is in active state and can be deactivated/reactived as wish.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Return the status of Reactor. If this function returns 0, the reactor is actively handling events. If it returns non-zero, handling_events() and handle_alertable_events() return -1 immediately.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Dump the state of an object.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Return the Event_Handler associated with handle. Return 0 if handle is not registered.
Implements ACE_Reactor_Impl.
|
overridevirtual |
This method is just like the one above, except the max_wait_time value is a reference and can therefore never be NULL.
The only difference between alertable_handle_events() and handle_events() is that in the alertable case, the eventloop will return when the system queues an I/O completion routine or an Asynchronous Procedure Call.
Implements ACE_Reactor_Impl.
|
overridevirtual |
This event loop driver blocks for up to max_wait_time before returning. It will return earlier if events occur. Note that max_wait_time can be 0, in which case this method blocks indefinitely until events occur.
max_wait_time is decremented to reflect how much time this call took. For instance, if a time value of 3 seconds is passed to handle_events and an event occurs after 2 seconds, max_wait_time will equal 1 second. This can be used if an application wishes to handle events for some fixed amount of time.
Returns the total number of ACE_Event_Handlers that were dispatched, 0 if the max_wait_time elapsed without dispatching any handlers, or -1 if an error occurs.
The only difference between alertable_handle_events() and handle_events() is that in the alertable case, the eventloop will return when the system queues an I/O completion routine or an Asynchronous Procedure Call.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Check to see if handle is associated with a valid Event_Handler bound to mask. Return the event_handler associated with this handler if event_handler != 0.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Check to see if signum is associated with a valid Event_Handler bound to a signal. Return the event_handler associated with this handler if event_handler != 0.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Returns true if Reactor has been successfully initialized, else false.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Returns a reference to the Reactor's internal lock.
Implements ACE_Reactor_Impl.
|
overridevirtual |
GET/SET/ADD/CLR the dispatch mask "bit" bound with the event_handler and mask.
Implements ACE_Reactor_Impl.
|
overridevirtual |
GET/SET/ADD/CLR the dispatch MASK "bit" bound with the handle and mask.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Get the maximum number of times that the ACE_Reactor_Impl will iterate and dispatch the ACE_Event_Handlers that are passed in via the notify queue before breaking out of its ACE_Message_Queue::dequeue() loop.
Implements ACE_Reactor_Impl.
Set the maximum number of times that ACE_Reactor_Impl will iterate and dispatch the ACE_Event_Handlers that are passed in via the notify queue before breaking out of its ACE_Message_Queue::dequeue() loop. By default, this is set to -1, which means "iterate until the queue is empty." Setting this to a value like "1 or 2" will increase "fairness" (and thus prevent starvation) at the expense of slightly higher dispatching overhead.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Notify event_handler of mask event. The ACE_Time_Value indicates how long to blocking trying to notify. If timeout == 0, the caller will block until action is possible, else will wait until the relative time specified in timeout elapses).
Implements ACE_Reactor_Impl.
|
overridevirtual |
Initialization.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Return the ID of the "owner" thread.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Transfers ownership of Reactor_Impl to the new_owner.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Purge any notifications pending in this reactor for the specified ACE_Event_Handler object. Returns the number of notifications purged. Returns -1 on error.
Implements ACE_Reactor_Impl.
|
overridevirtual |
GET/SET/ADD/CLR the ready "bit" bound with the event_handler and mask.
Implements ACE_Reactor_Impl.
|
overridevirtual |
GET/SET/ADD/CLR the ready "bit" bound with the handle and mask.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Register an event_handler that will be notified when event_handle is signaled. Since no event mask is passed through this interface, it is assumed that the event_handler being passed in is an event handle and not an I/O handle.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Register event_handler with mask. The I/O handle will always come from get_handle() on the event_handler.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Register an event_handler that will be notified when event_handle is signaled. mask specifies the network events that the event_handler is interested in.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Register event_handler with mask. The I/O handle is provided through the io_handle parameter.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Register event_handler with all the handles in the Handle_Set.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Registers new_sh to handle a set of signals sigset using the new_disp.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Register new_sh to handle the signal signum using the new_disp. Returns the old_sh that was previously registered (if any), along with the old_disp of the signal handler.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Removes event_handler. Note that the I/O handle will be obtained using get_handle() method of event_handler . If mask == ACE_Event_Handler::DONT_CALL then the handle_close() method of the event_handler is not invoked.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Removes handle. If mask == ACE_Event_Handler::DONT_CALL then the handle_close() method of the associated event_handler is not invoked.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Removes all handles in handle_set. If mask == ACE_Event_Handler::DONT_CALL then the handle_close() method of the associated event_handlers is not invoked.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Calls remove_handler() for every signal in sigset.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Remove the ACE_Event_Handler currently associated with signum. Install the new disposition (if given) and return the previous disposition (if desired by the caller). Returns 0 on success and -1 if signum is invalid.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Get position of the owner thread.
Implements ACE_Reactor_Impl.
Set position of the owner thread.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Resets the interval of the timer represented by timer_id to interval, which is specified in relative time to the current gettimeofday(). If interval is equal to ACE_Time_Value::zero, the timer will become a non-rescheduling timer. Returns 0 if successful, -1 if not.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Get the existing restart value.
Implements ACE_Reactor_Impl.
Set a new value for restart and return the original value.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Does the reactor allow the application to resume the handle on its own ie. can it pass on the control of handle resumption to the application
Implements ACE_Reactor_Impl.
|
overridevirtual |
Resume event_handler. Uses ACE_Event_Handler::get_handle() to get the handle.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Resume handle.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Resume all handles in handle set.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Resume all handles.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Schedule an ACE_Event_Handler that will expire after an amount of time. The return value of this method, a timer_id value, uniquely identifies the event_handler in the ACE_Reactor's internal list of timers. This timer_id value can be used to cancel the timer with the cancel_timer() call.
event_handler | event handler to schedule on reactor |
arg | argument passed to the handle_timeout() method of event_handler |
delay | time interval after which the timer will expire |
interval | time interval after which the timer will be automatically rescheduled |
Implements ACE_Reactor_Impl.
|
overridevirtual |
Add masks_to_be_added to the event_handler's entry. event_handler must already have been registered.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Add masks_to_be_added to the handle's entry. <event_handler> associated with handle must already have been registered.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Use a user specified signal handler instead.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Returns the current size of the Reactor's internal descriptor table.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Suspend event_handler temporarily. Uses ACE_Event_Handler::get_handle() to get the handle.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Suspend handle temporarily.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Suspend all handles in handle set temporarily.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Suspend all <handles> temporarily.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Return the current ACE_Timer_Queue.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Set a user-specified timer queue.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Return true if we any event associations were made by the reactor for the handles that it waits on, false otherwise.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Wake up all threads in waiting in the event loop.
Implements ACE_Reactor_Impl.
|
overridevirtual |
Returns non-zero if there are I/O events "ready" for dispatching, but does not actually dispatch the event handlers. By default, don't block while checking this, i.e., "poll".
Implements ACE_Reactor_Impl.
|
private |