summaryrefslogtreecommitdiff
path: root/trunk/TAO/tao/Object_Argument_T.h
diff options
context:
space:
mode:
Diffstat (limited to 'trunk/TAO/tao/Object_Argument_T.h')
-rw-r--r--trunk/TAO/tao/Object_Argument_T.h206
1 files changed, 206 insertions, 0 deletions
diff --git a/trunk/TAO/tao/Object_Argument_T.h b/trunk/TAO/tao/Object_Argument_T.h
new file mode 100644
index 00000000000..1479ff7217d
--- /dev/null
+++ b/trunk/TAO/tao/Object_Argument_T.h
@@ -0,0 +1,206 @@
+// -*- C++ -*-
+
+//=============================================================================
+/**
+ * @file Object_Argument_T.h
+ *
+ * $Id$
+ *
+ * @authors Jeff Parsons and Carlos O'Ryan
+ */
+//=============================================================================
+
+
+#ifndef TAO_OBJECT_ARGUMENT_T_H
+#define TAO_OBJECT_ARGUMENT_T_H
+
+#include /**/ "ace/pre.h"
+
+#include "tao/Argument.h"
+
+#if !defined (ACE_LACKS_PRAGMA_ONCE)
+# pragma once
+#endif /* ACE_LACKS_PRAGMA_ONCE */
+
+TAO_BEGIN_VERSIONED_NAMESPACE_DECL
+
+namespace TAO
+{
+ /**
+ * @class In_Object_Argument_T
+ *
+ * @brief Template class for IN object argument.
+ *
+ */
+ template<typename S_ptr,
+ class Insert_Policy>
+ class In_Object_Argument_T : public InArgument
+ {
+ public:
+ In_Object_Argument_T (S_ptr x);
+
+ virtual CORBA::Boolean marshal (TAO_OutputCDR &cdr);
+#if TAO_HAS_INTERCEPTORS == 1
+ virtual void interceptor_value (CORBA::Any *any) const;
+#endif /* TAO_HAS_INTERCEPTORS == 1 */
+ S_ptr arg (void) const;
+
+ protected:
+ S_ptr x_;
+ };
+
+ template<typename S_ptr>
+ struct In_Object_Argument_Cloner_T
+ {
+ static void duplicate(S_ptr objref);
+ static void release(S_ptr objref);
+ };
+
+ /**
+ * @class In_Object_Clonable_Argument_T
+ *
+ * @brief Template class for IN object argument.
+ *
+ */
+ template<typename S_ptr,
+ class Insert_Policy>
+ class In_Object_Clonable_Argument_T :
+ public In_Object_Argument_T<S_ptr, Insert_Policy>
+ {
+ public:
+ In_Object_Clonable_Argument_T (S_ptr x);
+ virtual ~In_Object_Clonable_Argument_T (void);
+
+ virtual Argument* clone (void);
+
+ private:
+ bool is_clone_;
+ };
+
+ /**
+ * @class Inout_Object_Argument_T
+ *
+ * @brief Template class for INOUT object argument.
+ *
+ */
+ template<typename S_ptr,
+ typename S_traits,
+ class Insert_Policy>
+ class Inout_Object_Argument_T : public InoutArgument
+ {
+ public:
+ Inout_Object_Argument_T (S_ptr & x);
+
+ virtual CORBA::Boolean marshal (TAO_OutputCDR &cdr);
+ virtual CORBA::Boolean demarshal (TAO_InputCDR &cdr);
+#if TAO_HAS_INTERCEPTORS == 1
+ virtual void interceptor_value (CORBA::Any *any) const;
+#endif /* TAO_HAS_INTERCEPTORS == 1 */
+ S_ptr & arg (void);
+
+ private:
+ S_ptr & x_;
+ };
+
+ /**
+ * @class Out_Object_Argument_T
+ *
+ * @brief Template class for OUT object argument.
+ *
+ */
+ template<typename S_ptr,
+ typename S_out,
+ class Insert_Policy>
+ class Out_Object_Argument_T : public OutArgument
+ {
+ public:
+ Out_Object_Argument_T (S_out & x);
+
+ virtual CORBA::Boolean demarshal (TAO_InputCDR &cdr);
+#if TAO_HAS_INTERCEPTORS == 1
+ virtual void interceptor_value (CORBA::Any *any) const;
+#endif /* TAO_HAS_INTERCEPTORS == 1 */
+ S_out arg (void);
+
+ private:
+ S_ptr & x_;
+ };
+
+ /**
+ * @class Ret_Object_Argument_T
+ *
+ * @brief Template class for return stub value of object argument.
+ *
+ */
+ template<typename S_ptr,
+ typename S_var,
+ class Insert_Policy>
+ class Ret_Object_Argument_T : public RetArgument
+ {
+ public:
+
+ Ret_Object_Argument_T (void);
+
+ virtual CORBA::Boolean demarshal (TAO_InputCDR &);
+#if TAO_HAS_INTERCEPTORS == 1
+ virtual void interceptor_value (CORBA::Any *any) const;
+#endif /* TAO_HAS_INTERCEPTORS == 1 */
+ S_ptr & arg (void);
+
+ S_ptr excp (void);
+ S_ptr retn (void);
+
+ private:
+ S_var x_;
+ };
+
+ /**
+ * @struct Object_Arg_Traits_T
+ *
+ * @brief Template class for stub argument traits of objects.
+ */
+ template<typename T_ptr,
+ typename T_var,
+ typename T_out,
+ typename T_traits,
+ class Insert_Policy>
+ struct Object_Arg_Traits_T
+ {
+ typedef T_ptr ret_type;
+ typedef T_ptr in_type;
+ typedef T_ptr & inout_type;
+ typedef T_out out_type;
+
+ typedef In_Object_Argument_T<T_ptr,
+ Insert_Policy> in_arg_val;
+ typedef In_Object_Clonable_Argument_T<T_ptr,
+ Insert_Policy> in_clonable_arg_val;
+ typedef Inout_Object_Argument_T<T_ptr,
+ T_traits,
+ Insert_Policy> inout_arg_val;
+ typedef Out_Object_Argument_T<T_ptr,
+ T_out,
+ Insert_Policy> out_arg_val;
+ typedef Ret_Object_Argument_T<T_ptr,
+ T_var,
+ Insert_Policy> ret_val;
+ };
+}
+
+TAO_END_VERSIONED_NAMESPACE_DECL
+
+#if defined (__ACE_INLINE__)
+#include "tao/Object_Argument_T.inl"
+#endif /* __ACE_INLINE__ */
+
+#if defined (ACE_TEMPLATES_REQUIRE_SOURCE)
+#include "tao/Object_Argument_T.cpp"
+#endif /* ACE_TEMPLATES_REQUIRE_SOURCE */
+
+#if defined (ACE_TEMPLATES_REQUIRE_PRAGMA)
+#pragma implementation ("Object_Argument_T.cpp")
+#endif /* ACE_TEMPLATES_REQUIRE_PRAGMA */
+
+#include /**/ "ace/post.h"
+
+#endif /* TAO_OBJECT_ARGUMENT_T_H */