#include <POSIX_Proactor.h>
Inheritance diagram for ACE_POSIX_AIOCB_Proactor


| Public Methods | |
| ACE_POSIX_AIOCB_Proactor (size_t nmaxop = ACE_AIO_DEFAULT_SIZE) | |
| Constructor defines max number asynchronous operations which can be started at the same time. | |
| virtual Proactor_Type | get_impl_type (void) | 
| virtual | ~ACE_POSIX_AIOCB_Proactor (void) | 
| Destructor. | |
| virtual int | handle_events (ACE_Time_Value &wait_time) | 
| virtual int | handle_events (void) | 
| virtual int | post_completion (ACE_POSIX_Asynch_Result *result) | 
| Post a result to the completion port of the Proactor. | |
| virtual ACE_Asynch_Read_Stream_Impl* | create_asynch_read_stream (void) | 
| Create the correct implementation class for doing Asynch_Read_Stream. | |
| virtual ACE_Asynch_Write_Stream_Impl* | create_asynch_write_stream (void) | 
| Create the correct implementation class for doing Asynch_Write_Stream. | |
| virtual ACE_Asynch_Read_Dgram_Impl* | create_asynch_read_dgram (void) | 
| Create the correct implementation class for doing Asynch_Read_Dgram. | |
| virtual ACE_Asynch_Write_Dgram_Impl* | create_asynch_write_dgram (void) | 
| Create the correct implementation class for doing Asynch_Write_Dgram. | |
| virtual ACE_Asynch_Read_File_Impl* | create_asynch_read_file (void) | 
| Create the correct implementation class for doing Asynch_Read_File. | |
| virtual ACE_Asynch_Write_File_Impl* | create_asynch_write_file (void) | 
| Create the correct implementation class for doing Asynch_Write_File. | |
| virtual ACE_Asynch_Accept_Impl* | create_asynch_accept (void) | 
| Create the correct implementation class for doing Asynch_Accept. | |
| virtual ACE_Asynch_Transmit_File_Impl* | create_asynch_transmit_file (void) | 
| Create the correct implementation class for doing Asynch_Transmit_File. | |
| virtual int | cancel_aio (ACE_HANDLE h) | 
| Protected Methods | |
| ACE_POSIX_AIOCB_Proactor (size_t nmaxop, ACE_POSIX_Proactor::Proactor_Type ptype) | |
| Special constructor for ACE_SUN_Proactor and ACE_POSIX_SIG_Proactor. | |
| void | create_notify_manager (void) | 
| Call these methods from derived class when virtual table is built. | |
| void | delete_notify_manager (void) | 
| void | check_max_aio_num (void) | 
| Define the maximum number of asynchronous I/O requests for the current OS. | |
| void | set_notify_handle (ACE_HANDLE h) | 
| To identify requests from Notify_Pipe_Manager. | |
| virtual int | handle_events (u_long milli_seconds) | 
| void | application_specific_code (ACE_POSIX_Asynch_Result *asynch_result, u_long bytes_transferred, int success, const void *completion_key, u_long error) | 
| We will call the base class's application_specific_code from here. | |
| virtual int | register_and_start_aio (ACE_POSIX_Asynch_Result *result, int op) | 
| virtual int | start_aio (ACE_POSIX_Asynch_Result *result) | 
| Op code now is saved in ACE_POSIX_Asynch_Result. | |
| int | start_deferred_aio () | 
| Start deferred AIO if necessary. | |
| virtual int | cancel_aiocb ( ACE_POSIX_Asynch_Result * result ) | 
| Cancel running or deferred AIO. | |
| ACE_POSIX_Asynch_Result* | find_completed_aio (int &error_status, int &return_status, size_t &index, size_t &count) | 
| Extract the results of aio. | |
| virtual int | allocate_aio_slot (ACE_POSIX_Asynch_Result *result) | 
| Find free slot to store result and aiocb pointer. | |
| virtual int | notify_completion ( int sig_num ) | 
| Notify queue of "post_completed" ACE_POSIX_Asynch_Results called from post_completion method. | |
| int | putq_result (ACE_POSIX_Asynch_Result *result) | 
| Put "post_completed" result into the internal queue. | |
| ACE_POSIX_Asynch_Result* | getq_result (void) | 
| Get "post_completed" result from the internal queue. | |
| int | clear_result_queue (void) | 
| Clear the internal results queue. | |
| int | process_result_queue (void) | 
| Process the internal results queue. | |
| Protected Attributes | |
| ACE_AIOCB_Notify_Pipe_Manager* | aiocb_notify_pipe_manager_ | 
| This class takes care of doing  when we use AIO_CONTROL_BLOCKS strategy. | |
| aiocb** | aiocb_list_ | 
| Use a dynamically allocated array to keep track of all the aio's issued currently. | |
| ACE_POSIX_Asynch_Result** | result_list_ | 
| size_t | aiocb_list_max_size_ | 
| To maintain the maximum size of the array (list). | |
| size_t | aiocb_list_cur_size_ | 
| To maintain the current size of the array (list). | |
| ACE_SYNCH_MUTEX | mutex_ | 
| Mutex to protect work with lists. | |
| ACE_HANDLE | notify_pipe_read_handle_ | 
| The purpose of this member is only to identify asynchronous request from NotifyManager. We will reserve for it always slot 0 in the list of aiocb's to be sure that don't lose notifications. | |
| size_t | num_deferred_aiocb_ | 
| number of ACE_POSIX_Asynch_Result's waiting for start i.e. deferred AIOs. | |
| size_t | num_started_aio_ | 
| Number active,i.e. running requests. | |
| ACE_Unbounded_Queue<ACE_POSIX_Asynch_Result *> | result_queue_ | 
| Queue which keeps "post_completed" ACE_POSIX_Asynch_Result's. | |
| Friends | |
| class | ACE_AIOCB_Notify_Pipe_Manager | 
| class | ACE_POSIX_AIOCB_Asynch_Operation | 
| 
 | 
| Constructor defines max number asynchronous operations which can be started at the same time. 
 | 
| 
 | 
| Destructor. 
 | 
| 
 | 
| Special constructor for ACE_SUN_Proactor and ACE_POSIX_SIG_Proactor. 
 | 
| 
 | 
| Find free slot to store result and aiocb pointer. 
 Reimplemented in ACE_POSIX_SIG_Proactor. | 
| 
 | 
| We will call the base class's application_specific_code from here. 
 Reimplemented from ACE_POSIX_Proactor. | 
| 
 | 
| This method should be called from ACE_POSIX_Asynch_Operation::cancel() instead of usual aio_cancel. For all deferred AIO requests with handle "h" it removes its from the lists and notifies user. For all running AIO requests with handle "h" it calls aio_cancel. According to the POSIX standards we will receive ECANCELED for all aio_canceled AIO requests later on return from aio_suspend | 
| 
 | 
| Cancel running or deferred AIO. 
 | 
| 
 | 
| Define the maximum number of asynchronous I/O requests for the current OS. 
 | 
| 
 | 
| Clear the internal results queue. 
 | 
| 
 | 
| Create the correct implementation class for doing Asynch_Accept. 
 Reimplemented from ACE_Proactor_Impl. | 
| 
 | 
| Create the correct implementation class for doing Asynch_Read_Dgram. 
 Reimplemented from ACE_Proactor_Impl. | 
| 
 | 
| Create the correct implementation class for doing Asynch_Read_File. 
 Reimplemented from ACE_Proactor_Impl. | 
| 
 | 
| Create the correct implementation class for doing Asynch_Read_Stream. 
 Reimplemented from ACE_Proactor_Impl. | 
| 
 | 
| Create the correct implementation class for doing Asynch_Transmit_File. 
 Reimplemented from ACE_Proactor_Impl. | 
| 
 | 
| Create the correct implementation class for doing Asynch_Write_Dgram. 
 Reimplemented from ACE_Proactor_Impl. | 
| 
 | 
| Create the correct implementation class for doing Asynch_Write_File. 
 Reimplemented from ACE_Proactor_Impl. | 
| 
 | 
| Create the correct implementation class for doing Asynch_Write_Stream. 
 Reimplemented from ACE_Proactor_Impl. | 
| 
 | 
| Call these methods from derived class when virtual table is built. 
 | 
| 
 | 
| 
 | 
| 
 | 
| Extract the results of aio. 
 | 
| 
 | 
| 
 Reimplemented from ACE_POSIX_Proactor. Reimplemented in ACE_POSIX_SIG_Proactor. | 
| 
 | 
| Get "post_completed" result from the internal queue. 
 | 
| 
 | 
| Dispatch a single set of events. If <milli_seconds> elapses before any events occur, return 0. Return 1 if a completion dispatched. Return -1 on errors. Reimplemented in ACE_POSIX_SIG_Proactor. | 
| 
 | 
| Block indefinitely until at least one event is dispatched. Dispatch a single set of events. If <wait_time> elapses before any events occur, return 0. Return 1 on success i.e., when a completion is dispatched, non-zero (-1) on errors and errno is set accordingly. Reimplemented from ACE_Proactor_Impl. Reimplemented in ACE_POSIX_SIG_Proactor. | 
| 
 | 
| Dispatch a single set of events. If <wait_time> elapses before any events occur, return 0. Return 1 on success i.e., when a completion is dispatched, non-zero (-1) on errors and errno is set accordingly. Reimplemented from ACE_Proactor_Impl. Reimplemented in ACE_POSIX_SIG_Proactor. | 
| 
 | 
| Notify queue of "post_completed" ACE_POSIX_Asynch_Results called from post_completion method. 
 Reimplemented in ACE_POSIX_SIG_Proactor. | 
| 
 | 
| Post a result to the completion port of the Proactor. 
 Reimplemented from ACE_POSIX_Proactor. | 
| 
 | 
| Process the internal results queue. 
 | 
| 
 | 
| Put "post_completed" result into the internal queue. 
 | 
| 
 | 
| 
 | 
| 
 | 
| To identify requests from Notify_Pipe_Manager. 
 | 
| 
 | 
| Op code now is saved in ACE_POSIX_Asynch_Result. 
 | 
| 
 | 
| Start deferred AIO if necessary. 
 | 
| 
 | 
| Handler needs to call application specific code. 
 | 
| 
 | 
| This class does the registering of Asynch Operations with the Proactor which is necessary in the AIOCB strategy. 
 | 
| 
 | 
| Use a dynamically allocated array to keep track of all the aio's issued currently. 
 | 
| 
 | 
| To maintain the current size of the array (list). 
 | 
| 
 | 
| To maintain the maximum size of the array (list). 
 | 
| 
 | 
| This class takes care of doing when we use AIO_CONTROL_BLOCKS strategy. 
 | 
| 
 | 
| Mutex to protect work with lists. 
 | 
| 
 | 
| The purpose of this member is only to identify asynchronous request from NotifyManager. We will reserve for it always slot 0 in the list of aiocb's to be sure that don't lose notifications. 
 | 
| 
 | 
| number of ACE_POSIX_Asynch_Result's waiting for start i.e. deferred AIOs. 
 | 
| 
 | 
| Number active,i.e. running requests. 
 | 
| 
 | 
| 
 | 
| 
 | 
| Queue which keeps "post_completed" ACE_POSIX_Asynch_Result's. 
 | 
 1.2.3 written by Dimitri van Heesch,
 © 1997-2000
1.2.3 written by Dimitri van Heesch,
 © 1997-2000