summaryrefslogtreecommitdiff
path: root/TAO/tao/Sequence_TypeCode.cpp
blob: 8dbd0ba8b121b225550b6abb5e6fbf8faf4103a8 (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
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
// $Id$

#ifndef TAO_SEQUENCE_TYPECODE_CPP
#define TAO_SEQUENCE_TYPECODE_CPP

#include "tao/Sequence_TypeCode.h"

#ifndef __ACE_INLINE__
# include "tao/Sequence_TypeCode.inl"
#endif  /* !__ACE_INLINE__ */

#include "tao/RefCount_Policy_Traits.h"


template <class RefCountPolicy>
TAO::TypeCode::Sequence<RefCountPolicy>::~Sequence (void)
{
#if !defined (_MSC_VER) || (_MSC_VER >= 1310)

  if (this->content_type_)
    TAO::RefCount_Policy_Traits<RefCountPolicy,
                                CORBA::TypeCode_ptr>::release (
      *this->content_type_);

#else

  // MSVC++ 6 can't handle partial template specializations.

  if (TAO::RefCount_Policy_Traits<RefCountPolicy>::is_refcounted ()
      && this->content_type_)
    CORBA::release (*this->content_type_);

#endif  /* !_MSC_VER ||_MSC_VER >= 1310 */
}

template <class RefCountPolicy>
bool
TAO::TypeCode::Sequence<RefCountPolicy>::tao_marshal (
  TAO_OutputCDR & cdr) const
{
  // A tk_array or tk_sequence TypeCode has a "complex" parameter list
  // type (see Table 15-2 in Section 15.3.5.1 "TypeCode" in the CDR
  // section of the CORBA specification), meaning that it must be
  // marshaled into a CDR encapsulation.

  // Create a CDR encapsulation.
  return
    (cdr << TAO_OutputCDR::from_boolean (TAO_ENCAP_BYTE_ORDER))
    && (cdr << *(this->content_type_))
    && (cdr << this->length_);
}

template <class RefCountPolicy>
void
TAO::TypeCode::Sequence<RefCountPolicy>::tao_duplicate (void)
{
  this->RefCountPolicy::add_ref ();
}

template <class RefCountPolicy>
void
TAO::TypeCode::Sequence<RefCountPolicy>::tao_release (void)
{
  this->RefCountPolicy::remove_ref ();
}

template <class RefCountPolicy>
CORBA::Boolean
TAO::TypeCode::Sequence<RefCountPolicy>::equal_i (CORBA::TypeCode_ptr tc
                                               ACE_ENV_ARG_DECL) const
{
  // The following calls won't throw since CORBA::TypeCode::equal()
  // has already established the kind of tc is the same as our kind.
  CORBA::ULong const tc_length = tc->length (ACE_ENV_SINGLE_ARG_PARAMETER);
  ACE_CHECK_RETURN (0);

  if (this->length_ != tc_length)
    return 0;

  CORBA::TypeCode_var rhs_content_type =
    tc->content_type (ACE_ENV_SINGLE_ARG_PARAMETER);
  ACE_CHECK_RETURN (0);

  return (*this->content_type_)->equal (rhs_content_type.in ()
                                        ACE_ENV_ARG_PARAMETER);
}

template <class RefCountPolicy>
CORBA::Boolean
TAO::TypeCode::Sequence<RefCountPolicy>::equivalent_i (CORBA::TypeCode_ptr tc
                                                     ACE_ENV_ARG_DECL) const
{
  // We could refactor this code to the CORBA::TypeCode::equivalent()
  // method but doing so would force us to determine the unaliased
  // kind of this TypeCode.  Since we already know the unaliased kind
  // of this TypeCode, choose to optimize away the additional kind
  // unaliasing operation rather than save space.

  CORBA::TCKind const tc_kind =
    TAO::unaliased_kind (tc
                         ACE_ENV_ARG_PARAMETER);
  ACE_CHECK_RETURN (0);

  if (tc_kind != this->kind_)
    return 0;

  CORBA::TypeCode_var rhs_content_type =
    tc->content_type (ACE_ENV_SINGLE_ARG_PARAMETER);
  ACE_CHECK_RETURN (0);

  return (*this->content_type_)->equivalent (rhs_content_type.in ()
                                             ACE_ENV_ARG_PARAMETER);
}

template <class RefCountPolicy>
CORBA::TCKind
TAO::TypeCode::Sequence<RefCountPolicy>::kind_i (
  ACE_ENV_SINGLE_ARG_DECL_NOT_USED) const
{
  return this->kind_;
}

template <class RefCountPolicy>
CORBA::TypeCode_ptr
TAO::TypeCode::Sequence<RefCountPolicy>::get_compact_typecode_i (
  ACE_ENV_SINGLE_ARG_DECL_NOT_USED) const
{
  // Already compact since tk_sequence and tk_array TypeCodes have no
  // name or member names, meaning that we can simply call
  // _duplicate() on this TypeCode.

  CORBA::TypeCode_ptr mutable_tc =
    const_cast<TAO::TypeCode::Sequence<RefCountPolicy> *> (this);

  return CORBA::TypeCode::_duplicate (mutable_tc);
}

template <class RefCountPolicy>
CORBA::ULong
TAO::TypeCode::Sequence<RefCountPolicy>::length_i (
  ACE_ENV_SINGLE_ARG_DECL_NOT_USED) const
{
  return this->length_;
}

template <class RefCountPolicy>
CORBA::TypeCode_ptr
TAO::TypeCode::Sequence<RefCountPolicy>::content_type_i (
  ACE_ENV_SINGLE_ARG_DECL_NOT_USED) const
{
  return CORBA::TypeCode::_duplicate (*this->content_type_);
}


#endif  /* TAO_SEQUENCE_TYPECODE_CPP */