/* -*- C++ -*- */ //============================================================================= /** * @file Service_Object.h * * $Id$ * * @author Douglas C. Schmidt */ //============================================================================= #ifndef ACE_SERVICE_OBJECT_H #define ACE_SERVICE_OBJECT_H #include "ace/pre.h" #include "ace/Shared_Object.h" #include "ace/Svc_Conf_Tokens.h" #if !defined (ACE_LACKS_PRAGMA_ONCE) # pragma once #endif /* ACE_LACKS_PRAGMA_ONCE */ #include "ace/Event_Handler.h" #define ACE_Component ACE_Service_Object /** * @class ACE_Service_Object * * @brief Provide the abstract base class common to all service * implementations. * * Classes that inherit from are capable * of being registered with the (due to the * , as well as being dynamically linked by * the (due to the ). */ class ACE_Export ACE_Service_Object : public ACE_Event_Handler, public ACE_Shared_Object { public: // = Initialization and termination methods. /// Constructor. ACE_Service_Object (ACE_Reactor * = 0); /// Destructor. virtual ~ACE_Service_Object (void); /// Temporarily disable a service without removing it completely. virtual int suspend (void); /// Re-enable a previously suspended service. virtual int resume (void); }; // Forward decl. class ACE_Service_Type_Impl; /** * @class ACE_Service_Type * * @brief Keeps track of information related to the various * subclasses. * * This class acts as the interface of the "Bridge" pattern. */ class ACE_Export ACE_Service_Type { public: enum { /// Delete the payload object. DELETE_OBJ = 1, /// Delete the enclosing object. DELETE_THIS = 2 }; enum { SERVICE_OBJECT = ACE_SVC_OBJ_T, MODULE = ACE_MODULE_T, STREAM = ACE_STREAM_T, INVALID_TYPE = -1 }; // = Initialization and termination methods. ACE_Service_Type (const ACE_TCHAR *n, ACE_Service_Type_Impl *o, const ACE_SHLIB_HANDLE handle, int active); ~ACE_Service_Type (void); const ACE_TCHAR *name (void) const; void name (const ACE_TCHAR *); const ACE_Service_Type_Impl *type (void) const; void type (const ACE_Service_Type_Impl *, int active = 1); ACE_SHLIB_HANDLE handle (void) const; void handle (const ACE_SHLIB_HANDLE); void suspend (void) const; void resume (void) const; int active (void) const; void active (int); /// Calls on void fini (void); /// Check if the service has been fini'ed. int fini_called (void) const; /// Dump the state of an object. void dump (void) const; /// Declare the dynamic allocation hooks. ACE_ALLOC_HOOK_DECLARE; private: /// Humanly readible name of svc. const ACE_TCHAR *name_; /// Pointer to C++ object that implements the svc. const ACE_Service_Type_Impl *type_; /// Handle to shared object file (non-zero if dynamically linked). ACE_SHLIB_HANDLE handle_; /// 1 if svc is currently active, otherwise 0. int active_; /// 1 if on has already been called, otherwise 0. int fini_already_called_; }; /** * @class ACE_Service_Object_Ptr * * @brief This is a smart pointer that holds onto the associated * * until the current scope is left, at * which point the object's hook is called and the * service_object_ gets deleted. * * This class is similar to the Standard C++ Library class * . It is used in conjunction with statically linked * , as shown in the * ./netsvcs/server/main.cpp example. */ class ACE_Export ACE_Service_Object_Ptr { public: // = Initialization and termination methods. /// Acquire ownership of the . ACE_Service_Object_Ptr (ACE_Service_Object *so); /// Release the held by calling its hook. ~ACE_Service_Object_Ptr (void); /// Smart pointer to access the underlying . ACE_Service_Object *operator-> (); private: /// Holds the service object until we're done. ACE_Service_Object *service_object_; }; #if defined (__ACE_INLINE__) #include "ace/Service_Object.i" #endif /* __ACE_INLINE__ */ #include "ace/post.h" #endif /* ACE_SERVICE_OBJECT_H */