annotate dmd/mtype.h @ 1137:45d73f0a9b43

Automated merge with http://hg.dsource.org/projects/ldc
author Christian Kamm <kamm incasoftware de>
date Tue, 24 Mar 2009 14:34:16 +0100
parents b30fe7e1dbb9
children 1860414bf3b7
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
1
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
2 // Compiler implementation of the D programming language
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
3 // Copyright (c) 1999-2007 by Digital Mars
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
4 // All Rights Reserved
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
5 // written by Walter Bright
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
6 // http://www.digitalmars.com
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
7 // License for redistribution is by either the Artistic License
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
8 // in artistic.txt, or the GNU General Public License in gnu.txt.
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
9 // See the included readme.txt for details.
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
10
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
11 #ifndef DMD_MTYPE_H
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
12 #define DMD_MTYPE_H
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
13
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
14 #ifdef __DMC__
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
15 #pragma once
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
16 #endif /* __DMC__ */
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
17
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
18 #include "root.h"
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
19 #include "stringtable.h"
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
20
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
21 #include "arraytypes.h"
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
22 #include "expression.h"
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
23
173
db9890b3fb64 [svn r189] moving IR data back into DMD frontend nodes
ChristianK
parents: 162
diff changeset
24 // llvm
db9890b3fb64 [svn r189] moving IR data back into DMD frontend nodes
ChristianK
parents: 162
diff changeset
25 #include "../ir/irtype.h"
1051
dc608dc33081 Make IrFuncTy a member of TypeFunction. Reset between modules compiled in the
Christian Kamm <kamm incasoftware de>
parents: 1029
diff changeset
26 #include "../ir/irfuncty.h"
938
a904cc9bc064 Convert struct arg to integer when passing inreg to make sure LLVM doesn't
Christian Kamm <kamm incasoftware de>
parents: 930
diff changeset
27 namespace llvm { class Type; }
173
db9890b3fb64 [svn r189] moving IR data back into DMD frontend nodes
ChristianK
parents: 162
diff changeset
28
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
29 struct Scope;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
30 struct Identifier;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
31 struct Expression;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
32 struct StructDeclaration;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
33 struct ClassDeclaration;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
34 struct VarDeclaration;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
35 struct EnumDeclaration;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
36 struct TypedefDeclaration;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
37 struct TypeInfoDeclaration;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
38 struct Dsymbol;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
39 struct TemplateInstance;
1103
b30fe7e1dbb9 - Updated to DMD frontend 1.041.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1051
diff changeset
40 struct CppMangleState;
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
41 enum LINK;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
42
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
43 struct TypeBasic;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
44 struct HdrGenState;
1103
b30fe7e1dbb9 - Updated to DMD frontend 1.041.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1051
diff changeset
45 struct Argument;
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
46
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
47 // Back end
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
48 #if IN_GCC
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
49 union tree_node; typedef union tree_node TYPE;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
50 typedef TYPE type;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
51 #else
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
52 typedef struct TYPE type;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
53 #endif
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
54 struct Symbol;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
55
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
56 enum TY
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
57 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
58 Tarray, // dynamic array
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
59 Tsarray, // static array
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
60 Taarray, // associative array
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
61 Tpointer,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
62 Treference,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
63 Tfunction,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
64 Tident,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
65 Tclass,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
66 Tstruct,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
67 Tenum,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
68 Ttypedef,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
69 Tdelegate,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
70
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
71 Tnone,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
72 Tvoid,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
73 Tint8,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
74 Tuns8,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
75 Tint16,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
76 Tuns16,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
77 Tint32,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
78 Tuns32,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
79 Tint64,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
80 Tuns64,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
81 Tfloat32,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
82 Tfloat64,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
83 Tfloat80,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
84
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
85 Timaginary32,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
86 Timaginary64,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
87 Timaginary80,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
88
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
89 Tcomplex32,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
90 Tcomplex64,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
91 Tcomplex80,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
92
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
93 Tbit,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
94 Tbool,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
95 Tchar,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
96 Twchar,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
97 Tdchar,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
98
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
99 Terror,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
100 Tinstance,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
101 Ttypeof,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
102 Ttuple,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
103 Tslice,
1103
b30fe7e1dbb9 - Updated to DMD frontend 1.041.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1051
diff changeset
104 Treturn,
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
105 TMAX
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
106 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
107
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
108 #define Tascii Tchar
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
109
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
110 extern int Tsize_t;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
111 extern int Tptrdiff_t;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
112
1103
b30fe7e1dbb9 - Updated to DMD frontend 1.041.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1051
diff changeset
113
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
114 struct Type : Object
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
115 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
116 TY ty;
1103
b30fe7e1dbb9 - Updated to DMD frontend 1.041.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1051
diff changeset
117 unsigned char mod; // modifiers MODxxxx
b30fe7e1dbb9 - Updated to DMD frontend 1.041.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1051
diff changeset
118 /* pick this order of numbers so switch statements work better
b30fe7e1dbb9 - Updated to DMD frontend 1.041.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1051
diff changeset
119 */
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
120 #define MODconst 1 // type is const
1103
b30fe7e1dbb9 - Updated to DMD frontend 1.041.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1051
diff changeset
121 #define MODinvariant 4 // type is invariant
b30fe7e1dbb9 - Updated to DMD frontend 1.041.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1051
diff changeset
122 #define MODshared 2 // type is shared
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
123 char *deco;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
124 Type *pto; // merged pointer to this type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
125 Type *rto; // reference to this type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
126 Type *arrayof; // array of this type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
127 TypeInfoDeclaration *vtinfo; // TypeInfo object for this Type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
128
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
129 type *ctype; // for back end
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
130
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
131 #define tvoid basic[Tvoid]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
132 #define tint8 basic[Tint8]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
133 #define tuns8 basic[Tuns8]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
134 #define tint16 basic[Tint16]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
135 #define tuns16 basic[Tuns16]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
136 #define tint32 basic[Tint32]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
137 #define tuns32 basic[Tuns32]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
138 #define tint64 basic[Tint64]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
139 #define tuns64 basic[Tuns64]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
140 #define tfloat32 basic[Tfloat32]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
141 #define tfloat64 basic[Tfloat64]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
142 #define tfloat80 basic[Tfloat80]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
143
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
144 #define timaginary32 basic[Timaginary32]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
145 #define timaginary64 basic[Timaginary64]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
146 #define timaginary80 basic[Timaginary80]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
147
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
148 #define tcomplex32 basic[Tcomplex32]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
149 #define tcomplex64 basic[Tcomplex64]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
150 #define tcomplex80 basic[Tcomplex80]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
151
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
152 #define tbit basic[Tbit]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
153 #define tbool basic[Tbool]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
154 #define tchar basic[Tchar]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
155 #define twchar basic[Twchar]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
156 #define tdchar basic[Tdchar]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
157
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
158 // Some special types
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
159 #define tshiftcnt tint32 // right side of shift expression
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
160 // #define tboolean tint32 // result of boolean expression
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
161 #define tboolean tbool // result of boolean expression
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
162 #define tindex tint32 // array/ptr index
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
163 static Type *tvoidptr; // void*
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
164 #define terror basic[Terror] // for error recovery
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
165
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
166 #define tsize_t basic[Tsize_t] // matches size_t alias
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
167 #define tptrdiff_t basic[Tptrdiff_t] // matches ptrdiff_t alias
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
168 #define thash_t tsize_t // matches hash_t alias
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
169
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
170 static ClassDeclaration *typeinfo;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
171 static ClassDeclaration *typeinfoclass;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
172 static ClassDeclaration *typeinfointerface;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
173 static ClassDeclaration *typeinfostruct;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
174 static ClassDeclaration *typeinfotypedef;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
175 static ClassDeclaration *typeinfopointer;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
176 static ClassDeclaration *typeinfoarray;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
177 static ClassDeclaration *typeinfostaticarray;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
178 static ClassDeclaration *typeinfoassociativearray;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
179 static ClassDeclaration *typeinfoenum;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
180 static ClassDeclaration *typeinfofunction;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
181 static ClassDeclaration *typeinfodelegate;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
182 static ClassDeclaration *typeinfotypelist;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
183
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
184 static Type *basic[TMAX];
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
185 static unsigned char mangleChar[TMAX];
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
186 static StringTable stringtable;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
187
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
188 // These tables are for implicit conversion of binary ops;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
189 // the indices are the type of operand one, followed by operand two.
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
190 static unsigned char impcnvResult[TMAX][TMAX];
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
191 static unsigned char impcnvType1[TMAX][TMAX];
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
192 static unsigned char impcnvType2[TMAX][TMAX];
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
193
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
194 // If !=0, give warning on implicit conversion
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
195 static unsigned char impcnvWarn[TMAX][TMAX];
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
196
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
197 Type(TY ty, Type *next);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
198 virtual Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
199 int equals(Object *o);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
200 int dyncast() { return DYNCAST_TYPE; } // kludge for template.isType()
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
201 int covariant(Type *t);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
202 char *toChars();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
203 static char needThisPrefix();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
204 static void init();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
205 d_uns64 size();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
206 virtual d_uns64 size(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
207 virtual unsigned alignsize();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
208 virtual Type *semantic(Loc loc, Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
209 virtual void toDecoBuffer(OutBuffer *buf);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
210 Type *merge();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
211 virtual void toCBuffer(OutBuffer *buf, Identifier *ident, HdrGenState *hgs);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
212 virtual void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
213 void toCBuffer3(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
214 virtual int isbit();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
215 virtual int isintegral();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
216 virtual int isfloating(); // real, imaginary, or complex
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
217 virtual int isreal();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
218 virtual int isimaginary();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
219 virtual int iscomplex();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
220 virtual int isscalar();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
221 virtual int isunsigned();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
222 virtual int isauto();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
223 virtual int isString();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
224 virtual int checkBoolean(); // if can be converted to boolean value
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
225 void checkDeprecated(Loc loc, Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
226 Type *pointerTo();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
227 Type *referenceTo();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
228 Type *arrayOf();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
229 virtual Dsymbol *toDsymbol(Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
230 virtual Type *toBasetype();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
231 virtual int isBaseOf(Type *t, int *poffset);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
232 virtual MATCH implicitConvTo(Type *to);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
233 virtual ClassDeclaration *isClassHandle();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
234 virtual Expression *getProperty(Loc loc, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
235 virtual Expression *dotExp(Scope *sc, Expression *e, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
236 virtual unsigned memalign(unsigned salign);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
237 virtual Expression *defaultInit(Loc loc = 0);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
238 virtual int isZeroInit(); // if initializer is 0
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
239 virtual dt_t **toDt(dt_t **pdt);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
240 Identifier *getTypeInfoIdent(int internal);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
241 virtual MATCH deduceType(Scope *sc, Type *tparam, TemplateParameters *parameters, Objects *dedtypes);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
242 virtual void resolve(Loc loc, Scope *sc, Expression **pe, Type **pt, Dsymbol **ps);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
243 Expression *getInternalTypeInfo(Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
244 Expression *getTypeInfo(Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
245 virtual TypeInfoDeclaration *getTypeInfoDeclaration();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
246 virtual int builtinTypeInfo();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
247 virtual Type *reliesOnTident();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
248 virtual Expression *toExpression();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
249 virtual int hasPointers();
1103
b30fe7e1dbb9 - Updated to DMD frontend 1.041.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1051
diff changeset
250 Type *next;
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
251 Type *nextOf() { return next; }
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
252
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
253 static void error(Loc loc, const char *format, ...);
1103
b30fe7e1dbb9 - Updated to DMD frontend 1.041.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1051
diff changeset
254 static void warning(Loc loc, const char *format, ...);
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
255
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
256 // For backend
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
257 virtual unsigned totym();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
258 virtual type *toCtype();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
259 virtual type *toCParamtype();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
260 virtual Symbol *toSymbol();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
261
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
262 // For eliminating dynamic_cast
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
263 virtual TypeBasic *isTypeBasic();
173
db9890b3fb64 [svn r189] moving IR data back into DMD frontend nodes
ChristianK
parents: 162
diff changeset
264
663
6aaa3d3c1183 First part of rename to LDC.
Christian Kamm <kamm incasoftware de>
parents: 658
diff changeset
265 // LDC
173
db9890b3fb64 [svn r189] moving IR data back into DMD frontend nodes
ChristianK
parents: 162
diff changeset
266 IrType ir;
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
267 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
268
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
269 struct TypeBasic : Type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
270 {
658
50383e476c7e Upgraded frontend to DMD 1.035
Tomas Lindquist Olsen <tomas.l.olsen@gmail.com>
parents: 508
diff changeset
271 const char *dstring;
50383e476c7e Upgraded frontend to DMD 1.035
Tomas Lindquist Olsen <tomas.l.olsen@gmail.com>
parents: 508
diff changeset
272 const char *cstring;
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
273 unsigned flags;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
274
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
275 TypeBasic(TY ty);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
276 Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
277 d_uns64 size(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
278 unsigned alignsize();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
279 Expression *getProperty(Loc loc, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
280 Expression *dotExp(Scope *sc, Expression *e, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
281 char *toChars();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
282 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
283 int isintegral();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
284 int isbit();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
285 int isfloating();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
286 int isreal();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
287 int isimaginary();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
288 int iscomplex();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
289 int isscalar();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
290 int isunsigned();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
291 MATCH implicitConvTo(Type *to);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
292 Expression *defaultInit(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
293 int isZeroInit();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
294 int builtinTypeInfo();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
295
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
296 // For eliminating dynamic_cast
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
297 TypeBasic *isTypeBasic();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
298 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
299
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
300 struct TypeArray : Type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
301 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
302 TypeArray(TY ty, Type *next);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
303 Expression *dotExp(Scope *sc, Expression *e, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
304 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
305
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
306 // Static array, one with a fixed dimension
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
307 struct TypeSArray : TypeArray
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
308 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
309 Expression *dim;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
310
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
311 TypeSArray(Type *t, Expression *dim);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
312 Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
313 d_uns64 size(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
314 unsigned alignsize();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
315 Type *semantic(Loc loc, Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
316 void resolve(Loc loc, Scope *sc, Expression **pe, Type **pt, Dsymbol **ps);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
317 void toDecoBuffer(OutBuffer *buf);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
318 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
319 Expression *dotExp(Scope *sc, Expression *e, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
320 int isString();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
321 int isZeroInit();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
322 unsigned memalign(unsigned salign);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
323 MATCH implicitConvTo(Type *to);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
324 Expression *defaultInit(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
325 dt_t **toDt(dt_t **pdt);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
326 dt_t **toDtElem(dt_t **pdt, Expression *e);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
327 MATCH deduceType(Scope *sc, Type *tparam, TemplateParameters *parameters, Objects *dedtypes);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
328 TypeInfoDeclaration *getTypeInfoDeclaration();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
329 Expression *toExpression();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
330 int hasPointers();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
331
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
332 type *toCtype();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
333 type *toCParamtype();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
334 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
335
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
336 // Dynamic array, no dimension
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
337 struct TypeDArray : TypeArray
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
338 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
339 TypeDArray(Type *t);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
340 Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
341 d_uns64 size(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
342 unsigned alignsize();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
343 Type *semantic(Loc loc, Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
344 void toDecoBuffer(OutBuffer *buf);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
345 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
346 Expression *dotExp(Scope *sc, Expression *e, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
347 int isString();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
348 int isZeroInit();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
349 int checkBoolean();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
350 MATCH implicitConvTo(Type *to);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
351 Expression *defaultInit(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
352 int builtinTypeInfo();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
353 TypeInfoDeclaration *getTypeInfoDeclaration();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
354 int hasPointers();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
355
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
356 type *toCtype();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
357 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
358
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
359 struct TypeAArray : TypeArray
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
360 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
361 Type *index; // key type for type checking
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
362 Type *key; // actual key type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
363
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
364 TypeAArray(Type *t, Type *index);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
365 Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
366 d_uns64 size(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
367 Type *semantic(Loc loc, Scope *sc);
336
aaade6ded589 [svn r357] Merged DMD 1.033
lindquist
parents: 217
diff changeset
368 void resolve(Loc loc, Scope *sc, Expression **pe, Type **pt, Dsymbol **ps);
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
369 void toDecoBuffer(OutBuffer *buf);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
370 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
371 Expression *dotExp(Scope *sc, Expression *e, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
372 Expression *defaultInit(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
373 MATCH deduceType(Scope *sc, Type *tparam, TemplateParameters *parameters, Objects *dedtypes);
211
f66219e0d530 [svn r227] Fixed: crash in lifetime.d when resizing array of AAs by .length assignment.
lindquist
parents: 173
diff changeset
374 int isZeroInit();
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
375 int checkBoolean();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
376 TypeInfoDeclaration *getTypeInfoDeclaration();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
377 int hasPointers();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
378
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
379 // Back end
758
f04dde6e882c Added initial D2 support, D2 frontend and changes to codegen to make things compile.
Tomas Lindquist Olsen <tomas.l.olsen@gmail.com>
parents: 723
diff changeset
380 Symbol *aaGetSymbol(const char *func, int flags);
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
381
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
382 type *toCtype();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
383 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
384
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
385 struct TypePointer : Type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
386 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
387 TypePointer(Type *t);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
388 Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
389 Type *semantic(Loc loc, Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
390 d_uns64 size(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
391 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
392 MATCH implicitConvTo(Type *to);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
393 int isscalar();
663
6aaa3d3c1183 First part of rename to LDC.
Christian Kamm <kamm incasoftware de>
parents: 658
diff changeset
394 // LDC: pointers are unsigned
411
3545f9eddbfc Switch TypePointer::isunsigned from false to true, so CmpExp::toElem chooses the right operand for pointer comparisons.
Christian Kamm <kamm incasoftware de>
parents: 379
diff changeset
395 int isunsigned() { return TRUE; };
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
396 Expression *defaultInit(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
397 int isZeroInit();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
398 TypeInfoDeclaration *getTypeInfoDeclaration();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
399 int hasPointers();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
400
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
401 type *toCtype();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
402 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
403
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
404 struct TypeReference : Type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
405 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
406 TypeReference(Type *t);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
407 Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
408 d_uns64 size(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
409 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
410 Expression *dotExp(Scope *sc, Expression *e, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
411 Expression *defaultInit(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
412 int isZeroInit();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
413 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
414
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
415 enum RET
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
416 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
417 RETregs = 1, // returned in registers
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
418 RETstack = 2, // returned on stack
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
419 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
420
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
421 struct TypeFunction : Type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
422 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
423 Arguments *parameters; // function parameters
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
424 int varargs; // 1: T t, ...) style for variable number of arguments
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
425 // 2: T t ...) style for variable number of arguments
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
426 enum LINK linkage; // calling convention
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
427
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
428 int inuse;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
429
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
430 TypeFunction(Arguments *parameters, Type *treturn, int varargs, enum LINK linkage);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
431 Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
432 Type *semantic(Loc loc, Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
433 void toDecoBuffer(OutBuffer *buf);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
434 void toCBuffer(OutBuffer *buf, Identifier *ident, HdrGenState *hgs);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
435 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
436 MATCH deduceType(Scope *sc, Type *tparam, TemplateParameters *parameters, Objects *dedtypes);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
437 TypeInfoDeclaration *getTypeInfoDeclaration();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
438 Type *reliesOnTident();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
439
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
440 int callMatch(Expressions *toargs);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
441 type *toCtype();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
442 enum RET retStyle();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
443
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
444 unsigned totym();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
445
663
6aaa3d3c1183 First part of rename to LDC.
Christian Kamm <kamm incasoftware de>
parents: 658
diff changeset
446 // LDC
1051
dc608dc33081 Make IrFuncTy a member of TypeFunction. Reset between modules compiled in the
Christian Kamm <kamm incasoftware de>
parents: 1029
diff changeset
447 IrFuncTy fty;
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
448 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
449
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
450 struct TypeDelegate : Type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
451 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
452 TypeDelegate(Type *t);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
453 Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
454 Type *semantic(Loc loc, Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
455 d_uns64 size(Loc loc);
797
340acf1535d0 Removed KDevelop3 project files, CMake can generate them just fine!
Tomas Lindquist Olsen <tomas.l.olsen@gmail.com>
parents: 758
diff changeset
456 unsigned alignsize(); // added in LDC
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
457 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
458 Expression *defaultInit(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
459 int isZeroInit();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
460 int checkBoolean();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
461 TypeInfoDeclaration *getTypeInfoDeclaration();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
462 Expression *dotExp(Scope *sc, Expression *e, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
463 int hasPointers();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
464
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
465 type *toCtype();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
466 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
467
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
468 struct TypeQualified : Type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
469 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
470 Loc loc;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
471 Array idents; // array of Identifier's representing ident.ident.ident etc.
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
472
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
473 TypeQualified(TY ty, Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
474 void syntaxCopyHelper(TypeQualified *t);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
475 void addIdent(Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
476 void toCBuffer2Helper(OutBuffer *buf, HdrGenState *hgs);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
477 d_uns64 size(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
478 void resolveHelper(Loc loc, Scope *sc, Dsymbol *s, Dsymbol *scopesym,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
479 Expression **pe, Type **pt, Dsymbol **ps);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
480 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
481
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
482 struct TypeIdentifier : TypeQualified
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
483 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
484 Identifier *ident;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
485
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
486 TypeIdentifier(Loc loc, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
487 Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
488 //char *toChars();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
489 void toDecoBuffer(OutBuffer *buf);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
490 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
491 void resolve(Loc loc, Scope *sc, Expression **pe, Type **pt, Dsymbol **ps);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
492 Dsymbol *toDsymbol(Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
493 Type *semantic(Loc loc, Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
494 MATCH deduceType(Scope *sc, Type *tparam, TemplateParameters *parameters, Objects *dedtypes);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
495 Type *reliesOnTident();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
496 Expression *toExpression();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
497 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
498
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
499 /* Similar to TypeIdentifier, but with a TemplateInstance as the root
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
500 */
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
501 struct TypeInstance : TypeQualified
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
502 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
503 TemplateInstance *tempinst;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
504
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
505 TypeInstance(Loc loc, TemplateInstance *tempinst);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
506 Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
507 //char *toChars();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
508 //void toDecoBuffer(OutBuffer *buf);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
509 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
510 void resolve(Loc loc, Scope *sc, Expression **pe, Type **pt, Dsymbol **ps);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
511 Type *semantic(Loc loc, Scope *sc);
875
330f999ade44 Merged DMD 1.038
Tomas Lindquist Olsen <tomas.l.olsen@gmail.com>
parents: 797
diff changeset
512 Dsymbol *toDsymbol(Scope *sc);
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
513 MATCH deduceType(Scope *sc, Type *tparam, TemplateParameters *parameters, Objects *dedtypes);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
514 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
515
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
516 struct TypeTypeof : TypeQualified
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
517 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
518 Expression *exp;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
519
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
520 TypeTypeof(Loc loc, Expression *exp);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
521 Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
522 Dsymbol *toDsymbol(Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
523 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
524 Type *semantic(Loc loc, Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
525 d_uns64 size(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
526 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
527
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
528 struct TypeStruct : Type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
529 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
530 StructDeclaration *sym;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
531
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
532 TypeStruct(StructDeclaration *sym);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
533 d_uns64 size(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
534 unsigned alignsize();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
535 char *toChars();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
536 Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
537 Type *semantic(Loc loc, Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
538 Dsymbol *toDsymbol(Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
539 void toDecoBuffer(OutBuffer *buf);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
540 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
541 Expression *dotExp(Scope *sc, Expression *e, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
542 unsigned memalign(unsigned salign);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
543 Expression *defaultInit(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
544 int isZeroInit();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
545 int checkBoolean();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
546 dt_t **toDt(dt_t **pdt);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
547 MATCH deduceType(Scope *sc, Type *tparam, TemplateParameters *parameters, Objects *dedtypes);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
548 TypeInfoDeclaration *getTypeInfoDeclaration();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
549 int hasPointers();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
550
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
551 type *toCtype();
1029
4d366a75d95f Added hasUnalignedFields helper to check if a type has unaligned fields - as per request from fvbommel. Result is cached in TypeStruct.
Tomas Lindquist Olsen <tomas.l.olsen@gmail.com>
parents: 1024
diff changeset
552
4d366a75d95f Added hasUnalignedFields helper to check if a type has unaligned fields - as per request from fvbommel. Result is cached in TypeStruct.
Tomas Lindquist Olsen <tomas.l.olsen@gmail.com>
parents: 1024
diff changeset
553 // LDC
4d366a75d95f Added hasUnalignedFields helper to check if a type has unaligned fields - as per request from fvbommel. Result is cached in TypeStruct.
Tomas Lindquist Olsen <tomas.l.olsen@gmail.com>
parents: 1024
diff changeset
554 // cache the hasUnalignedFields check
4d366a75d95f Added hasUnalignedFields helper to check if a type has unaligned fields - as per request from fvbommel. Result is cached in TypeStruct.
Tomas Lindquist Olsen <tomas.l.olsen@gmail.com>
parents: 1024
diff changeset
555 // 0 = not checked, 1 = aligned, 2 = unaligned
4d366a75d95f Added hasUnalignedFields helper to check if a type has unaligned fields - as per request from fvbommel. Result is cached in TypeStruct.
Tomas Lindquist Olsen <tomas.l.olsen@gmail.com>
parents: 1024
diff changeset
556 int unaligned;
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
557 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
558
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
559 struct TypeEnum : Type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
560 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
561 EnumDeclaration *sym;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
562
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
563 TypeEnum(EnumDeclaration *sym);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
564 d_uns64 size(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
565 unsigned alignsize();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
566 char *toChars();
486
a34078905d01 Added pragma(llvmdc, "string") for misc per-module compiler configuration, currently "string" can only be "verbose" which forces -vv for module it appears in.
Tomas Lindquist Olsen <tomas.l.olsen@gmail.com>
parents: 445
diff changeset
567 Type *syntaxCopy();
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
568 Type *semantic(Loc loc, Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
569 Dsymbol *toDsymbol(Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
570 void toDecoBuffer(OutBuffer *buf);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
571 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
572 Expression *dotExp(Scope *sc, Expression *e, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
573 Expression *getProperty(Loc loc, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
574 int isintegral();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
575 int isfloating();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
576 int isscalar();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
577 int isunsigned();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
578 MATCH implicitConvTo(Type *to);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
579 Type *toBasetype();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
580 Expression *defaultInit(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
581 int isZeroInit();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
582 MATCH deduceType(Scope *sc, Type *tparam, TemplateParameters *parameters, Objects *dedtypes);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
583 TypeInfoDeclaration *getTypeInfoDeclaration();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
584 int hasPointers();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
585
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
586 type *toCtype();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
587 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
588
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
589 struct TypeTypedef : Type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
590 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
591 TypedefDeclaration *sym;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
592
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
593 TypeTypedef(TypedefDeclaration *sym);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
594 Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
595 d_uns64 size(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
596 unsigned alignsize();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
597 char *toChars();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
598 Type *semantic(Loc loc, Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
599 Dsymbol *toDsymbol(Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
600 void toDecoBuffer(OutBuffer *buf);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
601 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
602 Expression *dotExp(Scope *sc, Expression *e, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
603 Expression *getProperty(Loc loc, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
604 int isbit();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
605 int isintegral();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
606 int isfloating();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
607 int isreal();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
608 int isimaginary();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
609 int iscomplex();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
610 int isscalar();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
611 int isunsigned();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
612 int checkBoolean();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
613 Type *toBasetype();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
614 MATCH implicitConvTo(Type *to);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
615 Expression *defaultInit(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
616 int isZeroInit();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
617 dt_t **toDt(dt_t **pdt);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
618 MATCH deduceType(Scope *sc, Type *tparam, TemplateParameters *parameters, Objects *dedtypes);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
619 TypeInfoDeclaration *getTypeInfoDeclaration();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
620 int hasPointers();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
621
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
622 type *toCtype();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
623 type *toCParamtype();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
624 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
625
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
626 struct TypeClass : Type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
627 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
628 ClassDeclaration *sym;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
629
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
630 TypeClass(ClassDeclaration *sym);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
631 d_uns64 size(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
632 char *toChars();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
633 Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
634 Type *semantic(Loc loc, Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
635 Dsymbol *toDsymbol(Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
636 void toDecoBuffer(OutBuffer *buf);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
637 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
638 Expression *dotExp(Scope *sc, Expression *e, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
639 ClassDeclaration *isClassHandle();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
640 int isBaseOf(Type *t, int *poffset);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
641 MATCH implicitConvTo(Type *to);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
642 Expression *defaultInit(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
643 int isZeroInit();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
644 MATCH deduceType(Scope *sc, Type *tparam, TemplateParameters *parameters, Objects *dedtypes);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
645 int isauto();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
646 int checkBoolean();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
647 TypeInfoDeclaration *getTypeInfoDeclaration();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
648 int hasPointers();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
649
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
650 type *toCtype();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
651
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
652 Symbol *toSymbol();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
653 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
654
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
655 struct TypeTuple : Type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
656 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
657 Arguments *arguments; // types making up the tuple
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
658
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
659 TypeTuple(Arguments *arguments);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
660 TypeTuple(Expressions *exps);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
661 Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
662 Type *semantic(Loc loc, Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
663 int equals(Object *o);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
664 Type *reliesOnTident();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
665 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
666 void toDecoBuffer(OutBuffer *buf);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
667 Expression *getProperty(Loc loc, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
668 TypeInfoDeclaration *getTypeInfoDeclaration();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
669 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
670
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
671 struct TypeSlice : Type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
672 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
673 Expression *lwr;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
674 Expression *upr;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
675
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
676 TypeSlice(Type *next, Expression *lwr, Expression *upr);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
677 Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
678 Type *semantic(Loc loc, Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
679 void resolve(Loc loc, Scope *sc, Expression **pe, Type **pt, Dsymbol **ps);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
680 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
681 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
682
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
683 /**************************************************************/
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
684
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
685 //enum InOut { None, In, Out, InOut, Lazy };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
686
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
687 struct Argument : Object
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
688 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
689 //enum InOut inout;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
690 unsigned storageClass;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
691 Type *type;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
692 Identifier *ident;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
693 Expression *defaultArg;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
694
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
695 Argument(unsigned storageClass, Type *type, Identifier *ident, Expression *defaultArg);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
696 Argument *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
697 Type *isLazyArray();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
698 void toDecoBuffer(OutBuffer *buf);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
699 static Arguments *arraySyntaxCopy(Arguments *args);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
700 static char *argsTypesToChars(Arguments *args, int varargs);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
701 static void argsToCBuffer(OutBuffer *buf, HdrGenState *hgs, Arguments *arguments, int varargs);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
702 static void argsToDecoBuffer(OutBuffer *buf, Arguments *arguments);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
703 static size_t dim(Arguments *arguments);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
704 static Argument *getNth(Arguments *arguments, size_t nth, size_t *pn = NULL);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
705 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
706
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
707 extern int PTRSIZE;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
708 extern int REALSIZE;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
709 extern int REALPAD;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
710 extern int Tsize_t;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
711 extern int Tptrdiff_t;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
712
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
713 #endif /* DMD_MTYPE_H */