summaryrefslogtreecommitdiff
path: root/trunk/TAO/tao/Var_Array_Argument_T.h
diff options
context:
space:
mode:
Diffstat (limited to 'trunk/TAO/tao/Var_Array_Argument_T.h')
-rw-r--r--trunk/TAO/tao/Var_Array_Argument_T.h195
1 files changed, 195 insertions, 0 deletions
diff --git a/trunk/TAO/tao/Var_Array_Argument_T.h b/trunk/TAO/tao/Var_Array_Argument_T.h
new file mode 100644
index 00000000000..622c7bbf27d
--- /dev/null
+++ b/trunk/TAO/tao/Var_Array_Argument_T.h
@@ -0,0 +1,195 @@
+// -*- C++ -*-
+
+//=============================================================================
+/**
+ * @file Var_Array_Argument_T.h
+ *
+ * $Id$
+ *
+ * @authors Jeff Parsons and Carlos O'Ryan
+ */
+//=============================================================================
+
+#ifndef TAO_VAR_ARRAY_ARGUMENT_T_H
+#define TAO_VAR_ARRAY_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_Var_Array_Argument_T
+ *
+ * @brief IN stub argument of variable size element array.
+ *
+ */
+ template<typename S_forany,
+ class Insert_Policy>
+ class In_Var_Array_Argument_T : public InArgument
+ {
+ public:
+ In_Var_Array_Argument_T (const typename S_forany::_slice_type * 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 */
+ typename S_forany::_slice_type const * arg (void) const;
+
+ protected:
+ S_forany x_;
+ };
+
+ /**
+ * @class In_Var_Array_Clonable_Argument_T
+ *
+ * @brief IN stub argument of variable size element array.
+ *
+ */
+ template<typename S_forany,
+ class Insert_Policy>
+ class In_Var_Array_Clonable_Argument_T :
+ public In_Var_Array_Argument_T<S_forany, Insert_Policy>
+ {
+ public:
+ In_Var_Array_Clonable_Argument_T (const typename S_forany::_slice_type * x);
+ virtual ~In_Var_Array_Clonable_Argument_T (void);
+
+ virtual Argument* clone (void);
+
+ private:
+ bool is_clone_;
+ };
+
+ /**
+ * @class Inout_Var_Array_Argument_T
+ *
+ * @brief INOUT stub argument of variable size element array.
+ *
+ */
+ template<typename S_forany,
+ class Insert_Policy>
+ class Inout_Var_Array_Argument_T : public InoutArgument
+ {
+ public:
+ Inout_Var_Array_Argument_T (typename S_forany::_slice_type *&x);
+
+ virtual CORBA::Boolean marshal (TAO_OutputCDR &cdr);
+ virtual CORBA::Boolean demarshal (TAO_InputCDR &);
+#if TAO_HAS_INTERCEPTORS == 1
+ virtual void interceptor_value (CORBA::Any *any) const;
+#endif /* TAO_HAS_INTERCEPTORS == 1 */
+ typename S_forany::_slice_type * arg (void);
+
+ private:
+ S_forany x_;
+ };
+
+ /**
+ * @class Out_Var_Array_Argument_T
+ *
+ * @brief OUT stub argument of variable size element array.
+ *
+ */
+ template<typename S_out,
+ typename S_forany,
+ class Insert_Policy>
+ class Out_Var_Array_Argument_T : public OutArgument
+ {
+ public:
+ Out_Var_Array_Argument_T (S_out x);
+
+ virtual CORBA::Boolean demarshal (TAO_InputCDR &);
+#if TAO_HAS_INTERCEPTORS == 1
+ virtual void interceptor_value (CORBA::Any *any) const;
+#endif /* TAO_HAS_INTERCEPTORS == 1 */
+ typename S_forany::_slice_type *& arg (void);
+
+ private:
+ typename S_forany::_slice_type *& x_;
+ };
+
+ /**
+ * @class Ret_Var_Array_Argument_T
+ *
+ * @brief Return stub value of variable size element array.
+ *
+ */
+ template<typename S_var,
+ typename S_forany,
+ class Insert_Policy>
+ class Ret_Var_Array_Argument_T : public RetArgument
+ {
+ public:
+ Ret_Var_Array_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 */
+ typename S_forany::_slice_type *& arg (void);
+
+ typename S_forany::_slice_type * excp (void);
+ typename S_forany::_slice_type * retn (void);
+
+ private:
+ S_var x_;
+ };
+
+ /**
+ * @struct Var_Array_Arg_Traits_T
+ *
+ * @brief Argument traits of variable size element array.
+ *
+ */
+ template<typename T_out,
+ typename T_forany,
+ class Insert_Policy>
+ struct Var_Array_Arg_Traits_T
+ {
+ typedef typename T_forany::_slice_type * ret_type;
+ typedef const typename T_forany::_array_type in_type;
+ typedef typename T_forany::_array_type inout_type;
+ typedef T_out out_type;
+
+ typedef In_Var_Array_Argument_T<T_forany,
+ Insert_Policy> in_arg_val;
+ typedef In_Var_Array_Clonable_Argument_T<T_forany,
+ Insert_Policy>
+ in_clonable_arg_val;
+ typedef Inout_Var_Array_Argument_T<T_forany,
+ Insert_Policy> inout_arg_val;
+ typedef Out_Var_Array_Argument_T<T_out,
+ T_forany,
+ Insert_Policy> out_arg_val;
+ typedef Ret_Var_Array_Argument_T<typename T_out::_var_type,
+ T_forany,
+ Insert_Policy> ret_val;
+ };
+}
+
+TAO_END_VERSIONED_NAMESPACE_DECL
+
+#if defined (__ACE_INLINE__)
+#include "tao/Var_Array_Argument_T.inl"
+#endif /* __ACE_INLINE__ */
+
+#if defined (ACE_TEMPLATES_REQUIRE_SOURCE)
+#include "tao/Var_Array_Argument_T.cpp"
+#endif /* ACE_TEMPLATES_REQUIRE_SOURCE */
+
+#if defined (ACE_TEMPLATES_REQUIRE_PRAGMA)
+#pragma implementation ("Var_Array_Argument_T.cpp")
+#endif /* ACE_TEMPLATES_REQUIRE_PRAGMA */
+
+#include /**/ "ace/post.h"
+
+#endif /* TAO_VAR_ARRAY_ARGUMENT_T_H */