blob: c7032dde5024fd8395195f2370d28bc58d866522 (
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
|
//=============================================================================
/**
* @file valuetype_sh.cpp
*
* Visitor generating code for value types in the server header
*
* @author Jeff Parsons
*/
//=============================================================================
#include "valuetype.h"
// ************************************************************
// Valuetype visitor for server header.
// ************************************************************
be_visitor_valuetype_sh::be_visitor_valuetype_sh (be_visitor_context *ctx)
: be_visitor_valuetype (ctx)
{
}
be_visitor_valuetype_sh::~be_visitor_valuetype_sh ()
{
}
int
be_visitor_valuetype_sh::visit_valuetype (be_valuetype *node)
{
if (node->srv_hdr_gen () || node->imported () || node->is_abstract ())
{
return 0;
}
AST_Type *concrete = node->supports_concrete ();
// We generate a skeleton class only if the valuetype supports a
// non-abstract interface.
if (concrete == nullptr)
{
return 0;
}
TAO_OutStream *os = this->ctx_->stream ();
os->indent ();
ACE_CString class_name;
// We shall have a POA_ prefix only if we are at the topmost level.
if (!node->is_nested ())
{
// We are outermost.
class_name += "POA_";
class_name += node->local_name ();
}
else
{
class_name += node->local_name ();
}
*os << "// TAO_IDL - Generated from" << be_nl
<< "// " << __FILE__ << ":" << __LINE__ << be_nl_2;
// Generate the skeleton class name.
*os << "class " << class_name.c_str () << ";" << be_nl;
// Generate the _ptr declaration.
*os << "typedef " << class_name.c_str () << " *" << class_name.c_str ()
<< "_ptr;" << be_nl;
// Forward class declaration.
*os << "// Forward Classes Declaration" << be_nl;
if (be_global->gen_direct_collocation ())
{
*os << "class " << node->direct_proxy_impl_name () << ";" << be_nl;
}
*os << be_nl;
// Now generate the class definition.
*os << "class " << be_global->skel_export_macro ()
<< " " << class_name.c_str () << be_idt_nl << ": " << be_idt;
*os << "public virtual " << "POA_"
<< concrete->name () << ",";
*os << be_nl << "public virtual " << "::" << node->full_name ();
*os << be_uidt << be_uidt_nl
<< "{" << be_nl
<< "protected:" << be_idt_nl
<< class_name.c_str () << " ();" << be_uidt_nl << be_nl
<< "public:" << be_idt_nl;
*os << "virtual ~" << class_name.c_str () << " ();" << be_nl << be_uidt_nl;
// No copy constructor for locality constraint interface.
*os << "private:" << be_idt_nl
<< class_name.c_str () << " (const " << class_name.c_str ()
<< "& rhs);" << be_uidt_nl;
*os << "};" << be_nl_2;
return 0;
}
int
be_visitor_valuetype_sh::visit_eventtype (be_eventtype *node)
{
return this->visit_valuetype (node);
}
|