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
|
/* -*- c++ -*- */
// $Id$
// ============================================================================
//
// = LIBRARY
// TAO IDL
//
// = FILENAME
// be_interface.h
//
// = DESCRIPTION
// Extension of class AST_Interface that provides additional means for C++
// mapping of an interface.
//
// = AUTHOR
// Copyright 1994-1995 by Sun Microsystems, Inc.
// and
// Aniruddha Gokhale
//
// ============================================================================
#ifndef TAO_BE_INTERFACE_H
#define TAO_BE_INTERFACE_H
class TAO_OutStream;
/*
* BE_Interface
*/
class be_interface : public virtual AST_Interface,
public virtual be_scope,
public virtual be_type
{
// = TITLE
// The back end extension of the AST_Interface class
//
// = DESCRIPTION
//
public:
// used to pass functions to the template method
typedef int (*tao_code_emitter) (be_interface *, be_interface *, TAO_OutStream *);
// Operations
be_interface (void);
// Default constructor
be_interface (UTL_ScopedName *n, AST_Interface **ih, long nih,
UTL_StrList *p);
// Constructor that sets its scoped name <n>, a list of inherited interfaces
// <ih>, the number of inherited interfaces <nih>, and any prgmas <p>
~be_interface (void);
// dtor
virtual int gen_var_defn (void);
// generate the _var class definition
virtual int gen_var_impl (void);
// generate the implementation for the _var class
virtual int gen_out_defn (void);
// generate the _out class definition
virtual int gen_out_impl (void);
// generate the _out implementation
const char *full_skel_name (void);
// retrieve the fully scoped skel class name
//
// Each interface (to fix names "T") also defines two help classes,
// the "collocated" class inherits from T, but delegates on the
// skeleton for T (usually POA_T or POA_ModuleName::T), in other
// words it is a Bridge from T to its implementation.
// The class is nested inside the skeleton class.
//
// The "stub" is a class defined on the client scope, it actually
// defines the stubs (all operations in T are pure virtual).
// @@ TODO currently the stub class is not implemented.
//
const char *full_coll_name (void);
// retrieve the fully qualified collocated class name
const char *local_coll_name (void) const;
// retrieve the fully qualified collocated class name
virtual int gen_typecode (void);
// generate the typecode
virtual int gen_encapsulation (void);
// encapsulation for parameters
virtual long tc_size (void);
// return typecode size
virtual long tc_encap_len (void);
// return length of encapsulation
virtual int traverse_inheritance_graph (tao_code_emitter gen,
TAO_OutStream *os);
// template method using breadth first traversal of inheritance graph
const char *relative_skel_name (const char *other_class_name);
// relative skeleton name
const char *relative_coll_name (const char *other_class_name);
// relative name for collocated class.
int in_mult_inheritance (void);
// am I in some form of multiple inheritance
// -1 => error
// 0 => no
// 1 => yes
void in_mult_inheritance (int mi);
// set a new value
// Visiting
virtual int accept (be_visitor *visitor);
// Narrowing
DEF_NARROW_METHODS3 (be_interface, AST_Interface, be_scope, be_type);
DEF_NARROW_FROM_DECL (be_interface);
DEF_NARROW_FROM_SCOPE (be_interface);
static int is_a_helper (be_interface *, be_interface *, TAO_OutStream *os);
// helper method passed to the template method that generates code for the
// is_a method
static int downcast_helper (be_interface *,
be_interface *,
TAO_OutStream *os);
// helper method passed to the template method that generates code for the
// downcast.
static int gen_optable_helper (be_interface *,
be_interface *,
TAO_OutStream *os);
// helper method passed to the template method to generate code for the
// operation table
static int gen_skel_helper (be_interface *,
be_interface *,
TAO_OutStream *os);
// helper method passed to the template method to generate code for the
// skeletons in the inline file
static int collocated_ctor_helper (be_interface *,
be_interface *,
TAO_OutStream *os);
// helper method passed to the template method to invoke ctors of all the
// base classes.
static int copy_ctor_helper (be_interface *,
be_interface *,
TAO_OutStream *os);
// helper method passed to the template method to invoke ctors of all the
// base classes.
static int in_mult_inheritance_helper (be_interface *,
be_interface *,
TAO_OutStream *os);
// helper method to determine if the interface node is involved in some kind
// of multiple inheritance or not. Required on the skeleton side
void compute_fullskelname (void);
// compute the fully scoped skel class name
int gen_operation_table (void);
// generate the operation table including entries for inherited interfaces
static const char *relative_name (const char* our_name,
const char *other_class_name);
// relative name for collocated class.
int gen_optable_entries (be_interface *);
// generate the operation table entries.
void compute_coll_name (void);
// compute the fully qualified collocated class name.
private:
void gen_gperf_input_header (TAO_OutStream *ss);
// Output the header (type declaration and %%) to the gperf's input
// file.
int gen_gperf_things (void);
// Run GPERF and get the correct lookup and other operations
// depending on which strategy we are using. Returns 0 on sucess, -1
// on error.
void gen_perfect_hash_class_definition (void);
// Outputs the class definition for the perfect hashing. This class
// will inherit from the TAO_Perfect_Hash_OpTable.
void gen_binary_search_class_definition (void);
// Outputs the class definition for the binary search . This class
// will inherit from the TAO_Binary_Search_OpTable.
void gen_linear_search_class_definition (void);
// Outputs the class defintion for the linear search. This class
// will inherit from the TAO_Linear_Search.
int gen_gperf_lookup_methods (void);
// This calls the GPERF program and gets the correct operation
// lookup methods for the current OpLookup strategy.
void gen_perfect_hash_instance (void);
// Create an instance of this perfect hash table.
void gen_binary_search_instance (void);
// Create an instance of the binary search optable.
void gen_linear_search_instance (void);
// Create an instance of the linear search optable.
char *full_skel_name_;
// Fully scoped skeleton name.
int skel_count_;
// Number of static skeletons in the operation table.
char *full_coll_name_;
// full collocated name
char *local_coll_name_;
// local collocated name
int in_mult_inheritance_;
// am I directly or indirectly involved in a multiple inheritance. If the
// value is -1 => not computed yet.
};
#endif // if !defined
|