blob: a70776479fa4ec0ad3968257223e2b8bfa988ede (
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
|
// $Id$
// ============================================================================
//
// = LIBRARY
// TAO IDL
//
// = FILENAME
// be_array.h
//
// = DESCRIPTION
// Extension of class AST_Array that provides additional means for C++
// mapping.
//
// = AUTHOR
// Copyright 1994-1995 by Sun Microsystems, Inc.
// and
// Aniruddha Gokhale
//
// ============================================================================
#ifndef BE_ARRAY_H
#define BE_ARRAY_H
#include "be_type.h"
#include "ast_array.h"
class UTL_ExprList;
class TAO_OutStream;
class be_visitor;
class be_array : public virtual AST_Array,
public virtual be_type
{
public:
be_array (void);
// Default constructor.
be_array (UTL_ScopedName *n,
unsigned long ndims,
UTL_ExprList *dims,
idl_bool local,
idl_bool abstract);
// Constructor.
~be_array (void);
virtual int gen_dimensions (TAO_OutStream *os,
unsigned short slice = 0);
// Generate dimensions. If slice == 1, generate dimensions for the slice
// definition.
// Visiting.
virtual int accept (be_visitor *visitor);
// Narrowing.
DEF_NARROW_METHODS2 (be_array, AST_Array, be_type);
DEF_NARROW_FROM_DECL (be_array);
protected:
virtual int compute_size_type (void);
// Compute the size type if it is unknown.
virtual int create_name (void);
// Create a name for us.
const char* tao_name (void);
private:
char* tao_name_;
// We need a name to generate typecodes and other objects, but it
// must be different from the typedef name.
};
#endif
|