#include <PICurrent_Guard.h>
Collaboration diagram for TAO::PICurrent_Guard:
Public Member Functions | |
PICurrent_Guard (TAO_ServerRequest &server_request, bool tsc_to_rsc) | |
Constructor. | |
~PICurrent_Guard (void) | |
Destructor. | |
Private Attributes | |
PICurrent_Impl * | src_ |
The PICurrent implementation whose slot table will be copied. | |
PICurrent_Impl * | dest_ |
PICurrent_Copy_Callback & | copy_callback_ |
const bool | tsc_to_rsc_ |
Flag that indicates if the TSC is to be copied to the RSC. |
Since copies between the request scope current and thread scope current must also occur if an exception is thrown, e.g. made available to the send_exception() interception points, the "guard" idiom is used to make this action exception-safe.
|
Constructor. This constructor sets up this guard to copy the data held in a given PICurrent when transitioning from that PICurrent's scope to another scope (e.g. request scope to thread scope transition immediately following receive_request_service_contexts() on server side).
|
|
Destructor. The destructor copies (a logical copy whenever possible) data held in a given PICurrent when transitioning from one PICurrent scope to another immediately before any ending interception points are invoked, and after the starting and intermediate (if any) interception points are invoked. |
|
Callback object responsible for performing deep copies of a PICurrent's slot table. |
|
The PICurrent implementation whose slot table will be filled with the contents of another PICurrent's slot table. |
|
The PICurrent implementation whose slot table will be copied.
|
|
Flag that indicates if the TSC is to be copied to the RSC. If false, then the RSC must be deep copied upon leaving the request scope and entering the thread scope. This is necessary since the RSC slot table is no longer available upon leaving the thread scope, meaning that a logical copy is not enough. |