]> gcc.gnu.org Git - gcc.git/blame - gcc/tree.def
configopts.html: Quote StyleSheet attribute values.
[gcc.git] / gcc / tree.def
CommitLineData
6d77ee89
BK
1/* This file contains the definitions and documentation for the
2 tree codes used in the GNU C compiler.
b4e3fabb
RK
3 Copyright (C) 1987, 1988, 1993, 1995, 1997, 1998, 2000, 2001
4 Free Software Foundation, Inc.
6d77ee89 5
1322177d 6This file is part of GCC.
6d77ee89 7
1322177d
LB
8GCC is free software; you can redistribute it and/or modify it under
9the terms of the GNU General Public License as published by the Free
10Software Foundation; either version 2, or (at your option) any later
11version.
6d77ee89 12
1322177d
LB
13GCC is distributed in the hope that it will be useful, but WITHOUT ANY
14WARRANTY; without even the implied warranty of MERCHANTABILITY or
15FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
16for more details.
6d77ee89
BK
17
18You should have received a copy of the GNU General Public License
1322177d
LB
19along with GCC; see the file COPYING. If not, write to the Free
20Software Foundation, 59 Temple Place - Suite 330, Boston, MA
2102111-1307, USA. */
6d77ee89
BK
22
23
24/* The third argument can be:
cba734ea
JL
25 'x' for an exceptional code (fits no category).
26 't' for a type object code.
27 'b' for a lexical block.
28 'c' for codes for constants.
29 'd' for codes for declarations (also serving as variable refs).
30 'r' for codes for references to storage.
31 '<' for codes for comparison expressions.
32 '1' for codes for unary arithmetic expressions.
33 '2' for codes for binary arithmetic expressions.
34 's' for codes for expressions with inherent side effects.
35 'e' for codes for other kinds of expressions. */
6d77ee89
BK
36
37/* For `r', `e', `<', `1', `2', `s' and `x' nodes,
38 the 4th element is the number of argument slots to allocate.
39 This determines the size of the tree node object. */
40
41/* Any erroneous construct is parsed into a node of this type.
42 This type of node is accepted without complaint in all contexts
43 by later parsing activities, to avoid multiple error messages
44 for one error.
45 No fields in these nodes are used except the TREE_CODE. */
cba734ea 46DEFTREECODE (ERROR_MARK, "error_mark", 'x', 0)
6d77ee89
BK
47
48/* Used to represent a name (such as, in the DECL_NAME of a decl node).
49 Internally it looks like a STRING_CST node.
50 There is only one IDENTIFIER_NODE ever made for any particular name.
51 Use `get_identifier' to get it (or create it, the first time). */
cba734ea 52DEFTREECODE (IDENTIFIER_NODE, "identifier_node", 'x', -1)
6d77ee89 53
6d77ee89
BK
54/* Has the TREE_VALUE and TREE_PURPOSE fields. */
55/* These nodes are made into lists by chaining through the
56 TREE_CHAIN field. The elements of the list live in the
57 TREE_VALUE fields, while TREE_PURPOSE fields are occasionally
58 used as well to get the effect of Lisp association lists. */
cba734ea 59DEFTREECODE (TREE_LIST, "tree_list", 'x', 2)
6d77ee89
BK
60
61/* These nodes contain an array of tree nodes. */
cba734ea 62DEFTREECODE (TREE_VEC, "tree_vec", 'x', 2)
6d77ee89
BK
63
64/* A symbol binding block. These are arranged in a tree,
65 where the BLOCK_SUBBLOCKS field contains a chain of subblocks
66 chained through the BLOCK_CHAIN field.
67 BLOCK_SUPERCONTEXT points to the parent block.
68 For a block which represents the outermost scope of a function, it
69 points to the FUNCTION_DECL node.
70 BLOCK_VARS points to a chain of decl nodes.
71 BLOCK_TYPE_TAGS points to a chain of types which have their own names.
72 BLOCK_CHAIN points to the next BLOCK at the same level.
73 BLOCK_ABSTRACT_ORIGIN points to the original (abstract) tree node which
74 this block is an instance of, or else is NULL to indicate that this
75 block is not an instance of anything else. When non-NULL, the value
76 could either point to another BLOCK node or it could point to a
77 FUNCTION_DECL node (e.g. in the case of a block representing the
78 outermost scope of a particular inlining of a function).
79 BLOCK_ABSTRACT is non-zero if the block represents an abstract
80 instance of a block (i.e. one which is nested within an abstract
18c038b9
MM
81 instance of an inline function).
82 TREE_ASM_WRITTEN is non-zero if the block was actually referenced
83 in the generated assembly. */
cba734ea 84DEFTREECODE (BLOCK, "block", 'b', 0)
6d77ee89
BK
85\f
86/* Each data type is represented by a tree node whose code is one of
87 the following: */
88/* Each node that represents a data type has a component TYPE_SIZE
89 containing a tree that is an expression for the size in bits.
90 The TYPE_MODE contains the machine mode for values of this type.
91 The TYPE_POINTER_TO field contains a type for a pointer to this type,
92 or zero if no such has been created yet.
93 The TYPE_NEXT_VARIANT field is used to chain together types
94 that are variants made by type modifiers such as "const" and "volatile".
95 The TYPE_MAIN_VARIANT field, in any member of such a chain,
96 points to the start of the chain.
97 The TYPE_NONCOPIED_PARTS field is a list specifying which parts
98 of an object of this type should *not* be copied by assignment.
c15398de
MM
99 The TREE_VALUE of each is a FIELD_DECL that should not be
100 copied. The TREE_PURPOSE is an initial value for that field when
101 an object of this type is initialized via an INIT_EXPR. It may
102 be NULL if no special value is required. Even the things in this
103 list are copied if the right-hand side of an assignment is known
104 to be a complete object (rather than being, perhaps, a subobject
105 of some other object.) The determination of what constitutes a
106 complete object is done by fixed_type_p.
6d77ee89
BK
107 The TYPE_NAME field contains info on the name used in the program
108 for this type (for GDB symbol table output). It is either a
109 TYPE_DECL node, for types that are typedefs, or an IDENTIFIER_NODE
110 in the case of structs, unions or enums that are known with a tag,
111 or zero for types that have no special name.
112 The TYPE_CONTEXT for any sort of type which could have a name or
113 which could have named members (e.g. tagged types in C/C++) will
114 point to the node which represents the scope of the given type, or
115 will be NULL_TREE if the type has "file scope". For most types, this
116 will point to a BLOCK node or a FUNCTION_DECL node, but it could also
117 point to a FUNCTION_TYPE node (for types whose scope is limited to the
118 formal parameter list of some function type specification) or it
08703ee4
RK
119 could point to a RECORD_TYPE, UNION_TYPE or QUAL_UNION_TYPE node
120 (for C++ "member" types).
6d77ee89
BK
121 For non-tagged-types, TYPE_CONTEXT need not be set to anything in
122 particular, since any type which is of some type category (e.g.
123 an array type or a function type) which cannot either have a name
08703ee4
RK
124 itself or have named members doesn't really have a "scope" per se.
125 The TREE_CHAIN field is used as a forward-references to names for
126 ENUMERAL_TYPE, RECORD_TYPE, UNION_TYPE, and QUAL_UNION_TYPE nodes;
127 see below. */
6d77ee89 128
0a6969ad 129DEFTREECODE (VOID_TYPE, "void_type", 't', 0) /* The void type in C */
6d77ee89 130
442cb32d
PB
131/* Integer types in all languages, including char in C.
132 Also used for sub-ranges of other discrete types.
133 Has components TYPE_MIN_VALUE, TYPE_MAX_VALUE (expressions, inclusive)
6d77ee89
BK
134 and TYPE_PRECISION (number of bits used by this type).
135 In the case of a subrange type in Pascal, the TREE_TYPE
442cb32d
PB
136 of this will point at the supertype (another INTEGER_TYPE,
137 or an ENUMERAL_TYPE, CHAR_TYPE, or BOOLEAN_TYPE).
6d77ee89 138 Otherwise, the TREE_TYPE is zero. */
0a6969ad 139DEFTREECODE (INTEGER_TYPE, "integer_type", 't', 0)
6d77ee89
BK
140
141/* C's float and double. Different floating types are distinguished
142 by machine mode and by the TYPE_SIZE and the TYPE_PRECISION. */
0a6969ad 143DEFTREECODE (REAL_TYPE, "real_type", 't', 0)
6d77ee89
BK
144
145/* Complex number types. The TREE_TYPE field is the data type
146 of the real and imaginary parts. */
0a6969ad 147DEFTREECODE (COMPLEX_TYPE, "complex_type", 't', 0)
6d77ee89 148
0b4565c9
BS
149/* Vector types. The TREE_TYPE field is the data type of the vector
150 elements. */
151DEFTREECODE (VECTOR_TYPE, "vector_type", 't', 0)
152
6d77ee89
BK
153/* C enums. The type node looks just like an INTEGER_TYPE node.
154 The symbols for the values of the enum type are defined by
155 CONST_DECL nodes, but the type does not point to them;
e6702919 156 however, the TYPE_VALUES is a list in which each element's TREE_PURPOSE
6d77ee89
BK
157 is a name and the TREE_VALUE is the value (an INTEGER_CST node). */
158/* A forward reference `enum foo' when no enum named foo is defined yet
159 has zero (a null pointer) in its TYPE_SIZE. The tag name is in
160 the TYPE_NAME field. If the type is later defined, the normal
161 fields are filled in.
08703ee4
RK
162 RECORD_TYPE, UNION_TYPE, and QUAL_UNION_TYPE forward refs are
163 treated similarly. */
0a6969ad 164DEFTREECODE (ENUMERAL_TYPE, "enumeral_type", 't', 0)
6d77ee89
BK
165
166/* Pascal's boolean type (true or false are the only values);
167 no special fields needed. */
0a6969ad 168DEFTREECODE (BOOLEAN_TYPE, "boolean_type", 't', 0)
6d77ee89
BK
169
170/* CHAR in Pascal; not used in C.
171 No special fields needed. */
0a6969ad 172DEFTREECODE (CHAR_TYPE, "char_type", 't', 0)
6d77ee89
BK
173
174/* All pointer-to-x types have code POINTER_TYPE.
175 The TREE_TYPE points to the node for the type pointed to. */
0a6969ad 176DEFTREECODE (POINTER_TYPE, "pointer_type", 't', 0)
6d77ee89
BK
177
178/* An offset is a pointer relative to an object.
179 The TREE_TYPE field is the type of the object at the offset.
180 The TYPE_OFFSET_BASETYPE points to the node for the type of object
181 that the offset is relative to. */
0a6969ad 182DEFTREECODE (OFFSET_TYPE, "offset_type", 't', 0)
6d77ee89
BK
183
184/* A reference is like a pointer except that it is coerced
185 automatically to the value it points to. Used in C++. */
0a6969ad 186DEFTREECODE (REFERENCE_TYPE, "reference_type", 't', 0)
6d77ee89
BK
187
188/* METHOD_TYPE is the type of a function which takes an extra first
189 argument for "self", which is not present in the declared argument list.
190 The TREE_TYPE is the return type of the method. The TYPE_METHOD_BASETYPE
191 is the type of "self". TYPE_ARG_TYPES is the real argument list, which
192 includes the hidden argument for "self". */
0a6969ad 193DEFTREECODE (METHOD_TYPE, "method_type", 't', 0)
6d77ee89
BK
194
195/* Used for Pascal; details not determined right now. */
0a6969ad 196DEFTREECODE (FILE_TYPE, "file_type", 't', 0)
6d77ee89
BK
197
198/* Types of arrays. Special fields:
199 TREE_TYPE Type of an array element.
200 TYPE_DOMAIN Type to index by.
201 Its range of values specifies the array length.
202 TYPE_SEP Expression for units from one elt to the next.
203 TYPE_SEP_UNIT Number of bits in a unit for previous.
204 The field TYPE_POINTER_TO (TREE_TYPE (array_type)) is always nonzero
70b78a26
PB
205 and holds the type to coerce a value of that array type to in C.
206 TYPE_STRING_FLAG indicates a string (in contrast to an array of chars)
207 in languages (such as Chill) that make a distinction. */
6d77ee89 208/* Array types in C or Pascal */
0a6969ad 209DEFTREECODE (ARRAY_TYPE, "array_type", 't', 0)
6d77ee89
BK
210
211/* Types of sets for Pascal. Special fields are the same as
38d42ddb
PB
212 in an array type. The target type is always a boolean type.
213 Used for both bitstrings and powersets in Chill;
214 TYPE_STRING_FLAG indicates a bitstring. */
0a6969ad 215DEFTREECODE (SET_TYPE, "set_type", 't', 0)
6d77ee89 216
6d77ee89
BK
217/* Struct in C, or record in Pascal. */
218/* Special fields:
a082c85a
JM
219 TYPE_FIELDS chain of FIELD_DECLs for the fields of the struct,
220 and VAR_DECLs, TYPE_DECLs and CONST_DECLs for record-scope variables,
221 types and enumerators.
6d77ee89
BK
222 A few may need to be added for Pascal. */
223/* See the comment above, before ENUMERAL_TYPE, for how
224 forward references to struct tags are handled in C. */
0a6969ad 225DEFTREECODE (RECORD_TYPE, "record_type", 't', 0)
6d77ee89
BK
226
227/* Union in C. Like a struct, except that the offsets of the fields
228 will all be zero. */
229/* See the comment above, before ENUMERAL_TYPE, for how
230 forward references to union tags are handled in C. */
0a6969ad 231DEFTREECODE (UNION_TYPE, "union_type", 't', 0) /* C union type */
6d77ee89 232
08703ee4
RK
233/* Similar to UNION_TYPE, except that the expressions in DECL_QUALIFIER
234 in each FIELD_DECL determine what the union contains. The first
235 field whose DECL_QUALIFIER expression is true is deemed to occupy
236 the union. */
0a6969ad 237DEFTREECODE (QUAL_UNION_TYPE, "qual_union_type", 't', 0)
08703ee4 238
6d77ee89
BK
239/* Type of functions. Special fields:
240 TREE_TYPE type of value returned.
241 TYPE_ARG_TYPES list of types of arguments expected.
242 this list is made of TREE_LIST nodes.
243 Types of "Procedures" in languages where they are different from functions
244 have code FUNCTION_TYPE also, but then TREE_TYPE is zero or void type. */
0a6969ad 245DEFTREECODE (FUNCTION_TYPE, "function_type", 't', 0)
6d77ee89
BK
246
247/* This is a language-specific kind of type.
248 Its meaning is defined by the language front end.
249 layout_type does not know how to lay this out,
250 so the front-end must do so manually. */
0a6969ad 251DEFTREECODE (LANG_TYPE, "lang_type", 't', 0)
6d77ee89
BK
252\f
253/* Expressions */
254
255/* First, the constants. */
256
257/* Contents are in TREE_INT_CST_LOW and TREE_INT_CST_HIGH fields,
258 32 bits each, giving us a 64 bit constant capability.
259 Note: constants of type char in Pascal are INTEGER_CST,
260 and so are pointer constants such as nil in Pascal or NULL in C.
261 `(int *) 1' in C also results in an INTEGER_CST. */
0a6969ad 262DEFTREECODE (INTEGER_CST, "integer_cst", 'c', 2)
6d77ee89
BK
263
264/* Contents are in TREE_REAL_CST field. Also there is TREE_CST_RTL. */
0a6969ad 265DEFTREECODE (REAL_CST, "real_cst", 'c', 3)
6d77ee89
BK
266
267/* Contents are in TREE_REALPART and TREE_IMAGPART fields,
268 whose contents are other constant nodes.
269 Also there is TREE_CST_RTL. */
0a6969ad 270DEFTREECODE (COMPLEX_CST, "complex_cst", 'c', 3)
6d77ee89
BK
271
272/* Contents are TREE_STRING_LENGTH and TREE_STRING_POINTER fields.
273 Also there is TREE_CST_RTL. */
0a6969ad 274DEFTREECODE (STRING_CST, "string_cst", 'c', 3)
6d77ee89
BK
275
276/* Declarations. All references to names are represented as ..._DECL nodes.
277 The decls in one binding context are chained through the TREE_CHAIN field.
278 Each DECL has a DECL_NAME field which contains an IDENTIFIER_NODE.
279 (Some decls, most often labels, may have zero as the DECL_NAME).
280 DECL_CONTEXT points to the node representing the context in which
281 this declaration has its scope. For FIELD_DECLs, this is the
08703ee4
RK
282 RECORD_TYPE, UNION_TYPE, or QUAL_UNION_TYPE node that the field
283 is a member of. For VAR_DECL, PARM_DECL, FUNCTION_DECL, LABEL_DECL,
a082c85a
JM
284 and CONST_DECL nodes, this points to either the FUNCTION_DECL for the
285 containing function, the RECORD_TYPE or UNION_TYPE for the containing
286 type, or NULL_TREE if the given decl has "file scope".
6d77ee89
BK
287 DECL_ABSTRACT_ORIGIN, if non-NULL, points to the original (abstract)
288 ..._DECL node of which this decl is an (inlined or template expanded)
289 instance.
290 The TREE_TYPE field holds the data type of the object, when relevant.
291 LABEL_DECLs have no data type. For TYPE_DECL, the TREE_TYPE field
292 contents are the type whose name is being declared.
293 The DECL_ALIGN, DECL_SIZE,
294 and DECL_MODE fields exist in decl nodes just as in type nodes.
295 They are unused in LABEL_DECL, TYPE_DECL and CONST_DECL nodes.
296
297 DECL_OFFSET holds an integer number of bits offset for the location.
298 DECL_VOFFSET holds an expression for a variable offset; it is
299 to be multiplied by DECL_VOFFSET_UNIT (an integer).
300 These fields are relevant only in FIELD_DECLs and PARM_DECLs.
301
302 DECL_INITIAL holds the value to initialize a variable to,
303 or the value of a constant. For a function, it holds the body
304 (a node of type BLOCK representing the function's binding contour
305 and whose body contains the function's statements.) For a LABEL_DECL
306 in C, it is a flag, nonzero if the label's definition has been seen.
307
308 PARM_DECLs use a special field:
309 DECL_ARG_TYPE is the type in which the argument is actually
310 passed, which may be different from its type within the function.
311
312 FUNCTION_DECLs use four special fields:
313 DECL_ARGUMENTS holds a chain of PARM_DECL nodes for the arguments.
314 DECL_RESULT holds a RESULT_DECL node for the value of a function,
315 or it is 0 for a function that returns no value.
316 (C functions returning void have zero here.)
dce2e8c0
JW
317 The TREE_TYPE field is the type in which the result is actually
318 returned. This is usually the same as the return type of the
319 FUNCTION_DECL, but it may be a wider integer type because of
320 promotion.
6d77ee89
BK
321 DECL_FUNCTION_CODE is a code number that is nonzero for
322 built-in functions. Its value is an enum built_in_function
323 that says which built-in function it is.
324
325 DECL_SOURCE_FILE holds a filename string and DECL_SOURCE_LINE
326 holds a line number. In some cases these can be the location of
327 a reference, if no definition has been seen.
328
329 DECL_ABSTRACT is non-zero if the decl represents an abstract instance
330 of a decl (i.e. one which is nested within an abstract instance of a
331 inline function. */
332
0a6969ad
JC
333DEFTREECODE (FUNCTION_DECL, "function_decl", 'd', 0)
334DEFTREECODE (LABEL_DECL, "label_decl", 'd', 0)
335DEFTREECODE (CONST_DECL, "const_decl", 'd', 0)
336DEFTREECODE (TYPE_DECL, "type_decl", 'd', 0)
337DEFTREECODE (VAR_DECL, "var_decl", 'd', 0)
338DEFTREECODE (PARM_DECL, "parm_decl", 'd', 0)
339DEFTREECODE (RESULT_DECL, "result_decl", 'd', 0)
340DEFTREECODE (FIELD_DECL, "field_decl", 'd', 0)
2addbe1d
JM
341
342/* A namespace declaration. Namespaces appear in DECL_CONTEXT of other
343 _DECLs, providing a hierarchy of names. */
344DEFTREECODE (NAMESPACE_DECL, "namespace_decl", 'd', 0)
6d77ee89
BK
345\f
346/* References to storage. */
347
348/* Value is structure or union component.
349 Operand 0 is the structure or union (an expression);
350 operand 1 is the field (a node of type FIELD_DECL). */
0a6969ad 351DEFTREECODE (COMPONENT_REF, "component_ref", 'r', 2)
6d77ee89
BK
352
353/* Reference to a group of bits within an object. Similar to COMPONENT_REF
354 except the position is given explicitly rather than via a FIELD_DECL.
355 Operand 0 is the structure or union expression;
356 operand 1 is a tree giving the number of bits being referenced;
357 operand 2 is a tree giving the position of the first referenced bit.
358 The field can be either a signed or unsigned field;
359 TREE_UNSIGNED says which. */
0a6969ad 360DEFTREECODE (BIT_FIELD_REF, "bit_field_ref", 'r', 3)
6d77ee89
BK
361
362/* C unary `*' or Pascal `^'. One operand, an expression for a pointer. */
0a6969ad 363DEFTREECODE (INDIRECT_REF, "indirect_ref", 'r', 1)
6d77ee89 364
6d77ee89 365/* Pascal `^` on a file. One operand, an expression for the file. */
0a6969ad 366DEFTREECODE (BUFFER_REF, "buffer_ref", 'r', 1)
6d77ee89 367
b4e3fabb 368/* Array indexing.
abf82aab 369 Operand 0 is the array; operand 1 is a (single) array index. */
0a6969ad 370DEFTREECODE (ARRAY_REF, "array_ref", 'r', 2)
6d77ee89 371
75c2550a
RK
372/* Likewise, except that the result is a range ("slice") of the array. The
373 starting index of the resulting array is taken from operand 1 and the size
374 of the range is taken from the type of the expression. */
b4e3fabb
RK
375DEFTREECODE (ARRAY_RANGE_REF, "array_range_ref", 'r', 2)
376
6d77ee89
BK
377/* Constructor: return an aggregate value made from specified components.
378 In C, this is used only for structure and array initializers.
69b4bf98 379 Also used for SET_TYPE in Chill (and potentially Pascal).
6d77ee89
BK
380 The first "operand" is really a pointer to the RTL,
381 for constant constructors only.
382 The second operand is a list of component values
69b4bf98
PB
383 made out of a chain of TREE_LIST nodes.
384
385 For ARRAY_TYPE:
386 The TREE_PURPOSE of each node is the corresponding index.
387 If the TREE_PURPOSE is a RANGE_EXPR, it is a short-hand for many nodes,
388 one for each index in the range. (If the corresponding TREE_VALUE
389 has side-effects, they are evaluated once for each element. Wrap the
390 value in a SAVE_EXPR if you want to evaluate side effects only once.)
391
392 For RECORD_TYPE, UNION_TYPE, or QUAL_UNION_TYPE:
393 The TREE_PURPOSE of each node is a FIELD_DECL.
394
395 For SET_TYPE:
396 The TREE_VALUE specifies a value (index) in the set that is true.
397 If TREE_PURPOSE is non-NULL, it specifies the lower limit of a
398 range of true values. Elements not listed are false (not in the set). */
0a6969ad 399DEFTREECODE (CONSTRUCTOR, "constructor", 'e', 2)
6d77ee89 400
340af9ef
RK
401/* The expression types are mostly straightforward, with the fourth argument
402 of DEFTREECODE saying how many operands there are.
403 Unless otherwise specified, the operands are expressions and the
404 types of all the operands and the expression must all be the same. */
6d77ee89
BK
405
406/* Contains two expressions to compute, one followed by the other.
340af9ef
RK
407 the first value is ignored. The second one's value is used. The
408 type of the first expression need not agree with the other types. */
0a6969ad 409DEFTREECODE (COMPOUND_EXPR, "compound_expr", 'e', 2)
6d77ee89
BK
410
411/* Assignment expression. Operand 0 is the what to set; 1, the new value. */
0a6969ad 412DEFTREECODE (MODIFY_EXPR, "modify_expr", 'e', 2)
6d77ee89
BK
413
414/* Initialization expression. Operand 0 is the variable to initialize;
415 Operand 1 is the initializer. */
0a6969ad 416DEFTREECODE (INIT_EXPR, "init_expr", 'e', 2)
6d77ee89
BK
417
418/* For TARGET_EXPR, operand 0 is the target of an initialization,
419 operand 1 is the initializer for the target,
4847c938
MS
420 and operand 2 is the cleanup for this node, if any.
421 and operand 3 is the saved initializer after this node has been
422 expanded once, this is so we can re-expand the tree later. */
0a6969ad 423DEFTREECODE (TARGET_EXPR, "target_expr", 'e', 4)
6d77ee89
BK
424
425/* Conditional expression ( ... ? ... : ... in C).
426 Operand 0 is the condition.
427 Operand 1 is the then-value.
340af9ef 428 Operand 2 is the else-value.
68626d4f
MM
429 Operand 0 may be of any type.
430 Operand 1 must have the same type as the entire expression, unless
431 it unconditionally throws an exception, in which case it should
432 have VOID_TYPE. The same constraints apply to operand 2. */
0a6969ad 433DEFTREECODE (COND_EXPR, "cond_expr", 'e', 3)
6d77ee89
BK
434
435/* Declare local variables, including making RTL and allocating space.
436 Operand 0 is a chain of VAR_DECL nodes for the variables.
437 Operand 1 is the body, the expression to be computed using
438 the variables. The value of operand 1 becomes that of the BIND_EXPR.
439 Operand 2 is the BLOCK that corresponds to these bindings
440 for debugging purposes. If this BIND_EXPR is actually expanded,
441 that sets the TREE_USED flag in the BLOCK.
442
443 The BIND_EXPR is not responsible for informing parsers
444 about these variables. If the body is coming from the input file,
445 then the code that creates the BIND_EXPR is also responsible for
446 informing the parser of the variables.
447
448 If the BIND_EXPR is ever expanded, its TREE_USED flag is set.
449 This tells the code for debugging symbol tables not to ignore the BIND_EXPR.
450 If the BIND_EXPR should be output for debugging but will not be expanded,
451 set the TREE_USED flag by hand.
452
453 In order for the BIND_EXPR to be known at all, the code that creates it
454 must also install it as a subblock in the tree of BLOCK
455 nodes for the function. */
0a6969ad 456DEFTREECODE (BIND_EXPR, "bind_expr", 'e', 3)
6d77ee89
BK
457
458/* Function call. Operand 0 is the function.
459 Operand 1 is the argument list, a list of expressions
f9808f81
MM
460 made out of a chain of TREE_LIST nodes. */
461DEFTREECODE (CALL_EXPR, "call_expr", 'e', 2)
6d77ee89
BK
462
463/* Call a method. Operand 0 is the method, whose type is a METHOD_TYPE.
464 Operand 1 is the expression for "self".
465 Operand 2 is the list of explicit arguments. */
0a6969ad 466DEFTREECODE (METHOD_CALL_EXPR, "method_call_expr", 'e', 4)
6d77ee89
BK
467
468/* Specify a value to compute along with its corresponding cleanup.
469 Operand 0 argument is an expression whose value needs a cleanup.
6ad7895a
APB
470 Operand 1 is the cleanup expression for the object.
471 Operand 2 is an RTL_EXPR which will eventually represent that value.
6d77ee89
BK
472 The RTL_EXPR is used in this expression, which is how the expression
473 manages to act on the proper value.
5dab5552
MS
474 The cleanup is executed by the first enclosing CLEANUP_POINT_EXPR, if
475 it exists, otherwise it is the responsibility of the caller to manually
e976b8b2
MS
476 call expand_start_target_temps/expand_end_target_temps, as needed.
477
478 This differs from TRY_CATCH_EXPR in that operand 2 is always
d32ecec2 479 evaluated when an exception isn't thrown when cleanups are run. */
0a6969ad 480DEFTREECODE (WITH_CLEANUP_EXPR, "with_cleanup_expr", 'e', 3)
5dab5552
MS
481
482/* Specify a cleanup point.
8736e836
JM
483 Operand 0 is an expression that may have cleanups. If it does, those
484 cleanups are executed after the expression is expanded.
485
486 Note that if the expression is a reference to storage, it is forced out
487 of memory before the cleanups are run. This is necessary to handle
488 cases where the cleanups modify the storage referenced; in the
489 expression 't.i', if 't' is a struct with an integer member 'i' and a
490 cleanup which modifies 'i', the value of the expression depends on
491 whether the cleanup is run before or after 't.i' is evaluated. When
492 expand_expr is run on 't.i', it returns a MEM. This is not good enough;
493 the value of 't.i' must be forced out of memory.
494
495 As a consequence, the operand of a CLEANUP_POINT_EXPR must not have
496 BLKmode, because it will not be forced out of memory. */
0a6969ad 497DEFTREECODE (CLEANUP_POINT_EXPR, "cleanup_point_expr", 'e', 1)
6d77ee89 498
ab487f12 499/* The following two codes are used in languages that have types where
2a7b6292
PG
500 some field in an object of the type contains a value that is used in
501 the computation of another field's offset or size and/or the size of
502 the type. The positions and/or sizes of fields can vary from object
503 to object of the same type.
504
505 Record types with discriminants in Ada or schema types in Pascal are
506 examples of such types. This mechanism is also used to create "fat
507 pointers" for unconstrained array types in Ada; the fat pointer is a
508 structure one of whose fields is a pointer to the actual array type
509 and the other field is a pointer to a template, which is a structure
510 containing the bounds of the array. The bounds in the type pointed
511 to by the first field in the fat pointer refer to the values in the
512 template.
513
514 When you wish to construct such a type you need "self-references"
515 that allow you to reference the object having this type from the
516 TYPE node, i.e. without having a variable instantiating this type.
517
518 Such a "self-references" is done using a PLACEHOLDER_EXPR. This is
519 a node that will later be replaced with the object being referenced.
520 Its type is that of the object and selects which object to use from
521 a chain of references (see below). No other slots are used in the
522 PLACEHOLDER_EXPR.
523
524 For example, if your type FOO is a RECORD_TYPE with a field BAR,
525 and you need the value of <variable>.BAR to calculate TYPE_SIZE
526 (FOO), just substitute <variable> above with a PLACEHOLDER_EXPR
527 what contains both the expression we wish to
528 evaluate and an expression within which the object may be found.
529 The latter expression is the object itself in the simple case of an
530 Ada record with discriminant, but it can be the array in the case of
531 an unconstrained array.
532
533 In the latter case, we need the fat pointer, because the bounds of
534 the array can only be accessed from it. However, we rely here on the
535 fact that the expression for the array contains the dereference of
536 the fat pointer that obtained the array pointer.
ab487f12
RK
537
538 Accordingly, when looking for the object to substitute in place of
539 a PLACEHOLDER_EXPR, we look down the first operand of the expression
2a7b6292
PG
540 passed as the second operand to WITH_RECORD_EXPR until we find
541 something of the desired type or reach a constant. */
ab487f12
RK
542
543/* Denotes a record to later be supplied with a WITH_RECORD_EXPR when
544 evaluating this expression. The type of this expression is used to
545 find the record to replace it. */
0a6969ad 546DEFTREECODE (PLACEHOLDER_EXPR, "placeholder_expr", 'x', 0)
ab487f12
RK
547
548/* Provide an expression that references a record to be used in place
549 of a PLACEHOLDER_EXPR. The record to be used is the record within
550 operand 1 that has the same type as the PLACEHOLDER_EXPR in
551 operand 0. */
0a6969ad 552DEFTREECODE (WITH_RECORD_EXPR, "with_record_expr", 'e', 2)
ab487f12 553
340af9ef 554/* Simple arithmetic. */
0a6969ad
JC
555DEFTREECODE (PLUS_EXPR, "plus_expr", '2', 2)
556DEFTREECODE (MINUS_EXPR, "minus_expr", '2', 2)
557DEFTREECODE (MULT_EXPR, "mult_expr", '2', 2)
6d77ee89
BK
558
559/* Division for integer result that rounds the quotient toward zero. */
0a6969ad 560DEFTREECODE (TRUNC_DIV_EXPR, "trunc_div_expr", '2', 2)
6d77ee89
BK
561
562/* Division for integer result that rounds the quotient toward infinity. */
0a6969ad 563DEFTREECODE (CEIL_DIV_EXPR, "ceil_div_expr", '2', 2)
6d77ee89
BK
564
565/* Division for integer result that rounds toward minus infinity. */
0a6969ad 566DEFTREECODE (FLOOR_DIV_EXPR, "floor_div_expr", '2', 2)
6d77ee89
BK
567
568/* Division for integer result that rounds toward nearest integer. */
0a6969ad 569DEFTREECODE (ROUND_DIV_EXPR, "round_div_expr", '2', 2)
6d77ee89
BK
570
571/* Four kinds of remainder that go with the four kinds of division. */
0a6969ad
JC
572DEFTREECODE (TRUNC_MOD_EXPR, "trunc_mod_expr", '2', 2)
573DEFTREECODE (CEIL_MOD_EXPR, "ceil_mod_expr", '2', 2)
574DEFTREECODE (FLOOR_MOD_EXPR, "floor_mod_expr", '2', 2)
575DEFTREECODE (ROUND_MOD_EXPR, "round_mod_expr", '2', 2)
6d77ee89 576
340af9ef 577/* Division for real result. */
0a6969ad 578DEFTREECODE (RDIV_EXPR, "rdiv_expr", '2', 2)
6d77ee89
BK
579
580/* Division which is not supposed to need rounding.
581 Used for pointer subtraction in C. */
0a6969ad 582DEFTREECODE (EXACT_DIV_EXPR, "exact_div_expr", '2', 2)
6d77ee89
BK
583
584/* Conversion of real to fixed point: four ways to round,
585 like the four ways to divide.
586 CONVERT_EXPR can also be used to convert a real to an integer,
587 and that is what is used in languages that do not have ways of
588 specifying which of these is wanted. Maybe these are not needed. */
0a6969ad
JC
589DEFTREECODE (FIX_TRUNC_EXPR, "fix_trunc_expr", '1', 1)
590DEFTREECODE (FIX_CEIL_EXPR, "fix_ceil_expr", '1', 1)
591DEFTREECODE (FIX_FLOOR_EXPR, "fix_floor_expr", '1', 1)
592DEFTREECODE (FIX_ROUND_EXPR, "fix_round_expr", '1', 1)
6d77ee89
BK
593
594/* Conversion of an integer to a real. */
0a6969ad 595DEFTREECODE (FLOAT_EXPR, "float_expr", '1', 1)
6d77ee89 596
340af9ef 597/* Unary negation. */
0a6969ad 598DEFTREECODE (NEGATE_EXPR, "negate_expr", '1', 1)
6d77ee89 599
0a6969ad
JC
600DEFTREECODE (MIN_EXPR, "min_expr", '2', 2)
601DEFTREECODE (MAX_EXPR, "max_expr", '2', 2)
68e568c2
MM
602
603/* Represents the absolute value of the operand.
604
605 An ABS_EXPR must have either an INTEGER_TYPE or a REAL_TYPE. The
606 operand of the ABS_EXPR must have the same type. */
0a6969ad 607DEFTREECODE (ABS_EXPR, "abs_expr", '1', 1)
68e568c2 608
0a6969ad 609DEFTREECODE (FFS_EXPR, "ffs_expr", '1', 1)
6d77ee89
BK
610
611/* Shift operations for shift and rotate.
4b7ee615
NS
612 Shift means logical shift if done on an
613 unsigned type, arithmetic shift if done on a signed type.
6d77ee89 614 The second operand is the number of bits to
7d46d516
TM
615 shift by; it need not be the same type as the first operand and result.
616 Note that the result is undefined if the second operand is larger
617 than the first operand's type size. */
0a6969ad
JC
618DEFTREECODE (LSHIFT_EXPR, "lshift_expr", '2', 2)
619DEFTREECODE (RSHIFT_EXPR, "rshift_expr", '2', 2)
620DEFTREECODE (LROTATE_EXPR, "lrotate_expr", '2', 2)
621DEFTREECODE (RROTATE_EXPR, "rrotate_expr", '2', 2)
6d77ee89
BK
622
623/* Bitwise operations. Operands have same mode as result. */
0a6969ad
JC
624DEFTREECODE (BIT_IOR_EXPR, "bit_ior_expr", '2', 2)
625DEFTREECODE (BIT_XOR_EXPR, "bit_xor_expr", '2', 2)
626DEFTREECODE (BIT_AND_EXPR, "bit_and_expr", '2', 2)
627DEFTREECODE (BIT_ANDTC_EXPR, "bit_andtc_expr", '2', 2)
628DEFTREECODE (BIT_NOT_EXPR, "bit_not_expr", '1', 1)
6d77ee89 629
330aa9a3
MM
630/* ANDIF and ORIF allow the second operand not to be computed if the
631 value of the expression is determined from the first operand. AND,
632 OR, and XOR always compute the second operand whether its value is
633 needed or not (for side effects). The operand may have
634 BOOLEAN_TYPE or INTEGER_TYPE. In either case, the argument will be
635 either zero or one. For example, a TRUTH_NOT_EXPR will never have
636 a INTEGER_TYPE VAR_DECL as its argument; instead, a NE_EXPR will be
637 used to compare the VAR_DECL to zero, thereby obtaining a node with
638 value zero or one. */
0a6969ad
JC
639DEFTREECODE (TRUTH_ANDIF_EXPR, "truth_andif_expr", 'e', 2)
640DEFTREECODE (TRUTH_ORIF_EXPR, "truth_orif_expr", 'e', 2)
641DEFTREECODE (TRUTH_AND_EXPR, "truth_and_expr", 'e', 2)
642DEFTREECODE (TRUTH_OR_EXPR, "truth_or_expr", 'e', 2)
643DEFTREECODE (TRUTH_XOR_EXPR, "truth_xor_expr", 'e', 2)
644DEFTREECODE (TRUTH_NOT_EXPR, "truth_not_expr", 'e', 1)
6d77ee89
BK
645
646/* Relational operators.
647 `EQ_EXPR' and `NE_EXPR' are allowed for any types.
648 The others are allowed only for integer (or pointer or enumeral)
649 or real types.
650 In all cases the operands will have the same type,
651 and the value is always the type used by the language for booleans. */
0a6969ad
JC
652DEFTREECODE (LT_EXPR, "lt_expr", '<', 2)
653DEFTREECODE (LE_EXPR, "le_expr", '<', 2)
654DEFTREECODE (GT_EXPR, "gt_expr", '<', 2)
655DEFTREECODE (GE_EXPR, "ge_expr", '<', 2)
656DEFTREECODE (EQ_EXPR, "eq_expr", '<', 2)
657DEFTREECODE (NE_EXPR, "ne_expr", '<', 2)
6d77ee89 658
1eb8759b
RH
659/* Additional relational operators for floating point unordered. */
660DEFTREECODE (UNORDERED_EXPR, "unordered_expr", '<', 2)
661DEFTREECODE (ORDERED_EXPR, "ordered_expr", '<', 2)
662
663/* These are equivalent to unordered or ... */
664DEFTREECODE (UNLT_EXPR, "unlt_expr", '<', 2)
665DEFTREECODE (UNLE_EXPR, "unle_expr", '<', 2)
666DEFTREECODE (UNGT_EXPR, "ungt_expr", '<', 2)
667DEFTREECODE (UNGE_EXPR, "unge_expr", '<', 2)
668DEFTREECODE (UNEQ_EXPR, "uneq_expr", '<', 2)
1eb8759b 669
6d77ee89 670/* Operations for Pascal sets. Not used now. */
0a6969ad
JC
671DEFTREECODE (IN_EXPR, "in_expr", '2', 2)
672DEFTREECODE (SET_LE_EXPR, "set_le_expr", '<', 2)
673DEFTREECODE (CARD_EXPR, "card_expr", '1', 1)
674DEFTREECODE (RANGE_EXPR, "range_expr", '2', 2)
6d77ee89
BK
675
676/* Represents a conversion of type of a value.
677 All conversions, including implicit ones, must be
340af9ef 678 represented by CONVERT_EXPR or NOP_EXPR nodes. */
0a6969ad 679DEFTREECODE (CONVERT_EXPR, "convert_expr", '1', 1)
6d77ee89
BK
680
681/* Represents a conversion expected to require no code to be generated. */
0a6969ad 682DEFTREECODE (NOP_EXPR, "nop_expr", '1', 1)
6d77ee89
BK
683
684/* Value is same as argument, but guaranteed not an lvalue. */
0a6969ad 685DEFTREECODE (NON_LVALUE_EXPR, "non_lvalue_expr", '1', 1)
6d77ee89
BK
686
687/* Represents something we computed once and will use multiple times.
688 First operand is that expression. Second is the function decl
689 in which the SAVE_EXPR was created. The third operand is the RTL,
690 nonzero only after the expression has been computed. */
0a6969ad 691DEFTREECODE (SAVE_EXPR, "save_expr", 'e', 3)
6d77ee89 692
679163cf
MS
693/* For a UNSAVE_EXPR, operand 0 is the value to unsave. By unsave, we
694 mean that all _EXPRs such as TARGET_EXPRs, SAVE_EXPRs,
695 CALL_EXPRs and RTL_EXPRs, that are protected
696 from being evaluated more than once should be reset so that a new
697 expand_expr call of this expr will cause those to be re-evaluated.
698 This is useful when we want to reuse a tree in different places,
699 but where we must re-expand. */
0a6969ad 700DEFTREECODE (UNSAVE_EXPR, "unsave_expr", 'e', 1)
679163cf 701
9f937026
MM
702/* Represents something whose RTL has already been expanded as a
703 sequence which should be emitted when this expression is expanded.
704 The first operand is the RTL to emit. It is the first of a chain
64dc53f3
MM
705 of insns. The second is the RTL expression for the result. Any
706 temporaries created during the building of the RTL_EXPR can be
707 reused once the RTL_EXPR has been expanded, with the exception of
708 the RTL_EXPR_RTL. */
0a6969ad 709DEFTREECODE (RTL_EXPR, "rtl_expr", 'e', 2)
6d77ee89
BK
710
711/* & in C. Value is the address at which the operand's value resides.
712 Operand may have any mode. Result mode is Pmode. */
0a6969ad 713DEFTREECODE (ADDR_EXPR, "addr_expr", 'e', 1)
6d77ee89
BK
714
715/* Non-lvalue reference or pointer to an object. */
0a6969ad 716DEFTREECODE (REFERENCE_EXPR, "reference_expr", 'e', 1)
6d77ee89
BK
717
718/* Operand is a function constant; result is a function variable value
67231816 719 of type EPmode. Used only for languages that need static chains. */
0a6969ad 720DEFTREECODE (ENTRY_VALUE_EXPR, "entry_value_expr", 'e', 1)
6d77ee89 721
67231816
RH
722/* Operand0 is a function constant; result is part N of a function
723 descriptor of type ptr_mode. */
724DEFTREECODE (FDESC_EXPR, "fdesc_expr", 'e', 2)
725
6d77ee89
BK
726/* Given two real or integer operands of the same type,
727 returns a complex value of the corresponding complex type. */
0a6969ad 728DEFTREECODE (COMPLEX_EXPR, "complex_expr", '2', 2)
6d77ee89 729
340af9ef 730/* Complex conjugate of operand. Used only on complex types. */
0a6969ad 731DEFTREECODE (CONJ_EXPR, "conj_expr", '1', 1)
6d77ee89
BK
732
733/* Used only on an operand of complex type, these return
734 a value of the corresponding component type. */
0a6969ad
JC
735DEFTREECODE (REALPART_EXPR, "realpart_expr", '1', 1)
736DEFTREECODE (IMAGPART_EXPR, "imagpart_expr", '1', 1)
6d77ee89
BK
737
738/* Nodes for ++ and -- in C.
739 The second arg is how much to increment or decrement by.
740 For a pointer, it would be the size of the object pointed to. */
0a6969ad
JC
741DEFTREECODE (PREDECREMENT_EXPR, "predecrement_expr", 'e', 2)
742DEFTREECODE (PREINCREMENT_EXPR, "preincrement_expr", 'e', 2)
743DEFTREECODE (POSTDECREMENT_EXPR, "postdecrement_expr", 'e', 2)
744DEFTREECODE (POSTINCREMENT_EXPR, "postincrement_expr", 'e', 2)
e976b8b2 745
d3707adb
RH
746/* Used to implement `va_arg'. */
747DEFTREECODE (VA_ARG_EXPR, "va_arg_expr", 'e', 1)
748
956d6950 749/* Evaluate operand 1. If and only if an exception is thrown during
e976b8b2
MS
750 the evaluation of operand 1, evaluate operand 2.
751
752 This differs from WITH_CLEANUP_EXPR, in that operand 2 is never
753 evaluated unless an exception is throw. */
0a6969ad 754DEFTREECODE (TRY_CATCH_EXPR, "try_catch_expr", 'e', 2)
e976b8b2 755
502bf1f3
PB
756/* Evaluate the first operand.
757 The second operand is a a cleanup expression which is evaluated
758 before an exit (normal, exception, or jump out) from this expression.
759
760 Like a CLEANUP_POINT_EXPR/WITH_CLEANUP_EXPR combination, but those
761 always copy the cleanup expression where needed. In contrast,
762 TRY_FINALLY_EXPR generates a jump to a cleanup subroutine.
763 (At least conceptually; the optimizer could inline the cleanup
764 subroutine in the same way it could inline normal subroutines.)
765 TRY_FINALLY_EXPR should be used when the cleanup is actual statements
766 in the source of the current function (which people might want to
767 set breakpoints in). */
768DEFTREECODE (TRY_FINALLY_EXPR, "try_finally", 'e', 2)
769
770/* Used internally for cleanups in the implementation of TRY_FINALLY_EXPR.
771 (Specifically, it is created by expand_expr, not front-ends.)
772 Operand 0 is the rtx for the start of the subroutine we need to call.
773 Operand 1 is the rtx for a variable in which to store the address
774 of where the subroutine should return to. */
775DEFTREECODE (GOTO_SUBROUTINE_EXPR, "goto_subroutine", 'e', 2)
6d77ee89
BK
776\f
777/* These types of expressions have no useful value,
778 and always have side effects. */
779
780/* A label definition, encapsulated as a statement.
781 Operand 0 is the LABEL_DECL node for the label that appears here.
782 The type should be void and the value should be ignored. */
0a6969ad 783DEFTREECODE (LABEL_EXPR, "label_expr", 's', 1)
6d77ee89 784
70e6ca43 785/* GOTO. Operand 0 is a LABEL_DECL node or an expression.
6d77ee89 786 The type should be void and the value should be ignored. */
0a6969ad 787DEFTREECODE (GOTO_EXPR, "goto_expr", 's', 1)
6d77ee89
BK
788
789/* RETURN. Evaluates operand 0, then returns from the current function.
790 Presumably that operand is an assignment that stores into the
791 RESULT_DECL that hold the value to be returned.
792 The operand may be null.
793 The type should be void and the value should be ignored. */
0a6969ad 794DEFTREECODE (RETURN_EXPR, "return_expr", 's', 1)
6d77ee89
BK
795
796/* Exit the inner most loop conditionally. Operand 0 is the condition.
797 The type should be void and the value should be ignored. */
0a6969ad 798DEFTREECODE (EXIT_EXPR, "exit_expr", 's', 1)
6d77ee89
BK
799
800/* A loop. Operand 0 is the body of the loop.
801 It must contain an EXIT_EXPR or is an infinite loop.
802 The type should be void and the value should be ignored. */
0a6969ad 803DEFTREECODE (LOOP_EXPR, "loop_expr", 's', 1)
6d77ee89 804
0044c65c
APB
805/* A labeled block. Operand 0 is the label that will be generated to
806 mark the end of the block.
807 Operand 1 is the labeled block body. */
808DEFTREECODE (LABELED_BLOCK_EXPR, "labeled_block_expr", 'e', 2)
809
810/* Exit a labeled block, possibly returning a value. Operand 0 is a
811 LABELED_BLOCK_EXPR to exit. Operand 1 is the value to return. It
812 may be left null. */
813DEFTREECODE (EXIT_BLOCK_EXPR, "exit_block_expr", 'e', 2)
814
2491f72d
APB
815/* Annotates a tree node (usually an expression) with source location
816 information: a file name (EXPR_WFL_FILENAME); a line number
817 (EXPR_WFL_LINENO); and column number (EXPR_WFL_COLNO). It is
818 expanded as the contained node (EXPR_WFL_NODE); a line note should
be821c5e
APB
819 be emitted first if EXPR_WFL_EMIT_LINE_NOTE.
820 The third operand is only used in the Java front-end, and will
821 eventually be removed. */
822DEFTREECODE (EXPR_WITH_FILE_LOCATION, "expr_with_file_location", 'e', 3)
7c226435
APB
823
824/* Switch expression.
825 Operand 0 is the expression used to perform the branch,
826 Operand 1 contains the case values. The way they're organized is
827 front-end implementation defined. */
828DEFTREECODE (SWITCH_EXPR, "switch_expr", 'e', 2)
52a11cbf
RH
829
830/* The exception object from the runtime. */
831DEFTREECODE (EXC_PTR_EXPR, "exc_ptr_expr", 'e', 0)
832
6d77ee89
BK
833/*
834Local variables:
835mode:c
6d77ee89
BK
836End:
837*/
This page took 1.621521 seconds and 5 git commands to generate.