annotate dmd/mtype.h @ 1578:1dee66f6ec0b

Removed a chunk of code in favour of a shorter and more portable method
author Robert Clipsham <robert@octarineparrot.com>
date Tue, 08 Sep 2009 11:21:30 +0100
parents 05c235309d6f
children def7a1d494fd
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
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
24 #if IN_LLVM
1051
dc608dc33081 Make IrFuncTy a member of TypeFunction. Reset between modules compiled in the
Christian Kamm <kamm incasoftware de>
parents: 1029
diff changeset
25 #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
26 namespace llvm { class Type; }
1364
46f6365a50d7 Added IrTypeFunction and IrTypeDelegate and eliminated IrDType. This means the Type::ir field can be removed. It's the final part needed for the move to a slightly more sane type system. Now the whole thing just needs to be cleaned up :P
Tomas Lindquist Olsen <tomas.l.olsen gmail com>
parents: 1245
diff changeset
27 class Ir;
1192
3251ce06c820 Started seperating type resolution from the rest of codegen again, the merge had too many regressions.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1184
diff changeset
28 class IrType;
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
29 #endif
173
db9890b3fb64 [svn r189] moving IR data back into DMD frontend nodes
ChristianK
parents: 162
diff changeset
30
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
31 struct Scope;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
32 struct Identifier;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
33 struct Expression;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
34 struct StructDeclaration;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
35 struct ClassDeclaration;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
36 struct VarDeclaration;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
37 struct EnumDeclaration;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
38 struct TypedefDeclaration;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
39 struct TypeInfoDeclaration;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
40 struct Dsymbol;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
41 struct TemplateInstance;
1103
b30fe7e1dbb9 - Updated to DMD frontend 1.041.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1051
diff changeset
42 struct CppMangleState;
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
43 enum LINK;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
44
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
45 struct TypeBasic;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
46 struct HdrGenState;
1103
b30fe7e1dbb9 - Updated to DMD frontend 1.041.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1051
diff changeset
47 struct Argument;
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
48
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
49 // Back end
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
50 #if IN_GCC
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
51 union tree_node; typedef union tree_node TYPE;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
52 typedef TYPE type;
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
53 #endif
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
54
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
55 #if IN_DMD
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
56 typedef struct TYPE type;
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
57 struct Symbol;
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
58 #endif
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
59
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
60 enum TY
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
61 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
62 Tarray, // dynamic array
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
63 Tsarray, // static array
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
64 Taarray, // associative array
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
65 Tpointer,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
66 Treference,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
67 Tfunction,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
68 Tident,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
69 Tclass,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
70 Tstruct,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
71 Tenum,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
72 Ttypedef,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
73 Tdelegate,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
74
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
75 Tnone,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
76 Tvoid,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
77 Tint8,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
78 Tuns8,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
79 Tint16,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
80 Tuns16,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
81 Tint32,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
82 Tuns32,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
83 Tint64,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
84 Tuns64,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
85 Tfloat32,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
86 Tfloat64,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
87 Tfloat80,
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 Timaginary32,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
90 Timaginary64,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
91 Timaginary80,
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 Tcomplex32,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
94 Tcomplex64,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
95 Tcomplex80,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
96
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
97 Tbit,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
98 Tbool,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
99 Tchar,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
100 Twchar,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
101 Tdchar,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
102
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
103 Terror,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
104 Tinstance,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
105 Ttypeof,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
106 Ttuple,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
107 Tslice,
1103
b30fe7e1dbb9 - Updated to DMD frontend 1.041.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1051
diff changeset
108 Treturn,
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
109 TMAX
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
110 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
111
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
112 #define Tascii Tchar
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
113
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
114 extern int Tsize_t;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
115 extern int Tptrdiff_t;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
116
1103
b30fe7e1dbb9 - Updated to DMD frontend 1.041.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1051
diff changeset
117
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
118 struct Type : Object
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
119 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
120 TY ty;
1103
b30fe7e1dbb9 - Updated to DMD frontend 1.041.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1051
diff changeset
121 unsigned char mod; // modifiers MODxxxx
b30fe7e1dbb9 - Updated to DMD frontend 1.041.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1051
diff changeset
122 /* 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
123 */
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
124 #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
125 #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
126 #define MODshared 2 // type is shared
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
127 char *deco;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
128 Type *pto; // merged pointer to this type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
129 Type *rto; // reference to this type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
130 Type *arrayof; // array of this type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
131 TypeInfoDeclaration *vtinfo; // TypeInfo object for this Type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
132
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
133 #if IN_DMD
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
134 type *ctype; // for back end
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
135 #endif
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
136
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
137 #define tvoid basic[Tvoid]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
138 #define tint8 basic[Tint8]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
139 #define tuns8 basic[Tuns8]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
140 #define tint16 basic[Tint16]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
141 #define tuns16 basic[Tuns16]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
142 #define tint32 basic[Tint32]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
143 #define tuns32 basic[Tuns32]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
144 #define tint64 basic[Tint64]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
145 #define tuns64 basic[Tuns64]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
146 #define tfloat32 basic[Tfloat32]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
147 #define tfloat64 basic[Tfloat64]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
148 #define tfloat80 basic[Tfloat80]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
149
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
150 #define timaginary32 basic[Timaginary32]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
151 #define timaginary64 basic[Timaginary64]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
152 #define timaginary80 basic[Timaginary80]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
153
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
154 #define tcomplex32 basic[Tcomplex32]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
155 #define tcomplex64 basic[Tcomplex64]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
156 #define tcomplex80 basic[Tcomplex80]
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 #define tbit basic[Tbit]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
159 #define tbool basic[Tbool]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
160 #define tchar basic[Tchar]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
161 #define twchar basic[Twchar]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
162 #define tdchar basic[Tdchar]
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
163
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
164 // Some special types
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
165 #define tshiftcnt tint32 // right side of shift expression
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
166 // #define tboolean tint32 // result of boolean expression
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
167 #define tboolean tbool // result of boolean expression
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
168 #define tindex tint32 // array/ptr index
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
169 static Type *tvoidptr; // void*
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
170 #define terror basic[Terror] // for error recovery
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
171
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
172 #define tsize_t basic[Tsize_t] // matches size_t alias
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
173 #define tptrdiff_t basic[Tptrdiff_t] // matches ptrdiff_t alias
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
174 #define thash_t tsize_t // matches hash_t alias
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
175
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
176 static ClassDeclaration *typeinfo;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
177 static ClassDeclaration *typeinfoclass;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
178 static ClassDeclaration *typeinfointerface;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
179 static ClassDeclaration *typeinfostruct;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
180 static ClassDeclaration *typeinfotypedef;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
181 static ClassDeclaration *typeinfopointer;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
182 static ClassDeclaration *typeinfoarray;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
183 static ClassDeclaration *typeinfostaticarray;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
184 static ClassDeclaration *typeinfoassociativearray;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
185 static ClassDeclaration *typeinfoenum;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
186 static ClassDeclaration *typeinfofunction;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
187 static ClassDeclaration *typeinfodelegate;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
188 static ClassDeclaration *typeinfotypelist;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
189
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
190 static Type *basic[TMAX];
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
191 static unsigned char mangleChar[TMAX];
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
192 static StringTable stringtable;
1245
465a77c904d4 Fixed all issues preventing Tango 0.99.8 to compile with `sh build-tango.sh --verbose ldc'.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1228
diff changeset
193 #if IN_LLVM
465a77c904d4 Fixed all issues preventing Tango 0.99.8 to compile with `sh build-tango.sh --verbose ldc'.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1228
diff changeset
194 static StringTable deco_stringtable;
465a77c904d4 Fixed all issues preventing Tango 0.99.8 to compile with `sh build-tango.sh --verbose ldc'.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1228
diff changeset
195 #endif
159
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 // These tables are for implicit conversion of binary ops;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
198 // the indices are the type of operand one, followed by operand two.
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
199 static unsigned char impcnvResult[TMAX][TMAX];
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
200 static unsigned char impcnvType1[TMAX][TMAX];
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
201 static unsigned char impcnvType2[TMAX][TMAX];
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
202
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
203 // If !=0, give warning on implicit conversion
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
204 static unsigned char impcnvWarn[TMAX][TMAX];
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
205
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
206 Type(TY ty, Type *next);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
207 virtual Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
208 int equals(Object *o);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
209 int dyncast() { return DYNCAST_TYPE; } // kludge for template.isType()
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
210 int covariant(Type *t);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
211 char *toChars();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
212 static char needThisPrefix();
1147
dbe4af57b240 Changed use of toObjFile to a new codegen method.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1146
diff changeset
213 #if IN_LLVM
dbe4af57b240 Changed use of toObjFile to a new codegen method.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1146
diff changeset
214 static void init(Ir*);
dbe4af57b240 Changed use of toObjFile to a new codegen method.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1146
diff changeset
215 #else
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
216 static void init();
1147
dbe4af57b240 Changed use of toObjFile to a new codegen method.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1146
diff changeset
217 #endif
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
218 d_uns64 size();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
219 virtual d_uns64 size(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
220 virtual unsigned alignsize();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
221 virtual Type *semantic(Loc loc, Scope *sc);
1228
79758fd2f48a Added Doxygen file.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1192
diff changeset
222 // append the mangleof or a string uniquely identifying this type to buf
79758fd2f48a Added Doxygen file.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1192
diff changeset
223 virtual void toDecoBuffer(OutBuffer *buf, bool mangle);
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
224 Type *merge();
1367
8026319762be Merged DMD 1.045 !!!
Tomas Lindquist Olsen <tomas.l.olsen gmail com>
parents: 1364
diff changeset
225 Type *merge2();
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
226 virtual void toCBuffer(OutBuffer *buf, Identifier *ident, HdrGenState *hgs);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
227 virtual void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
228 void toCBuffer3(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
229 virtual int isbit();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
230 virtual int isintegral();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
231 virtual int isfloating(); // real, imaginary, or complex
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
232 virtual int isreal();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
233 virtual int isimaginary();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
234 virtual int iscomplex();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
235 virtual int isscalar();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
236 virtual int isunsigned();
1530
05c235309d6f Make the auto storage class never have the same meaning as scope.
Christian Kamm <kamm incasoftware de>
parents: 1372
diff changeset
237 virtual int isscope();
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
238 virtual int isString();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
239 virtual int checkBoolean(); // if can be converted to boolean value
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
240 void checkDeprecated(Loc loc, Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
241 Type *pointerTo();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
242 Type *referenceTo();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
243 Type *arrayOf();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
244 virtual Dsymbol *toDsymbol(Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
245 virtual Type *toBasetype();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
246 virtual int isBaseOf(Type *t, int *poffset);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
247 virtual MATCH implicitConvTo(Type *to);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
248 virtual ClassDeclaration *isClassHandle();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
249 virtual Expression *getProperty(Loc loc, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
250 virtual Expression *dotExp(Scope *sc, Expression *e, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
251 virtual unsigned memalign(unsigned salign);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
252 virtual Expression *defaultInit(Loc loc = 0);
1367
8026319762be Merged DMD 1.045 !!!
Tomas Lindquist Olsen <tomas.l.olsen gmail com>
parents: 1364
diff changeset
253 virtual int isZeroInit(Loc loc = 0); // if initializer is 0
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
254 #if IN_DMD
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
255 virtual dt_t **toDt(dt_t **pdt);
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
256 #endif
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
257 Identifier *getTypeInfoIdent(int internal);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
258 virtual MATCH deduceType(Scope *sc, Type *tparam, TemplateParameters *parameters, Objects *dedtypes);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
259 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
260 Expression *getInternalTypeInfo(Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
261 Expression *getTypeInfo(Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
262 virtual TypeInfoDeclaration *getTypeInfoDeclaration();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
263 virtual int builtinTypeInfo();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
264 virtual Type *reliesOnTident();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
265 virtual Expression *toExpression();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
266 virtual int hasPointers();
1103
b30fe7e1dbb9 - Updated to DMD frontend 1.041.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1051
diff changeset
267 Type *next;
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
268 Type *nextOf() { return next; }
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
269
1372
229e02867307 Fix format-string bugs by adding __attribute__((__format__)) in all applicable
Frits van Bommel <fvbommel wxs.nl>
parents: 1367
diff changeset
270 static void error(Loc loc, const char *format, ...) IS_PRINTF(2);
229e02867307 Fix format-string bugs by adding __attribute__((__format__)) in all applicable
Frits van Bommel <fvbommel wxs.nl>
parents: 1367
diff changeset
271 static void warning(Loc loc, const char *format, ...) IS_PRINTF(2);
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
272
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
273 #if IN_DMD
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
274 // For backend
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
275 virtual unsigned totym();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
276 virtual type *toCtype();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
277 virtual type *toCParamtype();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
278 virtual Symbol *toSymbol();
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
279 #endif
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
280
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
281 // For eliminating dynamic_cast
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
282 virtual TypeBasic *isTypeBasic();
173
db9890b3fb64 [svn r189] moving IR data back into DMD frontend nodes
ChristianK
parents: 162
diff changeset
283
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
284 #if IN_LLVM
1147
dbe4af57b240 Changed use of toObjFile to a new codegen method.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1146
diff changeset
285 static Ir* sir;
1192
3251ce06c820 Started seperating type resolution from the rest of codegen again, the merge had too many regressions.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1184
diff changeset
286 IrType* irtype;
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
287 #endif
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
288 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
289
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
290 struct TypeBasic : Type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
291 {
658
50383e476c7e Upgraded frontend to DMD 1.035
Tomas Lindquist Olsen <tomas.l.olsen@gmail.com>
parents: 508
diff changeset
292 const char *dstring;
50383e476c7e Upgraded frontend to DMD 1.035
Tomas Lindquist Olsen <tomas.l.olsen@gmail.com>
parents: 508
diff changeset
293 const char *cstring;
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
294 unsigned flags;
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 TypeBasic(TY ty);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
297 Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
298 d_uns64 size(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
299 unsigned alignsize();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
300 Expression *getProperty(Loc loc, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
301 Expression *dotExp(Scope *sc, Expression *e, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
302 char *toChars();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
303 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
304 int isintegral();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
305 int isbit();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
306 int isfloating();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
307 int isreal();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
308 int isimaginary();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
309 int iscomplex();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
310 int isscalar();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
311 int isunsigned();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
312 MATCH implicitConvTo(Type *to);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
313 Expression *defaultInit(Loc loc);
1367
8026319762be Merged DMD 1.045 !!!
Tomas Lindquist Olsen <tomas.l.olsen gmail com>
parents: 1364
diff changeset
314 int isZeroInit(Loc loc);
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
315 int builtinTypeInfo();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
316
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
317 // For eliminating dynamic_cast
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
318 TypeBasic *isTypeBasic();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
319 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
320
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
321 struct TypeArray : Type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
322 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
323 TypeArray(TY ty, Type *next);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
324 Expression *dotExp(Scope *sc, Expression *e, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
325 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
326
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
327 // Static array, one with a fixed dimension
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
328 struct TypeSArray : TypeArray
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
329 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
330 Expression *dim;
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 TypeSArray(Type *t, Expression *dim);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
333 Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
334 d_uns64 size(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
335 unsigned alignsize();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
336 Type *semantic(Loc loc, Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
337 void resolve(Loc loc, Scope *sc, Expression **pe, Type **pt, Dsymbol **ps);
1228
79758fd2f48a Added Doxygen file.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1192
diff changeset
338 void toDecoBuffer(OutBuffer *buf, bool mangle);
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
339 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
340 Expression *dotExp(Scope *sc, Expression *e, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
341 int isString();
1367
8026319762be Merged DMD 1.045 !!!
Tomas Lindquist Olsen <tomas.l.olsen gmail com>
parents: 1364
diff changeset
342 int isZeroInit(Loc loc);
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
343 unsigned memalign(unsigned salign);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
344 MATCH implicitConvTo(Type *to);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
345 Expression *defaultInit(Loc loc);
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
346 #if IN_DMD
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
347 dt_t **toDt(dt_t **pdt);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
348 dt_t **toDtElem(dt_t **pdt, Expression *e);
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
349 #endif
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
350 MATCH deduceType(Scope *sc, Type *tparam, TemplateParameters *parameters, Objects *dedtypes);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
351 TypeInfoDeclaration *getTypeInfoDeclaration();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
352 Expression *toExpression();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
353 int hasPointers();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
354
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
355 #if IN_DMD
159
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 type *toCParamtype();
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
358 #endif
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
359 };
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 // Dynamic array, no dimension
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
362 struct TypeDArray : TypeArray
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 TypeDArray(Type *t);
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 unsigned alignsize();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
368 Type *semantic(Loc loc, Scope *sc);
1228
79758fd2f48a Added Doxygen file.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1192
diff changeset
369 void toDecoBuffer(OutBuffer *buf, bool mangle);
159
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 int isString();
1367
8026319762be Merged DMD 1.045 !!!
Tomas Lindquist Olsen <tomas.l.olsen gmail com>
parents: 1364
diff changeset
373 int isZeroInit(Loc loc);
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
374 int checkBoolean();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
375 MATCH implicitConvTo(Type *to);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
376 Expression *defaultInit(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
377 int builtinTypeInfo();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
378 TypeInfoDeclaration *getTypeInfoDeclaration();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
379 int hasPointers();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
380
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
381 #if IN_DMD
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
382 type *toCtype();
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
383 #endif
159
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
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
386 struct TypeAArray : TypeArray
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
387 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
388 Type *index; // key type for type checking
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
389 Type *key; // actual key type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
390
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
391 TypeAArray(Type *t, Type *index);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
392 Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
393 d_uns64 size(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
394 Type *semantic(Loc loc, Scope *sc);
336
aaade6ded589 [svn r357] Merged DMD 1.033
lindquist
parents: 217
diff changeset
395 void resolve(Loc loc, Scope *sc, Expression **pe, Type **pt, Dsymbol **ps);
1228
79758fd2f48a Added Doxygen file.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1192
diff changeset
396 void toDecoBuffer(OutBuffer *buf, bool mangle);
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
397 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
398 Expression *dotExp(Scope *sc, Expression *e, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
399 Expression *defaultInit(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
400 MATCH deduceType(Scope *sc, Type *tparam, TemplateParameters *parameters, Objects *dedtypes);
1367
8026319762be Merged DMD 1.045 !!!
Tomas Lindquist Olsen <tomas.l.olsen gmail com>
parents: 1364
diff changeset
401 int isZeroInit(Loc loc);
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
402 int checkBoolean();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
403 TypeInfoDeclaration *getTypeInfoDeclaration();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
404 int hasPointers();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
405
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
406 #if IN_DMD
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
407 // 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
408 Symbol *aaGetSymbol(const char *func, int flags);
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
409
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
410 type *toCtype();
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
411 #endif
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
412 };
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 struct TypePointer : Type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
415 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
416 TypePointer(Type *t);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
417 Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
418 Type *semantic(Loc loc, Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
419 d_uns64 size(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
420 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
421 MATCH implicitConvTo(Type *to);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
422 int isscalar();
663
6aaa3d3c1183 First part of rename to LDC.
Christian Kamm <kamm incasoftware de>
parents: 658
diff changeset
423 // 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
424 int isunsigned() { return TRUE; };
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
425 Expression *defaultInit(Loc loc);
1367
8026319762be Merged DMD 1.045 !!!
Tomas Lindquist Olsen <tomas.l.olsen gmail com>
parents: 1364
diff changeset
426 int isZeroInit(Loc loc);
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
427 TypeInfoDeclaration *getTypeInfoDeclaration();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
428 int hasPointers();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
429
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
430 #if IN_DMD
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
431 type *toCtype();
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
432 #endif
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
433 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
434
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
435 struct TypeReference : Type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
436 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
437 TypeReference(Type *t);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
438 Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
439 d_uns64 size(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
440 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
441 Expression *dotExp(Scope *sc, Expression *e, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
442 Expression *defaultInit(Loc loc);
1367
8026319762be Merged DMD 1.045 !!!
Tomas Lindquist Olsen <tomas.l.olsen gmail com>
parents: 1364
diff changeset
443 int isZeroInit(Loc loc);
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
444 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
445
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
446 enum RET
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
447 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
448 RETregs = 1, // returned in registers
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
449 RETstack = 2, // returned on stack
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
450 };
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 struct TypeFunction : Type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
453 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
454 Arguments *parameters; // function parameters
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
455 int varargs; // 1: T t, ...) style for variable number of arguments
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
456 // 2: T t ...) style for variable number of arguments
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
457 enum LINK linkage; // calling convention
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
458
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
459 int inuse;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
460
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
461 TypeFunction(Arguments *parameters, Type *treturn, int varargs, enum LINK linkage);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
462 Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
463 Type *semantic(Loc loc, Scope *sc);
1228
79758fd2f48a Added Doxygen file.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1192
diff changeset
464 void toDecoBuffer(OutBuffer *buf, bool mangle);
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
465 void toCBuffer(OutBuffer *buf, Identifier *ident, HdrGenState *hgs);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
466 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
467 MATCH deduceType(Scope *sc, Type *tparam, TemplateParameters *parameters, Objects *dedtypes);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
468 TypeInfoDeclaration *getTypeInfoDeclaration();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
469 Type *reliesOnTident();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
470
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
471 int callMatch(Expressions *toargs);
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
472 #if IN_DMD
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
473 type *toCtype();
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
474 #endif
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
475
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
476 enum RET retStyle();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
477
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
478 #if IN_DMD
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
479 unsigned totym();
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
480 #elif IN_LLVM
663
6aaa3d3c1183 First part of rename to LDC.
Christian Kamm <kamm incasoftware de>
parents: 658
diff changeset
481 // LDC
1051
dc608dc33081 Make IrFuncTy a member of TypeFunction. Reset between modules compiled in the
Christian Kamm <kamm incasoftware de>
parents: 1029
diff changeset
482 IrFuncTy fty;
1228
79758fd2f48a Added Doxygen file.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1192
diff changeset
483
79758fd2f48a Added Doxygen file.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1192
diff changeset
484 FuncDeclaration* funcdecl;
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
485 #endif
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
486 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
487
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
488 struct TypeDelegate : Type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
489 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
490 TypeDelegate(Type *t);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
491 Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
492 Type *semantic(Loc loc, Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
493 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
494 unsigned alignsize(); // added in LDC
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
495 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
496 Expression *defaultInit(Loc loc);
1367
8026319762be Merged DMD 1.045 !!!
Tomas Lindquist Olsen <tomas.l.olsen gmail com>
parents: 1364
diff changeset
497 int isZeroInit(Loc loc);
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
498 int checkBoolean();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
499 TypeInfoDeclaration *getTypeInfoDeclaration();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
500 Expression *dotExp(Scope *sc, Expression *e, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
501 int hasPointers();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
502
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
503 #if IN_DMD
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
504 type *toCtype();
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
505 #endif
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
506 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
507
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
508 struct TypeQualified : Type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
509 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
510 Loc loc;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
511 Array idents; // array of Identifier's representing ident.ident.ident etc.
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
512
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
513 TypeQualified(TY ty, Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
514 void syntaxCopyHelper(TypeQualified *t);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
515 void addIdent(Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
516 void toCBuffer2Helper(OutBuffer *buf, HdrGenState *hgs);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
517 d_uns64 size(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
518 void resolveHelper(Loc loc, Scope *sc, Dsymbol *s, Dsymbol *scopesym,
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
519 Expression **pe, Type **pt, Dsymbol **ps);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
520 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
521
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
522 struct TypeIdentifier : TypeQualified
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
523 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
524 Identifier *ident;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
525
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
526 TypeIdentifier(Loc loc, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
527 Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
528 //char *toChars();
1228
79758fd2f48a Added Doxygen file.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1192
diff changeset
529 void toDecoBuffer(OutBuffer *buf, bool mangle);
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
530 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
531 void resolve(Loc loc, Scope *sc, Expression **pe, Type **pt, Dsymbol **ps);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
532 Dsymbol *toDsymbol(Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
533 Type *semantic(Loc loc, Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
534 MATCH deduceType(Scope *sc, Type *tparam, TemplateParameters *parameters, Objects *dedtypes);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
535 Type *reliesOnTident();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
536 Expression *toExpression();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
537 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
538
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
539 /* Similar to TypeIdentifier, but with a TemplateInstance as the root
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
540 */
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
541 struct TypeInstance : TypeQualified
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
542 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
543 TemplateInstance *tempinst;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
544
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
545 TypeInstance(Loc loc, TemplateInstance *tempinst);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
546 Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
547 //char *toChars();
1228
79758fd2f48a Added Doxygen file.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1192
diff changeset
548 //void toDecoBuffer(OutBuffer *buf, bool mangle);
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
549 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
550 void resolve(Loc loc, Scope *sc, Expression **pe, Type **pt, Dsymbol **ps);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
551 Type *semantic(Loc loc, Scope *sc);
875
330f999ade44 Merged DMD 1.038
Tomas Lindquist Olsen <tomas.l.olsen@gmail.com>
parents: 797
diff changeset
552 Dsymbol *toDsymbol(Scope *sc);
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
553 MATCH deduceType(Scope *sc, Type *tparam, TemplateParameters *parameters, Objects *dedtypes);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
554 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
555
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
556 struct TypeTypeof : TypeQualified
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 Expression *exp;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
559
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
560 TypeTypeof(Loc loc, Expression *exp);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
561 Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
562 Dsymbol *toDsymbol(Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
563 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
564 Type *semantic(Loc loc, Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
565 d_uns64 size(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
566 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
567
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
568 struct TypeStruct : Type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
569 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
570 StructDeclaration *sym;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
571
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
572 TypeStruct(StructDeclaration *sym);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
573 d_uns64 size(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
574 unsigned alignsize();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
575 char *toChars();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
576 Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
577 Type *semantic(Loc loc, Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
578 Dsymbol *toDsymbol(Scope *sc);
1228
79758fd2f48a Added Doxygen file.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1192
diff changeset
579 void toDecoBuffer(OutBuffer *buf, bool mangle);
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
580 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
581 Expression *dotExp(Scope *sc, Expression *e, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
582 unsigned memalign(unsigned salign);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
583 Expression *defaultInit(Loc loc);
1367
8026319762be Merged DMD 1.045 !!!
Tomas Lindquist Olsen <tomas.l.olsen gmail com>
parents: 1364
diff changeset
584 int isZeroInit(Loc loc);
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
585 int checkBoolean();
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
586 #if IN_DMD
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
587 dt_t **toDt(dt_t **pdt);
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
588 #endif
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
589 MATCH deduceType(Scope *sc, Type *tparam, TemplateParameters *parameters, Objects *dedtypes);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
590 TypeInfoDeclaration *getTypeInfoDeclaration();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
591 int hasPointers();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
592
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
593 #if IN_DMD
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
594 type *toCtype();
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
595 #elif IN_LLVM
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
596 // 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
597 // 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
598 // 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
599 int unaligned;
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
600 #endif
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
601 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
602
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
603 struct TypeEnum : Type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
604 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
605 EnumDeclaration *sym;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
606
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
607 TypeEnum(EnumDeclaration *sym);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
608 d_uns64 size(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
609 unsigned alignsize();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
610 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
611 Type *syntaxCopy();
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
612 Type *semantic(Loc loc, Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
613 Dsymbol *toDsymbol(Scope *sc);
1228
79758fd2f48a Added Doxygen file.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1192
diff changeset
614 void toDecoBuffer(OutBuffer *buf, bool mangle);
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
615 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
616 Expression *dotExp(Scope *sc, Expression *e, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
617 Expression *getProperty(Loc loc, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
618 int isintegral();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
619 int isfloating();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
620 int isscalar();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
621 int isunsigned();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
622 MATCH implicitConvTo(Type *to);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
623 Type *toBasetype();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
624 Expression *defaultInit(Loc loc);
1367
8026319762be Merged DMD 1.045 !!!
Tomas Lindquist Olsen <tomas.l.olsen gmail com>
parents: 1364
diff changeset
625 int isZeroInit(Loc loc);
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
626 MATCH deduceType(Scope *sc, Type *tparam, TemplateParameters *parameters, Objects *dedtypes);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
627 TypeInfoDeclaration *getTypeInfoDeclaration();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
628 int hasPointers();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
629
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
630 #if IN_DMD
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
631 type *toCtype();
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
632 #endif
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
633 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
634
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
635 struct TypeTypedef : Type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
636 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
637 TypedefDeclaration *sym;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
638
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
639 TypeTypedef(TypedefDeclaration *sym);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
640 Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
641 d_uns64 size(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
642 unsigned alignsize();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
643 char *toChars();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
644 Type *semantic(Loc loc, Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
645 Dsymbol *toDsymbol(Scope *sc);
1228
79758fd2f48a Added Doxygen file.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1192
diff changeset
646 void toDecoBuffer(OutBuffer *buf, bool mangle);
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
647 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
648 Expression *dotExp(Scope *sc, Expression *e, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
649 Expression *getProperty(Loc loc, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
650 int isbit();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
651 int isintegral();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
652 int isfloating();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
653 int isreal();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
654 int isimaginary();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
655 int iscomplex();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
656 int isscalar();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
657 int isunsigned();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
658 int checkBoolean();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
659 Type *toBasetype();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
660 MATCH implicitConvTo(Type *to);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
661 Expression *defaultInit(Loc loc);
1367
8026319762be Merged DMD 1.045 !!!
Tomas Lindquist Olsen <tomas.l.olsen gmail com>
parents: 1364
diff changeset
662 int isZeroInit(Loc loc);
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
663 #if IN_DMD
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
664 dt_t **toDt(dt_t **pdt);
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
665 #endif
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
666 MATCH deduceType(Scope *sc, Type *tparam, TemplateParameters *parameters, Objects *dedtypes);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
667 TypeInfoDeclaration *getTypeInfoDeclaration();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
668 int hasPointers();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
669
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
670 #if IN_DMD
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
671 type *toCtype();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
672 type *toCParamtype();
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
673 #endif
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
674 };
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 struct TypeClass : Type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
677 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
678 ClassDeclaration *sym;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
679
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
680 TypeClass(ClassDeclaration *sym);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
681 d_uns64 size(Loc loc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
682 char *toChars();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
683 Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
684 Type *semantic(Loc loc, Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
685 Dsymbol *toDsymbol(Scope *sc);
1228
79758fd2f48a Added Doxygen file.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1192
diff changeset
686 void toDecoBuffer(OutBuffer *buf, bool mangle);
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
687 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
688 Expression *dotExp(Scope *sc, Expression *e, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
689 ClassDeclaration *isClassHandle();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
690 int isBaseOf(Type *t, int *poffset);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
691 MATCH implicitConvTo(Type *to);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
692 Expression *defaultInit(Loc loc);
1367
8026319762be Merged DMD 1.045 !!!
Tomas Lindquist Olsen <tomas.l.olsen gmail com>
parents: 1364
diff changeset
693 int isZeroInit(Loc loc);
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
694 MATCH deduceType(Scope *sc, Type *tparam, TemplateParameters *parameters, Objects *dedtypes);
1530
05c235309d6f Make the auto storage class never have the same meaning as scope.
Christian Kamm <kamm incasoftware de>
parents: 1372
diff changeset
695 int isscope();
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
696 int checkBoolean();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
697 TypeInfoDeclaration *getTypeInfoDeclaration();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
698 int hasPointers();
1367
8026319762be Merged DMD 1.045 !!!
Tomas Lindquist Olsen <tomas.l.olsen gmail com>
parents: 1364
diff changeset
699 int builtinTypeInfo();
8026319762be Merged DMD 1.045 !!!
Tomas Lindquist Olsen <tomas.l.olsen gmail com>
parents: 1364
diff changeset
700 #if DMDV2
8026319762be Merged DMD 1.045 !!!
Tomas Lindquist Olsen <tomas.l.olsen gmail com>
parents: 1364
diff changeset
701 Type *toHeadMutable();
8026319762be Merged DMD 1.045 !!!
Tomas Lindquist Olsen <tomas.l.olsen gmail com>
parents: 1364
diff changeset
702 MATCH constConv(Type *to);
8026319762be Merged DMD 1.045 !!!
Tomas Lindquist Olsen <tomas.l.olsen gmail com>
parents: 1364
diff changeset
703 #if TARGET_LINUX || TARGET_OSX
8026319762be Merged DMD 1.045 !!!
Tomas Lindquist Olsen <tomas.l.olsen gmail com>
parents: 1364
diff changeset
704 void toCppMangle(OutBuffer *buf, CppMangleState *cms);
8026319762be Merged DMD 1.045 !!!
Tomas Lindquist Olsen <tomas.l.olsen gmail com>
parents: 1364
diff changeset
705 #endif
8026319762be Merged DMD 1.045 !!!
Tomas Lindquist Olsen <tomas.l.olsen gmail com>
parents: 1364
diff changeset
706 #endif
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
707
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
708 #if IN_DMD
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
709 type *toCtype();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
710
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
711 Symbol *toSymbol();
1146
1860414bf3b7 * Moved ir/irsymbol.cpp/h into ir/irdsymbol.cpp/h.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1103
diff changeset
712 #endif
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
713 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
714
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
715 struct TypeTuple : Type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
716 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
717 Arguments *arguments; // types making up the tuple
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
718
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
719 TypeTuple(Arguments *arguments);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
720 TypeTuple(Expressions *exps);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
721 Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
722 Type *semantic(Loc loc, Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
723 int equals(Object *o);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
724 Type *reliesOnTident();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
725 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
1228
79758fd2f48a Added Doxygen file.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1192
diff changeset
726 void toDecoBuffer(OutBuffer *buf, bool mangle);
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
727 Expression *getProperty(Loc loc, Identifier *ident);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
728 TypeInfoDeclaration *getTypeInfoDeclaration();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
729 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
730
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
731 struct TypeSlice : Type
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
732 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
733 Expression *lwr;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
734 Expression *upr;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
735
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
736 TypeSlice(Type *next, Expression *lwr, Expression *upr);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
737 Type *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
738 Type *semantic(Loc loc, Scope *sc);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
739 void resolve(Loc loc, Scope *sc, Expression **pe, Type **pt, Dsymbol **ps);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
740 void toCBuffer2(OutBuffer *buf, HdrGenState *hgs, int mod);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
741 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
742
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
743 /**************************************************************/
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
744
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
745 //enum InOut { None, In, Out, InOut, Lazy };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
746
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
747 struct Argument : Object
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
748 {
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
749 //enum InOut inout;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
750 unsigned storageClass;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
751 Type *type;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
752 Identifier *ident;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
753 Expression *defaultArg;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
754
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
755 Argument(unsigned storageClass, Type *type, Identifier *ident, Expression *defaultArg);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
756 Argument *syntaxCopy();
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
757 Type *isLazyArray();
1228
79758fd2f48a Added Doxygen file.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1192
diff changeset
758 void toDecoBuffer(OutBuffer *buf, bool mangle);
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
759 static Arguments *arraySyntaxCopy(Arguments *args);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
760 static char *argsTypesToChars(Arguments *args, int varargs);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
761 static void argsToCBuffer(OutBuffer *buf, HdrGenState *hgs, Arguments *arguments, int varargs);
1228
79758fd2f48a Added Doxygen file.
Tomas Lindquist Olsen <tomas.l.olsen gmail.com>
parents: 1192
diff changeset
762 static void argsToDecoBuffer(OutBuffer *buf, Arguments *arguments, bool mangle);
159
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
763 static size_t dim(Arguments *arguments);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
764 static Argument *getNth(Arguments *arguments, size_t nth, size_t *pn = NULL);
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
765 };
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
766
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
767 extern int PTRSIZE;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
768 extern int REALSIZE;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
769 extern int REALPAD;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
770 extern int Tsize_t;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
771 extern int Tptrdiff_t;
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
772
5acec6b2eef8 [svn r175] merged dmd 1.029
ChristianK
parents: 157
diff changeset
773 #endif /* DMD_MTYPE_H */