Main Page   Class Hierarchy   Alphabetical List   Compound List   File List   Compound Members   File Members   Related Pages  

ACE_QtReactor Class Reference

An object-oriented event demultiplexor and event handler dispatcher that uses the Qt Library. This class declaration also uses the extension facilities provided by the Qt. So, readers of the class declaration should not be upset with the appearence of the Keywords like Q_OBJECT, private slots etc. They are specific to Qt which uses these as a call back methods implementation mechanism. More...

#include <QtReactor.h>

Inheritance diagram for ACE_QtReactor

Inheritance graph
[legend]
Collaboration diagram for ACE_QtReactor:

Collaboration graph
[legend]
List of all members.

Public Methods

 ACE_QtReactor (QApplication *qapp = NULL, size_t size = DEFAULT_SIZE, int restart = 0, ACE_Sig_Handler *handler = 0)
virtual ~ACE_QtReactor (void)
void qapplication (QApplication *qapp)
virtual long schedule_timer (ACE_Event_Handler *handler, const void *arg, const ACE_Time_Value &delay_time, const ACE_Time_Value &interval)
virtual int cancel_timer (ACE_Event_Handler *handler, int dont_call_handle_close = 1)
virtual int cancel_timer (long timer_id, const void **arg = 0, int dont_call_handle_close = 1)

Protected Types

typedef ACE_Map_Manager<ACE_HANDLE,
QSocketNotifier *, ACE_Null_Mutex
MAP
 Typedef of a map.


Protected Methods

virtual int register_handler_i (ACE_HANDLE handle, ACE_Event_Handler *handler, ACE_Reactor_Mask mask)
 Register a single <handler>.

virtual int register_handler_i (const ACE_Handle_Set &handles, ACE_Event_Handler *handler, ACE_Reactor_Mask mask)
 Register a set of <handlers> with Qt.

virtual int remove_handler_i (ACE_HANDLE handle, ACE_Reactor_Mask mask)
 Remove the <handler> associated with this <handle>.

virtual int remove_handler_i (const ACE_Handle_Set &handles, ACE_Reactor_Mask mask)
 Remove a set of <handles>.

virtual int wait_for_multiple_events (ACE_Select_Reactor_Handle_Set &handle_set, ACE_Time_Value *max_wait_time)
 Wait for events to occur.

virtual int QtWaitForMultipleEvents (int width, ACE_Select_Reactor_Handle_Set &wait_set, ACE_Time_Value *max_wait_time)

Protected Attributes

QApplication* qapp_
 Some Qt stuff that we need to have.

MAP read_notifier_
 A notifier for a read.

MAP write_notifier_
 A write notifier.

MAP exception_notifier_
 An exception notifier.

QTimer* qtime_
 The timer class that would provide timer-sgnals & single-shot timers.


Private Methods

void reset_timeout (void)
 This method ensures there's an Qt timeout for the first timeout in the Reactor's Timer_Queue.

 ACE_QtReactor (const ACE_QtReactor &)
 Deny access since member-wise won't work...

ACE_QtReactor& operator= (const ACE_QtReactor &)

Private Slots

void read_event (int FD)
 Dispatch a Read Event.

void write_event (int FD)
 Dispatch a Write Event.

void exception_event (int FD)
 Dispatch an exception event.

void timeout_event (void)
 Dispach a timeout event.


Detailed Description

An object-oriented event demultiplexor and event handler dispatcher that uses the Qt Library. This class declaration also uses the extension facilities provided by the Qt. So, readers of the class declaration should not be upset with the appearence of the Keywords like Q_OBJECT, private slots etc. They are specific to Qt which uses these as a call back methods implementation mechanism.


Member Typedef Documentation

typedef ACE_Map_Manager<ACE_HANDLE, QSocketNotifier *, ACE_Null_Mutex> ACE_QtReactor::MAP [protected]
 

Typedef of a map.


Constructor & Destructor Documentation

ACE_QtReactor::ACE_QtReactor ( QApplication * qapp = NULL,
size_t size = DEFAULT_SIZE,
int restart = 0,
ACE_Sig_Handler * handler = 0 )
 

ACE_QtReactor::~ACE_QtReactor ( void ) [virtual]
 

ACE_QtReactor::ACE_QtReactor ( const ACE_QtReactor & ) [private]
 

Deny access since member-wise won't work...


Member Function Documentation

int ACE_QtReactor::QtWaitForMultipleEvents ( int width,
ACE_Select_Reactor_Handle_Set & wait_set,
ACE_Time_Value * max_wait_time ) [protected, virtual]
 

int ACE_QtReactor::cancel_timer ( long timer_id,
const void ** arg = 0,
int dont_call_handle_close = 1 ) [virtual]
 

Cancel the single 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. If <dont_call_handle_close> is 0 then the <handle_close> method of <event_handler> will be invoked. Returns 1 if cancellation succeeded and 0 if the <timer_id> wasn't found.

Reimplemented from ACE_Select_Reactor_T.

int ACE_QtReactor::cancel_timer ( ACE_Event_Handler * handler,
int dont_call_handle_close = 1 ) [virtual]
 

Cancel all <event_handlers> that match the address of <event_handler>. If <dont_call_handle_close> is 0 then the <handle_close> method of <event_handler> will be invoked. Returns number of handler's cancelled.

Reimplemented from ACE_Select_Reactor_T.

void ACE_QtReactor::exception_event ( int FD ) [private, slot]
 

Dispatch an exception event.

ACE_QtReactor& ACE_QtReactor::operator= ( const ACE_QtReactor & ) [private]
 

void ACE_QtReactor::qapplication ( QApplication * qapp )
 

void ACE_QtReactor::read_event ( int FD ) [private, slot]
 

Dispatch a Read Event.

int ACE_QtReactor::register_handler_i ( const ACE_Handle_Set & handles,
ACE_Event_Handler * handler,
ACE_Reactor_Mask mask ) [protected, virtual]
 

Register a set of <handlers> with Qt.

Reimplemented from ACE_Select_Reactor_T.

int ACE_QtReactor::register_handler_i ( ACE_HANDLE handle,
ACE_Event_Handler * handler,
ACE_Reactor_Mask mask ) [protected, virtual]
 

Register a single <handler>.

Reimplemented from ACE_Select_Reactor_T.

int ACE_QtReactor::remove_handler_i ( const ACE_Handle_Set & handles,
ACE_Reactor_Mask mask ) [protected, virtual]
 

Remove a set of <handles>.

Reimplemented from ACE_Select_Reactor_T.

int ACE_QtReactor::remove_handler_i ( ACE_HANDLE handle,
ACE_Reactor_Mask mask ) [protected, virtual]
 

Remove the <handler> associated with this <handle>.

Reimplemented from ACE_Select_Reactor_T.

void ACE_QtReactor::reset_timeout ( void ) [private]
 

This method ensures there's an Qt timeout for the first timeout in the Reactor's Timer_Queue.

long ACE_QtReactor::schedule_timer ( ACE_Event_Handler * handler,
const void * arg,
const ACE_Time_Value & delay_time,
const ACE_Time_Value & interval ) [virtual]
 

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.

See also:
cancel_timer() , reset_timer_interval()
Parameters:
event_handler   event handler to schedule on reactor
arg   argument passed to the handle_timeout() method of event_handler
delta   time interval after which the timer will expire
interval   time interval after which the timer will be automatically rescheduled
Returns:
-1 on failure, a timer_id value on success

Reimplemented from ACE_Select_Reactor_T.

void ACE_QtReactor::timeout_event ( void ) [private, slot]
 

Dispach a timeout event.

int ACE_QtReactor::wait_for_multiple_events ( ACE_Select_Reactor_Handle_Set & handle_set,
ACE_Time_Value * max_wait_time ) [protected, virtual]
 

Wait for events to occur.

Reimplemented from ACE_Select_Reactor_T.

void ACE_QtReactor::write_event ( int FD ) [private, slot]
 

Dispatch a Write Event.


Member Data Documentation

MAP ACE_QtReactor::exception_notifier_ [protected]
 

An exception notifier.

QApplication * ACE_QtReactor::qapp_ [protected]
 

Some Qt stuff that we need to have.

QTimer * ACE_QtReactor::qtime_ [protected]
 

The timer class that would provide timer-sgnals & single-shot timers.

MAP ACE_QtReactor::read_notifier_ [protected]
 

A notifier for a read.

MAP ACE_QtReactor::write_notifier_ [protected]
 

A write notifier.


The documentation for this class was generated from the following files:
Generated at Sat Dec 1 11:04:29 2001 for ACE by doxygen1.2.3 written by Dimitri van Heesch, © 1997-2000