summaryrefslogtreecommitdiff
path: root/ACE/TAO/tao/AnyTypeCode/Recursive_Type_TypeCode.h
diff options
context:
space:
mode:
Diffstat (limited to 'ACE/TAO/tao/AnyTypeCode/Recursive_Type_TypeCode.h')
-rw-r--r--ACE/TAO/tao/AnyTypeCode/Recursive_Type_TypeCode.h191
1 files changed, 191 insertions, 0 deletions
diff --git a/ACE/TAO/tao/AnyTypeCode/Recursive_Type_TypeCode.h b/ACE/TAO/tao/AnyTypeCode/Recursive_Type_TypeCode.h
new file mode 100644
index 00000000000..75bcdd79a30
--- /dev/null
+++ b/ACE/TAO/tao/AnyTypeCode/Recursive_Type_TypeCode.h
@@ -0,0 +1,191 @@
+// -*- C++ -*-
+
+//=============================================================================
+/**
+ * @file Recursive_Type_TypeCode.h
+ *
+ * $Id$
+ *
+ * Header file for a recursive type (@c struct, @c union or
+ * @c valuetype) CORBA::TypeCode.
+ *
+ * @author Ossama Othman
+ */
+//=============================================================================
+
+#ifndef TAO_RECURSIVE_TYPE_TYPECODE_H
+#define TAO_RECURSIVE_TYPE_TYPECODE_H
+
+#include /**/ "ace/pre.h"
+
+#include "tao/Basic_Types.h"
+#include "tao/Typecode_typesC.h"
+#include "ace/Recursive_Thread_Mutex.h"
+
+TAO_BEGIN_VERSIONED_NAMESPACE_DECL
+
+namespace TAO
+{
+ namespace TypeCode
+ {
+
+ /**
+ * @class Recursive_Type
+ *
+ * @brief Recursive type @c TypeCode decorator template.
+ *
+ * This class template decorates the underlying @c TypeCode
+ * implementation @a TypeCodeBase to provide support for IDL
+ * defined recursive types. Only IDL an @c struct, @c union or
+ * @c valuetype may be recursive, which is why this decorator only
+ * supports constructors for the corresponding @c TypeCode
+ * implementations.
+ */
+ template <class TypeCodeBase,
+ typename TypeCodeType,
+ typename MemberArrayType>
+ class Recursive_Type
+ : public TypeCodeBase
+ {
+ public:
+
+ /// Recursive @c struct constructor.
+ Recursive_Type (CORBA::TCKind kind,
+ char const * id,
+ char const * name,
+ MemberArrayType const & fields,
+ CORBA::ULong nfields);
+
+ /// Recursive @c union constructor.
+ Recursive_Type (char const * id,
+ char const * name,
+ TypeCodeType const & discriminant_type,
+ MemberArrayType const & cases,
+ CORBA::ULong ncases,
+ CORBA::Long default_index);
+
+ /// Recursive @c valuetype constructor.
+ Recursive_Type (CORBA::TCKind kind,
+ char const * id,
+ char const * name,
+ CORBA::ValueModifier modifier,
+ TypeCodeType const & concrete_base,
+ MemberArrayType const & fields,
+ CORBA::ULong nfields);
+
+ /// Dynamic @c Recursive_Type TypeCode constructor.
+ Recursive_Type (CORBA::TCKind kind,
+ char const * id);
+
+ /**
+ * @name TAO-specific @c CORBA::TypeCode Methods
+ *
+ * Methods required by TAO's implementation of the
+ * @c CORBA::TypeCode class.
+ *
+ * @par
+ *
+ * These are recursive type @c TypeCode marshaling operation
+ * overrides.
+ *
+ * @see @c CORBA::TypeCode
+ */
+ //@{
+ virtual bool tao_marshal_kind (TAO_OutputCDR & cdr) const;
+ virtual bool tao_marshal (TAO_OutputCDR & cdr,
+ CORBA::ULong offset) const;
+ //@}
+
+ protected:
+
+ /**
+ * @name TAO @c CORBA::TypeCode Template Methods
+ *
+ * Recursive type @c CORBA::TypeCode -specific
+ * template methods.
+ *
+ * @see @c CORBA::TypeCode
+ */
+ //@{
+ virtual CORBA::Boolean equal_i (CORBA::TypeCode_ptr tc) const;
+ virtual CORBA::Boolean equivalent_i (CORBA::TypeCode_ptr tc) const;
+ //@}
+
+ public:
+
+ /// Set @c struct @c TypeCode parameters.
+ bool struct_parameters (char const * name,
+ MemberArrayType const & fields,
+ CORBA::ULong nfields);
+
+ /// Set @c union @c TypeCode parameters.
+ bool union_parameters (
+ char const * name,
+ TypeCodeType const & discriminant_type,
+ MemberArrayType const & cases,
+ CORBA::ULong ncases,
+ CORBA::Long default_index);
+
+ /// Set @c valuetype or @c eventtype @c TypeCode parameters.
+ bool valuetype_parameters (char const * name,
+ CORBA::ValueModifier modifier,
+ TypeCodeType const & concrete_base,
+ MemberArrayType const & fields,
+ CORBA::ULong nfields);
+
+ private:
+
+ /**
+ * @class Reset
+ *
+ * @brief Reset flag to false in an exception-safe manner.
+ *
+ * Reset flag to false in an exception-safe manner.
+ */
+ class Reset
+ {
+ public:
+ Reset (bool & flag) : flag_ (flag) { }
+ ~Reset (void) { this->flag_ = false; }
+ private:
+ bool & flag_;
+ };
+
+ private:
+
+ /// Internal state thread synchronization mutex.
+ mutable TAO_SYNCH_RECURSIVE_MUTEX lock_;
+
+ /// @c true if equality or equivalence is being determined
+ /// recursively.
+ /**
+ * This flag is used to prevent @c TypeCode equality and
+ * equivalence operations from recursing indefinitely.
+ */
+ mutable bool in_recursion_;
+
+ /// Track whether data has been initialized.
+ bool data_initialized_;
+ };
+
+ } // End namespace TypeCode
+} // End namespace TAO
+
+TAO_END_VERSIONED_NAMESPACE_DECL
+
+
+#ifdef __ACE_INLINE__
+# include "tao/AnyTypeCode/Recursive_Type_TypeCode.inl"
+#endif /* __ACE_INLINE__ */
+
+#ifdef ACE_TEMPLATES_REQUIRE_SOURCE
+# include "tao/AnyTypeCode/Recursive_Type_TypeCode.cpp"
+#endif /* ACE_TEMPLATES_REQUIRE_SOURCE */
+
+#ifdef ACE_TEMPLATES_REQUIRE_PRAGMA
+# pragma implementation ("Recursive_Type_TypeCode.cpp")
+#endif /* ACE_TEMPLATES_REQUIRE_PRAGMA */
+
+#include /**/ "ace/post.h"
+
+#endif /* TAO_RECURSIVE_TYPE_TYPECODE_H */