blob: 80a1fc61cbd604e9125b040cba9c48e456e2b014 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
|
// -*- C++ -*-
//=============================================================================
/**
* @file Sequence_TypeCode.h
*
* Header file for @c tk_sequence and @c tk_array @c CORBA::TypeCodes.
*
* @author Ossama Othman <ossama@dre.vanderbilt.edu>
*/
//=============================================================================
#ifndef TAO_SEQUENCE_TYPECODE_H
#define TAO_SEQUENCE_TYPECODE_H
#include /**/ "ace/pre.h"
#include "tao/AnyTypeCode/TypeCode.h"
#if !defined (ACE_LACKS_PRAGMA_ONCE)
# pragma once
#endif /* ACE_LACKS_PRAGMA_ONCE */
TAO_BEGIN_VERSIONED_NAMESPACE_DECL
namespace TAO
{
namespace TypeCode
{
/**
* @class Sequence
*
* @brief @c CORBA::TypeCode implementation for OMG IDL
* @c sequence and @c array types.
*
* This class implements a @c CORBA::TypeCode for OMG IDL
* @c sequence and array types.
*/
template <typename TypeCodeType, class RefCountPolicy>
class Sequence
: public CORBA::TypeCode
, private RefCountPolicy
{
public:
/// Constructor.
Sequence (CORBA::TCKind kind,
TypeCodeType const & content_type,
CORBA::ULong length);
/**
* @name TAO-specific @c CORBA::TypeCode Methods
*
* Methods required by TAO's implementation of the
* @c CORBA::TypeCode class.
*
* @see @c CORBA::TypeCode
*/
//@{
virtual bool tao_marshal (TAO_OutputCDR & cdr, CORBA::ULong offset) const;
virtual void tao_duplicate ();
virtual void tao_release ();
//@}
protected:
/**
* @name @c TAO CORBA::TypeCode Template Methods
*
* @c CORBA::TypeCode template methods specific to @c tk_sequence
* @c TypeCodes.
*
* @see @c CORBA::TypeCode
*/
//@{
virtual CORBA::Boolean equal_i (CORBA::TypeCode_ptr tc) const;
virtual CORBA::Boolean equivalent_i (CORBA::TypeCode_ptr tc) const;
virtual CORBA::TypeCode_ptr get_compact_typecode_i () const;
virtual CORBA::ULong length_i () const;
virtual CORBA::TypeCode_ptr content_type_i () const;
private:
/// Element type of the sequence.
/**
* A pointer to the @c CORBA::TypeCode_ptr rather than the
* @c CORBA::TypeCode_ptr itself is stored since that address is
* well-defined. We may not know the value of the @c
* CORBA::TypeCode_ptr when creating this @c Field statically at
* compile-time, hence the indirection.
*
* @note This @c TypeCode is released upon destruction of this
* @c TypeCode::Sequence.
*/
TypeCodeType const content_type_;
/// Length of the @c sequence or array. A length of zero
/// indicates an unbounded @c sequence.
CORBA::ULong const length_;
};
} // End namespace TypeCode
} // End namespace TAO
TAO_END_VERSIONED_NAMESPACE_DECL
#ifdef __ACE_INLINE__
# include "tao/AnyTypeCode/Sequence_TypeCode.inl"
#endif /* __ACE_INLINE__ */
#ifdef ACE_TEMPLATES_REQUIRE_SOURCE
# include "tao/AnyTypeCode/Sequence_TypeCode.cpp"
#endif /* ACE_TEMPLATES_REQUIRE_SOURCE */
#include /**/ "ace/post.h"
#endif /* TAO_SEQUENCE_TYPECODE_H */
|