3 //=============================================================================
5 * @file ClientRequestInterceptor.h
7 * @author Ossama Othman <ossama@uci.edu>
9 //=============================================================================
11 #ifndef CLIENT_REQUEST_INTERCEPTOR_H
12 #define CLIENT_REQUEST_INTERCEPTOR_H
14 #include "ace/config-all.h"
16 #if !defined (ACE_LACKS_PRAGMA_ONCE)
18 #endif /* ACE_LACKS_PRAGMA_ONCE */
20 #include "tao/PI/PI.h"
21 #include "tao/PortableInterceptorC.h"
22 #include "tao/LocalObject.h"
26 #pragma warning(disable:4250)
30 * @class ClientRequestInterceptor
32 * @brief Simple concrete client request interceptor.
34 * This is a test client request interceptor that verifies that the
35 * client side PICurrent semantics are correct. In particular, it
36 * verifies that the request-scope current (RSC) is not modified after
37 * the contents of the thread-scope current (TSC) are copied to it.
38 * This is particularly important for ORBs that initially perform a
39 * logical copy for performance reasons.
41 class ClientRequestInterceptor
42 : public virtual PortableInterceptor::ClientRequestInterceptor
,
43 public virtual ::CORBA::LocalObject
47 ClientRequestInterceptor (PortableInterceptor::SlotId slot_id
,
48 PortableInterceptor::Current_ptr pi_current
);
51 * @name Methods Required by the Client Request Interceptor
54 * These are methods that must be implemented since they are pure
55 * virtual in the abstract base class. They are the canonical
56 * methods required for all client request interceptors.
59 /// Return the name of this ClientRequestInterceptor.
60 virtual char * name ();
62 virtual void destroy ();
64 virtual void send_request (
65 PortableInterceptor::ClientRequestInfo_ptr ri
);
67 virtual void send_poll (
68 PortableInterceptor::ClientRequestInfo_ptr ri
);
70 virtual void receive_reply (
71 PortableInterceptor::ClientRequestInfo_ptr ri
);
73 virtual void receive_exception (
74 PortableInterceptor::ClientRequestInfo_ptr ri
);
76 virtual void receive_other (
77 PortableInterceptor::ClientRequestInfo_ptr ri
);
81 /// The PICurrent slot ID allocated to this application during ORB
83 PortableInterceptor::SlotId slot_id_
;
85 /// Reference to the PICurrent object.
86 PortableInterceptor::Current_var pi_current_
;
93 #endif /* CLIENT_REQUEST_INTERCEPTOR_H */