blob: 870ba6618cc5196569f306a5aa72387a5675835e (
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
|
//
// $Id$
//
// ============================================================================
//
// = LIBRARY
// TAO IDL
//
// = FILENAME
// argument.cpp
//
// = DESCRIPTION
// generic visitor for Argument node
//
// = AUTHOR
// Aniruddha Gokhale
//
// ============================================================================
#include "idl.h"
#include "be.h"
#include "be_visitor_argument.h"
ACE_RCSID(be_visitor_argument, argument, "$Id$")
be_visitor_args::be_visitor_args (be_visitor_context *ctx)
: be_visitor_decl (ctx)
{
}
be_visitor_args::~be_visitor_args (void)
{
}
int be_visitor_args::visit_argument (be_argument *)
{
return -1;
}
// helper that returns the type name either as a nested type name (for header
// files) or as a fully scoped name. In addition, we make sure that if the type
// is an alias, we use that name
const char *
be_visitor_args::type_name (be_type *node,
const char *suffix)
{
static char namebuf [NAMEBUFSIZE];
ACE_OS::memset (namebuf, '\0', NAMEBUFSIZE);
be_type *bt; // type to use
// use the typedefed name if that is the one used in the IDL defn
if (this->ctx_->alias ())
bt = this->ctx_->alias ();
else
bt = node;
ACE_OS::sprintf (namebuf,
"%s",
bt->full_name ());
if (suffix)
ACE_OS::strcat (namebuf,
suffix);
return namebuf;
}
// helper that returns the direction type of the argument
AST_Argument::Direction
be_visitor_args::direction (void)
{
// grab the argument node. We know that our context has stored the right
// argument node
be_argument *arg = this->ctx_->be_node_as_argument ();
ACE_ASSERT (arg != 0);
return arg->direction ();
}
|