- BugFix: make_function_1_type_variadic() must hash the type itself, NOT
[cparser] / type_t.h
1 /*
2  * This file is part of cparser.
3  * Copyright (C) 2007-2008 Matthias Braun <matze@braunis.de>
4  *
5  * This program is free software; you can redistribute it and/or
6  * modify it under the terms of the GNU General Public License
7  * as published by the Free Software Foundation; either version 2
8  * of the License, or (at your option) any later version.
9  *
10  * This program is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13  * GNU General Public License for more details.
14  *
15  * You should have received a copy of the GNU General Public License
16  * along with this program; if not, write to the Free Software
17  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
18  * 02111-1307, USA.
19  */
20 #ifndef TYPE_T_H
21 #define TYPE_T_H
22
23 #include <stdbool.h>
24 #include <assert.h>
25
26 #include <libfirm/firm_types.h>
27
28 #include "type.h"
29 #include "symbol.h"
30 #include "token_t.h"
31 #include "ast_t.h"
32 #include "adt/obst.h"
33
34 extern struct obstack *type_obst;
35
36 typedef enum type_kind_t {
37         TYPE_INVALID,
38         TYPE_ERROR,
39         TYPE_ATOMIC,
40         TYPE_COMPLEX,
41         TYPE_IMAGINARY,
42         TYPE_COMPOUND_STRUCT,
43         TYPE_COMPOUND_UNION,
44         TYPE_ENUM,
45         TYPE_FUNCTION,
46         TYPE_POINTER,
47         TYPE_REFERENCE,
48         TYPE_ARRAY,
49         TYPE_BITFIELD,
50         TYPE_BUILTIN,
51         TYPE_TYPEDEF,
52         TYPE_TYPEOF,
53 } type_kind_t;
54
55 struct type_base_t {
56         type_kind_t       kind;
57         type_qualifiers_t qualifiers;
58
59         /* cached ast2firm infos */
60         ir_type          *firm_type;
61 };
62
63 struct atomic_type_t {
64         type_base_t         base;
65         atomic_type_kind_t  akind;
66 };
67
68 struct complex_type_t {
69         type_base_t         base;
70         atomic_type_kind_t  akind;
71 };
72
73 struct imaginary_type_t {
74         type_base_t         base;
75         atomic_type_kind_t  akind;
76 };
77
78 struct builtin_type_t {
79         type_base_t  base;
80         symbol_t    *symbol;
81         type_t      *real_type;
82 };
83
84 struct pointer_type_t {
85         type_base_t  base;
86         type_t      *points_to;
87         variable_t  *base_variable;  /**< Microsoft __based() extension: base variable or NULL. */
88 };
89
90 struct reference_type_t {
91         type_base_t  base;
92         type_t      *refers_to;
93 };
94
95 struct array_type_t {
96         type_base_t   base;
97         type_t       *element_type;
98         expression_t *size_expression;
99         size_t        size;
100
101         ir_node      *size_node; /**< used by ast2firm phase */
102
103         bool          is_static         : 1; /**< a [static] type */
104         bool          is_variable       : 1; /**< a [*] type */
105         bool          has_implicit_size : 1;
106         bool          size_constant     : 1; /**< size expression is constant */
107         bool          is_vla            : 1; /**< it's a variable length array */
108 };
109
110 /**
111  * An entry in the parameter list of a function type.
112  */
113 struct function_parameter_t {
114         type_t               *type;  /**< The parameter type. */
115         function_parameter_t *next;  /**< Points to the next type in the parameter list.*/
116 };
117
118 /** Linkage specifications. */
119 typedef enum linkage_kind_t {
120         LINKAGE_INVALID,
121         LINKAGE_C,       /**< C linkage. */
122         LINKAGE_CXX      /**< C++ linkage. */
123 } linkage_kind_t;
124
125 /** Calling conventions. */
126 typedef enum cc_kind_t {
127         CC_DEFAULT,      /**< default calling convention. */
128         CC_CDECL,        /**< cdecl calling convention. */
129         CC_STDCALL,      /**< stdcall calling convention. */
130         CC_FASTCALL,     /**< fastcall calling convention. */
131         CC_THISCALL      /**< thiscall calling convention. */
132 } cc_kind_t;
133
134 /**
135  * A function type.
136  */
137 struct function_type_t {
138         type_base_t           base;
139         type_t               *return_type;        /**< The return type. */
140         function_parameter_t *parameters;         /**< A list of the parameter types. */
141         linkage_kind_t        linkage;
142         cc_kind_t             calling_convention; /**< The specified calling convention. */
143         decl_modifiers_t      modifiers;
144         bool                  variadic : 1;
145         bool                  unspecified_parameters : 1;
146         bool                  kr_style_parameters : 1;
147         bool                  prototyped : 1;
148 };
149
150 struct compound_type_t {
151         type_base_t     base;
152         bool            packed : 1; /**< Set if packed was specified. */
153         /** the declaration of the compound type, the scope of the declaration
154          *  contains the compound entries. */
155         compound_t     *compound;
156 };
157
158 struct enum_type_t {
159         type_base_t         base;
160         atomic_type_kind_t  akind; /**< underlying atomic type */
161         /** the enum entity. You can find the enum entries by walking the
162          *  enum->base.next list until you don't find ENTITY_ENUM_VALUE entities
163          *  anymore */
164         enum_t             *enume;
165 };
166
167 struct typedef_type_t {
168         type_base_t  base;
169         typedef_t   *typedefe;
170         type_t      *resolved_type;
171 };
172
173 struct typeof_type_t {
174         type_base_t   base;
175         expression_t *expression;
176         type_t       *typeof_type;
177         type_t       *resolved_type;
178 };
179
180 struct bitfield_type_t {
181         type_base_t   base;
182         type_t       *base_type;
183         expression_t *size_expression; /**< The expression for the bit size. */
184         il_size_t     bit_size;        /**< Size of this bitfield in bits. */
185 };
186
187 union type_t {
188         type_kind_t      kind;
189         type_base_t      base;
190         atomic_type_t    atomic;
191         complex_type_t   complex;
192         imaginary_type_t imaginary;
193         builtin_type_t   builtin;
194         pointer_type_t   pointer;
195         reference_type_t reference;
196         array_type_t     array;
197         function_type_t  function;
198         compound_type_t  compound;
199         enum_type_t      enumt;
200         typedef_type_t   typedeft;
201         bitfield_type_t  bitfield;
202         typeof_type_t    typeoft;
203 };
204
205 type_t *make_atomic_type(atomic_type_kind_t type, type_qualifiers_t qualifiers);
206 type_t *make_complex_type(atomic_type_kind_t type, type_qualifiers_t qualifiers);
207 type_t *make_imaginary_type(atomic_type_kind_t type, type_qualifiers_t qualifiers);
208 type_t *make_pointer_type(type_t *points_to, type_qualifiers_t qualifiers);
209 type_t *make_reference_type(type_t *refers_to);
210 type_t *make_based_pointer_type(type_t *points_to,
211                                                                 type_qualifiers_t qualifiers, variable_t *variable);
212 type_t *make_array_type(type_t *element_type, size_t size,
213                         type_qualifiers_t qualifiers);
214
215 type_t *duplicate_type(const type_t *type);
216 type_t *identify_new_type(type_t *type);
217
218 static inline bool is_typeref(const type_t *type)
219 {
220         return type->kind == TYPE_TYPEDEF || type->kind == TYPE_TYPEOF;
221 }
222
223 static inline bool is_type_atomic(const type_t *type, atomic_type_kind_t atype)
224 {
225         assert(!is_typeref(type));
226
227         if(type->kind != TYPE_ATOMIC)
228                 return false;
229         const atomic_type_t *atomic_type = &type->atomic;
230
231         return atomic_type->akind == atype;
232 }
233
234 static inline bool is_type_pointer(const type_t *type)
235 {
236         assert(!is_typeref(type));
237         return type->kind == TYPE_POINTER;
238 }
239
240 static inline bool is_type_reference(const type_t *type)
241 {
242         assert(!is_typeref(type));
243         return type->kind == TYPE_REFERENCE;
244 }
245
246 static inline bool is_type_array(const type_t *type)
247 {
248         assert(!is_typeref(type));
249         return type->kind == TYPE_ARRAY;
250 }
251
252 static inline bool is_type_function(const type_t *type)
253 {
254         assert(!is_typeref(type));
255         return type->kind == TYPE_FUNCTION;
256 }
257
258 static inline bool is_type_union(const type_t *type)
259 {
260         assert(!is_typeref(type));
261         return type->kind == TYPE_COMPOUND_UNION;
262 }
263
264 static inline bool is_type_struct(const type_t *type)
265 {
266         assert(!is_typeref(type));
267         return type->kind == TYPE_COMPOUND_STRUCT;
268 }
269
270 static inline bool is_type_builtin(const type_t *type)
271 {
272         assert(!is_typeref(type));
273         return type->kind == TYPE_BUILTIN;
274 }
275
276 static inline bool is_type_compound(const type_t *type)
277 {
278         assert(!is_typeref(type));
279         return type->kind == TYPE_COMPOUND_STRUCT
280                 || type->kind == TYPE_COMPOUND_UNION;
281 }
282
283 static inline bool is_type_valid(const type_t *type)
284 {
285         assert(!is_typeref(type));
286         return type->kind != TYPE_ERROR;
287 }
288
289 #endif