summaryrefslogtreecommitdiff
path: root/TAO/tao/TypeCode_Non_Default_Case.cpp
blob: ba451c3ad976b507e4444532d321b4e6b2dbe7fc (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
// $Id$

#ifndef TAO_TYPECODE_NON_DEFAULT_CASE_CPP
#define TAO_TYPECODE_NON_DEFAULT_CASE_CPP

#include "TypeCode_Non_Default_Case.h"

#include "tao/CDR.h"
#include "tao/Any.h"

#ifndef __ACE_INLINE__
# include "tao/TypeCode_Non_Default_Case.inl"
#endif /* __ACE_INLINE__ */

namespace TAO
{
  namespace TypeCode
  {
    template <typename T>
    struct Case_Traits
    {
      inline static T any_from (T v)
      {
        return v;
      }

      inline static T any_to (T & v)
      {
        return v;
      }
    };

    // Specializations for types that require wrapper for Any
    // insertion.  Note that we only define specializations for types
    // that can be used in an IDL union discriminator.

    template <>
    struct Case_Traits<CORBA::Boolean>
    {
      inline static CORBA::Any::from_boolean any_from (CORBA::Boolean v)
      {
        return CORBA::Any::from_boolean (v);
      }

      inline static CORBA::Any::to_boolean any_to (CORBA::Boolean & v)
      {
        return CORBA::Any::to_boolean (v);
      }
    };

    template <>
    struct Case_Traits<CORBA::Char>
    {
      inline static CORBA::Any::from_char any_from (CORBA::Char v)
      {
        return CORBA::Any::from_char (v);
      }

      inline static CORBA::Any::to_char any_to (CORBA::Char & v)
      {
        return CORBA::Any::to_char (v);
      }
    };

    template <>
    struct Case_Traits<CORBA::WChar>
    {
      inline static CORBA::Any::from_wchar any_from (CORBA::WChar v)
      {
        return CORBA::Any::from_wchar (v);
      }

      inline static CORBA::Any::to_wchar any_to (CORBA::WChar & v)
      {
        return CORBA::Any::to_wchar (v);
      }
    };

  } // End TypeCode namespace
}  // End TAO namespace

// ----------------------------------------------------------------

template <typename DISCRIMINATOR_TYPE, typename STRING_TYPE>
bool
TAO::TypeCode::Non_Default_Case<DISCRIMINATOR_TYPE,
                                STRING_TYPE>::marshal_label (
  TAO_OutputCDR & cdr) const
{
  return (cdr << this->label_);
}

template <typename DISCRIMINATOR_TYPE, typename STRING_TYPE>
bool
TAO::TypeCode::Non_Default_Case<DISCRIMINATOR_TYPE,
                                STRING_TYPE>::equal_label (
  CORBA::ULong index
  CORBA::TypeCode_ptr tc
  ACE_ENV_ARG_DECL) const
{
  CORBA::Any_var const any = tc->member_label (index
                                               ACE_ENV_ARG_PARAMETER);
  ACE_CHECK_RETURN (false);

  // The equality operator==() below is guaranteed to be defined for
  // the discriminator type since an IDL union discriminator type must
  // be any of the following: (1) an integer, (2) a character, (3) a
  // boolean, or (4) an enumeration.

  DISCRIMINATOR_TYPE tc_label;
  if (any.in ()
        >>= TAO::TypeCode::Case_Traits<DISCRIMINATOR_TYPE>::any_to (tc_label)
      && this->label_ == tc_label)
    {
      return true;
    }

  return false;
}

template <typename DISCRIMINATOR_TYPE, typename STRING_TYPE>
CORBA::Any *
TAO::TypeCode::Non_Default_Case<DISCRIMINATOR_TYPE, STRING_TYPE>::label (
  ACE_ENV_SINGLE_ARG_DECL) const
{
  CORBA::Any * value;

  ACE_NEW_THROW_EX (value,
                    CORBA::Any,
                    CORBA::NO_MEMORY ());
  ACE_CHECK_RETURN (0);

  CORBA::Any_var safe_value (value);

  *value <<=
    TAO::TypeCode::Case_Traits<DISCRIMINATOR_TYPE>::any_from (this->label_);

  return safe_value._retn ();
}



#endif  /* TAO_TYPECODE_NON_DEFAULT_CASE_CPP */