// -*- C++ -*- //============================================================================= /** * @file Servant_Base.h * * $Id$ * * @author Irfan Pyarali */ //============================================================================= #ifndef TAO_SERVANT_BASE_H #define TAO_SERVANT_BASE_H #include /**/ "ace/pre.h" #include "tao/PortableServer/portableserver_export.h" #if !defined (ACE_LACKS_PRAGMA_ONCE) # pragma once #endif /* ACE_LACKS_PRAGMA_ONCE */ #include "tao/PortableServer/PS_ForwardC.h" #include "tao/PortableServer/Servant_var.h" #include "tao/Abstract_Servant_Base.h" #include "ace/Atomic_Op.h" TAO_BEGIN_VERSIONED_NAMESPACE_DECL class TAO_Operation_Table; /** * @class TAO_ServantBase * * @brief Base class for skeletons and servants. * * The POA spec requires that all servants inherit from this class' * base class. * * An instance of a servant class derived from * ServantBase initially has a reference count of * one. Invoking _add_ref on the servant instance increases its * reference count by one. Invoking _remove_ref on the servant * instance decreases its reference count by one; if the * resulting reference count equals zero, _remove_ref invokes * delete on its this pointer in order to destroy the * servant. For ORBs that operate in multi-threaded * environments, the implementations of _add_ref and _remove_ref * that the ServantBase class provides shall be * thread-safe. * * Like ServantBase supports copy * construction and the default assignment operation. Copy * construction always sets the reference count of the new * servant instance to one. The default assignment * implementation merely returns *this and does not affect the * reference count. * */ class TAO_PortableServer_Export TAO_ServantBase : public virtual TAO_Abstract_ServantBase { public: /// Useful for template programming. typedef CORBA::Object _stub_type; typedef CORBA::Object_ptr _stub_ptr_type; typedef CORBA::Object_var _stub_var_type; /// Destructor. virtual ~TAO_ServantBase (void); /// Returns the default POA for this servant. virtual PortableServer::POA_ptr _default_POA (void); /// Local implementation of the CORBA::Object::_is_a method. virtual CORBA::Boolean _is_a (const char *logical_type_id); /// Default _non_existent: always returns false. virtual CORBA::Boolean _non_existent (void); /// Query the Interface Repository for the interface definition. virtual CORBA::InterfaceDef_ptr _get_interface (void); /// Default _get_component: always returns CORBA::Object::_nil(). virtual CORBA::Object_ptr _get_component (void); /// Get the repository id. virtual char * _repository_id (void); /// This is an auxiliary method for _this() and _narrow(). virtual TAO_Stub *_create_stub (void); /** * Dispatches a request to the object: find the operation, cast the * type to the most derived type, demarshall all the parameters from * the request and finally invokes the operation, storing the * results and out parameters (if any) or the exceptions thrown into * @a request. */ virtual void _dispatch (TAO_ServerRequest &request, void *servant_upcall) = 0; /// Please see documentation in tao/Abstract_Servant_Base.h for /// details. virtual int _find (const char *opname, TAO_Skeleton &skelfunc, const size_t length = 0); virtual int _find (const char *opname, TAO_Collocated_Skeleton &skelfunc, TAO::Collocation_Strategy st, const size_t length = 0); /// Get this interface's repository id (TAO specific). virtual const char *_interface_repository_id (void) const = 0; //@{ /** * @name Reference Counting Operations */ /// Increase reference count by one. virtual void _add_ref (void); /** * Decreases reference count by one; if the resulting reference * count equals zero, _remove_ref invokes delete on its this pointer * in order to destroy the servant. */ virtual void _remove_ref (void); /** * Returns the current reference count value. */ virtual CORBA::ULong _refcount_value (void) const; //@} protected: /// Default constructor, only derived classes can be created. TAO_ServantBase (void); /// Copy constructor, protected so no instances can be created. TAO_ServantBase (const TAO_ServantBase &); /// Assignment operator. TAO_ServantBase &operator= (const TAO_ServantBase &); virtual void synchronous_upcall_dispatch (TAO_ServerRequest & req, void * servant_upcall, void * derived_this); virtual void asynchronous_upcall_dispatch (TAO_ServerRequest & req, void * servant_upcall, void * derived_this); protected: /// Reference counter. ACE_Atomic_Op ref_count_; /// The operation table for this servant. It is initialized by the /// most derived class. TAO_Operation_Table * optable_; }; class TAO_PortableServer_Export TAO_Servant_Hash { public: /// Returns hash value. u_long operator () (PortableServer::Servant servant) const; }; namespace PortableServer { typedef Servant_var ServantBase_var; } TAO_END_VERSIONED_NAMESPACE_DECL #if defined (__ACE_INLINE__) # include "tao/PortableServer/Servant_Base.inl" #endif /* __ACE_INLINE__ */ #include /**/ "ace/post.h" #endif /* TAO_SERVANT_BASE_H */