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
|
// $Id$
// ============================================================================
//
// = LIBRARY
// TAO IDL
//
// = FILENAME
// be_enum.cpp
//
// = DESCRIPTION
// Extension of class AST_Enum that provides additional means for C++
// mapping.
//
// = AUTHOR
// Copyright 1994-1995 by Sun Microsystems, Inc.
// and
// Aniruddha Gokhale
//
// ============================================================================
#include "be_enum.h"
#include "be_visitor.h"
#include "be_helper.h"
#include "global_extern.h"
be_enum::be_enum (void)
: COMMON_Base (),
AST_Decl (),
AST_Type (),
AST_ConcreteType (),
UTL_Scope (),
AST_Enum (),
be_scope (),
be_decl (),
be_type ()
{
}
be_enum::be_enum (UTL_ScopedName *n,
bool local,
bool abstract)
: COMMON_Base (local,
abstract),
AST_Decl (AST_Decl::NT_enum,
n),
AST_Type (AST_Decl::NT_enum,
n),
AST_ConcreteType (AST_Decl::NT_enum,
n),
UTL_Scope (AST_Decl::NT_enum),
AST_Enum (n,
local,
abstract),
be_scope (AST_Decl::NT_enum),
be_decl (AST_Decl::NT_enum,
n),
be_type (AST_Decl::NT_enum,
n)
{
if (!this->imported ())
{
idl_global->enum_seen_ = true;
}
}
void
be_enum::gen_ostream_operator (TAO_OutStream *os,
bool /* use_underscore */)
{
*os << be_nl
<< "std::ostream& operator<< (std::ostream &strm, const "
<< this->name () << " _tao_enumerator)" << be_nl
<< "{" << be_idt_nl
<< "switch (_tao_enumerator)" << be_idt_nl
<< "{" << be_idt_nl;
for (int i = 0; i < this->member_count (); ++i)
{
UTL_ScopedName *mname =
this->value_to_name (static_cast<unsigned long> (i));
*os << "case " << mname << ": return strm << \""
<< mname << "\";" << be_nl;
}
*os << "default: return strm;" << be_uidt_nl
<< "}" << be_uidt << be_uidt_nl
<< "}" << be_nl;
}
void
be_enum::destroy (void)
{
// Call the destroy methods of our base classes.
// No need to call be_scope::destroy(). It has no
// allocated members, and AST_Enum::destroy() will
// call UTL_Scope::destroy().
this->be_type::destroy ();
this->be_scope::destroy ();
this->AST_Enum::destroy ();
}
int
be_enum::accept (be_visitor *visitor)
{
return visitor->visit_enum (this);
}
IMPL_NARROW_FROM_DECL (be_enum)
IMPL_NARROW_FROM_SCOPE (be_enum)
|