summaryrefslogtreecommitdiff
path: root/TAO/tao/any.h
blob: a16f9b95ac658e4d9e95b87331032f95a3b76356 (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
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
// This may look like C, but it's really -*- C++ -*-

// ============================================================================
//
// = LIBRARY
//    TAO
//
// = FILENAME
//    any.h
//
// = DESCRIPTION
//     Header file for Win32 C/C++/COM interface to CORBA's "Any" type.
//
// = AUTHOR
//     Copyright 1994-1995 by Sun Microsystems, Inc.
//
//     Remaining CORBA compliant functions added by Aniruddha Gokhale
//
// ============================================================================

#if !defined (TAO_ANY_H)
#define TAO_ANY_H

class TAO_Export CORBA_Any
  //
  // = TITLE
  //   Class "Any" can wrap values of any type, with the assistance
  //   of a TypeCode to describe that type.
  //
  // = DESCRIPTION
  //   XXX should find a way to make its memory allocation always go
  //   within the appropriate OLE heap...
{
public:
  // = Minor codes for exceptional returns
  enum
  {
    UNINITIALIZED_type = 0xf000,
    VALUE_WITHOUT_TYPE,
    UNSUPPORTED_OPERATION
  };

  // = Initialization and termination operations.
  CORBA_Any (void);
  // Default constructor.

  CORBA_Any (CORBA::TypeCode_ptr type,
	     void *value = 0,
	     CORBA::Boolean orb_owns_data = CORBA::B_FALSE);
  // Constructor.

  CORBA_Any (const CORBA_Any &a);
  // Copy constructor.

  ~CORBA_Any (void);
  // Destructor.

  CORBA_Any &operator= (const CORBA_Any &);
  // assignment operator

  // = NOTE: 94-9-14 has assignment operator plus many insertion, as specified
  // below

  // =type safe insertion

  void operator<<= (CORBA::Short);
  // insert a short

  void operator<<= (CORBA::UShort);
  // insert an unsigned short

  void operator<<= (CORBA::Long);
  // insert a long

  void operator<<= (CORBA::ULong);
  // insert an unsigned long

  void operator<<= (CORBA::Float);
  // insert a float

  void operator<<= (CORBA::Double);
  // insert a double

  void operator<<= (const CORBA_Any&);
  // insert an Any

  void operator<<= (const char*);
  // insert unbounded strings

  // =type safe extraction

  CORBA::Boolean operator>>= (CORBA::Short&) const;
  // extract a short

  CORBA::Boolean operator>>= (CORBA::UShort&) const;
  // extract an unsigned short

  CORBA::Boolean operator>>= (CORBA::Long&) const;
  // extract a long

  CORBA::Boolean operator>>= (CORBA::ULong&) const;
  // extract an unsigned long

  CORBA::Boolean operator>>= (CORBA::Float&) const;
  // extract a float

  CORBA::Boolean operator>>= (CORBA::Double&) const;
  // extract a double

  CORBA::Boolean operator>>= (CORBA_Any&) const;
  // extract an Any

  CORBA::Boolean operator>>= (char*&) const;
  // extract an unbounded string

  // special types needed for insertion and extraction of booleans, octets,
  // chars, and bounded strings

  struct from_boolean
  {
    from_boolean (CORBA::Boolean b);
    CORBA::Boolean val_;
  };

  struct from_octet
  {
    from_octet (CORBA::Octet o);
    CORBA::Octet val_;
  };

  struct from_char
  {
    from_char (CORBA::Char c);
    CORBA::Char val_;
  };

  struct from_string
  {
    from_string (char* s, CORBA::ULong b,
		 CORBA::Boolean nocopy = CORBA::B_FALSE);
    char *val_;
    CORBA::ULong bound_;
    CORBA::Boolean nocopy_;
  };

  void operator<<= (from_boolean);
  // insert a boolean

  void operator<<= (from_char);
  // insert a char

  void operator<<= (from_octet);
  // insert an octet

  void operator<<= (from_string);
  // insert a bounded string

  // special types for extracting octets, chars, booleans, bounded
  // strings, and object references

  struct to_boolean
  {
    to_boolean (CORBA::Boolean &b);
    CORBA::Boolean &ref_;
  };

  struct to_char
  {
    to_char (CORBA::Char &c);
    CORBA::Char &ref_;
  };

  struct to_octet
  {
    to_octet (CORBA::Octet &o);
    CORBA::Octet &ref_;
  };

  struct to_string
  {
    to_string (char *&s, CORBA::ULong b);
    char *&val_;
    CORBA::ULong bound_;
  };

  struct to_object
  {
    to_object (CORBA::Object_ptr &obj);
    CORBA::Object_ptr &ref_;
  };

  // extraction of the special types
  CORBA::Boolean operator>>= (to_boolean) const;
  CORBA::Boolean operator>>= (to_octet) const;
  CORBA::Boolean operator>>= (to_char) const;
  CORBA::Boolean operator>>= (to_string) const;
  CORBA::Boolean operator>>= (to_object) const;

  // = ALLOCATION
  void *operator new (size_t, const void *p);
  // Placement new.
  void *operator new (size_t s);
  // Default new.
  void operator delete (void *p);
  // Default delete

  void replace (CORBA::TypeCode_ptr type,
		const void *value,
		CORBA::Boolean orb_owns_data,
		CORBA::Environment &env);
  // replace the current typecode and data with the specified one - unsafe

  CORBA::TypeCode_ptr type (void) const;
  // Return TypeCode of the element stored in the Any

  const void *value (void) const;
  // Returns 0 if the Any has not been assigned a value, following the
  // CORBA spec (TODO: give a reference) it returns a non-zero value
  // otherwise. TAO does *not* guarantee that this value may be
  // casted to the contained type safely.

  // = Methods required for COM <IUnknown> support.

  CORBA::ULong AddRef (void);
  CORBA::ULong Release (void);

private:
  CORBA::TypeCode_ptr type_;
  // Typecode for the <Any>.

  void *value_;
  // Value for the <Any>.

  CORBA::Boolean orb_owns_data_;
  // Flag that indicates the ORB is responsible for deleting the data.

  CORBA::ULong refcount_;
  // Reference count the <Any> to reduce copying costs.

  void replace (CORBA::TypeCode_ptr type,
		const void *value,
		CORBA::Boolean orb_owns_data);
  // Helper for extraction operators that don't pass an environment
  // parameter.


  // 94-9-14 hides unsigned char insert/extract
  void operator<<= (unsigned char);
  CORBA::Boolean operator>>= (unsigned char&) const;
};

class TAO_Export CORBA_Any_var
  // = TITLE
  //   Provide for automatic storage deallocation on going out of scope.
{
public:
  CORBA_Any_var (void);
  // default constructor

  CORBA_Any_var (CORBA_Any *a);
  // construct from an Any pointer

  CORBA_Any_var (const CORBA_Any_var &a);
  // copy constructor

  ~CORBA_Any_var (void);
  // destructor

  CORBA_Any_var &operator= (CORBA_Any *a);
  // assignment from a pointer to Any

  CORBA_Any_var &operator= (const CORBA_Any_var &a);
  // assignment from an Any_var

  CORBA_Any *operator-> (void);
  // arrow operator (smart pointer)

  operator const CORBA_Any *() const;
  // cast

  operator CORBA_Any *&();
  // cast

  const CORBA_Any &in (void) const;
  // for in Any parameter

  CORBA_Any &inout (void);
  // for inout Any parameter

  CORBA_Any *&out (void);
  // for out Any parameter

  CORBA_Any *_retn (void);
  // for Any return types

private:
  CORBA_Any *ptr_;
};

class TAO_Export CORBA_Any_out
  // = TITLE
  //   @@ (ANDY) Please document me.
{
public:
  // = operations.

  CORBA_Any_out (CORBA_Any *&p);
  // construction from a reference to a CORBA_Any

  CORBA_Any_out (CORBA_Any_var &p);
  // construction from a var

  CORBA_Any_out (CORBA_Any_out &s);
  // copy constructor

  CORBA_Any_out &operator= (CORBA_Any_out &s);
  // assignment from a CORBA_Any_out

  CORBA_Any_out &operator= (CORBA_Any *p);
  // assignment from a CORBA_Any

  CORBA_Any_out &operator= (const CORBA_Any *p);
  // assignment from a const CORBA_Any

  operator CORBA_Any *&();
  // cast

  CORBA_Any *& ptr (void);
  // return underlying instance

private:
  CORBA_Any *&ptr_;
  // instance

  void operator= (const CORBA_Any_var &);
  // assignment from _var disallowed
};

#endif /* TAO_ANY_H */