// This may look like C, but it's really -*- C++ -*- // $Id$ // ============================================================================ // // = LIBRARY // TAO // // = FILENAME // IIOP_Connector.h // // = DESCRIPTION // IIOP specific connector processing // // = AUTHOR // Fred Kuhns // // ============================================================================ #ifndef TAO_IIOP_CONNECTOR_H #define TAO_IIOP_CONNECTOR_H #include "ace/pre.h" #include "ace/Connector.h" #if !defined (ACE_LACKS_PRAGMA_ONCE) # pragma once #endif /* ACE_LACKS_PRAGMA_ONCE */ #include "ace/SOCK_Connector.h" #include "tao/Pluggable.h" #include "tao/IIOP_Connect.h" #include "tao/Resource_Factory.h" #if defined (TAO_USES_ROBUST_CONNECTION_MGMT) #if defined(__GNUC__) && __GNUC__ == 2 && __GNUC_MINOR__ < 8 #define ACE_HAS_BROKEN_EXTENDED_TEMPLATES #endif /* __GNUC__ */ // Necessary to do this so that the set of classes used in ACE // for TAO_HAS_MINIMUM_CONNECTION_CACHING_STRATEGY = 1 option is // the same as those used for ACE_HAS_BROKEN_EXTENDED_TEMPLATES #if (TAO_HAS_MINIMUM_CONNECTION_CACHING_STRATEGY == 1) #define ACE_HAS_BROKEN_EXTENDED_TEMPLATES #endif /*TAO_HAS_MINIMUM_CONNECTION_CACHING_STRATEGY == 1*/ #include "ace/Cached_Connect_Strategy_T.h" #endif /* TAO_USES_ROBUST_CONNECTION_MGMT */ typedef ACE_Strategy_Connector TAO_IIOP_BASE_CONNECTOR; // **************************************************************** class TAO_Export TAO_IIOP_Connect_Creation_Strategy : public ACE_Creation_Strategy { // = TITLE // Helper creation strategy // // = DESCRIPTION // Creates UIOP_Client_Connection_Handler objects but satisfies // the interface required by the // ACE_Creation_Strategy // public: TAO_IIOP_Connect_Creation_Strategy (ACE_Thread_Manager * = 0, TAO_ORB_Core* orb_core = 0, void *arg = 0, CORBA::Boolean flag = 0); // Constructor. parameter is used to pass any special // state/info to the service handler upon creation. Currently used // by IIOP and UIOP to pass protocol configuration properties. virtual int make_svc_handler (TAO_IIOP_Client_Connection_Handler *&sh); // Makes TAO_IIOP_Client_Connection_Handlers private: TAO_ORB_Core* orb_core_; // The ORB void *arg_; // Some info/state to be passed to the service handler we create. CORBA::Boolean lite_flag_; // Are we using GIOP? }; // **************************************************************** class TAO_Export TAO_IIOP_Connector : public TAO_Connector { // = TITLE // IIOP-specific Connector bridge for pluggable protocols. // // = DESCRIPTION // Concrete instance of the TAO_Connector class. Responsible // for establishing a connection with a server and is called from the // Connector_Registory. // public: // = Initialization and termination methods. TAO_IIOP_Connector (CORBA::Boolean flag = 0); // Constructor. // = The TAO_Connector methods, please check the documentation on // Pluggable.h int open (TAO_ORB_Core *orb_core); int close (void); int connect (TAO_Endpoint *endpoint, TAO_Transport *&transport, ACE_Time_Value *max_wait_time, CORBA::Environment &ACE_TRY_ENV); int preconnect (const char *preconnections); TAO_Profile *create_profile (TAO_InputCDR& cdr); virtual int check_prefix (const char *endpoint); virtual char object_key_delimiter (void) const; #if defined (TAO_USES_ROBUST_CONNECTION_MGMT) virtual int purge_connections (void); // Purge "old" connections. #endif /* TAO_USES_ROBUST_CONNECTION_MGMT */ protected: // = More TAO_Connector methods, please check the documentation on // Pluggable.h virtual void make_profile (const char *endpoint, TAO_Profile *&, CORBA::Environment &ACE_TRY_ENV = TAO_default_environment ()); #if defined (TAO_USES_ROBUST_CONNECTION_MGMT) virtual int make_caching_strategy (void); // According to the option specified, create the appropriate caching // strategy used for purging unused connections from the connection // cache. #endif /* TAO_USES_ROBUST_CONNECTION_MGMT */ protected: int init_tcp_properties (void); // Obtain tcp properties that must be used by this connector, i.e., // initialize . public: #if defined (TAO_USES_ROBUST_CONNECTION_MGMT) // = Connection Caching Strategy. typedef size_t TAO_ATTRIBUTES; typedef ACE_Pair TAO_CACHED_HANDLER; typedef ACE_Refcounted_Hash_Recyclable TAO_IADDR; typedef ACE_Hash TAO_HASH_KEY; typedef ACE_Equal_To TAO_COMPARE_KEYS; typedef ACE_Hash_Map_Manager_Ex TAO_HASH_MAP; typedef ACE_Hash_Map_Iterator_Ex TAO_HASH_MAP_ITERATOR; typedef ACE_Hash_Map_Reverse_Iterator_Ex TAO_HASH_MAP_REVERSE_ITERATOR; typedef ACE_Refcounted_Recyclable_Handler_Caching_Utility TAO_CACHING_UTILITY; #if defined (ACE_HAS_BROKEN_EXTENDED_TEMPLATES) || (TAO_HAS_MINIMUM_CONNECTION_CACHING_STRATEGY == 1) typedef ACE_LRU_Caching_Strategy TAO_CACHING_STRATEGY; #else #if (TAO_HAS_MINIMUM_CONNECTION_CACHING_STRATEGY == 0) typedef ACE_Caching_Strategy TAO_CACHING_STRATEGY; #endif /* (TAO_HAS_MINIMUM_CONNECTION_CACHING_STRATEGY == 0) */ #endif /* ACE_HAS_BROKEN_EXTENDED_TEMPLATES TAO_HAS_MINIMUM_CONNECTION_CACHING_STRATEGY == 1*/ typedef ACE_Cached_Connect_Strategy_Ex TAO_CACHED_CONNECT_STRATEGY; #endif /* TAO_USES_ROBUST_CONNECTION_MGMT */ typedef ACE_NOOP_Concurrency_Strategy TAO_NULL_ACTIVATION_STRATEGY; typedef ACE_NOOP_Creation_Strategy TAO_NULL_CREATION_STRATEGY; protected: TAO_ORB_Core *orb_core_; // ORB Core. TAO_IIOP_Handler_Base::TCP_Properties tcp_properties_; // TCP configuration properties to be used for all // connections established by this connector. private: TAO_NULL_ACTIVATION_STRATEGY null_activation_strategy_; TAO_NULL_CREATION_STRATEGY null_creation_strategy_; TAO_IIOP_BASE_CONNECTOR base_connector_; // The connector initiating connection requests for IIOP. CORBA::Boolean lite_flag_; // Do we need to use a GIOP_Lite for sending messages? #if defined (TAO_USES_ROBUST_CONNECTION_MGMT) TAO_CACHED_CONNECT_STRATEGY *cached_connect_strategy_; // Cached connect strategy. TAO_CACHING_STRATEGY *caching_strategy_; // Caching strategy which decides the order of removal of entries // from the connection cache. #endif /* TAO_USES_ROBUST_CONNECTION_MGMT */ }; #include "ace/post.h" #endif /* TAO_IIOP_CONNECTOR_H */