]> gcc.gnu.org Git - gcc.git/blame - gcc/cp/cp-tree.h
typeck.c (get_delta_difference): If via a virtual base, return zero.
[gcc.git] / gcc / cp / cp-tree.h
CommitLineData
8d08fdba 1/* Definitions for C++ parsing and type checking.
06ceef4e
RK
2 Copyright (C) 1987, 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000
3 Free Software Foundation, Inc.
4 Contributed by Michael Tiemann (tiemann@cygnus.com)
8d08fdba
MS
5
6This file is part of GNU CC.
7
8GNU CC is free software; you can redistribute it and/or modify
9it under the terms of the GNU General Public License as published by
10the Free Software Foundation; either version 2, or (at your option)
11any later version.
12
13GNU CC is distributed in the hope that it will be useful,
14but WITHOUT ANY WARRANTY; without even the implied warranty of
15MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16GNU General Public License for more details.
17
18You should have received a copy of the GNU General Public License
19along with GNU CC; see the file COPYING. If not, write to
e9fa0c7c
RK
20the Free Software Foundation, 59 Temple Place - Suite 330,
21Boston, MA 02111-1307, USA. */
8d08fdba 22
99dccabc 23#include "function.h"
ee94fce6 24#include "hashtab.h"
46e8c075 25#include "splay-tree.h"
9cd64686 26#include "varray.h"
7f4edbcb 27
8d08fdba
MS
28#ifndef _CP_TREE_H
29#define _CP_TREE_H
30
d7e7759d
BC
31#include "c-common.h"
32
cfdd0551 33/* Usage of TREE_LANG_FLAG_?:
280f9385 34 0: BINFO_MARKED (BINFO nodes).
0e5921e8 35 IDENTIFIER_MARKED (IDENTIFIER_NODEs)
cfdd0551
PB
36 NEW_EXPR_USE_GLOBAL (in NEW_EXPR).
37 DELETE_EXPR_USE_GLOBAL (in DELETE_EXPR).
38 LOOKUP_EXPR_GLOBAL (in LOOKUP_EXPR).
b26caacd 39 TREE_INDIRECT_USING (in NAMESPACE_DECL).
f181d4ae 40 LOCAL_BINDING_P (in CPLUS_BINDING)
27b8d0cd 41 ICS_USER_FLAG (in _CONV)
f1dedc31 42 CLEANUP_P (in TRY_BLOCK)
e1376b00 43 AGGR_INIT_VIA_CTOR_P (in AGGR_INIT_EXPR)
46e8c075 44 CTOR_BEGIN_P (in CTOR_STMT)
31f8e4f3 45 BV_USE_VCALL_INDEX_P (in the BINFO_VIRTUALS TREE_LIST)
19420d00 46 PTRMEM_OK_P (in ADDR_EXPR, OFFSET_REF)
5cce22b6 47 PARMLIST_ELLIPSIS_P (in PARMLIST)
4bb0968f 48 1: IDENTIFIER_VIRTUAL_P.
cfdd0551 49 TI_PENDING_TEMPLATE_FLAG.
cfdd0551
PB
50 TEMPLATE_PARMS_FOR_INLINE.
51 DELETE_EXPR_USE_VEC (in DELETE_EXPR).
52 (TREE_CALLS_NEW) (in _EXPR or _REF) (commented-out).
4c6b7393 53 TYPE_BASE_CONVS_MAY_REQUIRE_CODE_P (in _TYPE).
8f032717 54 INHERITED_VALUE_BINDING_P (in CPLUS_BINDING)
4bb0968f 55 BASELINK_P (in TREE_LIST)
27b8d0cd 56 ICS_ELLIPSIS_FLAG (in _CONV)
db3d8cde 57 BINFO_ACCESS (in BINFO)
31f8e4f3 58 BV_GENERATE_THUNK_WITH_VTABLE_P (in TREE_LIST)
cfdd0551 59 2: IDENTIFIER_OPNAME_P.
4c6b7393 60 TYPE_POLYMORHPIC_P (in _TYPE)
27b8d0cd 61 ICS_THIS_FLAG (in _CONV)
a7e4cfa0 62 BINDING_HAS_LEVEL_P (in CPLUS_BINDING)
db3d8cde 63 BINFO_OVERRIDE_ALONG_VIRTUAL_PATH_P (in BINFO)
cfdd0551
PB
64 3: TYPE_USES_VIRTUAL_BASECLASSES (in a class TYPE).
65 BINFO_VTABLE_PATH_MARKED.
0ec57017 66 BINFO_PUSHDECLS_MARKED.
cfdd0551 67 (TREE_REFERENCE_EXPR) (in NON_LVALUE_EXPR) (commented-out).
27b8d0cd 68 ICS_BAD_FLAG (in _CONV)
62409b39 69 FN_TRY_BLOCK_P (in TRY_BLOCK)
298d6f60 70 IDENTIFIER_CTOR_OR_DTOR_P (in IDENTIFIER_NODE)
cfdd0551
PB
71 4: BINFO_NEW_VTABLE_MARKED.
72 TREE_HAS_CONSTRUCTOR (in INDIRECT_REF, SAVE_EXPR, CONSTRUCTOR,
73 or FIELD_DECL).
27b8d0cd 74 NEED_TEMPORARY_P (in REF_BIND, BASE_CONV)
421844e7 75 IDENTIFIER_TYPENAME_P (in IDENTIFIER_NODE)
0e5921e8 76 5: C_IS_RESERVED_WORD (in IDENTIFIER_NODE)
911a71a7 77 6: BINFO_ACCESS (in BINFO)
cfdd0551
PB
78
79 Usage of TYPE_LANG_FLAG_?:
80 0: C_TYPE_FIELDS_READONLY (in RECORD_TYPE or UNION_TYPE).
81 1: TYPE_HAS_CONSTRUCTOR.
82 2: TYPE_HAS_DESTRUCTOR.
ea419909 83 3: TYPE_FOR_JAVA.
834c6dff 84 4: TYPE_HAS_NONTRIVIAL_DESTRUCTOR
cfdd0551 85 5: IS_AGGR_TYPE.
ea419909 86 6: TYPE_BUILT_IN.
cfdd0551
PB
87
88 Usage of DECL_LANG_FLAG_?:
89 0: DECL_ERROR_REPORTED (in VAR_DECL).
50714e79 90 DECL_TEMPLATE_PARM_P (in CONST_DECL, TYPE_DECL, or TEMPLATE_DECL)
cd9f6678 91 DECL_LOCAL_FUNCTION_P (in FUNCTION_DECL)
721c3b42 92 DECL_MUTABLE_P (in FIELD_DECL)
cfdd0551 93 1: C_TYPEDEF_EXPLICITLY_SIGNED (in TYPE_DECL).
fbf1c34b 94 DECL_TEMPLATE_INSTANTIATED (in a VAR_DECL or a FUNCTION_DECL)
721c3b42 95 DECL_C_BITFIELD (in FIELD_DECL)
cfdd0551 96 2: DECL_THIS_EXTERN (in VAR_DECL or FUNCTION_DECL).
9188c363 97 DECL_IMPLICIT_TYPEDEF_P (in a TYPE_DECL)
cfdd0551 98 3: DECL_IN_AGGR_P.
0a7394bc 99 4: DECL_C_BIT_FIELD
cfdd0551
PB
100 5: DECL_INTERFACE_KNOWN.
101 6: DECL_THIS_STATIC (in VAR_DECL or FUNCTION_DECL).
102 7: DECL_DEAD_FOR_LOCAL (in VAR_DECL).
cc057ef3 103 DECL_THUNK_P (in a member FUNCTION_DECL)
7ddedda4
MM
104
105 Usage of language-independent fields in a language-dependent manner:
911a71a7
MM
106
107 TREE_USED
108 This field is BINFO_INDIRECT_PRIMARY_P in a BINFO.
109
7ddedda4
MM
110 TYPE_ALIAS_SET
111 This field is used by TYPENAME_TYPEs, TEMPLATE_TYPE_PARMs, and so
112 forth as a substitute for the mark bits provided in `lang_type'.
113 At present, only the six low-order bits are used.
114
115 TYPE_BINFO
116 For an ENUMERAL_TYPE, this is ENUM_TEMPLATE_INFO.
117 For a TYPENAME_TYPE, this is TYPENAME_TYPE_FULLNAME.
bb20cc46 118 For a TEMPLATE_TEMPLATE_PARM or BOUND_TEMPLATE_TEMPLATE_PARM,
a1281f45 119 this is TEMPLATE_TEMPLATE_PARM_TEMPLATE_INFO.
0aafb128 120
9df2c88c 121 BINFO_VIRTUALS
5e19c053 122 For a binfo, this is a TREE_LIST. The BV_DELTA of each node
83f2ccf4 123 gives the amount by which to adjust the `this' pointer when
174eceea
MM
124 calling the function. If the method is an overriden version of a
125 base class method, then it is assumed that, prior to adjustment,
126 the this pointer points to an object of the base class.
127
5e19c053 128 The BV_VCALL_INDEX of each node, if non-NULL, gives the vtable
31f8e4f3
MM
129 index of the vcall offset for this entry. If
130 BV_USE_VCALL_INDEX_P then the corresponding vtable entry should
131 use a virtual thunk, as opposed to an ordinary thunk.
c0bbf652 132
5e19c053 133 The BV_FN is the declaration for the virtual function itself.
c0bbf652 134 When CLASSTYPE_COM_INTERFACE_P does not hold, the first entry
5e19c053
MM
135 does not have a BV_FN; it is just an offset.
136
137 The BV_OVERRIDING_BASE is the binfo for the final overrider for
138 this function. (This binfo's BINFO_TYPE will always be the same
139 as the DECL_CLASS_CONTEXT for the function.)
0fa5e05c 140
c35cce41
MM
141 BINFO_VTABLE
142 Sometimes this is a VAR_DECL. Under the new ABI, it is instead
143 an expression with POINTER_TYPE pointing that gives the value
144 to which the vptr should be initialized. Use get_vtbl_decl_for_binfo
145 to extract the VAR_DECL for the complete vtable; that macro works
146 in both ABIs.
147
0fa5e05c 148 DECL_ARGUMENTS
bb20cc46 149 For a VAR_DECL this is DECL_ANON_UNION_ELEMS.
051e6fd7
MM
150
151 DECL_VINDEX
152 This field is NULL for a non-virtual function. For a virtual
153 function, it is eventually set to an INTEGER_CST indicating the
154 index in the vtable at which this function can be found. When
155 a virtual function is declared, but before it is known what
156 function is overriden, this field is the error_mark_node.
157
bb20cc46 158 Temporarily, it may be set to a TREE_LIST whose TREE_VALUE is
051e6fd7
MM
159 the virtual function this one overrides, and whose TREE_CHAIN is
160 the old DECL_VINDEX. */
cfdd0551 161
da8a66fc
ML
162/* Language-specific tree checkers. */
163
f4524c9e 164#if defined ENABLE_TREE_CHECKING && (GCC_VERSION >= 2007)
da8a66fc
ML
165
166#define VAR_OR_FUNCTION_DECL_CHECK(NODE) \
167({ const tree __t = NODE; \
168 enum tree_code __c = TREE_CODE(__t); \
169 if (__c != VAR_DECL && __c != FUNCTION_DECL) \
1b493b81
ZW
170 tree_check_failed (__t, VAR_DECL, __FILE__, __LINE__, \
171 __FUNCTION__); \
da8a66fc
ML
172 __t; })
173
07c88314
MM
174#define VAR_FUNCTION_OR_PARM_DECL_CHECK(NODE) \
175({ const tree __t = NODE; \
176 enum tree_code __c = TREE_CODE(__t); \
bb20cc46
AJ
177 if (__c != VAR_DECL \
178 && __c != FUNCTION_DECL \
07c88314 179 && __c != PARM_DECL) \
1b493b81
ZW
180 tree_check_failed (__t, VAR_DECL, __FILE__, __LINE__, \
181 __FUNCTION__); \
07c88314
MM
182 __t; })
183
7c355bca
ML
184#define VAR_TEMPL_TYPE_OR_FUNCTION_DECL_CHECK(NODE) \
185({ const tree __t = NODE; \
186 enum tree_code __c = TREE_CODE(__t); \
bb20cc46 187 if (__c != VAR_DECL \
7c355bca
ML
188 && __c != FUNCTION_DECL \
189 && __c != TYPE_DECL \
190 && __c != TEMPLATE_DECL) \
1b493b81
ZW
191 tree_check_failed (__t, VAR_DECL, __FILE__, __LINE__, \
192 __FUNCTION__); \
7c355bca
ML
193 __t; })
194
da8a66fc
ML
195#define RECORD_OR_UNION_TYPE_CHECK(NODE) \
196({ const tree __t = NODE; \
197 enum tree_code __c = TREE_CODE(__t); \
198 if (__c != RECORD_TYPE && __c != UNION_TYPE) \
1b493b81
ZW
199 tree_check_failed (__t, RECORD_TYPE, __FILE__, __LINE__, \
200 __FUNCTION__); \
da8a66fc
ML
201 __t; })
202
f4524c9e 203#else /* not ENABLE_TREE_CHECKING, or not gcc */
da8a66fc
ML
204
205#define VAR_OR_FUNCTION_DECL_CHECK(NODE) NODE
07c88314 206#define VAR_FUNCTION_OR_PARM_DECL_CHECK(NODE) NODE
7c355bca 207#define VAR_TEMPL_TYPE_OR_FUNCTION_DECL_CHECK(NODE) NODE
da8a66fc
ML
208#define RECORD_OR_UNION_TYPE_CHECK(NODE) NODE
209
210#endif
d7e7759d 211
bbd15aac
MM
212\f
213/* ABI control. */
214
215/* Nonzero to enable experimental ABI changes. */
216
217extern int flag_new_abi;
218
219/* Nonzero to use __cxa_atexit, rather than atexit, to register
220 destructors for local statics and global objects. */
221
222extern int flag_use_cxa_atexit;
223
224/* Nonzero to not ignore namespace std. */
da8a66fc 225
bbd15aac
MM
226extern int flag_honor_std;
227
228/* Nonzero means generate 'rtti' that give run-time type information. */
229
230extern int flag_rtti;
231
4e7512c9
MM
232/* Nonzero if we want to support huge (> 2^(sizeof(short)*8-1) bytes)
233 objects. */
234
235extern int flag_huge_objects;
236
bbd15aac
MM
237/* Nonzero if virtual base class offsets are stored in the virtual
238 function table. Zero if, instead, a pointer to the virtual base is
239 stored in the object itself. */
240#define vbase_offsets_in_vtable_p() (flag_new_abi)
241
1a588ad7
MM
242/* Nonzero if displacements to the `this' pointer to use when calling
243 virtual functions in a virtual base class are present in the
244 vtable. */
245#define vcall_offsets_in_vtable_p() (flag_new_abi)
246
bbd15aac
MM
247/* Nonzero if a derived class that needs a vptr should always get one,
248 even if a non-primary base class already has one. For example,
249 given:
250
251 struct S { int i; virtual void f(); };
252 struct T : virtual public S {};
253
254 one could either reuse the vptr in `S' for `T', or create a new
255 vptr for `T'. If this flag is nonzero we choose the latter
256 alternative; otherwise, we choose the former. */
257#define vptrs_present_everywhere_p() (flag_new_abi)
258
051e6fd7
MM
259/* Nonzero if the vtable for a derived class should contain the
260 virtual functions from the primary base and all virtual functions
261 present in the class itself. Zero if, instead, it should contain
262 only those virtual functions from the primary base together with
263 the functions declared in the derived class (but not in any base
264 class). */
265#define all_overridden_vfuns_in_vtables_p() (flag_new_abi)
266
7267d692
NS
267/* Nonzero if we use access type_info objects directly, and use the
268 cross-vendor layout for them. Zero if we use an accessor function
269 to get the type_info object address. */
808c61c8 270#define new_abi_rtti_p() (flag_new_abi)
7267d692 271
8d7a5379
MM
272/* Nonzero if primary and secondary vtables are combined into a single
273 vtable. */
274#define merge_primary_and_secondary_vtables_p() (flag_new_abi)
275
bbd15aac 276\f
8d08fdba
MS
277/* Language-dependent contents of an identifier. */
278
279struct lang_identifier
280{
281 struct tree_identifier ignore;
f181d4ae
MM
282 tree namespace_bindings;
283 tree bindings;
8d08fdba
MS
284 tree class_value;
285 tree class_template_info;
286 struct lang_id2 *x;
0e5921e8 287 enum rid rid_code;
8d08fdba
MS
288};
289
0e5921e8
ZW
290/* In an IDENTIFIER_NODE, nonzero if this identifier is actually a
291 keyword. C_RID_CODE (node) is then the RID_* value of the keyword,
292 and C_RID_YYCODE is the token number wanted by Yacc. */
293
294#define C_IS_RESERVED_WORD(id) TREE_LANG_FLAG_5 (id)
295#define C_RID_CODE(id) \
296 (((struct lang_identifier *) (id))->rid_code)
297
298extern const short rid_to_yy[RID_MAX];
299#define C_RID_YYCODE(id) \
300 rid_to_yy[((struct lang_identifier *) (id))->rid_code]
301
da8a66fc
ML
302#define LANG_IDENTIFIER_CAST(NODE) \
303 ((struct lang_identifier*)IDENTIFIER_NODE_CHECK (NODE))
304
8d08fdba
MS
305struct lang_id2
306{
307 tree label_value, implicit_decl;
9e0781b5 308 tree error_locus;
8d08fdba
MS
309};
310
bb20cc46 311typedef struct
46b02c6d
MS
312{
313 tree t;
314 int new_type_flag;
70adf8a9 315 tree lookups;
46b02c6d
MS
316} flagged_type_tree;
317
bb20cc46 318typedef struct
f84b4be9 319{
2bf105ab 320 struct tree_common common;
f84b4be9
JM
321 HOST_WIDE_INT index;
322 HOST_WIDE_INT level;
323 HOST_WIDE_INT orig_level;
324 tree decl;
325} template_parm_index;
326
61a127b3
MM
327typedef struct ptrmem_cst
328{
2bf105ab 329 struct tree_common common;
bb20cc46 330 /* This isn't used, but the middle-end expects all constants to have
87e3dbc9
MM
331 this field. */
332 struct rtx_def *rtl;
61a127b3
MM
333 tree member;
334}* ptrmem_cst_t;
335
f181d4ae
MM
336/* Nonzero if this binding is for a local scope, as opposed to a class
337 or namespace scope. */
338#define LOCAL_BINDING_P(NODE) TREE_LANG_FLAG_0(NODE)
339
8f032717
MM
340/* Nonzero if BINDING_VALUE is from a base class of the class which is
341 currently being defined. */
342#define INHERITED_VALUE_BINDING_P(NODE) TREE_LANG_FLAG_1(NODE)
343
f181d4ae
MM
344/* For a binding between a name and an entity at a non-local scope,
345 defines the scope where the binding is declared. (Either a class
346 _TYPE node, or a NAMESPACE_DECL.) This macro should be used only
347 for namespace-level bindings; on the IDENTIFIER_BINDING list
348 BINDING_LEVEL is used instead. */
da8a66fc 349#define BINDING_SCOPE(NODE) (((struct tree_binding*)CPLUS_BINDING_CHECK (NODE))->scope.scope)
f181d4ae 350
87e3dbc9
MM
351/* Nonzero if NODE has BINDING_LEVEL, rather than BINDING_SCOPE. */
352#define BINDING_HAS_LEVEL_P(NODE) TREE_LANG_FLAG_2 ((NODE))
353
2c73f9f5
ML
354/* This is the declaration bound to the name. Possible values:
355 variable, overloaded function, namespace, template, enumerator. */
da8a66fc 356#define BINDING_VALUE(NODE) (((struct tree_binding*)CPLUS_BINDING_CHECK (NODE))->value)
f181d4ae 357
2c73f9f5
ML
358/* If name is bound to a type, this is the type (struct, union, enum). */
359#define BINDING_TYPE(NODE) TREE_TYPE(NODE)
f181d4ae 360
30394414 361#define IDENTIFIER_GLOBAL_VALUE(NODE) \
2c73f9f5
ML
362 namespace_binding (NODE, global_namespace)
363#define SET_IDENTIFIER_GLOBAL_VALUE(NODE, VAL) \
364 set_namespace_binding (NODE, global_namespace, VAL)
30394414 365#define IDENTIFIER_NAMESPACE_VALUE(NODE) \
2c73f9f5
ML
366 namespace_binding (NODE, current_namespace)
367#define SET_IDENTIFIER_NAMESPACE_VALUE(NODE, VAL) \
368 set_namespace_binding (NODE, current_namespace, VAL)
30394414 369
d7e7759d
BC
370#define CLEANUP_P(NODE) TREE_LANG_FLAG_0 (TRY_BLOCK_CHECK (NODE))
371#define CLEANUP_DECL(NODE) TREE_OPERAND (CLEANUP_STMT_CHECK (NODE), 0)
372#define CLEANUP_EXPR(NODE) TREE_OPERAND (CLEANUP_STMT_CHECK (NODE), 1)
373
374/* Returns nonzero iff TYPE1 and TYPE2 are the same type, in the usual
375 sense of `same'. */
376#define same_type_p(type1, type2) \
377 comptypes ((type1), (type2), COMPARE_STRICT)
378
379/* Returns nonzero iff TYPE1 and TYPE2 are the same type, ignoring
380 top-level qualifiers. */
381#define same_type_ignoring_top_level_qualifiers_p(type1, type2) \
382 same_type_p (TYPE_MAIN_VARIANT (type1), TYPE_MAIN_VARIANT (type2))
383
384/* Non-zero if we are presently building a statement tree, rather
385 than expanding each statement as we encounter it. */
386#define building_stmt_tree() (last_tree != NULL_TREE)
387
388/* Returns non-zero iff NODE is a declaration for the global function
389 `main'. */
390#define DECL_MAIN_P(NODE) \
391 (DECL_EXTERN_C_FUNCTION_P (NODE) \
392 && DECL_NAME (NODE) != NULL_TREE \
393 && MAIN_NAME_P (DECL_NAME (NODE)))
394
d7e7759d 395
30394414
JM
396struct tree_binding
397{
2bf105ab 398 struct tree_common common;
c7a932b1
JM
399 union {
400 tree scope;
401 struct binding_level *level;
402 } scope;
30394414
JM
403 tree value;
404};
405
2c73f9f5 406/* The overloaded FUNCTION_DECL. */
da8a66fc 407#define OVL_FUNCTION(NODE) (((struct tree_overload*)OVERLOAD_CHECK (NODE))->function)
2c73f9f5
ML
408#define OVL_CHAIN(NODE) TREE_CHAIN(NODE)
409/* Polymorphic access to FUNCTION and CHAIN. */
410#define OVL_CURRENT(NODE) \
411 ((TREE_CODE(NODE)==OVERLOAD) ? OVL_FUNCTION(NODE) : NODE)
412#define OVL_NEXT(NODE) \
413 ((TREE_CODE(NODE)==OVERLOAD) ? TREE_CHAIN(NODE) : NULL_TREE)
414/* If set, this was imported in a using declaration.
415 This is not to confuse with being used somewhere, which
416 is not important for this node. */
417#define OVL_USED(NODE) TREE_USED(NODE)
418
419struct tree_overload
420{
2bf105ab 421 struct tree_common common;
2c73f9f5
ML
422 tree function;
423};
424
4bb0968f
MM
425/* A `baselink' is a TREE_LIST whose TREE_PURPOSE is a BINFO
426 indicating a particular base class, and whose TREE_VALUE is a
427 (possibly overloaded) function from that base class. */
428#define BASELINK_P(NODE) \
3927874d 429 (TREE_CODE (NODE) == TREE_LIST && TREE_LANG_FLAG_1 (NODE))
4bb0968f 430#define SET_BASELINK_P(NODE) \
3927874d 431 (TREE_LANG_FLAG_1 (NODE) = 1)
4bb0968f 432
da8a66fc
ML
433#define WRAPPER_PTR(NODE) (((struct tree_wrapper*)WRAPPER_CHECK (NODE))->u.ptr)
434#define WRAPPER_INT(NODE) (((struct tree_wrapper*)WRAPPER_CHECK (NODE))->u.i)
5ffe581d
JM
435
436struct tree_wrapper
437{
2bf105ab 438 struct tree_common common;
5ffe581d
JM
439 union {
440 void *ptr;
441 int i;
442 } u;
443};
444
da8a66fc
ML
445#define SRCLOC_FILE(NODE) (((struct tree_srcloc*)SRCLOC_CHECK (NODE))->filename)
446#define SRCLOC_LINE(NODE) (((struct tree_srcloc*)SRCLOC_CHECK (NODE))->linenum)
1139b3d8
JM
447struct tree_srcloc
448{
2bf105ab 449 struct tree_common common;
3b304f5b 450 const char *filename;
1139b3d8
JM
451 int linenum;
452};
453
8d08fdba
MS
454/* Macros for access to language-specific slots in an identifier. */
455
30394414 456#define IDENTIFIER_NAMESPACE_BINDINGS(NODE) \
da8a66fc 457 (LANG_IDENTIFIER_CAST (NODE)->namespace_bindings)
8d08fdba 458#define IDENTIFIER_TEMPLATE(NODE) \
da8a66fc 459 (LANG_IDENTIFIER_CAST (NODE)->class_template_info)
8d08fdba 460
f181d4ae
MM
461/* The IDENTIFIER_BINDING is the innermost CPLUS_BINDING for the
462 identifier. It's TREE_CHAIN is the next outermost binding. Each
463 BINDING_VALUE is a DECL for the associated declaration. Thus,
464 name lookup consists simply of pulling off the node at the front
465 of the list (modulo oddities for looking up the names of types,
466 and such.) You can use BINDING_SCOPE or BINDING_LEVEL to
467 determine the scope that bound the name. */
468#define IDENTIFIER_BINDING(NODE) \
da8a66fc 469 (LANG_IDENTIFIER_CAST (NODE)->bindings)
f181d4ae
MM
470
471/* The IDENTIFIER_VALUE is the value of the IDENTIFIER_BINDING, or
472 NULL_TREE if there is no binding. */
473#define IDENTIFIER_VALUE(NODE) \
bb20cc46 474 (IDENTIFIER_BINDING (NODE) \
f181d4ae
MM
475 ? BINDING_VALUE (IDENTIFIER_BINDING (NODE)) \
476 : NULL_TREE)
477
8f032717
MM
478/* If IDENTIFIER_CLASS_VALUE is set, then NODE is bound in the current
479 class, and IDENTIFIER_CLASS_VALUE is the value binding. This is
480 just a pointer to the BINDING_VALUE of one of the bindings in the
481 IDENTIFIER_BINDINGs list, so any time that this is non-NULL so is
f181d4ae
MM
482 IDENTIFIER_BINDING. */
483#define IDENTIFIER_CLASS_VALUE(NODE) \
da8a66fc 484 (LANG_IDENTIFIER_CAST (NODE)->class_value)
f181d4ae 485
2c73f9f5
ML
486/* TREE_TYPE only indicates on local and class scope the current
487 type. For namespace scope, the presence of a type in any namespace
488 is indicated with global_type_node, and the real type behind must
489 be found through lookup. */
490#define IDENTIFIER_TYPE_VALUE(NODE) (identifier_type_value(NODE))
491#define REAL_IDENTIFIER_TYPE_VALUE(NODE) (TREE_TYPE (NODE))
8d08fdba 492#define SET_IDENTIFIER_TYPE_VALUE(NODE,TYPE) (TREE_TYPE (NODE) = TYPE)
2c73f9f5 493#define IDENTIFIER_HAS_TYPE_VALUE(NODE) (IDENTIFIER_TYPE_VALUE (NODE) ? 1 : 0)
8d08fdba 494
da8a66fc
ML
495#define LANG_ID_FIELD(NAME,NODE) \
496 (LANG_IDENTIFIER_CAST (NODE)->x \
bb20cc46 497 ? LANG_IDENTIFIER_CAST (NODE)->x->NAME : 0)
da8a66fc
ML
498
499#define SET_LANG_ID(NODE,VALUE,NAME) \
500 (LANG_IDENTIFIER_CAST (NODE)->x == 0 \
501 ? LANG_IDENTIFIER_CAST (NODE)->x \
502 = (struct lang_id2 *)perm_calloc (1, sizeof (struct lang_id2)) : 0, \
503 LANG_IDENTIFIER_CAST (NODE)->x->NAME = (VALUE))
8d08fdba
MS
504
505#define IDENTIFIER_LABEL_VALUE(NODE) LANG_ID_FIELD(label_value, NODE)
506#define SET_IDENTIFIER_LABEL_VALUE(NODE,VALUE) \
507 SET_LANG_ID(NODE, VALUE, label_value)
508
509#define IDENTIFIER_IMPLICIT_DECL(NODE) LANG_ID_FIELD(implicit_decl, NODE)
510#define SET_IDENTIFIER_IMPLICIT_DECL(NODE,VALUE) \
511 SET_LANG_ID(NODE, VALUE, implicit_decl)
512
8d08fdba
MS
513#define IDENTIFIER_ERROR_LOCUS(NODE) LANG_ID_FIELD(error_locus, NODE)
514#define SET_IDENTIFIER_ERROR_LOCUS(NODE,VALUE) \
515 SET_LANG_ID(NODE, VALUE, error_locus)
516
517
518#define IDENTIFIER_VIRTUAL_P(NODE) TREE_LANG_FLAG_1(NODE)
519
f71f87f9
MM
520/* Nonzero if this identifier is the prefix for a mangled C++ operator
521 name. */
8d08fdba
MS
522#define IDENTIFIER_OPNAME_P(NODE) TREE_LANG_FLAG_2(NODE)
523
4c571114
MM
524/* Nonzero if this identifier is the name of a type-conversion
525 operator. */
421844e7
MM
526#define IDENTIFIER_TYPENAME_P(NODE) \
527 (TREE_LANG_FLAG_4 (NODE))
8d08fdba 528
298d6f60
MM
529/* Nonzero if this identifier is the name of a constructor or
530 destructor. */
531#define IDENTIFIER_CTOR_OR_DTOR_P(NODE) \
532 TREE_LANG_FLAG_3 (NODE)
533
cab1f180 534/* Nonzero means reject anything that ISO standard C++ forbids. */
8d08fdba
MS
535extern int pedantic;
536
537/* In a RECORD_TYPE or UNION_TYPE, nonzero if any component is read-only. */
538#define C_TYPE_FIELDS_READONLY(type) TYPE_LANG_FLAG_0 (type)
e1cd6e56
MS
539
540/* Record in each node resulting from a binary operator
541 what operator was specified for it. */
542#define C_EXP_ORIGINAL_CODE(exp) ((enum tree_code) TREE_COMPLEXITY (exp))
543
544/* Store a value in that field. */
545#define C_SET_EXP_ORIGINAL_CODE(exp, code) \
546 (TREE_COMPLEXITY (exp) = (int)(code))
8d08fdba
MS
547\f
548/* If non-zero, a VAR_DECL whose cleanup will cause a throw to the
549 next exception handler. */
550extern tree exception_throw_decl;
551
7f4edbcb
BS
552enum cp_tree_index
553{
e2d0a11c
MM
554 CPTI_JAVA_BYTE_TYPE,
555 CPTI_JAVA_SHORT_TYPE,
556 CPTI_JAVA_INT_TYPE,
557 CPTI_JAVA_LONG_TYPE,
558 CPTI_JAVA_FLOAT_TYPE,
559 CPTI_JAVA_DOUBLE_TYPE,
560 CPTI_JAVA_CHAR_TYPE,
561 CPTI_JAVA_BOOLEAN_TYPE,
562
7f4edbcb
BS
563 CPTI_WCHAR_DECL,
564 CPTI_VTABLE_ENTRY_TYPE,
565 CPTI_DELTA_TYPE,
c7e266a6 566 CPTI_VTABLE_INDEX_TYPE,
b3ab27f3 567 CPTI_CLEANUP_TYPE,
3ec6bad3 568 CPTI_VTT_PARM_TYPE,
7f4edbcb 569
db1147b2 570 CPTI_TI_DESC_TYPE,
7f4edbcb 571 CPTI_BLTN_DESC_TYPE,
7f4edbcb 572 CPTI_PTR_DESC_TYPE,
db1147b2 573 CPTI_ARY_DESC_TYPE,
7f4edbcb 574 CPTI_FUNC_DESC_TYPE,
db1147b2
NS
575 CPTI_ENUM_DESC_TYPE,
576 CPTI_CLASS_DESC_TYPE,
577 CPTI_SI_CLASS_DESC_TYPE,
578 CPTI_VMI_CLASS_DESC_TYPE,
387769ed 579 CPTI_PTM_DESC_TYPE,
db1147b2 580 CPTI_BASE_DESC_TYPE,
bb20cc46 581
7f4edbcb
BS
582 CPTI_CLASS_TYPE,
583 CPTI_RECORD_TYPE,
584 CPTI_UNION_TYPE,
585 CPTI_ENUM_TYPE,
586 CPTI_UNKNOWN_TYPE,
7f4edbcb
BS
587 CPTI_VTBL_TYPE,
588 CPTI_VTBL_PTR_TYPE,
589 CPTI_STD,
6bcedb4e 590 CPTI_FAKE_STD,
2854d3c6 591 CPTI_ABI,
7f4edbcb 592 CPTI_TYPE_INFO_TYPE,
669ec2b4 593 CPTI_TINFO_DECL_ID,
db1147b2 594 CPTI_TINFO_DECL_TYPE,
669ec2b4 595 CPTI_TINFO_VAR_ID,
7f4edbcb
BS
596 CPTI_ABORT_FNDECL,
597 CPTI_GLOBAL_DELETE_FNDECL,
4b054b80 598 CPTI_AGGR_TAG,
7f4edbcb 599
9cd64686
MM
600 CPTI_ACCESS_DEFAULT,
601 CPTI_ACCESS_PUBLIC,
602 CPTI_ACCESS_PROTECTED,
603 CPTI_ACCESS_PRIVATE,
604 CPTI_ACCESS_DEFAULT_VIRTUAL,
605 CPTI_ACCESS_PUBLIC_VIRTUAL,
606 CPTI_ACCESS_PROTECTED_VIRTUAL,
607 CPTI_ACCESS_PRIVATE_VIRTUAL,
608
609 CPTI_CTOR_IDENTIFIER,
9eb71d8c 610 CPTI_COMPLETE_CTOR_IDENTIFIER,
d43829f9
MM
611 CPTI_BASE_CTOR_IDENTIFIER,
612 CPTI_DTOR_IDENTIFIER,
db9b2174 613 CPTI_COMPLETE_DTOR_IDENTIFIER,
d43829f9
MM
614 CPTI_BASE_DTOR_IDENTIFIER,
615 CPTI_DELETING_DTOR_IDENTIFIER,
9cd64686
MM
616 CPTI_DELTA2_IDENTIFIER,
617 CPTI_DELTA_IDENTIFIER,
9cd64686 618 CPTI_IN_CHARGE_IDENTIFIER,
3ec6bad3 619 CPTI_VTT_PARM_IDENTIFIER,
9cd64686
MM
620 CPTI_INDEX_IDENTIFIER,
621 CPTI_NELTS_IDENTIFIER,
622 CPTI_THIS_IDENTIFIER,
623 CPTI_PFN_IDENTIFIER,
624 CPTI_PFN_OR_DELTA2_IDENTIFIER,
625 CPTI_VPTR_IDENTIFIER,
298d6f60 626 CPTI_PUSH_EXCEPTION_IDENTIFIER,
1f6e1acc 627 CPTI_STD_IDENTIFIER,
9cd64686
MM
628
629 CPTI_LANG_NAME_C,
630 CPTI_LANG_NAME_CPLUSPLUS,
631 CPTI_LANG_NAME_JAVA,
632
633 CPTI_EMPTY_EXCEPT_SPEC,
634 CPTI_NULL,
635 CPTI_JCLASS,
636 CPTI_MINUS_ONE,
637 CPTI_TERMINATE,
f0105ed3 638 CPTI_ATEXIT,
db4283a0 639 CPTI_DSO_HANDLE,
059fa5e7 640 CPTI_DCAST,
9cd64686 641
7f4edbcb
BS
642 CPTI_MAX
643};
8d08fdba 644
7f4edbcb
BS
645extern tree cp_global_trees[CPTI_MAX];
646
4d8a1dd6
MM
647#define java_byte_type_node cp_global_trees[CPTI_JAVA_BYTE_TYPE]
648#define java_short_type_node cp_global_trees[CPTI_JAVA_SHORT_TYPE]
649#define java_int_type_node cp_global_trees[CPTI_JAVA_INT_TYPE]
650#define java_long_type_node cp_global_trees[CPTI_JAVA_LONG_TYPE]
651#define java_float_type_node cp_global_trees[CPTI_JAVA_FLOAT_TYPE]
652#define java_double_type_node cp_global_trees[CPTI_JAVA_DOUBLE_TYPE]
653#define java_char_type_node cp_global_trees[CPTI_JAVA_CHAR_TYPE]
654#define java_boolean_type_node cp_global_trees[CPTI_JAVA_BOOLEAN_TYPE]
655
7f4edbcb
BS
656#define wchar_decl_node cp_global_trees[CPTI_WCHAR_DECL]
657#define vtable_entry_type cp_global_trees[CPTI_VTABLE_ENTRY_TYPE]
c7e266a6
MM
658/* The type used to represent an offset by which to adjust the `this'
659 pointer in pointer-to-member types and, when not using vtable
660 thunks, in vtables. */
7f4edbcb 661#define delta_type_node cp_global_trees[CPTI_DELTA_TYPE]
c7e266a6
MM
662/* The type used to represent an index into the vtable. */
663#define vtable_index_type cp_global_trees[CPTI_VTABLE_INDEX_TYPE]
db1147b2
NS
664
665#define ti_desc_type_node cp_global_trees[CPTI_TI_DESC_TYPE]
666#define bltn_desc_type_node cp_global_trees[CPTI_BLTN_DESC_TYPE]
667#define ptr_desc_type_node cp_global_trees[CPTI_PTR_DESC_TYPE]
db1147b2
NS
668#define ary_desc_type_node cp_global_trees[CPTI_ARY_DESC_TYPE]
669#define func_desc_type_node cp_global_trees[CPTI_FUNC_DESC_TYPE]
670#define enum_desc_type_node cp_global_trees[CPTI_ENUM_DESC_TYPE]
671#define class_desc_type_node cp_global_trees[CPTI_CLASS_DESC_TYPE]
672#define si_class_desc_type_node cp_global_trees[CPTI_SI_CLASS_DESC_TYPE]
673#define vmi_class_desc_type_node cp_global_trees[CPTI_VMI_CLASS_DESC_TYPE]
387769ed 674#define ptm_desc_type_node cp_global_trees[CPTI_PTM_DESC_TYPE]
db1147b2
NS
675#define base_desc_type_node cp_global_trees[CPTI_BASE_DESC_TYPE]
676
7f4edbcb
BS
677#define class_type_node cp_global_trees[CPTI_CLASS_TYPE]
678#define record_type_node cp_global_trees[CPTI_RECORD_TYPE]
679#define union_type_node cp_global_trees[CPTI_UNION_TYPE]
680#define enum_type_node cp_global_trees[CPTI_ENUM_TYPE]
681#define unknown_type_node cp_global_trees[CPTI_UNKNOWN_TYPE]
7f4edbcb
BS
682#define vtbl_type_node cp_global_trees[CPTI_VTBL_TYPE]
683#define vtbl_ptr_type_node cp_global_trees[CPTI_VTBL_PTR_TYPE]
6bcedb4e
MM
684/* When the `std' namespace is a real namespace, this is the
685 corresponding NAMESPACE_DECL. When the `std' namespace is an alias
686 for the global namespace, this is NULL_TREE. */
7f4edbcb 687#define std_node cp_global_trees[CPTI_STD]
6bcedb4e
MM
688/* When the `std' namespace is a real namespace, this is the
689 ERROR_MARK_NODE. Otherwise, this is a dummy NAMESPACE_DECL that
690 should be treated like the global namespace. */
691#define fake_std_node cp_global_trees[CPTI_FAKE_STD]
2854d3c6 692#define abi_node cp_global_trees[CPTI_ABI]
7f4edbcb 693#define type_info_type_node cp_global_trees[CPTI_TYPE_INFO_TYPE]
669ec2b4 694#define tinfo_decl_id cp_global_trees[CPTI_TINFO_DECL_ID]
db1147b2 695#define tinfo_decl_type cp_global_trees[CPTI_TINFO_DECL_TYPE]
669ec2b4 696#define tinfo_var_id cp_global_trees[CPTI_TINFO_VAR_ID]
7f4edbcb
BS
697#define abort_fndecl cp_global_trees[CPTI_ABORT_FNDECL]
698#define global_delete_fndecl cp_global_trees[CPTI_GLOBAL_DELETE_FNDECL]
4b054b80 699#define current_aggr cp_global_trees[CPTI_AGGR_TAG]
ea419909 700
9cd64686
MM
701/* Define the sets of attributes that member functions and baseclasses
702 can have. These are sensible combinations of {public,private,protected}
703 cross {virtual,non-virtual}. */
704
705#define access_default_node cp_global_trees[CPTI_ACCESS_DEFAULT]
706#define access_public_node cp_global_trees[CPTI_ACCESS_PUBLIC]
707#define access_protected_node cp_global_trees[CPTI_ACCESS_PROTECTED]
708#define access_private_node cp_global_trees[CPTI_ACCESS_PRIVATE]
709#define access_default_virtual_node cp_global_trees[CPTI_ACCESS_DEFAULT_VIRTUAL]
710#define access_public_virtual_node cp_global_trees[CPTI_ACCESS_PUBLIC_VIRTUAL]
711#define access_protected_virtual_node cp_global_trees[CPTI_ACCESS_PROTECTED_VIRTUAL]
712#define access_private_virtual_node cp_global_trees[CPTI_ACCESS_PRIVATE_VIRTUAL]
713
714/* We cache these tree nodes so as to call get_identifier less
715 frequently. */
716
9eb71d8c 717/* The name of a constructor that takes an in-charge parameter to
db9b2174 718 decide whether or not to construct virtual base classes. */
9cd64686 719#define ctor_identifier cp_global_trees[CPTI_CTOR_IDENTIFIER]
9eb71d8c
MM
720/* The name of a constructor that constructs virtual base classes. */
721#define complete_ctor_identifier cp_global_trees[CPTI_COMPLETE_CTOR_IDENTIFIER]
d43829f9
MM
722/* The name of a constructor that does not construct virtual base classes. */
723#define base_ctor_identifier cp_global_trees[CPTI_BASE_CTOR_IDENTIFIER]
db9b2174
MM
724/* The name of a destructor that takes an in-charge parameter to
725 decide whether or not to destroy virtual base classes and whether
726 or not to delete the object. */
d43829f9 727#define dtor_identifier cp_global_trees[CPTI_DTOR_IDENTIFIER]
db9b2174
MM
728/* The name of a destructor that destroys virtual base classes. */
729#define complete_dtor_identifier cp_global_trees[CPTI_COMPLETE_DTOR_IDENTIFIER]
d43829f9
MM
730/* The name of a destructor that does not destroy virtual base
731 classes. */
732#define base_dtor_identifier cp_global_trees[CPTI_BASE_DTOR_IDENTIFIER]
733/* The name of a destructor that destroys virtual base classes, and
734 then deletes the entire object. */
735#define deleting_dtor_identifier cp_global_trees[CPTI_DELETING_DTOR_IDENTIFIER]
736
9cd64686
MM
737#define delta2_identifier cp_global_trees[CPTI_DELTA2_IDENTIFIER]
738#define delta_identifier cp_global_trees[CPTI_DELTA_IDENTIFIER]
9cd64686 739#define in_charge_identifier cp_global_trees[CPTI_IN_CHARGE_IDENTIFIER]
3ec6bad3
MM
740
741/* The name of the parameter that contains a pointer to the VTT to use
742 for this subobject constructor or destructor. */
743#define vtt_parm_identifier cp_global_trees[CPTI_VTT_PARM_IDENTIFIER]
744
9cd64686
MM
745#define index_identifier cp_global_trees[CPTI_INDEX_IDENTIFIER]
746#define nelts_identifier cp_global_trees[CPTI_NELTS_IDENTIFIER]
747#define this_identifier cp_global_trees[CPTI_THIS_IDENTIFIER]
748#define pfn_identifier cp_global_trees[CPTI_PFN_IDENTIFIER]
749#define pfn_or_delta2_identifier cp_global_trees[CPTI_PFN_OR_DELTA2_IDENTIFIER]
750#define vptr_identifier cp_global_trees[CPTI_VPTR_IDENTIFIER]
298d6f60
MM
751/* The name of the function to call to push an exception onto the
752 exception stack. */
753#define cp_push_exception_identifier cp_global_trees[CPTI_PUSH_EXCEPTION_IDENTIFIER]
1f6e1acc
AS
754/* The name of the std namespace. */
755#define std_identifier cp_global_trees[CPTI_STD_IDENTIFIER]
9cd64686
MM
756#define lang_name_c cp_global_trees[CPTI_LANG_NAME_C]
757#define lang_name_cplusplus cp_global_trees[CPTI_LANG_NAME_CPLUSPLUS]
758#define lang_name_java cp_global_trees[CPTI_LANG_NAME_JAVA]
759
760/* Exception specifier used for throw(). */
761#define empty_except_spec cp_global_trees[CPTI_EMPTY_EXCEPT_SPEC]
762
763/* The node for `__null'. */
764#define null_node cp_global_trees[CPTI_NULL]
765
766/* If non-NULL, a POINTER_TYPE equivalent to (java::lang::Class*). */
767#define jclass_node cp_global_trees[CPTI_JCLASS]
768
769/* A node for `(int) -1'. */
770#define minus_one_node cp_global_trees[CPTI_MINUS_ONE]
771
772/* The declaration for `std::terminate'. */
773#define terminate_node cp_global_trees[CPTI_TERMINATE]
774
db4283a0 775/* A pointer to `std::atexit'. */
f0105ed3
MM
776#define atexit_node cp_global_trees[CPTI_ATEXIT]
777
db4283a0
MM
778/* A pointer to `__dso_handle'. */
779#define dso_handle_node cp_global_trees[CPTI_DSO_HANDLE]
780
059fa5e7
NS
781/* The declaration of the dynamic_cast runtime. */
782#define dynamic_cast_node cp_global_trees[CPTI_DCAST]
783
b3ab27f3
MM
784/* The type of a destructor. */
785#define cleanup_type cp_global_trees[CPTI_CLEANUP_TYPE]
786
3ec6bad3
MM
787/* The type of the vtt parameter passed to subobject constructors and
788 destructors. */
789#define vtt_parm_type cp_global_trees[CPTI_VTT_PARM_TYPE]
790
9cd64686
MM
791/* Global state. */
792
793struct saved_scope {
9cd64686
MM
794 tree old_bindings;
795 tree old_namespace;
fc0e7bf5
MM
796 tree class_name;
797 tree class_type;
9cd64686 798 tree access_specifier;
a8f73d4b 799 tree function_decl;
9cd64686
MM
800 varray_type lang_base;
801 tree *lang_stack;
802 tree lang_name;
9cd64686 803 tree template_parms;
9cd64686
MM
804 tree x_previous_class_type;
805 tree x_previous_class_values;
6f80451c 806 tree x_saved_tree;
70adf8a9
JM
807 tree incomplete;
808 tree lookups;
fc0e7bf5
MM
809
810 HOST_WIDE_INT x_processing_template_decl;
9cd64686
MM
811 int x_processing_specialization;
812 int x_processing_explicit_instantiation;
a8f73d4b 813 int need_pop_function_context;
fc0e7bf5 814
ae499cce 815 struct stmt_tree_s x_stmt_tree;
fc0e7bf5
MM
816
817 struct binding_level *class_bindings;
a8f73d4b 818 struct binding_level *bindings;
fc0e7bf5
MM
819
820 struct saved_scope *prev;
9cd64686
MM
821};
822
823/* The current open namespace. */
824
825#define current_namespace scope_chain->old_namespace
826
827/* IDENTIFIER_NODE: name of current class */
828
829#define current_class_name scope_chain->class_name
830
831/* _TYPE: the type of the current class */
832
833#define current_class_type scope_chain->class_type
834
835/* When parsing a class definition, the access specifier most recently
836 given by the user, or, if no access specifier was given, the
837 default value appropriate for the kind of class (i.e., struct,
838 class, or union). */
839
840#define current_access_specifier scope_chain->access_specifier
841
842/* Pointer to the top of the language name stack. */
843
844#define current_lang_stack scope_chain->lang_stack
845#define current_lang_base scope_chain->lang_base
846#define current_lang_name scope_chain->lang_name
847
848/* Parsing a function declarator leaves a list of parameter names
849 or a chain or parameter decls here. */
850
9cd64686
MM
851#define current_template_parms scope_chain->template_parms
852
853#define processing_template_decl scope_chain->x_processing_template_decl
854#define processing_specialization scope_chain->x_processing_specialization
855#define processing_explicit_instantiation scope_chain->x_processing_explicit_instantiation
856
857/* _TYPE: the previous type that was a class */
858
859#define previous_class_type scope_chain->x_previous_class_type
860
861/* This is a copy of the class_shadowed list of the previous class
862 binding contour when at global scope. It's used to reset
863 IDENTIFIER_CLASS_VALUEs when entering another class scope (i.e. a
864 cache miss). */
865
866#define previous_class_values scope_chain->x_previous_class_values
867
70adf8a9
JM
868/* A list of the declarations with incomplete type at namespace scope. */
869
870#define namespace_scope_incomplete scope_chain->incomplete
871
872/* A list of private types mentioned, for deferred access checking. */
873
874#define type_lookups scope_chain->lookups
875
9cd64686
MM
876extern struct saved_scope *scope_chain;
877
8012c983
MM
878/* Global state pertinent to the current function. */
879
ae499cce 880struct cp_language_function
8012c983 881{
ae499cce
MM
882 struct language_function base;
883
4519c0a8
MM
884 tree x_ctor_label;
885 tree x_dtor_label;
4519c0a8
MM
886 tree x_current_class_ptr;
887 tree x_current_class_ref;
2c146a76 888 tree x_eh_spec_try_block;
2c146a76 889 tree x_in_charge_parm;
4519c0a8 890
9bfadf57
MM
891 tree *x_vcalls_possible_p;
892
8012c983
MM
893 int returns_value;
894 int returns_null;
8012c983 895 int in_function_try_handler;
ed5511d9 896 int x_expanding_p;
9bfadf57 897 int vtbls_set_up_p;
8012c983 898
6625cdb5
JM
899 struct named_label_use_list *x_named_label_uses;
900 struct named_label_list *x_named_labels;
a8f73d4b 901 struct binding_level *bindings;
914653a2
MM
902
903 const char *cannot_inline;
8012c983
MM
904};
905
99dccabc 906/* The current C++-specific per-function global variables. */
8012c983 907
ae499cce
MM
908#define cp_function_chain \
909 ((struct cp_language_function *) (cfun->language))
8012c983
MM
910
911/* In a destructor, the point at which all derived class destroying
912 has been done, just before any base class destroying will be done. */
913
4519c0a8 914#define dtor_label cp_function_chain->x_dtor_label
8012c983
MM
915
916/* In a constructor, the point at which we are ready to return
917 the pointer to the initialized object. */
918
4519c0a8 919#define ctor_label cp_function_chain->x_ctor_label
8012c983 920
8012c983
MM
921/* When we're processing a member function, current_class_ptr is the
922 PARM_DECL for the `this' pointer. The current_class_ref is an
923 expression for `*this'. */
924
a8f73d4b 925#define current_class_ptr \
01d939e8 926 (cfun ? cp_function_chain->x_current_class_ptr : NULL_TREE)
a8f73d4b 927#define current_class_ref \
01d939e8 928 (cfun ? cp_function_chain->x_current_class_ref : NULL_TREE)
8012c983 929
2c146a76
MM
930/* The TRY_BLOCK for the exception-specifiers for the current
931 function, if any. */
932
933#define current_eh_spec_try_block cp_function_chain->x_eh_spec_try_block
934
2c146a76
MM
935/* The `__in_chrg' parameter for the current function. Only used for
936 destructors. */
937
938#define current_in_charge_parm cp_function_chain->x_in_charge_parm
939
9bfadf57
MM
940/* In destructors, this is a pointer to a condition in an
941 if-statement. If the pointed-to value is boolean_true_node, then
942 there may be virtual function calls in this destructor. */
943
944#define current_vcalls_possible_p cp_function_chain->x_vcalls_possible_p
945
8012c983
MM
946/* Set to 0 at beginning of a function definition, set to 1 if
947 a return statement that specifies a return value is seen. */
948
949#define current_function_returns_value cp_function_chain->returns_value
950
951/* Set to 0 at beginning of a function definition, set to 1 if
952 a return statement with no argument is seen. */
953
954#define current_function_returns_null cp_function_chain->returns_null
955
9bfadf57
MM
956/* Nonzero if we have already generated code to initialize virtual
957 function tables in this function. */
958
959#define vtbls_set_up_p cp_function_chain->vtbls_set_up_p
960
8012c983
MM
961/* Non-zero if we should generate RTL for functions that we process.
962 When this is zero, we just accumulate tree structure, without
963 interacting with the back end. */
964
ed5511d9 965#define expanding_p cp_function_chain->x_expanding_p
8012c983 966
b35d4555
MM
967/* Non-zero if we are in the semantic analysis phase for the current
968 function. */
969
6f80451c 970#define doing_semantic_analysis_p() (!expanding_p)
b35d4555 971
8012c983
MM
972#define in_function_try_handler cp_function_chain->in_function_try_handler
973
8f17b5c5
MM
974/* Nonzero if __FUNCTION__ and its ilk have been declared in this
975 function. */
976
977#define function_name_declared_p \
978 (cp_function_chain->base.x_function_name_declared_p)
979
8012c983 980extern tree current_function_return_value;
30394414
JM
981extern tree global_namespace;
982
596ea4e5
AS
983#define ansi_opname(CODE) \
984 (operator_name_info[(int) (CODE)].identifier)
985#define ansi_assopname(CODE) \
986 (assignment_operator_name_info[(int) (CODE)].identifier)
8d08fdba
MS
987
988/* Nonzero means `$' can be in an identifier. */
989
990extern int dollars_in_ident;
991
992/* Nonzero means allow type mismatches in conditional expressions;
993 just make their values `void'. */
994
995extern int flag_cond_mismatch;
996
997/* Nonzero means don't recognize the keyword `asm'. */
998
999extern int flag_no_asm;
1000
0e5921e8
ZW
1001/* Nonzero means don't recognize any extended keywords. */
1002
1003extern int flag_no_gnu_keywords;
1004
1005/* Nonzero means recognize the named operators from C++98. */
1006
1007extern int flag_operator_names;
1008
8d08fdba
MS
1009/* For cross referencing. */
1010
1011extern int flag_gnu_xref;
1012
1013/* For environments where you can use GNU binutils (as, ld in particular). */
1014
1015extern int flag_gnu_binutils;
1016
8d08fdba
MS
1017/* Nonzero means warn about implicit declarations. */
1018
1019extern int warn_implicit;
1020
795add94
VM
1021/* Nonzero means warn about usage of long long when `-pedantic'. */
1022
1023extern int warn_long_long;
1024
8d08fdba
MS
1025/* Nonzero means warn when all ctors or dtors are private, and the class
1026 has no friends. */
1027
1028extern int warn_ctor_dtor_privacy;
1029
1030/* Nonzero means warn about function definitions that default the return type
1031 or that use a null return and have a return-type other than void. */
1032
1033extern int warn_return_type;
1034
d9cf7c82
JM
1035/* Nonzero means warn about deprecated conversion from string constant to
1036 `char *'. */
8d08fdba
MS
1037
1038extern int warn_write_strings;
1039
1040/* Nonzero means warn about sizeof(function) or addition/subtraction
1041 of function pointers. */
1042
1043extern int warn_pointer_arith;
1044
8d08fdba
MS
1045/* Nonzero means warn about multiple (redundant) decls for the same single
1046 variable or function. */
1047
1048extern int warn_redundant_decls;
1049
1050/* Warn if initializer is not completely bracketed. */
1051
1052extern int warn_missing_braces;
1053
2ee887f2
MS
1054/* Warn about comparison of signed and unsigned values. */
1055
1056extern int warn_sign_compare;
1057
1bdba2c0
DZ
1058/* Warn about testing equality of floating point numbers. */
1059
1060extern int warn_float_equal;
1061
8d08fdba
MS
1062/* Warn about a subscript that has type char. */
1063
1064extern int warn_char_subscripts;
1065
1066/* Nonzero means warn about pointer casts that can drop a type qualifier
1067 from the pointer target type. */
1068
1069extern int warn_cast_qual;
1070
8d08fdba 1071/* Nonzero means warn about non virtual destructors in classes that have
e92cc029 1072 virtual functions. */
8d08fdba
MS
1073
1074extern int warn_nonvdtor;
1075
9a3b49ac
MS
1076/* Non-zero means warn when we convert a pointer to member function
1077 into a pointer to (void or function). */
1078
1079extern int warn_pmf2ptr;
1080
eb448459
MS
1081/* Nonzero means warn about violation of some Effective C++ style rules. */
1082
1083extern int warn_ecpp;
1084
da20811c
JM
1085/* Nonzero means warn where overload resolution chooses a promotion from
1086 unsigned to signed over a conversion to an unsigned of the same size. */
1087
1088extern int warn_sign_promo;
1089
8d08fdba 1090/* Non-zero means warn when a function is declared extern and later inline. */
eb448459 1091
8d08fdba
MS
1092extern int warn_extern_inline;
1093
0c4b14c4
JM
1094/* Non-zero means warn when an old-style cast is used. */
1095
1096extern int warn_old_style_cast;
1097
3dbc07b6
MM
1098/* Non-zero means warn when the compiler will reorder code. */
1099
1100extern int warn_reorder;
1101
8d08fdba
MS
1102/* Nonzero means to treat bitfields as unsigned unless they say `signed'. */
1103
1104extern int flag_signed_bitfields;
1105
38e01259 1106/* True for more efficient but incompatible (not fully tested)
8926095f 1107 vtable implementation (using thunks).
e92cc029 1108 0 is old behavior; 1 is new behavior. */
8926095f 1109extern int flag_vtable_thunks;
51c184be 1110
8d08fdba
MS
1111/* INTERFACE_ONLY nonzero means that we are in an "interface"
1112 section of the compiler. INTERFACE_UNKNOWN nonzero means
1113 we cannot trust the value of INTERFACE_ONLY. If INTERFACE_UNKNOWN
1114 is zero and INTERFACE_ONLY is zero, it means that we are responsible
1115 for exporting definitions that others might need. */
1116extern int interface_only, interface_unknown;
1117
1118/* Nonzero means we should attempt to elide constructors when possible. */
1119
1120extern int flag_elide_constructors;
1121
cab1f180
ML
1122/* Nonzero means enable obscure standard features and disable GNU
1123 extensions that might cause standard-compliant code to be
1124 miscompiled. */
39211cd5
MS
1125
1126extern int flag_ansi;
1127
8d08fdba
MS
1128/* Nonzero means that member functions defined in class scope are
1129 inline by default. */
1130
1131extern int flag_default_inline;
386b8a85 1132
669ec2b4
JM
1133/* The name-mangling scheme to use. Versions of gcc before 2.8 use
1134 version 0. */
1135extern int name_mangling_version;
1136
5096c664
JM
1137/* Nonzero if wchar_t should be `unsigned short' instead of whatever it
1138 would normally be, for use with WINE. */
1139extern int flag_short_wchar;
1140
bb20cc46
AJ
1141/* Nonzero if squashed mangling is to be performed.
1142 This uses the B and K codes to reference previously seen class types
669ec2b4
JM
1143 and class qualifiers. */
1144extern int flag_do_squangling;
1145
2aaf816d
JM
1146/* Nonzero means generate separate instantiation control files and juggle
1147 them at link time. */
1148extern int flag_use_repository;
1149
dc8263bc
JM
1150/* Nonzero if we want to issue diagnostics that the standard says are not
1151 required. */
1152extern int flag_optional_diags;
a1dd0d36
JM
1153
1154/* Nonzero means output .vtable_{entry,inherit} for use in doing vtable gc. */
1155extern int flag_vtable_gc;
2642b9bf
JM
1156
1157/* Nonzero means make the default pedwarns warnings instead of errors.
1158 The value of this flag is ignored if -pedantic is specified. */
dfcafcb6 1159extern int flag_permissive;
d6479fe7 1160
1660cb3a
JM
1161/* Nonzero means to implement standard semantics for exception
1162 specifications, calling unexpected if an exception is thrown that
1163 doesn't match the specification. Zero means to treat them as
1164 assertions and optimize accordingly, but not check them. */
1165extern int flag_enforce_eh_specs;
1166
d6479fe7
MM
1167/* Nonzero if we want to obey access control semantics. */
1168
1169extern int flag_access_control;
1170
708cae97
JM
1171/* Nonzero if we want to check the return value of new and avoid calling
1172 constructors if it is a null pointer. */
1173
1174extern int flag_check_new;
1175
8d08fdba
MS
1176\f
1177/* C++ language-specific tree codes. */
1178#define DEFTREECODE(SYM, NAME, TYPE, LENGTH) SYM,
1179enum cplus_tree_code {
c7d87c0a 1180 CP_DUMMY_TREE_CODE = LAST_C_TREE_CODE,
e92cc029 1181#include "cp-tree.def"
8d08fdba
MS
1182 LAST_CPLUS_TREE_CODE
1183};
1184#undef DEFTREECODE
1185
fcad5cf5 1186enum languages { lang_c, lang_cplusplus, lang_java };
8d08fdba
MS
1187
1188/* Macros to make error reporting functions' lives easier. */
1189#define TYPE_IDENTIFIER(NODE) (DECL_NAME (TYPE_NAME (NODE)))
1190#define TYPE_NAME_STRING(NODE) (IDENTIFIER_POINTER (TYPE_IDENTIFIER (NODE)))
1191#define TYPE_NAME_LENGTH(NODE) (IDENTIFIER_LENGTH (TYPE_IDENTIFIER (NODE)))
1192
1193#define TYPE_ASSEMBLER_NAME_STRING(NODE) (IDENTIFIER_POINTER (DECL_ASSEMBLER_NAME (TYPE_NAME (NODE))))
1194#define TYPE_ASSEMBLER_NAME_LENGTH(NODE) (IDENTIFIER_LENGTH (DECL_ASSEMBLER_NAME (TYPE_NAME (NODE))))
1195
a4443a08 1196/* The _DECL for this _TYPE. */
d2e5ee5c 1197#define TYPE_MAIN_DECL(NODE) (TYPE_STUB_DECL (TYPE_MAIN_VARIANT (NODE)))
a4443a08 1198
c92366fb 1199/* Nonzero if T is a class (or struct or union) type. Also nonzero
83233dca
MM
1200 for template type parameters, typename types, and instantiated
1201 template template parameters. Despite its name,
b80c4d77
MM
1202 this macro has nothing to do with the definition of aggregate given
1203 in the standard. Think of this macro as MAYBE_CLASS_TYPE_P. */
7ddedda4 1204#define IS_AGGR_TYPE(t) \
83233dca
MM
1205 (TREE_CODE (t) == TEMPLATE_TYPE_PARM \
1206 || TREE_CODE (t) == TYPENAME_TYPE \
7ddedda4 1207 || TREE_CODE (t) == TYPEOF_TYPE \
a1281f45 1208 || TREE_CODE (t) == BOUND_TEMPLATE_TEMPLATE_PARM \
7ddedda4
MM
1209 || TYPE_LANG_FLAG_5 (t))
1210
bb20cc46
AJ
1211/* Set IS_AGGR_TYPE for T to VAL. T must be a class, struct, or
1212 union type. */
7ddedda4
MM
1213#define SET_IS_AGGR_TYPE(T, VAL) \
1214 (TYPE_LANG_FLAG_5 (T) = (VAL))
c92366fb 1215
b80c4d77
MM
1216/* Nonzero if T is a class type. Zero for template type parameters,
1217 typename types, and so forth. */
c92366fb 1218#define CLASS_TYPE_P(t) \
7ddedda4 1219 (IS_AGGR_TYPE_CODE (TREE_CODE (t)) && IS_AGGR_TYPE (t))
c92366fb 1220
5566b478 1221#define IS_AGGR_TYPE_CODE(t) (t == RECORD_TYPE || t == UNION_TYPE)
8d08fdba
MS
1222#define IS_AGGR_TYPE_2(TYPE1,TYPE2) \
1223 (TREE_CODE (TYPE1) == TREE_CODE (TYPE2) \
829297e6 1224 && IS_AGGR_TYPE (TYPE1) && IS_AGGR_TYPE (TYPE2))
6467930b
MS
1225#define IS_OVERLOAD_TYPE(t) \
1226 (IS_AGGR_TYPE (t) || TREE_CODE (t) == ENUMERAL_TYPE)
8d08fdba
MS
1227
1228/* In a *_TYPE, nonzero means a built-in type. */
1229#define TYPE_BUILT_IN(NODE) TYPE_LANG_FLAG_6(NODE)
1230
ea419909
PB
1231/* True if this a "Java" type, defined in 'extern "Java"'. */
1232#define TYPE_FOR_JAVA(NODE) TYPE_LANG_FLAG_3(NODE)
1233
91063b51
MM
1234/* The type qualifiers for this type, including the qualifiers on the
1235 elements for an array type. */
0a7394bc 1236#define CP_TYPE_QUALS(NODE) C_TYPE_QUALS (NODE)
91063b51
MM
1237
1238/* Nonzero if this type is const-qualified. */
1239#define CP_TYPE_CONST_P(NODE) \
174bcdb9 1240 ((CP_TYPE_QUALS (NODE) & TYPE_QUAL_CONST) != 0)
91063b51
MM
1241
1242/* Nonzero if this type is volatile-qualified. */
1243#define CP_TYPE_VOLATILE_P(NODE) \
174bcdb9 1244 ((CP_TYPE_QUALS (NODE) & TYPE_QUAL_VOLATILE) != 0)
91063b51 1245
174bcdb9 1246/* Nonzero if this type is restrict-qualified. */
91063b51 1247#define CP_TYPE_RESTRICT_P(NODE) \
174bcdb9 1248 ((CP_TYPE_QUALS (NODE) & TYPE_QUAL_RESTRICT) != 0)
91063b51
MM
1249
1250/* Nonzero if this type is const-qualified, but not
1251 volatile-qualified. Other qualifiers are ignored. This macro is
1252 used to test whether or not it is OK to bind an rvalue to a
1253 reference. */
1254#define CP_TYPE_CONST_NON_VOLATILE_P(NODE) \
1255 ((CP_TYPE_QUALS (NODE) & (TYPE_QUAL_CONST | TYPE_QUAL_VOLATILE)) \
1256 == TYPE_QUAL_CONST)
1257
8d08fdba
MS
1258/* Virtual function addresses can be gotten from a virtual function
1259 table entry using this macro. */
eb68cb58
MM
1260#define FNADDR_FROM_VTABLE_ENTRY(ENTRY) \
1261 (!flag_vtable_thunks ? \
1262 TREE_VALUE (TREE_CHAIN (TREE_CHAIN (CONSTRUCTOR_ELTS (ENTRY)))) \
1263 : !DECL_THUNK_P (TREE_OPERAND ((ENTRY), 0)) \
1264 ? (ENTRY) \
8926095f 1265 : DECL_INITIAL (TREE_OPERAND ((ENTRY), 0)))
eb68cb58 1266
8d08fdba
MS
1267#define FUNCTION_ARG_CHAIN(NODE) (TREE_CHAIN (TYPE_ARG_TYPES (TREE_TYPE (NODE))))
1268#define PROMOTES_TO_AGGR_TYPE(NODE,CODE) \
1269 (((CODE) == TREE_CODE (NODE) \
1270 && IS_AGGR_TYPE (TREE_TYPE (NODE))) \
1271 || IS_AGGR_TYPE (NODE))
1272
8d08fdba
MS
1273/* Nonzero iff TYPE is uniquely derived from PARENT. Under MI, PARENT can
1274 be an ambiguous base class of TYPE, and this macro will be false. */
1275#define UNIQUELY_DERIVED_FROM_P(PARENT, TYPE) (get_base_distance (PARENT, TYPE, 0, (tree *)0) >= 0)
1276#define ACCESSIBLY_DERIVED_FROM_P(PARENT, TYPE) (get_base_distance (PARENT, TYPE, -1, (tree *)0) >= 0)
1277#define ACCESSIBLY_UNIQUELY_DERIVED_P(PARENT, TYPE) (get_base_distance (PARENT, TYPE, 1, (tree *)0) >= 0)
2bc9f1d1 1278#define PUBLICLY_UNIQUELY_DERIVED_P(PARENT, TYPE) (get_base_distance (PARENT, TYPE, 2, (tree *)0) >= 0)
a0a33927 1279#define DERIVED_FROM_P(PARENT, TYPE) (get_base_distance (PARENT, TYPE, 0, (tree *)0) != -1)
8d08fdba 1280\f
7ddedda4
MM
1281/* This structure provides additional information above and beyond
1282 what is provide in the ordinary tree_type. In the past, we used it
1283 for the types of class types, template parameters types, typename
1284 types, and so forth. However, there can be many (tens to hundreds
1285 of thousands) of template parameter types in a compilation, and
1286 there's no need for this additional information in that case.
1287 Therefore, we now use this data structure only for class types.
1288
1289 In the past, it was thought that there would be relatively few
1290 class types. However, in the presence of heavy use of templates,
1291 many (i.e., thousands) of classes can easily be generated.
1292 Therefore, we should endeavor to keep the size of this structure to
1293 a minimum. */
8d08fdba
MS
1294struct lang_type
1295{
8012c983
MM
1296 unsigned char align;
1297
1298 unsigned has_type_conversion : 1;
1299 unsigned has_init_ref : 1;
1300 unsigned has_default_ctor : 1;
1301 unsigned uses_multiple_inheritance : 1;
1302 unsigned const_needs_init : 1;
1303 unsigned ref_needs_init : 1;
1304 unsigned has_const_assign_ref : 1;
1305 unsigned anon_aggr : 1;
1306
5b0cec3b
MM
1307 unsigned has_mutable : 1;
1308 unsigned com_interface : 1;
1309 unsigned non_pod_class : 1;
1310 unsigned nearly_empty_p : 1;
8012c983
MM
1311 unsigned vtable_needs_writing : 1;
1312 unsigned has_assign_ref : 1;
834c6dff
MM
1313 unsigned has_new : 1;
1314 unsigned has_array_new : 1;
8012c983
MM
1315
1316 unsigned gets_delete : 2;
1317 unsigned has_call_overloaded : 1;
1318 unsigned has_array_ref_overloaded : 1;
1319 unsigned has_arrow_overloaded : 1;
1320 unsigned interface_only : 1;
1321 unsigned interface_unknown : 1;
1322 unsigned needs_virtual_reinit : 1;
1323
1324 unsigned marks: 6;
1325 unsigned vec_delete_takes_size : 1;
1326 unsigned declared_class : 1;
1327
1328 unsigned being_defined : 1;
1329 unsigned redefined : 1;
1330 unsigned debug_requested : 1;
1331 unsigned use_template : 2;
1332 unsigned got_semicolon : 1;
1333 unsigned ptrmemfunc_flag : 1;
1334 unsigned was_anonymous : 1;
1335
1336 unsigned has_real_assign_ref : 1;
1337 unsigned has_const_init_ref : 1;
1338 unsigned has_complex_init_ref : 1;
1339 unsigned has_complex_assign_ref : 1;
1340 unsigned has_abstract_assign_ref : 1;
1341 unsigned non_aggregate : 1;
1342 unsigned is_partial_instantiation : 1;
11cf4d18 1343 unsigned user_align : 1;
8012c983
MM
1344
1345 /* When adding a flag here, consider whether or not it ought to
1346 apply to a template instance if it applies to the template. If
1347 so, make sure to copy it in instantiate_class_template! */
1348
5b0cec3b
MM
1349 /* There are some bits left to fill out a 32-bit word. Keep track
1350 of this by updating the size of this bitfield whenever you add or
8012c983 1351 remove a flag. */
11cf4d18 1352 unsigned dummy : 8;
bb20cc46 1353
8d08fdba 1354 int vsize;
8d08fdba 1355
911a71a7 1356 tree primary_base;
c35cce41
MM
1357 tree vfields;
1358 tree vbases;
1359 tree tags;
c35cce41
MM
1360 tree size;
1361 tree size_unit;
1362 tree pure_virtuals;
1363 tree friend_classes;
1364 tree rtti;
1365 tree methods;
1366 tree template_info;
6a629cac 1367 tree befriending_classes;
8d08fdba
MS
1368};
1369
a0a33927
MS
1370/* Indicates whether or not (and how) a template was expanded for this class.
1371 0=no information yet/non-template class
1372 1=implicit template instantiation
1373 2=explicit template specialization
1374 3=explicit template instantiation */
8012c983 1375#define CLASSTYPE_USE_TEMPLATE(NODE) (TYPE_LANG_SPECIFIC(NODE)->use_template)
8d08fdba
MS
1376
1377/* Fields used for storing information before the class is defined.
1378 After the class is defined, these fields hold other information. */
1379
1380/* List of friends which were defined inline in this class definition. */
1381#define CLASSTYPE_INLINE_FRIENDS(NODE) (TYPE_NONCOPIED_PARTS (NODE))
1382
834c6dff 1383/* Nonzero for _CLASSTYPE means that operator delete is defined. */
8012c983 1384#define TYPE_GETS_DELETE(NODE) (TYPE_LANG_SPECIFIC(NODE)->gets_delete)
a28e3c7f
MS
1385#define TYPE_GETS_REG_DELETE(NODE) (TYPE_GETS_DELETE (NODE) & 1)
1386
1387/* Nonzero for _CLASSTYPE means that operator vec delete is defined and
1388 takes the optional size_t argument. */
1389#define TYPE_VEC_DELETE_TAKES_SIZE(NODE) \
8012c983 1390 (TYPE_LANG_SPECIFIC(NODE)->vec_delete_takes_size)
834c6dff
MM
1391
1392/* Nonzero if `new NODE[x]' should cause the allocation of extra
1393 storage to indicate how many array elements are in use. The old
1394 ABI had a bug in that we always allocate the extra storage if NODE
1395 has a two-argument array operator delete. */
1396#define TYPE_VEC_NEW_USES_COOKIE(NODE) \
1397 (TYPE_HAS_NONTRIVIAL_DESTRUCTOR (NODE) \
bb20cc46 1398 || (TYPE_LANG_SPECIFIC (NODE) \
834c6dff 1399 && TYPE_VEC_DELETE_TAKES_SIZE (NODE)))
8d08fdba 1400
8d08fdba
MS
1401/* Nonzero means that this _CLASSTYPE node defines ways of converting
1402 itself to other types. */
8012c983 1403#define TYPE_HAS_CONVERSION(NODE) (TYPE_LANG_SPECIFIC(NODE)->has_type_conversion)
8d08fdba 1404
8d08fdba 1405/* Nonzero means that this _CLASSTYPE node overloads operator=(X&). */
8012c983
MM
1406#define TYPE_HAS_ASSIGN_REF(NODE) (TYPE_LANG_SPECIFIC(NODE)->has_assign_ref)
1407#define TYPE_HAS_CONST_ASSIGN_REF(NODE) (TYPE_LANG_SPECIFIC(NODE)->has_const_assign_ref)
8d08fdba
MS
1408
1409/* Nonzero means that this _CLASSTYPE node has an X(X&) constructor. */
8012c983
MM
1410#define TYPE_HAS_INIT_REF(NODE) (TYPE_LANG_SPECIFIC(NODE)->has_init_ref)
1411#define TYPE_HAS_CONST_INIT_REF(NODE) (TYPE_LANG_SPECIFIC(NODE)->has_const_init_ref)
8d08fdba 1412
834c6dff
MM
1413/* Nonzero if this class defines an overloaded operator new. (An
1414 operator new [] doesn't count.) */
1415#define TYPE_HAS_NEW_OPERATOR(NODE) \
1416 (TYPE_LANG_SPECIFIC (NODE)->has_new)
1417
1418/* Nonzero if this class defines an overloaded operator new[]. */
1419#define TYPE_HAS_ARRAY_NEW_OPERATOR(NODE) \
1420 (TYPE_LANG_SPECIFIC (NODE)->has_array_new)
1421
8d08fdba
MS
1422/* Nonzero means that this type is being defined. I.e., the left brace
1423 starting the definition of this type has been seen. */
8012c983 1424#define TYPE_BEING_DEFINED(NODE) (TYPE_LANG_SPECIFIC(NODE)->being_defined)
8d08fdba
MS
1425/* Nonzero means that this type has been redefined. In this case, if
1426 convenient, don't reprocess any methods that appear in its redefinition. */
8012c983 1427#define TYPE_REDEFINED(NODE) (TYPE_LANG_SPECIFIC(NODE)->redefined)
8d08fdba 1428
9e0781b5 1429/* The is the basetype that contains NODE's rtti. */
db5ae43f 1430#define CLASSTYPE_RTTI(NODE) (TYPE_LANG_SPECIFIC(NODE)->rtti)
8d08fdba
MS
1431
1432/* Nonzero means that this _CLASSTYPE node overloads operator(). */
8012c983 1433#define TYPE_OVERLOADS_CALL_EXPR(NODE) (TYPE_LANG_SPECIFIC(NODE)->has_call_overloaded)
8d08fdba
MS
1434
1435/* Nonzero means that this _CLASSTYPE node overloads operator[]. */
8012c983 1436#define TYPE_OVERLOADS_ARRAY_REF(NODE) (TYPE_LANG_SPECIFIC(NODE)->has_array_ref_overloaded)
8d08fdba
MS
1437
1438/* Nonzero means that this _CLASSTYPE node overloads operator->. */
8012c983 1439#define TYPE_OVERLOADS_ARROW(NODE) (TYPE_LANG_SPECIFIC(NODE)->has_arrow_overloaded)
8d08fdba
MS
1440
1441/* Nonzero means that this _CLASSTYPE (or one of its ancestors) uses
1442 multiple inheritance. If this is 0 for the root of a type
1443 hierarchy, then we can use more efficient search techniques. */
8012c983 1444#define TYPE_USES_MULTIPLE_INHERITANCE(NODE) (TYPE_LANG_SPECIFIC(NODE)->uses_multiple_inheritance)
8d08fdba
MS
1445
1446/* Nonzero means that this _CLASSTYPE (or one of its ancestors) uses
1447 virtual base classes. If this is 0 for the root of a type
1448 hierarchy, then we can use more efficient search techniques. */
1449#define TYPE_USES_VIRTUAL_BASECLASSES(NODE) (TREE_LANG_FLAG_3(NODE))
1450
61a127b3 1451/* Vector member functions defined in this class. Each element is
03017874
MM
1452 either a FUNCTION_DECL, a TEMPLATE_DECL, or an OVERLOAD. All
1453 functions with the same name end up in the same slot. The first
61a127b3 1454 two elements are for constructors, and destructors, respectively.
db9b2174
MM
1455 Any conversion operators are next, followed by ordinary member
1456 functions. There may be empty entries at the end of the vector. */
72b7eeff 1457#define CLASSTYPE_METHOD_VEC(NODE) (TYPE_LANG_SPECIFIC(NODE)->methods)
8d08fdba 1458
db9b2174
MM
1459/* The slot in the CLASSTYPE_METHOD_VEC where constructors go. */
1460#define CLASSTYPE_CONSTRUCTOR_SLOT 0
1461
1462/* The slot in the CLASSTYPE_METHOD_VEC where destructors go. */
1463#define CLASSTYPE_DESTRUCTOR_SLOT 1
1464
1465/* The first slot in the CLASSTYPE_METHOD_VEC where conversion
1466 operators can appear. */
1467#define CLASSTYPE_FIRST_CONVERSION_SLOT 2
1468
1469/* A FUNCTION_DECL or OVERLOAD for the constructors for NODE. These
1470 are the constructors that take an in-charge parameter. */
1471#define CLASSTYPE_CONSTRUCTORS(NODE) \
1472 (TREE_VEC_ELT (CLASSTYPE_METHOD_VEC (NODE), CLASSTYPE_CONSTRUCTOR_SLOT))
1473
1474/* A FUNCTION_DECL for the destructor for NODE. These are te
1475 destructors that take an in-charge parameter. */
1476#define CLASSTYPE_DESTRUCTORS(NODE) \
1477 (TREE_VEC_ELT (CLASSTYPE_METHOD_VEC (NODE), CLASSTYPE_DESTRUCTOR_SLOT))
e1cd6e56 1478
8d08fdba 1479/* Mark bits for depth-first and breath-first searches. */
7ddedda4
MM
1480
1481/* Get the value of the Nth mark bit. */
ba793d6e 1482#define CLASSTYPE_MARKED_N(NODE, N) \
8012c983 1483 (((CLASS_TYPE_P (NODE) ? TYPE_LANG_SPECIFIC (NODE)->marks \
ba793d6e 1484 : ((unsigned) TYPE_ALIAS_SET (NODE))) & (1 << N)) != 0)
7ddedda4
MM
1485
1486/* Set the Nth mark bit. */
ba793d6e
MM
1487#define SET_CLASSTYPE_MARKED_N(NODE, N) \
1488 (CLASS_TYPE_P (NODE) \
1489 ? (void) (TYPE_LANG_SPECIFIC (NODE)->marks |= (1 << (N))) \
1490 : (void) (TYPE_ALIAS_SET (NODE) |= (1 << (N))))
7ddedda4
MM
1491
1492/* Clear the Nth mark bit. */
ba793d6e
MM
1493#define CLEAR_CLASSTYPE_MARKED_N(NODE, N) \
1494 (CLASS_TYPE_P (NODE) \
1495 ? (void) (TYPE_LANG_SPECIFIC (NODE)->marks &= ~(1 << (N))) \
1496 : (void) (TYPE_ALIAS_SET (NODE) &= ~(1 << (N))))
7ddedda4
MM
1497
1498/* Get the value of the mark bits. */
1499#define CLASSTYPE_MARKED(NODE) CLASSTYPE_MARKED_N(NODE, 0)
1500#define CLASSTYPE_MARKED2(NODE) CLASSTYPE_MARKED_N(NODE, 1)
1501#define CLASSTYPE_MARKED3(NODE) CLASSTYPE_MARKED_N(NODE, 2)
1502#define CLASSTYPE_MARKED4(NODE) CLASSTYPE_MARKED_N(NODE, 3)
1503#define CLASSTYPE_MARKED5(NODE) CLASSTYPE_MARKED_N(NODE, 4)
1504#define CLASSTYPE_MARKED6(NODE) CLASSTYPE_MARKED_N(NODE, 5)
1505
8d08fdba 1506/* Macros to modify the above flags */
7ddedda4
MM
1507#define SET_CLASSTYPE_MARKED(NODE) SET_CLASSTYPE_MARKED_N(NODE, 0)
1508#define CLEAR_CLASSTYPE_MARKED(NODE) CLEAR_CLASSTYPE_MARKED_N(NODE, 0)
1509#define SET_CLASSTYPE_MARKED2(NODE) SET_CLASSTYPE_MARKED_N(NODE, 1)
1510#define CLEAR_CLASSTYPE_MARKED2(NODE) CLEAR_CLASSTYPE_MARKED_N(NODE, 1)
1511#define SET_CLASSTYPE_MARKED3(NODE) SET_CLASSTYPE_MARKED_N(NODE, 2)
bb20cc46 1512#define CLEAR_CLASSTYPE_MARKED3(NODE) CLEAR_CLASSTYPE_MARKED_N(NODE, 2)
7ddedda4
MM
1513#define SET_CLASSTYPE_MARKED4(NODE) SET_CLASSTYPE_MARKED_N(NODE, 3)
1514#define CLEAR_CLASSTYPE_MARKED4(NODE) CLEAR_CLASSTYPE_MARKED_N(NODE, 3)
1515#define SET_CLASSTYPE_MARKED5(NODE) SET_CLASSTYPE_MARKED_N(NODE, 4)
1516#define CLEAR_CLASSTYPE_MARKED5(NODE) CLEAR_CLASSTYPE_MARKED_N(NODE, 4)
1517#define SET_CLASSTYPE_MARKED6(NODE) SET_CLASSTYPE_MARKED_N(NODE, 5)
1518#define CLEAR_CLASSTYPE_MARKED6(NODE) CLEAR_CLASSTYPE_MARKED_N(NODE, 5)
8d08fdba 1519
35acd3f2
MM
1520/* A list of the nested tag-types (class, struct, union, or enum)
1521 found within this class. The TREE_PURPOSE of each node is the name
1522 of the type; the TREE_VALUE is the type itself. This list includes
1523 nested member class templates. */
8d08fdba
MS
1524#define CLASSTYPE_TAGS(NODE) (TYPE_LANG_SPECIFIC(NODE)->tags)
1525
3ef397c1 1526/* Nonzero if NODE has a primary base class, i.e., a base class with
0811ea8f 1527 which it shares the virtual function table pointer. */
3ef397c1 1528#define CLASSTYPE_HAS_PRIMARY_BASE_P(NODE) \
911a71a7 1529 (CLASSTYPE_PRIMARY_BINFO (NODE) != NULL_TREE)
3ef397c1
MM
1530
1531/* If non-NULL, this is the binfo for the primary base class, i.e.,
1532 the base class which contains the virtual function table pointer
1533 for this class. */
5e19c053 1534#define CLASSTYPE_PRIMARY_BINFO(NODE) \
911a71a7 1535 (TYPE_LANG_SPECIFIC (NODE)->primary_base)
3ef397c1 1536
c35cce41 1537/* The number of virtual functions present in this class' virtual
da3d4dfa 1538 function table. */
8d08fdba 1539#define CLASSTYPE_VSIZE(NODE) (TYPE_LANG_SPECIFIC(NODE)->vsize)
23381155
MM
1540
1541/* A chain of BINFOs for the direct and indirect virtual base classes
c35cce41
MM
1542 that this type uses in a post-order depth-first left-to-right
1543 order. (In other words, these bases appear in the order that they
23656158
MM
1544 should be initialized.) If a virtual base is primary, then the
1545 primary copy will appear on this list. Thus, the BINFOs on this
1546 list are all "real"; they are the same BINFOs that will be
1547 encountered when using dfs_unmarked_real_bases_queue_p and related
1548 functions. */
8d08fdba 1549#define CLASSTYPE_VBASECLASSES(NODE) (TYPE_LANG_SPECIFIC(NODE)->vbases)
23381155 1550
3c9d6359 1551/* For a non-virtual BINFO, the BINFO itself; for a virtual BINFO, the
a55583e9 1552 binfo_for_vbase. C is the most derived class for the hierarchy
3c9d6359
MM
1553 containing BINFO. */
1554#define CANONICAL_BINFO(BINFO, C) \
bb20cc46
AJ
1555 (TREE_VIA_VIRTUAL (BINFO) \
1556 ? binfo_for_vbase (BINFO_TYPE (BINFO), C) \
3c9d6359
MM
1557 : BINFO)
1558
23381155 1559/* Number of direct baseclasses of NODE. */
8d08fdba 1560#define CLASSTYPE_N_BASECLASSES(NODE) \
99a6c6f4 1561 (BINFO_N_BASETYPES (TYPE_BINFO (NODE)))
8d08fdba 1562
2d926395
MM
1563/* These are the size and alignment of the type without its virtual
1564 base classes, for when we use this type as a base itself. */
8d08fdba 1565#define CLASSTYPE_SIZE(NODE) (TYPE_LANG_SPECIFIC(NODE)->size)
06ceef4e 1566#define CLASSTYPE_SIZE_UNIT(NODE) (TYPE_LANG_SPECIFIC(NODE)->size_unit)
8012c983 1567#define CLASSTYPE_ALIGN(NODE) (TYPE_LANG_SPECIFIC(NODE)->align)
11cf4d18 1568#define CLASSTYPE_USER_ALIGN(NODE) (TYPE_LANG_SPECIFIC(NODE)->user_align)
8d08fdba 1569
1b50716d
MM
1570/* The alignment of NODE, without its virtual bases, in bytes. */
1571#define CLASSTYPE_ALIGN_UNIT(NODE) \
1572 (CLASSTYPE_ALIGN (NODE) / BITS_PER_UNIT)
1573
8d08fdba
MS
1574/* A cons list of virtual functions which cannot be inherited by
1575 derived classes. When deriving from this type, the derived
1576 class must provide its own definition for each of these functions. */
fee7654e 1577#define CLASSTYPE_PURE_VIRTUALS(NODE) (TYPE_LANG_SPECIFIC(NODE)->pure_virtuals)
8d08fdba
MS
1578
1579/* Nonzero means that this aggr type has been `closed' by a semicolon. */
8012c983 1580#define CLASSTYPE_GOT_SEMICOLON(NODE) (TYPE_LANG_SPECIFIC (NODE)->got_semicolon)
8d08fdba
MS
1581
1582/* Nonzero means that the main virtual function table pointer needs to be
1583 set because base constructors have placed the wrong value there.
1584 If this is zero, it means that they placed the right value there,
1585 and there is no need to change it. */
8012c983 1586#define CLASSTYPE_NEEDS_VIRTUAL_REINIT(NODE) (TYPE_LANG_SPECIFIC(NODE)->needs_virtual_reinit)
8d08fdba
MS
1587
1588/* Nonzero means that if this type has virtual functions, that
1589 the virtual function table will be written out. */
8012c983 1590#define CLASSTYPE_VTABLE_NEEDS_WRITING(NODE) (TYPE_LANG_SPECIFIC(NODE)->vtable_needs_writing)
8d08fdba 1591
8d08fdba 1592/* Nonzero means that this type has an X() constructor. */
8012c983 1593#define TYPE_HAS_DEFAULT_CONSTRUCTOR(NODE) (TYPE_LANG_SPECIFIC(NODE)->has_default_ctor)
8d08fdba 1594
a7a7710d 1595/* Nonzero means that this type contains a mutable member */
8012c983 1596#define CLASSTYPE_HAS_MUTABLE(NODE) (TYPE_LANG_SPECIFIC(NODE)->has_mutable)
a7a7710d
NS
1597#define TYPE_HAS_MUTABLE_P(NODE) (cp_has_mutable_p (NODE))
1598
52fb2769 1599/* Nonzero means that this class type is a non-POD class. */
8012c983 1600#define CLASSTYPE_NON_POD_P(NODE) (TYPE_LANG_SPECIFIC (NODE)->non_pod_class)
52fb2769 1601
f9c528ea
MM
1602/* Nonzero if this class is "nearly empty", i.e., contains only a
1603 virtual function table pointer. */
1604#define CLASSTYPE_NEARLY_EMPTY_P(NODE) \
1605 (TYPE_LANG_SPECIFIC (NODE)->nearly_empty_p)
1606
aff08c18
JM
1607/* Nonzero means that this type is meant for communication via COM. */
1608#define CLASSTYPE_COM_INTERFACE(NODE) \
8012c983 1609 (TYPE_LANG_SPECIFIC(NODE)->com_interface)
aff08c18 1610
6a629cac 1611/* A list of class types of which this type is a friend. The
ea4e080b
MM
1612 TREE_VALUE is normally a TYPE, but will be a TEMPLATE_DECL in the
1613 case of a template friend. */
8d08fdba
MS
1614#define CLASSTYPE_FRIEND_CLASSES(NODE) (TYPE_LANG_SPECIFIC(NODE)->friend_classes)
1615
6a629cac
MM
1616/* A list of the classes which grant friendship to this class. */
1617#define CLASSTYPE_BEFRIENDING_CLASSES(NODE) \
1618 (TYPE_LANG_SPECIFIC (NODE)->befriending_classes)
1619
8d08fdba 1620/* Say whether this node was declared as a "class" or a "struct". */
8012c983 1621#define CLASSTYPE_DECLARED_CLASS(NODE) (TYPE_LANG_SPECIFIC(NODE)->declared_class)
8d08fdba
MS
1622
1623/* Nonzero if this class has const members which have no specified initialization. */
8012c983 1624#define CLASSTYPE_READONLY_FIELDS_NEED_INIT(NODE) (TYPE_LANG_SPECIFIC(NODE)->const_needs_init)
8d08fdba
MS
1625
1626/* Nonzero if this class has ref members which have no specified initialization. */
8012c983 1627#define CLASSTYPE_REF_FIELDS_NEED_INIT(NODE) (TYPE_LANG_SPECIFIC(NODE)->ref_needs_init)
8d08fdba
MS
1628
1629/* Nonzero if this class is included from a header file which employs
1630 `#pragma interface', and it is not included in its implementation file. */
8012c983 1631#define CLASSTYPE_INTERFACE_ONLY(NODE) (TYPE_LANG_SPECIFIC(NODE)->interface_only)
8d08fdba
MS
1632
1633/* Same as above, but for classes whose purpose we do not know. */
8012c983
MM
1634#define CLASSTYPE_INTERFACE_UNKNOWN(NODE) (TYPE_LANG_SPECIFIC(NODE)->interface_unknown)
1635#define CLASSTYPE_INTERFACE_KNOWN(NODE) (TYPE_LANG_SPECIFIC(NODE)->interface_unknown == 0)
1636#define SET_CLASSTYPE_INTERFACE_UNKNOWN_X(NODE,X) (TYPE_LANG_SPECIFIC(NODE)->interface_unknown = !!(X))
1637#define SET_CLASSTYPE_INTERFACE_UNKNOWN(NODE) (TYPE_LANG_SPECIFIC(NODE)->interface_unknown = 1)
1638#define SET_CLASSTYPE_INTERFACE_KNOWN(NODE) (TYPE_LANG_SPECIFIC(NODE)->interface_unknown = 0)
8d08fdba
MS
1639
1640/* Nonzero if a _DECL node requires us to output debug info for this class. */
8012c983 1641#define CLASSTYPE_DEBUG_REQUESTED(NODE) (TYPE_LANG_SPECIFIC(NODE)->debug_requested)
8d08fdba
MS
1642\f
1643/* Additional macros for inheritance information. */
1644
ca107ded
MM
1645/* The BINFO_INHERITANCE_CHAIN is used opposite to the description in
1646 gcc/tree.h. In particular if D is derived from B then the BINFO
1647 for B (in D) will have a BINFO_INHERITANCE_CHAIN pointing to
1648 D. In tree.h, this pointer is described as pointing in other
d6479fe7 1649 direction. There is a different BINFO for each path to a virtual
a55583e9 1650 base; BINFOs for virtual bases are not shared.
ca107ded 1651
d6479fe7
MM
1652 We use TREE_VIA_PROTECTED and TREE_VIA_PUBLIC, but private
1653 inheritance is indicated by the absence of the other two flags, not
c35cce41 1654 by TREE_VIA_PRIVATE, which is unused. */
ca107ded 1655
8d08fdba
MS
1656/* Nonzero means marked by DFS or BFS search, including searches
1657 by `get_binfo' and `get_base_distance'. */
1658#define BINFO_MARKED(NODE) (TREE_VIA_VIRTUAL(NODE)?CLASSTYPE_MARKED(BINFO_TYPE(NODE)):TREE_LANG_FLAG_0(NODE))
1659/* Macros needed because of C compilers that don't allow conditional
1660 expressions to be lvalues. Grr! */
1661#define SET_BINFO_MARKED(NODE) (TREE_VIA_VIRTUAL(NODE)?SET_CLASSTYPE_MARKED(BINFO_TYPE(NODE)):(TREE_LANG_FLAG_0(NODE)=1))
1662#define CLEAR_BINFO_MARKED(NODE) (TREE_VIA_VIRTUAL(NODE)?CLEAR_CLASSTYPE_MARKED(BINFO_TYPE(NODE)):(TREE_LANG_FLAG_0(NODE)=0))
1663
8d08fdba
MS
1664/* Nonzero means that this class is on a path leading to a new vtable. */
1665#define BINFO_VTABLE_PATH_MARKED(NODE) \
1666 (TREE_VIA_VIRTUAL(NODE)?CLASSTYPE_MARKED3(BINFO_TYPE(NODE)):TREE_LANG_FLAG_3(NODE))
1667#define SET_BINFO_VTABLE_PATH_MARKED(NODE) (TREE_VIA_VIRTUAL(NODE)?SET_CLASSTYPE_MARKED3(BINFO_TYPE(NODE)):(TREE_LANG_FLAG_3(NODE)=1))
1668#define CLEAR_BINFO_VTABLE_PATH_MARKED(NODE) (TREE_VIA_VIRTUAL(NODE)?CLEAR_CLASSTYPE_MARKED3(BINFO_TYPE(NODE)):(TREE_LANG_FLAG_3(NODE)=0))
1669
eaef69ce
MM
1670/* Nonzero means B (a BINFO) has its own vtable. Under the old ABI,
1671 secondary vtables are sometimes shared. Any copies will not have
1672 this flag set.
1673
1674 B is part of the hierarchy dominated by C. */
3c9d6359
MM
1675#define BINFO_NEW_VTABLE_MARKED(B, C) \
1676 (TREE_LANG_FLAG_4 (CANONICAL_BINFO (B, C)))
23656158
MM
1677
1678/* Any subobject that needs a new vtable must have a vptr and must not
1679 be a primary base (since it would then use the vtable from a
1680 derived class.) */
bb20cc46 1681#define SET_BINFO_NEW_VTABLE_MARKED(B, C) \
23656158
MM
1682 (BINFO_NEW_VTABLE_MARKED (B, C) = 1, \
1683 my_friendly_assert (!BINFO_PRIMARY_MARKED_P (B), 20000517), \
1684 my_friendly_assert (CLASSTYPE_VFIELDS (BINFO_TYPE (B)) != NULL_TREE, \
1685 20000517))
8d08fdba 1686
0ec57017
JM
1687/* Nonzero means this class has done dfs_pushdecls. */
1688#define BINFO_PUSHDECLS_MARKED(NODE) BINFO_VTABLE_PATH_MARKED (NODE)
1689#define SET_BINFO_PUSHDECLS_MARKED(NODE) SET_BINFO_VTABLE_PATH_MARKED (NODE)
1690#define CLEAR_BINFO_PUSHDECLS_MARKED(NODE) CLEAR_BINFO_VTABLE_PATH_MARKED (NODE)
72c4a2a6 1691
174eceea
MM
1692/* Nonzero if this BINFO is a primary base class.
1693
1694 In the TYPE_BINFO hierarchy, this flag is never set for a base
a55583e9
MM
1695 class of a non-primary virtual base. This flag is only valid for
1696 paths (given by BINFO_INHERITANCE_CHAIN) that really exist in the
1697 final object. */
911a71a7
MM
1698#define BINFO_PRIMARY_MARKED_P(NODE) \
1699 (BINFO_PRIMARY_BASE_OF (NODE) != NULL_TREE)
99a6c6f4 1700
3ec6bad3
MM
1701/* The index in the VTT where this subobject's sub-VTT can be found.
1702 NULL_TREE if there is no sub-VTT. */
1703#define BINFO_SUBVTT_INDEX(NODE) TREE_VEC_ELT ((NODE), 8)
1704
1705/* The index in the VTT where the vptr for this subobject can be
1706 found. NULL_TREE if there is no secondary vptr in the VTT. */
1707#define BINFO_VPTR_INDEX(NODE) TREE_VEC_ELT ((NODE), 9)
1708
911a71a7
MM
1709/* The binfo of which NODE is a primary base. (This is different from
1710 BINFO_INHERITANCE_CHAIN for virtual base because a virtual base is
1711 sometimes a primary base for a class for which it is not an
1712 immediate base.) */
1713#define BINFO_PRIMARY_BASE_OF(NODE) TREE_VEC_ELT ((NODE), 10)
1714
db3d8cde
MM
1715/* Nonzero if this binfo declares a virtual function which is
1716 overridden along a virtual path. */
1717#define BINFO_OVERRIDE_ALONG_VIRTUAL_PATH_P(NODE) TREE_LANG_FLAG_2 (NODE)
1718
911a71a7
MM
1719/* Nonzero if this binfo is an indirect primary base, i.e. a virtual
1720 base that is a primary base of some of other class in the
1721 hierarchy. */
1722#define BINFO_INDIRECT_PRIMARY_P(NODE) TREE_USED (NODE)
1723
72c4a2a6
JM
1724/* Used by various search routines. */
1725#define IDENTIFIER_MARKED(NODE) TREE_LANG_FLAG_0 (NODE)
8d08fdba
MS
1726\f
1727/* Accessor macros for the vfield slots in structures. */
1728
8026246f
MM
1729/* The virtual function pointer fields that this type contains. For a
1730 vfield defined just for this class, or from a primary base, the
1731 TREE_PURPOSE is NULL. Otherwise, the TREE_PURPOSE is the BINFO for
1732 the class containing the vfield. The TREE_VALUE is the class where
1733 the vfield was first defined. */
1734#define CLASSTYPE_VFIELDS(NODE) (TYPE_LANG_SPECIFIC(NODE)->vfields)
1735
8d08fdba
MS
1736/* Get the assoc info that caused this vfield to exist. */
1737#define VF_BINFO_VALUE(NODE) TREE_PURPOSE (NODE)
1738
1739/* Get that same information as a _TYPE. */
1740#define VF_BASETYPE_VALUE(NODE) TREE_VALUE (NODE)
1741
1742/* Get the value of the top-most type dominating the non-`normal' vfields. */
1743#define VF_DERIVED_VALUE(NODE) (VF_BINFO_VALUE (NODE) ? BINFO_TYPE (VF_BINFO_VALUE (NODE)) : NULL_TREE)
c0bbf652
MM
1744
1745/* The number of bytes by which to adjust the `this' pointer when
1746 calling this virtual function. */
5e19c053 1747#define BV_DELTA(NODE) (TREE_PURPOSE (NODE))
c0bbf652
MM
1748
1749/* If non-NULL, the vtable index at which to find the vcall offset
1750 when calling this virtual function. */
5e19c053 1751#define BV_VCALL_INDEX(NODE) (TREE_TYPE (NODE))
c0bbf652
MM
1752
1753/* The function to call. */
5e19c053
MM
1754#define BV_FN(NODE) (TREE_VALUE (NODE))
1755
31f8e4f3
MM
1756/* Nonzero if we should use a virtual thunk for this entry. */
1757#define BV_USE_VCALL_INDEX_P(NODE) \
1758 (TREE_LANG_FLAG_0 (NODE))
1759
1760/* Nonzero if we should generate this thunk when the vtable that
1761 references it is emitted, rather than with the final overrider. */
1762#define BV_GENERATE_THUNK_WITH_VTABLE_P(NODE) \
1763 (TREE_LANG_FLAG_1 (NODE))
1764
5e19c053 1765/* The most derived class. */
c0bbf652 1766
8d08fdba
MS
1767\f
1768/* Nonzero for TREE_LIST node means that this list of things
1769 is a list of parameters, as opposed to a list of expressions. */
1770#define TREE_PARMLIST(NODE) ((NODE)->common.unsigned_flag) /* overloaded! */
1771
5cce22b6
NS
1772/* Nonzero for a parmlist means that this parmlist ended in ... */
1773#define PARMLIST_ELLIPSIS_P(NODE) TREE_LANG_FLAG_0 (NODE)
1774
8d08fdba 1775/* For FUNCTION_TYPE or METHOD_TYPE, a list of the exceptions that
193306f7 1776 this type can raise. Each TREE_VALUE is a _TYPE. The TREE_VALUE
66a6250f
JM
1777 will be NULL_TREE to indicate a throw specification of `()', or
1778 no exceptions allowed. */
8d08fdba 1779#define TYPE_RAISES_EXCEPTIONS(NODE) TYPE_NONCOPIED_PARTS (NODE)
a9aedbc2 1780
7f477e81
NS
1781/* For FUNCTION_TYPE or METHOD_TYPE, return 1 iff it is declared `throw()'. */
1782#define TYPE_NOTHROW_P(NODE) \
1783 (TYPE_RAISES_EXCEPTIONS (NODE) \
1784 && TREE_VALUE (TYPE_RAISES_EXCEPTIONS (NODE)) == NULL_TREE)
1785
e92cc029 1786/* The binding level associated with the namespace. */
3ebc5c52
MM
1787#define NAMESPACE_LEVEL(NODE) \
1788 (DECL_LANG_SPECIFIC(NODE)->decl_flags.u.level)
8d08fdba 1789\f
6a629cac
MM
1790
1791/* If a DECL has DECL_LANG_SPECIFIC, it is either a lang_decl_flags or
b0d06515
MM
1792 a lang_decl (which has lang_decl_flags as its initial prefix).
1793 This macro is nonzero for tree nodes whose DECL_LANG_SPECIFIC is
1794 the full lang_decl, and not just lang_decl_flags. */
1795#define CAN_HAVE_FULL_LANG_DECL_P(NODE) \
1796 (!(TREE_CODE ((NODE)) == VAR_DECL \
1797 || TREE_CODE ((NODE)) == CONST_DECL \
bb20cc46 1798 || TREE_CODE ((NODE)) == FIELD_DECL \
b0d06515 1799 || TREE_CODE ((NODE)) == USING_DECL))
6a629cac 1800
8d08fdba
MS
1801struct lang_decl_flags
1802{
8f17b5c5
MM
1803 struct c_lang_decl base;
1804
e60a8c26 1805 ENUM_BITFIELD(languages) language : 8;
8d08fdba
MS
1806
1807 unsigned operator_attr : 1;
1808 unsigned constructor_attr : 1;
0d9eb3ba 1809 unsigned destructor_attr : 1;
8d08fdba
MS
1810 unsigned friend_attr : 1;
1811 unsigned static_function : 1;
fee7654e 1812 unsigned pure_virtual : 1;
454fa7a7 1813 unsigned has_in_charge_parm_p : 1;
721c3b42 1814 unsigned uninlinable : 1;
d60f72ae 1815
56e770bf 1816 unsigned deferred : 1;
a0a33927 1817 unsigned use_template : 2;
db5ae43f 1818 unsigned nonconverting : 1;
faae18ab
MS
1819 unsigned declared_inline : 1;
1820 unsigned not_really_extern : 1;
cdcb673e 1821 unsigned needs_final_overrider : 1;
6ba89f8e 1822 unsigned defined_in_class : 1;
721c3b42 1823
59026e79 1824 unsigned pending_inline_p : 1;
af3b4e59
MM
1825 unsigned global_ctor_p : 1;
1826 unsigned global_dtor_p : 1;
721c3b42 1827 unsigned tinfo_fn_p : 1;
596ea4e5 1828 unsigned assignment_operator_p : 1;
cc057ef3 1829 unsigned anticipated_p : 1;
31f8e4f3
MM
1830 unsigned generate_with_vtable_p : 1;
1831 unsigned dummy : 1;
8d08fdba 1832
3ebc5c52 1833 union {
7c355bca
ML
1834 /* In a FUNCTION_DECL, VAR_DECL, TYPE_DECL, or TEMPLATE_DECL, this
1835 is DECL_TEMPLATE_INFO. */
3ebc5c52
MM
1836 tree template_info;
1837
1838 /* In a NAMESPACE_DECL, this is NAMESPACE_LEVEL. */
1839 struct binding_level *level;
1840 } u;
af3b4e59
MM
1841
1842 union {
1843 /* This is DECL_ACCESS. */
1844 tree access;
1845
1846 /* In a namespace-scope FUNCTION_DECL, this is
1847 GLOBAL_INIT_PRIORITY. */
1848 int init_priority;
6462c441
MM
1849
1850 /* In a FUNCTION_DECL for which DECL_THUNK_P holds, this is
1851 THUNK_VCALL_OFFSET. */
31f8e4f3 1852 tree vcall_offset;
af3b4e59 1853 } u2;
8d08fdba
MS
1854};
1855
0e5921e8
ZW
1856struct unparsed_text;
1857
8d08fdba
MS
1858struct lang_decl
1859{
1860 struct lang_decl_flags decl_flags;
1861
6a629cac 1862 tree befriending_classes;
9188c363 1863
8f17b5c5
MM
1864 /* For a virtual FUNCTION_DECL, this is DECL_VIRTUAL_CONTEXT. For a
1865 non-virtual FUNCTION_DECL, this is DECL_FRIEND_CONTEXT. */
1866 tree context;
9188c363 1867
db9b2174
MM
1868 /* In a FUNCTION_DECL, this is DECL_CLONED_FUNCTION. */
1869 tree cloned_function;
1870
f90cdf34
MT
1871 union
1872 {
1873 tree sorted_fields;
0e5921e8 1874 struct unparsed_text *pending_inline_info;
ae499cce 1875 struct cp_language_function *saved_language_function;
f90cdf34 1876 } u;
596ea4e5
AS
1877
1878 union {
1879 /* In an overloaded operator, this is the value of
1880 DECL_OVERLOADED_OPERATOR_P. */
1881 enum tree_code operator_code;
1882 /* In a maybe-in-charge constructor or destructor, this is
1883 DECL_VTT_PARM. */
1884 tree vtt_parm;
1885 } u2;
8d08fdba
MS
1886};
1887
d7e7759d
BC
1888#define DEFARG_POINTER(NODE) (DEFAULT_ARG_CHECK(NODE)->identifier.pointer)
1889
8d08fdba
MS
1890/* Non-zero if NODE is a _DECL with TREE_READONLY set. */
1891#define TREE_READONLY_DECL_P(NODE) \
fc611ce0 1892 (TREE_READONLY (NODE) && DECL_P (NODE))
8d08fdba 1893
d7e7759d
BC
1894/* DECL_NEEDED_P holds of a declaration when we need to emit its
1895 definition. This is true when the back-end tells us that
1896 the symbol has been referenced in the generated code. If, however,
1897 we are not generating code, then it is also true when a symbol has
1898 just been used somewhere, even if it's not really needed. We need
1899 anything that isn't comdat, but we don't know for sure whether or
1900 not something is comdat until end-of-file. */
1901#define DECL_NEEDED_P(DECL) \
3f954fc3 1902 ((at_eof && TREE_PUBLIC (DECL) && !DECL_COMDAT (DECL)) \
d7e7759d
BC
1903 || (TREE_SYMBOL_REFERENCED (DECL_ASSEMBLER_NAME ((DECL)))) \
1904 || (flag_syntax_only && TREE_USED ((DECL))))
1905
cffa8729
MS
1906/* Non-zero iff DECL is memory-based. The DECL_RTL of
1907 certain const variables might be a CONST_INT, or a REG
1908 in some cases. We cannot use `memory_operand' as a test
1909 here because on most RISC machines, a variable's address
1910 is not, by itself, a legitimate address. */
1911#define DECL_IN_MEMORY_P(NODE) \
1912 (DECL_RTL (NODE) != NULL_RTX && GET_CODE (DECL_RTL (NODE)) == MEM)
1913
8d08fdba
MS
1914/* For FUNCTION_DECLs: return the language in which this decl
1915 was declared. */
1916#define DECL_LANGUAGE(NODE) (DECL_LANG_SPECIFIC(NODE)->decl_flags.language)
1917
1918/* For FUNCTION_DECLs: nonzero means that this function is a constructor. */
1919#define DECL_CONSTRUCTOR_P(NODE) (DECL_LANG_SPECIFIC(NODE)->decl_flags.constructor_attr)
aa45967f 1920
db9b2174
MM
1921/* Nonzero if NODE (a FUNCTION_DECL) is a constructor for a complete
1922 object. */
1923#define DECL_COMPLETE_CONSTRUCTOR_P(NODE) \
bb20cc46 1924 (DECL_CONSTRUCTOR_P (NODE) \
db9b2174
MM
1925 && DECL_NAME (NODE) == complete_ctor_identifier)
1926
1927/* Nonzero if NODE (a FUNCTION_DECL) is a constructor for a base
1928 object. */
1929#define DECL_BASE_CONSTRUCTOR_P(NODE) \
1930 (DECL_CONSTRUCTOR_P (NODE) \
1931 && DECL_NAME (NODE) == base_ctor_identifier)
1932
1933/* Nonzero if NODE (a FUNCTION_DECL) is a constructor, but not either the
1934 specialized in-charge constructor or the specialized not-in-charge
1935 constructor. */
1936#define DECL_MAYBE_IN_CHARGE_CONSTRUCTOR_P(NODE) \
1937 (DECL_CONSTRUCTOR_P (NODE) && !DECL_CLONED_FUNCTION_P (NODE))
1938
454fa7a7
MM
1939/* Nonzero if NODE (a FUNCTION_DECL) is a copy constructor. */
1940#define DECL_COPY_CONSTRUCTOR_P(NODE) \
1941 (DECL_CONSTRUCTOR_P (NODE) && copy_args_p (NODE))
1942
1f6e1acc 1943/* Nonzero if NODE is a destructor. */
aa45967f 1944#define DECL_DESTRUCTOR_P(NODE) \
0d9eb3ba 1945 (DECL_LANG_SPECIFIC (NODE)->decl_flags.destructor_attr)
aa45967f 1946
db9b2174
MM
1947/* Nonzero if NODE (a FUNCTION_DECL) is a destructor, but not the
1948 specialized in-charge constructor, in-charge deleting constructor,
1949 or the the base destructor. */
1950#define DECL_MAYBE_IN_CHARGE_DESTRUCTOR_P(NODE) \
1951 (DECL_DESTRUCTOR_P (NODE) && !DECL_CLONED_FUNCTION_P (NODE))
1952
298d6f60
MM
1953/* Nonzero if NODE (a FUNCTION_DECL) is a destructor for a complete
1954 object. */
1955#define DECL_COMPLETE_DESTRUCTOR_P(NODE) \
bb20cc46 1956 (DECL_DESTRUCTOR_P (NODE) \
298d6f60
MM
1957 && DECL_NAME (NODE) == complete_dtor_identifier)
1958
1959/* Nonzero if NODE (a FUNCTION_DECL) is a destructor for a base
1960 object. */
1961#define DECL_BASE_DESTRUCTOR_P(NODE) \
1962 (DECL_DESTRUCTOR_P (NODE) \
1963 && DECL_NAME (NODE) == base_dtor_identifier)
1964
1965/* Nonzero if NODE (a FUNCTION_DECL) is a destructor for a complete
872f37f9 1966 object that deletes the object after it has been destroyed. */
298d6f60 1967#define DECL_DELETING_DESTRUCTOR_P(NODE) \
bb20cc46 1968 (DECL_DESTRUCTOR_P (NODE) \
298d6f60
MM
1969 && DECL_NAME (NODE) == deleting_dtor_identifier)
1970
db9b2174
MM
1971/* Nonzero if NODE (a FUNCTION_DECL) is a cloned constructor or
1972 destructor. */
94350948 1973#define DECL_CLONED_FUNCTION_P(NODE) \
bb20cc46 1974 (DECL_LANG_SPECIFIC (NODE) \
94350948 1975 && DECL_CLONED_FUNCTION (NODE) != NULL_TREE)
db9b2174
MM
1976
1977/* If DECL_CLONED_FUNCTION_P holds, this is the function that was
1978 cloned. */
1979#define DECL_CLONED_FUNCTION(NODE) \
1980 (DECL_LANG_SPECIFIC (NODE)->cloned_function)
1981
3ec6bad3
MM
1982/* In a maybe-in-charge constructor or destructor, this is the VTT
1983 parameter. It's not actually on the DECL_ARGUMENTS list. */
1984#define DECL_VTT_PARM(NODE) \
596ea4e5 1985 (DECL_LANG_SPECIFIC (NODE)->u2.vtt_parm)
3ec6bad3
MM
1986
1987/* If there's a DECL_VTT_PARM, this is a magic variable that indicates
1988 whether or not the VTT parm should be used. In a subobject
1989 constructor, `true' is substituted for this value; in a complete
1990 object constructor, `false' is substituted instead. */
1991#define DECL_USE_VTT_PARM(NODE) \
1992 (TREE_CHAIN (DECL_VTT_PARM (NODE)))
1993
1994/* Non-zero if NODE is a FUNCTION_DECL for which a VTT parameter is
1995 required. */
1996#define DECL_NEEDS_VTT_PARM_P(NODE) \
1997 (TYPE_USES_VIRTUAL_BASECLASSES (DECL_CONTEXT (NODE)) \
1998 && (DECL_BASE_CONSTRUCTOR_P (NODE) \
1999 || DECL_BASE_DESTRUCTOR_P (NODE)))
2000
f71f87f9 2001/* Non-zero if NODE is a user-defined conversion operator. */
421844e7
MM
2002#define DECL_CONV_FN_P(NODE) \
2003 (IDENTIFIER_TYPENAME_P (DECL_NAME (NODE)))
711734a9 2004
596ea4e5
AS
2005/* Set the overloaded operator code for NODE to CODE. */
2006#define SET_OVERLOADED_OPERATOR_CODE(NODE, CODE) \
2007 (DECL_LANG_SPECIFIC (NODE)->u2.operator_code = (CODE))
2008
2009/* If NODE is an overloaded operator, then this returns the TREE_CODE
2010 associcated with the overloaded operator.
2011 DECL_ASSIGNMENT_OPERATOR_P must also be checked to determine
2012 whether or not NODE is an assignment operator. If NODE is not an
2013 overloaded operator, ERROR_MARK is returned. Since the numerical
2014 value of ERROR_MARK is zero, this macro can be used as a predicate
2015 to test whether or not NODE is an overloaded operator. */
bb20cc46 2016#define DECL_OVERLOADED_OPERATOR_P(NODE) \
596ea4e5
AS
2017 (IDENTIFIER_OPNAME_P (DECL_NAME ((NODE))) \
2018 ? DECL_LANG_SPECIFIC (NODE)->u2.operator_code : ERROR_MARK)
2019
2020/* Non-zero if NODE is an assignment operator. */
2021#define DECL_ASSIGNMENT_OPERATOR_P(NODE) \
2022 (DECL_LANG_SPECIFIC (NODE)->decl_flags.assignment_operator_p)
f71f87f9 2023
454fa7a7
MM
2024/* For FUNCTION_DECLs: nonzero means that this function is a
2025 constructor or a destructor with an extra in-charge parameter to
2026 control whether or not virtual bases are constructed. */
2027#define DECL_HAS_IN_CHARGE_PARM_P(NODE) \
2028 (DECL_LANG_SPECIFIC (NODE)->decl_flags.has_in_charge_parm_p)
8d08fdba 2029
db1147b2
NS
2030/* Non-zero for a FUNCTION_DECL that declares a type-info function.
2031 This only happens in the old abi. */
bb20cc46 2032#define DECL_TINFO_FN_P(NODE) \
0aafb128
MM
2033 (TREE_CODE (NODE) == FUNCTION_DECL \
2034 && DECL_ARTIFICIAL (NODE) \
721c3b42 2035 && DECL_LANG_SPECIFIC(NODE)->decl_flags.tinfo_fn_p)
0aafb128
MM
2036
2037/* Mark NODE as a type-info function. */
2038#define SET_DECL_TINFO_FN_P(NODE) \
721c3b42 2039 (DECL_LANG_SPECIFIC((NODE))->decl_flags.tinfo_fn_p = 1)
0aafb128 2040
834c6dff
MM
2041/* Nonzero if NODE is an overloaded `operator delete[]' function. */
2042#define DECL_ARRAY_DELETE_OPERATOR_P(NODE) \
596ea4e5 2043 (DECL_OVERLOADED_OPERATOR_P (NODE) == VEC_DELETE_EXPR)
834c6dff 2044
8d08fdba
MS
2045/* Nonzero for _DECL means that this decl appears in (or will appear
2046 in) as a member in a RECORD_TYPE or UNION_TYPE node. It is also for
2047 detecting circularity in case members are multiply defined. In the
2048 case of a VAR_DECL, it is also used to determine how program storage
2049 should be allocated. */
2050#define DECL_IN_AGGR_P(NODE) (DECL_LANG_FLAG_3(NODE))
2051
6ba89f8e
MM
2052/* Nonzero if the DECL was defined in the class definition itself,
2053 rather than outside the class. */
2054#define DECL_DEFINED_IN_CLASS_P(DECL) \
2055 (DECL_LANG_SPECIFIC (DECL)->decl_flags.defined_in_class)
2056
8d08fdba
MS
2057/* Nonzero for FUNCTION_DECL means that this decl is just a
2058 friend declaration, and should not be added to the list of
2059 member functions for this class. */
2060#define DECL_FRIEND_P(NODE) (DECL_LANG_SPECIFIC(NODE)->decl_flags.friend_attr)
2061
6a629cac
MM
2062/* A TREE_LIST of the types which have befriended this FUNCTION_DECL. */
2063#define DECL_BEFRIENDING_CLASSES(NODE) \
2064 (DECL_LANG_SPECIFIC(NODE)->befriending_classes)
2065
8d08fdba
MS
2066/* Nonzero for FUNCTION_DECL means that this decl is a static
2067 member function. */
2068#define DECL_STATIC_FUNCTION_P(NODE) (DECL_LANG_SPECIFIC(NODE)->decl_flags.static_function)
2069
700f8a87
MS
2070/* Nonzero for a class member means that it is shared between all objects
2071 of that class. */
2072#define SHARED_MEMBER_P(NODE) \
2073 (TREE_CODE (NODE) == VAR_DECL || TREE_CODE (NODE) == TYPE_DECL \
2074 || TREE_CODE (NODE) == CONST_DECL)
bb20cc46 2075
8857f91e
MM
2076/* Nonzero for FUNCTION_DECL means that this decl is a non-static
2077 member function. */
2078#define DECL_NONSTATIC_MEMBER_FUNCTION_P(NODE) \
2079 (TREE_CODE (TREE_TYPE (NODE)) == METHOD_TYPE)
2080
8926095f
MS
2081/* Nonzero for FUNCTION_DECL means that this decl is a member function
2082 (static or non-static). */
2083#define DECL_FUNCTION_MEMBER_P(NODE) \
8857f91e 2084 (DECL_NONSTATIC_MEMBER_FUNCTION_P (NODE) || DECL_STATIC_FUNCTION_P (NODE))
8926095f 2085
8d08fdba
MS
2086/* Nonzero for FUNCTION_DECL means that this member function
2087 has `this' as const X *const. */
0d9eb3ba
MM
2088#define DECL_CONST_MEMFUNC_P(NODE) \
2089 (DECL_NONSTATIC_MEMBER_FUNCTION_P (NODE) \
bb20cc46 2090 && CP_TYPE_CONST_P (TREE_TYPE (TREE_VALUE \
0d9eb3ba 2091 (TYPE_ARG_TYPES (TREE_TYPE (NODE))))))
8d08fdba 2092
1f6e1acc
AS
2093/* Nonzero for FUNCTION_DECL means that this member function
2094 has `this' as volatile X *const. */
2095#define DECL_VOLATILE_MEMFUNC_P(NODE) \
2096 (DECL_NONSTATIC_MEMBER_FUNCTION_P (NODE) \
2097 && CP_TYPE_VOLATILE_P (TREE_TYPE (TREE_VALUE \
2098 (TYPE_ARG_TYPES (TREE_TYPE (NODE))))))
2099
d6479fe7 2100/* Nonzero for a DECL means that this member is a non-static member. */
bb20cc46
AJ
2101#define DECL_NONSTATIC_MEMBER_P(NODE) \
2102 ((TREE_CODE (NODE) == FUNCTION_DECL \
d6479fe7
MM
2103 && DECL_NONSTATIC_MEMBER_FUNCTION_P (NODE)) \
2104 || TREE_CODE (NODE) == FIELD_DECL)
2105
8d08fdba
MS
2106/* Nonzero for _DECL means that this member object type
2107 is mutable. */
721c3b42 2108#define DECL_MUTABLE_P(NODE) (DECL_LANG_FLAG_0 (NODE))
8d08fdba 2109
db5ae43f
MS
2110/* Nonzero for _DECL means that this constructor is a non-converting
2111 constructor. */
2112#define DECL_NONCONVERTING_P(NODE) (DECL_LANG_SPECIFIC(NODE)->decl_flags.nonconverting)
2113
fee7654e
MM
2114/* Nonzero for FUNCTION_DECL means that this member function is a pure
2115 virtual function. */
2116#define DECL_PURE_VIRTUAL_P(NODE) (DECL_LANG_SPECIFIC(NODE)->decl_flags.pure_virtual)
8d08fdba 2117
cdcb673e
MH
2118/* Nonzero for FUNCTION_DECL means that this member function
2119 must be overridden by derived classes. */
2120#define DECL_NEEDS_FINAL_OVERRIDER_P(NODE) (DECL_LANG_SPECIFIC(NODE)->decl_flags.needs_final_overrider)
2121
eb68cb58
MM
2122/* Nonzero if NODE is a thunk, rather than an ordinary function. */
2123#define DECL_THUNK_P(NODE) \
2124 (TREE_CODE (NODE) == FUNCTION_DECL \
2125 && DECL_LANG_FLAG_7 (NODE))
2126
2127/* Nonzero if NODE is a FUNCTION_DECL, but not a thunk. */
2128#define DECL_NON_THUNK_FUNCTION_P(NODE) \
2129 (TREE_CODE (NODE) == FUNCTION_DECL && !DECL_THUNK_P (NODE))
2130
2131/* Nonzero if NODE is `extern "C"'. */
2132#define DECL_EXTERN_C_P(NODE) \
2133 (DECL_LANGUAGE (NODE) == lang_c)
2134
2135/* Nonzero if NODE is an `extern "C"' function. */
2136#define DECL_EXTERN_C_FUNCTION_P(NODE) \
2137 (DECL_NON_THUNK_FUNCTION_P (NODE) && DECL_EXTERN_C_P (NODE))
2138
2139/* Set DECL_THUNK_P for node. */
2140#define SET_DECL_THUNK_P(NODE) \
2141 (DECL_LANG_FLAG_7 (NODE) = 1)
2142
f9817201
MM
2143/* Nonzero if this DECL is the __PRETTY_FUNCTION__ variable in a
2144 template function. */
2145#define DECL_PRETTY_FUNCTION_P(NODE) \
6dfbb909 2146 (TREE_LANG_FLAG_0 (NODE))
f9817201 2147
8926095f 2148/* The _TYPE context in which this _DECL appears. This field holds the
4f1c5b7d
MM
2149 class where a virtual function instance is actually defined. */
2150#define DECL_CLASS_CONTEXT(NODE) \
2151 (DECL_CLASS_SCOPE_P (NODE) ? DECL_CONTEXT (NODE) : NULL_TREE)
2152
2153/* For a non-member friend function, the class (if any) in which this
2154 friend was defined. For example, given:
bb20cc46 2155
4f1c5b7d
MM
2156 struct S { friend void f (); };
2157
2158 the DECL_FRIEND_CONTEXT for `f' will be `S'. */
2159#define DECL_FRIEND_CONTEXT(NODE) \
2160 ((DECL_FRIEND_P (NODE) && !DECL_FUNCTION_MEMBER_P (NODE)) \
8f17b5c5 2161 ? DECL_LANG_SPECIFIC (NODE)->context \
4f1c5b7d
MM
2162 : NULL_TREE)
2163
2164/* Set the DECL_FRIEND_CONTEXT for NODE to CONTEXT. */
2165#define SET_DECL_FRIEND_CONTEXT(NODE, CONTEXT) \
8f17b5c5 2166 (DECL_LANG_SPECIFIC (NODE)->context = (CONTEXT))
cb0dbb9a
JM
2167
2168/* NULL_TREE in DECL_CONTEXT represents the global namespace. */
2169#define CP_DECL_CONTEXT(NODE) \
2170 (DECL_CONTEXT (NODE) ? DECL_CONTEXT (NODE) : global_namespace)
2171#define FROB_CONTEXT(NODE) ((NODE) == global_namespace ? NULL_TREE : (NODE))
8d08fdba 2172
3927874d
JM
2173/* For a virtual function, the base where we find its vtable entry.
2174 For a non-virtual function, the base where it is defined. */
4f1c5b7d 2175#define DECL_VIRTUAL_CONTEXT(NODE) \
8f17b5c5 2176 (DECL_LANG_SPECIFIC (NODE)->context)
3927874d 2177
42c7b807 2178/* 1 iff NODE has namespace scope, including the global namespace. */
4f71f630
MM
2179#define DECL_NAMESPACE_SCOPE_P(NODE) \
2180 (!DECL_TEMPLATE_PARM_P (NODE) \
2181 && TREE_CODE (CP_DECL_CONTEXT (NODE)) == NAMESPACE_DECL)
42c7b807
JM
2182
2183/* 1 iff NODE is a class member. */
6eb3bb27 2184#define DECL_CLASS_SCOPE_P(NODE) \
4f1c5b7d 2185 (DECL_CONTEXT (NODE) && TYPE_P (DECL_CONTEXT (NODE)))
42c7b807 2186
2642b9bf
JM
2187/* 1 iff NODE is function-local. */
2188#define DECL_FUNCTION_SCOPE_P(NODE) \
2189 (DECL_CONTEXT (NODE) \
2190 && TREE_CODE (DECL_CONTEXT (NODE)) == FUNCTION_DECL)
1f6e1acc 2191
881c6935
JM
2192/* 1 iff NODE is function-local, but for types. */
2193#define LOCAL_CLASS_P(NODE) \
495d26d6 2194 (decl_function_context (TYPE_MAIN_DECL (NODE)) != NULL_TREE)
881c6935 2195
2c73f9f5 2196/* For a NAMESPACE_DECL: the list of using namespace directives
30394414 2197 The PURPOSE is the used namespace, the value is the namespace
2c73f9f5 2198 that is the common ancestor. */
da8a66fc 2199#define DECL_NAMESPACE_USING(NODE) DECL_VINDEX (NAMESPACE_DECL_CHECK (NODE))
30394414
JM
2200
2201/* In a NAMESPACE_DECL, the DECL_INITIAL is used to record all users
2c73f9f5 2202 of a namespace, to record the transitive closure of using namespace. */
da8a66fc 2203#define DECL_NAMESPACE_USERS(NODE) DECL_INITIAL (NAMESPACE_DECL_CHECK (NODE))
30394414 2204
3e3f722c
ML
2205/* In a NAMESPACE_DECL, points to the original namespace if this is
2206 a namespace alias. */
da8a66fc
ML
2207#define DECL_NAMESPACE_ALIAS(NODE) \
2208 DECL_ABSTRACT_ORIGIN (NAMESPACE_DECL_CHECK (NODE))
3e3f722c
ML
2209#define ORIGINAL_NAMESPACE(NODE) \
2210 (DECL_NAMESPACE_ALIAS (NODE) ? DECL_NAMESPACE_ALIAS (NODE) : (NODE))
2211
1f6e1acc
AS
2212/* Non-zero if NODE is the std namespace. */
2213#define DECL_NAMESPACE_STD_P(NODE) \
2214 (TREE_CODE (NODE) == NAMESPACE_DECL \
2215 && CP_DECL_CONTEXT (NODE) == global_namespace \
2216 && DECL_NAME (NODE) == std_identifier)
2217
0aafb128
MM
2218/* In a non-local VAR_DECL with static storage duration, this is the
2219 initialization priority. If this value is zero, the NODE will be
2220 initialized at the DEFAULT_INIT_PRIORITY. */
9df2c88c 2221#define DECL_INIT_PRIORITY(NODE) (VAR_DECL_CHECK (NODE)->decl.u2.i)
0aafb128 2222
9df2c88c 2223/* In a TREE_LIST concatenating using directives, indicate indirect
30394414 2224 directives */
da8a66fc 2225#define TREE_INDIRECT_USING(NODE) (TREE_LIST_CHECK (NODE)->common.lang_flag_0)
8d08fdba 2226
d2ad151f 2227/* In a VAR_DECL for a variable declared in a for statement,
e92cc029 2228 this is the shadowed (local) variable. */
17aec3eb 2229#define DECL_SHADOWED_FOR_VAR(NODE) DECL_RESULT_FLD(VAR_DECL_CHECK (NODE))
d2ad151f 2230
59026e79
MM
2231/* In a FUNCTION_DECL, this is nonzero if this function was defined in
2232 the class definition. We have saved away the text of the function,
2233 but have not yet processed it. */
2234#define DECL_PENDING_INLINE_P(NODE) \
f5e6b7bc 2235 (DECL_LANG_SPECIFIC (NODE)->decl_flags.pending_inline_p)
bb20cc46 2236
59026e79
MM
2237/* If DECL_PENDING_INLINE_P holds, this is the saved text of the
2238 function. */
2239#define DECL_PENDING_INLINE_INFO(NODE) \
2240 (DECL_LANG_SPECIFIC(NODE)->u.pending_inline_info)
f90cdf34
MT
2241
2242/* For a TYPE_DECL: if this function has many fields, we'll sort them
2243 and put them into a TREE_VEC. */
da8a66fc
ML
2244#define DECL_SORTED_FIELDS(NODE) \
2245 (DECL_LANG_SPECIFIC (TYPE_DECL_CHECK (NODE))->u.sorted_fields)
8d08fdba 2246
56e770bf
MM
2247/* True if on the deferred_fns (see decl2.c) list. */
2248#define DECL_DEFERRED_FN(DECL) \
2249 (DECL_LANG_SPECIFIC(DECL)->decl_flags.deferred)
8926095f 2250
7c355bca
ML
2251/* For a VAR_DECL, FUNCTION_DECL, TYPE_DECL or TEMPLATE_DECL:
2252 template-specific information. */
3ebc5c52 2253#define DECL_TEMPLATE_INFO(NODE) \
7c355bca 2254 (DECL_LANG_SPECIFIC(VAR_TEMPL_TYPE_OR_FUNCTION_DECL_CHECK (NODE))->decl_flags.u.template_info)
ed44da02
MM
2255
2256/* Template information for a RECORD_TYPE or UNION_TYPE. */
da8a66fc
ML
2257#define CLASSTYPE_TEMPLATE_INFO(NODE) \
2258 (TYPE_LANG_SPECIFIC(RECORD_OR_UNION_TYPE_CHECK (NODE))->template_info)
ed44da02
MM
2259
2260/* Template information for an ENUMERAL_TYPE. Although an enumeration may
2261 not be a primary template, it may be declared within the scope of a
2262 primary template and the enumeration constants may depend on
2263 non-type template parameters. */
da8a66fc 2264#define ENUM_TEMPLATE_INFO(NODE) (TYPE_BINFO (ENUMERAL_TYPE_CHECK (NODE)))
ed44da02 2265
a1281f45 2266/* Template information for a bound template template parameter. */
7ddedda4
MM
2267#define TEMPLATE_TEMPLATE_PARM_TEMPLATE_INFO(NODE) (TYPE_BINFO (NODE))
2268
ed44da02 2269/* Template information for an ENUMERAL_, RECORD_, or UNION_TYPE. */
7ddedda4
MM
2270#define TYPE_TEMPLATE_INFO(NODE) \
2271 (TREE_CODE (NODE) == ENUMERAL_TYPE \
9076e292 2272 ? ENUM_TEMPLATE_INFO (NODE) : \
a1281f45 2273 (TREE_CODE (NODE) == BOUND_TEMPLATE_TEMPLATE_PARM \
9076e292
JM
2274 ? TEMPLATE_TEMPLATE_PARM_TEMPLATE_INFO (NODE) : \
2275 (TYPE_LANG_SPECIFIC (NODE) \
2276 ? CLASSTYPE_TEMPLATE_INFO (NODE) \
2277 : NULL_TREE)))
ed44da02
MM
2278
2279/* Set the template information for an ENUMERAL_, RECORD_, or
2280 UNION_TYPE to VAL. */
bb20cc46
AJ
2281#define SET_TYPE_TEMPLATE_INFO(NODE, VAL) \
2282 (TREE_CODE (NODE) == ENUMERAL_TYPE \
2283 ? (ENUM_TEMPLATE_INFO (NODE) = VAL) \
ed44da02
MM
2284 : (CLASSTYPE_TEMPLATE_INFO (NODE) = VAL))
2285
5566b478
MS
2286#define TI_TEMPLATE(NODE) (TREE_PURPOSE (NODE))
2287#define TI_ARGS(NODE) (TREE_VALUE (NODE))
824b9a4c 2288#define TI_PENDING_TEMPLATE_FLAG(NODE) TREE_LANG_FLAG_1 (NODE)
ed44da02 2289
b5ac18ea
MM
2290/* We use TREE_VECs to hold template arguments. If there is only one
2291 level of template arguments, then the TREE_VEC contains the
2292 arguments directly. If there is more than one level of template
2293 arguments, then each entry in the TREE_VEC is itself a TREE_VEC,
2294 containing the template arguments for a single level. The first
2295 entry in the outer TREE_VEC is the outermost level of template
bb20cc46 2296 parameters; the last is the innermost.
b5ac18ea
MM
2297
2298 It is incorrect to ever form a template argument vector containing
2299 only one level of arguments, but which is a TREE_VEC containing as
2300 its only entry the TREE_VEC for that level. */
2301
2302/* Non-zero if the template arguments is actually a vector of vectors,
2303 rather than just a vector. */
2304#define TMPL_ARGS_HAVE_MULTIPLE_LEVELS(NODE) \
2305 (NODE != NULL_TREE \
2306 && TREE_CODE (NODE) == TREE_VEC \
2307 && TREE_VEC_LENGTH (NODE) > 0 \
2308 && TREE_VEC_ELT (NODE, 0) != NULL_TREE \
2309 && TREE_CODE (TREE_VEC_ELT (NODE, 0)) == TREE_VEC)
2310
2311/* The depth of a template argument vector. When called directly by
2312 the parser, we use a TREE_LIST rather than a TREE_VEC to represent
2313 template arguments. In fact, we may even see NULL_TREE if there
2314 are no template arguments. In both of those cases, there is only
2315 one level of template arguments. */
2316#define TMPL_ARGS_DEPTH(NODE) \
2317 (TMPL_ARGS_HAVE_MULTIPLE_LEVELS (NODE) ? TREE_VEC_LENGTH (NODE) : 1)
2318
f9a7ae04
MM
2319/* The LEVELth level of the template ARGS. The outermost level of of
2320 args is level 1, not level 0. */
b5ac18ea 2321#define TMPL_ARGS_LEVEL(ARGS, LEVEL) \
bb20cc46 2322 (TMPL_ARGS_HAVE_MULTIPLE_LEVELS (ARGS) \
b5ac18ea
MM
2323 ? TREE_VEC_ELT ((ARGS), (LEVEL) - 1) : ARGS)
2324
2325/* Set the LEVELth level of the template ARGS to VAL. This macro does
2326 not work with single-level argument vectors. */
2327#define SET_TMPL_ARGS_LEVEL(ARGS, LEVEL, VAL) \
2328 (TREE_VEC_ELT ((ARGS), (LEVEL) - 1) = (VAL))
2329
2330/* Accesses the IDXth parameter in the LEVELth level of the ARGS. */
2331#define TMPL_ARG(ARGS, LEVEL, IDX) \
2332 (TREE_VEC_ELT (TMPL_ARGS_LEVEL (ARGS, LEVEL), IDX))
2333
2334/* Set the IDXth element in the LEVELth level of ARGS to VAL. This
2335 macro does not work with single-level argument vectors. */
2336#define SET_TMPL_ARG(ARGS, LEVEL, IDX, VAL) \
2337 (TREE_VEC_ELT (TREE_VEC_ELT ((ARGS), (LEVEL) - 1), (IDX)) = (VAL))
2338
2339/* Given a single level of template arguments in NODE, return the
2340 number of arguments. */
bb20cc46
AJ
2341#define NUM_TMPL_ARGS(NODE) \
2342 ((NODE) == NULL_TREE ? 0 \
2343 : (TREE_CODE (NODE) == TREE_VEC \
b5ac18ea
MM
2344 ? TREE_VEC_LENGTH (NODE) : list_length (NODE)))
2345
f9a7ae04
MM
2346/* Returns the innermost level of template arguments in ARGS. */
2347#define INNERMOST_TEMPLATE_ARGS(NODE) \
2348 (get_innermost_template_args ((NODE), 1))
2349
b5ac18ea
MM
2350/* The number of levels of template parameters given by NODE. */
2351#define TMPL_PARMS_DEPTH(NODE) \
2352 (TREE_INT_CST_HIGH (TREE_PURPOSE (NODE)))
2353
36a117a5
MM
2354/* The TEMPLATE_DECL instantiated or specialized by NODE. This
2355 TEMPLATE_DECL will be the immediate parent, not the most general
2356 template. For example, in:
2357
2358 template <class T> struct S { template <class U> void f(U); }
2359
2360 the FUNCTION_DECL for S<int>::f<double> will have, as its
bb20cc46 2361 DECL_TI_TEMPLATE, `template <class U> S<int>::f<U>'.
36a117a5
MM
2362
2363 As a special case, for a member friend template of a template
2364 class, this value will not be a TEMPLATE_DECL, but rather a
76e57b45
NS
2365 LOOKUP_EXPR, IDENTIFIER_NODE or OVERLOAD indicating the name of
2366 the template and any explicit template arguments provided. For
2367 example, in:
36a117a5
MM
2368
2369 template <class T> struct S { friend void f<int>(int, double); }
2370
2371 the DECL_TI_TEMPLATE will be a LOOKUP_EXPR for `f' and the
bb20cc46 2372 DECL_TI_ARGS will be {int}. */
5566b478 2373#define DECL_TI_TEMPLATE(NODE) TI_TEMPLATE (DECL_TEMPLATE_INFO (NODE))
ed44da02 2374
36a117a5
MM
2375/* The template arguments used to obtain this decl from the most
2376 general form of DECL_TI_TEMPLATE. For the example given for
2377 DECL_TI_TEMPLATE, the DECL_TI_ARGS will be {int, double}. These
2378 are always the full set of arguments required to instantiate this
2379 declaration from the most general template specialized here. */
5566b478
MS
2380#define DECL_TI_ARGS(NODE) TI_ARGS (DECL_TEMPLATE_INFO (NODE))
2381#define CLASSTYPE_TI_TEMPLATE(NODE) TI_TEMPLATE (CLASSTYPE_TEMPLATE_INFO (NODE))
2382#define CLASSTYPE_TI_ARGS(NODE) TI_ARGS (CLASSTYPE_TEMPLATE_INFO (NODE))
bb20cc46 2383#define ENUM_TI_TEMPLATE(NODE) \
ed44da02
MM
2384 TI_TEMPLATE (ENUM_TEMPLATE_INFO (NODE))
2385#define ENUM_TI_ARGS(NODE) \
2386 TI_ARGS (ENUM_TEMPLATE_INFO (NODE))
2387
2388/* Like DECL_TI_TEMPLATE, but for an ENUMERAL_, RECORD_, or UNION_TYPE. */
2389#define TYPE_TI_TEMPLATE(NODE) \
2390 (TI_TEMPLATE (TYPE_TEMPLATE_INFO (NODE)))
2391
59026e79 2392/* Like DECL_TI_ARGS, but for an ENUMERAL_, RECORD_, or UNION_TYPE. */
ed44da02
MM
2393#define TYPE_TI_ARGS(NODE) \
2394 (TI_ARGS (TYPE_TEMPLATE_INFO (NODE)))
2395
98c1c668 2396#define INNERMOST_TEMPLATE_PARMS(NODE) TREE_VALUE(NODE)
5566b478 2397
6ba89f8e
MM
2398/* Nonzero if the NODE corresponds to the template parameters for a
2399 member template, whose inline definition is being processed after
2400 the class definition is complete. */
cae40af6
JM
2401#define TEMPLATE_PARMS_FOR_INLINE(NODE) TREE_LANG_FLAG_1 (NODE)
2402
59026e79
MM
2403/* In a FUNCTION_DECL, the saved language-specific per-function data. */
2404#define DECL_SAVED_FUNCTION_DATA(NODE) \
da8a66fc 2405 (DECL_LANG_SPECIFIC (FUNCTION_DECL_CHECK (NODE))->u.saved_language_function)
59026e79 2406
5566b478
MS
2407#define NEW_EXPR_USE_GLOBAL(NODE) TREE_LANG_FLAG_0 (NODE)
2408#define DELETE_EXPR_USE_GLOBAL(NODE) TREE_LANG_FLAG_0 (NODE)
2409#define DELETE_EXPR_USE_VEC(NODE) TREE_LANG_FLAG_1 (NODE)
2410#define LOOKUP_EXPR_GLOBAL(NODE) TREE_LANG_FLAG_0 (NODE)
8d08fdba 2411
e1376b00
MM
2412/* Nonzero if this AGGR_INIT_EXPR provides for initialization via a
2413 constructor call, rather than an ordinary function call. */
da8a66fc
ML
2414#define AGGR_INIT_VIA_CTOR_P(NODE) \
2415 TREE_LANG_FLAG_0 (AGGR_INIT_EXPR_CHECK (NODE))
e1376b00 2416
6757edfe
MM
2417/* The TYPE_MAIN_DECL for a class template type is a TYPE_DECL, not a
2418 TEMPLATE_DECL. This macro determines whether or not a given class
2419 type is really a template type, as opposed to an instantiation or
2420 specialization of one. */
2421#define CLASSTYPE_IS_TEMPLATE(NODE) \
2422 (CLASSTYPE_TEMPLATE_INFO (NODE) \
2423 && !CLASSTYPE_USE_TEMPLATE (NODE) \
2424 && PRIMARY_TEMPLATE_P (CLASSTYPE_TI_TEMPLATE (NODE)))
2425
45869a6c
MM
2426/* The name used by the user to name the typename type. Typically,
2427 this is an IDENTIFIER_NODE, and the same as the DECL_NAME on the
2428 corresponding TYPE_DECL. However, this may also be a
2429 TEMPLATE_ID_EXPR if we had something like `typename X::Y<T>'. */
7ddedda4 2430#define TYPENAME_TYPE_FULLNAME(NODE) TYPE_BINFO (NODE)
ca40b399 2431
f181d4ae
MM
2432/* Nonzero if NODE is an implicit typename. */
2433#define IMPLICIT_TYPENAME_P(NODE) \
2434 (TREE_CODE (NODE) == TYPENAME_TYPE && TREE_TYPE (NODE))
2435
83233dca
MM
2436/* Nonzero if NODE is a TYPE_DECL that should not be visible because
2437 it is from a dependent base class. */
bb20cc46 2438#define IMPLICIT_TYPENAME_TYPE_DECL_P(NODE) \
83233dca
MM
2439 (TREE_CODE (NODE) == TYPE_DECL \
2440 && DECL_ARTIFICIAL (NODE) \
2441 && IMPLICIT_TYPENAME_P (TREE_TYPE (NODE)))
2442
cfdd0551 2443/* Nonzero in INTEGER_CST means that this int is negative by dint of
8d08fdba 2444 using a twos-complement negated operand. */
da8a66fc 2445#define TREE_NEGATED_INT(NODE) TREE_LANG_FLAG_0 (INTEGER_CST_CHECK (NODE))
8d08fdba 2446
4c6b7393
MM
2447/* Nonzero in any kind of _TYPE where conversions to base-classes may
2448 involve pointer arithmetic. If this is zero, then converting to
2449 a base-class never requires changing the value of the pointer. */
2450#define TYPE_BASE_CONVS_MAY_REQUIRE_CODE_P(NODE) (TREE_LANG_FLAG_1 (NODE))
8d08fdba 2451
4c6b7393 2452/* [class.virtual]
8d08fdba 2453
4c6b7393
MM
2454 A class that declares or inherits a virtual function is called a
2455 polymorphic class. */
2456#define TYPE_POLYMORPHIC_P(NODE) (TREE_LANG_FLAG_2 (NODE))
8d08fdba 2457
bbd15aac 2458/* Nonzero if this class has a virtual function table pointer. */
bb20cc46
AJ
2459#define TYPE_CONTAINS_VPTR_P(NODE) \
2460 (TYPE_POLYMORPHIC_P (NODE) \
2461 || (vbase_offsets_in_vtable_p () \
bbd15aac
MM
2462 && TYPE_USES_VIRTUAL_BASECLASSES (NODE)))
2463
d2ad151f
PB
2464extern int flag_new_for_scope;
2465
2466/* This flag is true of a local VAR_DECL if it was declared in a for
e92cc029 2467 statement, but we are no longer in the scope of the for. */
da8a66fc 2468#define DECL_DEAD_FOR_LOCAL(NODE) DECL_LANG_FLAG_7 (VAR_DECL_CHECK (NODE))
d2ad151f
PB
2469
2470/* This flag is set on a VAR_DECL that is a DECL_DEAD_FOR_LOCAL
2471 if we already emitted a warning about using it. */
da8a66fc 2472#define DECL_ERROR_REPORTED(NODE) DECL_LANG_FLAG_0 (VAR_DECL_CHECK (NODE))
d2ad151f 2473
cd9f6678
MM
2474/* Nonzero if NODE is a FUNCTION_DECL (for a function with global
2475 scope) declared in a local scope. */
2476#define DECL_LOCAL_FUNCTION_P(NODE) \
2477 DECL_LANG_FLAG_0 (FUNCTION_DECL_CHECK (NODE))
935d1834
ZW
2478
2479/* Nonzero if NODE is a FUNCTION_DECL for a built-in function, and we have
2480 not yet seen a prototype for that function. */
cc057ef3 2481#define DECL_ANTICIPATED(NODE) \
97ba1e3c 2482 (DECL_LANG_SPECIFIC (DECL_CHECK (NODE))->decl_flags.anticipated_p)
cd9f6678 2483
8d08fdba
MS
2484/* Record whether a typedef for type `int' was actually `signed int'. */
2485#define C_TYPEDEF_EXPLICITLY_SIGNED(exp) DECL_LANG_FLAG_1 ((exp))
2486
46e8c075
MM
2487/* In a FUNCTION_DECL, nonzero if the function cannot be inlined. */
2488#define DECL_UNINLINABLE(NODE) \
721c3b42 2489 (DECL_LANG_SPECIFIC (NODE)->decl_flags.uninlinable)
46e8c075 2490
ad50e811
MM
2491/* Returns non-zero if DECL has external linkage, as specified by the
2492 language standard. (This predicate may hold even when the
2493 corresponding entity is not actually given external linkage in the
2494 object file; see decl_linkage for details.) */
2495#define DECL_EXTERNAL_LINKAGE_P(DECL) \
2496 (decl_linkage (DECL) == lk_external)
2497
2986ae00
MS
2498#define INTEGRAL_CODE_P(CODE) \
2499 (CODE == INTEGER_TYPE || CODE == ENUMERAL_TYPE || CODE == BOOLEAN_TYPE)
a7a64a77
MM
2500
2501/* [basic.fundamental]
2502
2503 Types bool, char, wchar_t, and the signed and unsigned integer types
bb20cc46 2504 are collectively called integral types.
a7a64a77
MM
2505
2506 Note that INTEGRAL_TYPE_P, as defined in tree.h, allows enumeration
2507 types as well, which is incorrect in C++. */
bb20cc46
AJ
2508#define CP_INTEGRAL_TYPE_P(TYPE) \
2509 (TREE_CODE ((TYPE)) == BOOLEAN_TYPE \
a7a64a77
MM
2510 || TREE_CODE ((TYPE)) == INTEGER_TYPE)
2511
2512/* [basic.fundamental]
2513
2514 Integral and floating types are collectively called arithmetic
2515 types. */
2516#define ARITHMETIC_TYPE_P(TYPE) \
2517 (CP_INTEGRAL_TYPE_P (TYPE) || TREE_CODE (TYPE) == REAL_TYPE)
2986ae00 2518
8d08fdba
MS
2519/* Nonzero for _TYPE means that the _TYPE defines
2520 at least one constructor. */
2521#define TYPE_HAS_CONSTRUCTOR(NODE) (TYPE_LANG_FLAG_1(NODE))
2522
2523/* When appearing in an INDIRECT_REF, it means that the tree structure
2524 underneath is actually a call to a constructor. This is needed
2525 when the constructor must initialize local storage (which can
2526 be automatically destroyed), rather than allowing it to allocate
2527 space from the heap.
2528
2529 When appearing in a SAVE_EXPR, it means that underneath
2530 is a call to a constructor.
2531
2532 When appearing in a CONSTRUCTOR, it means that it was
2533 a GNU C constructor expression.
2534
2535 When appearing in a FIELD_DECL, it means that this field
2536 has been duly initialized in its constructor. */
2537#define TREE_HAS_CONSTRUCTOR(NODE) (TREE_LANG_FLAG_4(NODE))
2538
8452b1d3
JM
2539#define EMPTY_CONSTRUCTOR_P(NODE) (TREE_CODE (NODE) == CONSTRUCTOR \
2540 && CONSTRUCTOR_ELTS (NODE) == NULL_TREE \
2541 && ! TREE_HAS_CONSTRUCTOR (NODE))
a3203465 2542
8d08fdba
MS
2543/* Nonzero for _TYPE means that the _TYPE defines a destructor. */
2544#define TYPE_HAS_DESTRUCTOR(NODE) (TYPE_LANG_FLAG_2(NODE))
2545
f30432d7
MS
2546/* Nonzero means that an object of this type can not be initialized using
2547 an initializer list. */
2548#define CLASSTYPE_NON_AGGREGATE(NODE) \
8012c983 2549 (TYPE_LANG_SPECIFIC (NODE)->non_aggregate)
f30432d7
MS
2550#define TYPE_NON_AGGREGATE_CLASS(NODE) \
2551 (IS_AGGR_TYPE (NODE) && CLASSTYPE_NON_AGGREGATE (NODE))
2552
8d08fdba 2553/* Nonzero if there is a user-defined X::op=(x&) for this class. */
8012c983
MM
2554#define TYPE_HAS_REAL_ASSIGN_REF(NODE) (TYPE_LANG_SPECIFIC(NODE)->has_real_assign_ref)
2555#define TYPE_HAS_COMPLEX_ASSIGN_REF(NODE) (TYPE_LANG_SPECIFIC(NODE)->has_complex_assign_ref)
2556#define TYPE_HAS_ABSTRACT_ASSIGN_REF(NODE) (TYPE_LANG_SPECIFIC(NODE)->has_abstract_assign_ref)
2557#define TYPE_HAS_COMPLEX_INIT_REF(NODE) (TYPE_LANG_SPECIFIC(NODE)->has_complex_init_ref)
8d08fdba 2558
834c6dff 2559/* Nonzero if TYPE has a trivial destructor. From [class.dtor]:
bb20cc46 2560
834c6dff
MM
2561 A destructor is trivial if it is an implicitly declared
2562 destructor and if:
2563
2564 - all of the direct base classes of its class have trivial
bb20cc46 2565 destructors,
834c6dff
MM
2566
2567 - for all of the non-static data members of its class that are
bb20cc46 2568 of class type (or array thereof), each such class has a
834c6dff
MM
2569 trivial destructor. */
2570#define TYPE_HAS_TRIVIAL_DESTRUCTOR(NODE) \
2571 (!TYPE_HAS_NONTRIVIAL_DESTRUCTOR (NODE))
2572
2573/* Nonzero for _TYPE node means that this type does not have a trivial
2574 destructor. Therefore, destroying an object of this type will
2575 involve a call to a destructor. This can apply to objects of
2576 ARRAY_TYPE is the type of the elements needs a destructor. */
2577#define TYPE_HAS_NONTRIVIAL_DESTRUCTOR(NODE) \
2578 (TYPE_LANG_FLAG_4(NODE))
8d08fdba 2579
e8abc66f
MS
2580/* Nonzero for class type means that initialization of this type can use
2581 a bitwise copy. */
2582#define TYPE_HAS_TRIVIAL_INIT_REF(NODE) \
2583 (TYPE_HAS_INIT_REF (NODE) && ! TYPE_HAS_COMPLEX_INIT_REF (NODE))
2584
2585/* Nonzero for class type means that assignment of this type can use
2586 a bitwise copy. */
2587#define TYPE_HAS_TRIVIAL_ASSIGN_REF(NODE) \
2588 (TYPE_HAS_ASSIGN_REF (NODE) && ! TYPE_HAS_COMPLEX_ASSIGN_REF (NODE))
2589
c11b6f21
MS
2590#define TYPE_PTRMEM_P(NODE) \
2591 (TREE_CODE (NODE) == POINTER_TYPE \
2592 && TREE_CODE (TREE_TYPE (NODE)) == OFFSET_TYPE)
2593#define TYPE_PTR_P(NODE) \
2594 (TREE_CODE (NODE) == POINTER_TYPE \
2595 && TREE_CODE (TREE_TYPE (NODE)) != OFFSET_TYPE)
2596#define TYPE_PTROB_P(NODE) \
2597 (TYPE_PTR_P (NODE) && TREE_CODE (TREE_TYPE (NODE)) != FUNCTION_TYPE \
2598 && TREE_CODE (TREE_TYPE (NODE)) != VOID_TYPE)
2599#define TYPE_PTROBV_P(NODE) \
2600 (TYPE_PTR_P (NODE) && TREE_CODE (TREE_TYPE (NODE)) != FUNCTION_TYPE)
2601#define TYPE_PTRFN_P(NODE) \
2602 (TREE_CODE (NODE) == POINTER_TYPE \
2603 && TREE_CODE (TREE_TYPE (NODE)) == FUNCTION_TYPE)
2604
8d08fdba 2605/* Nonzero for _TYPE node means that this type is a pointer to member
e92cc029 2606 function type. */
83e9506e
RH
2607#define TYPE_PTRMEMFUNC_P(NODE) \
2608 (TREE_CODE(NODE) == RECORD_TYPE \
2609 && TYPE_LANG_SPECIFIC(NODE) \
2610 && TYPE_PTRMEMFUNC_FLAG (NODE))
2611
e08a8f45 2612#define TYPE_PTRMEMFUNC_FLAG(NODE) \
8012c983 2613 (TYPE_LANG_SPECIFIC(NODE)->ptrmemfunc_flag)
e08a8f45 2614
19420d00
NS
2615/* Indicates when overload resolution may resolve to a pointer to
2616 member function. [expr.unary.op]/3 */
2617#define PTRMEM_OK_P(NODE) TREE_LANG_FLAG_0 (NODE)
2618
e08a8f45
MM
2619/* A pointer-to-function member type looks like:
2620
2621 struct {
2622 short __delta;
2623 short __index;
2624 union {
2625 P __pfn;
2626 short __delta2;
2627 } __pfn_or_delta2;
2628 };
2629
2630 where P is a POINTER_TYPE to a METHOD_TYPE appropriate for the
2631 pointer to member. The fields are used as follows:
2632
2633 If __INDEX is -1, then the function to call is non-virtual, and
2634 is located at the address given by __PFN.
2635
2636 If __INDEX is zero, then this a NULL pointer-to-member.
2637
2638 Otherwise, the function to call is virtual. Then, __DELTA2 gives
2639 the offset from an instance of the object to the virtual function
2640 table, and __INDEX - 1 is the index into the vtable to use to
2641 find the function.
2642
2643 The value to use for the THIS parameter is the address of the
2644 object plus __DELTA.
2645
2646 For example, given:
2647
2648 struct B1 {
2649 int i;
2650 };
2651
2652 struct B2 {
2653 double d;
2654 void f();
2655 };
2656
2657 struct S : public B1, B2 {};
2658
2659 the pointer-to-member for `&S::f' looks like:
2660
2661 { 4, -1, { &f__2B2 } };
2662
2663 The `4' means that given an `S*' you have to add 4 bytes to get to
2664 the address of the `B2*'. Then, the -1 indicates that this is a
2665 non-virtual function. Of course, `&f__2B2' is the name of that
2666 function.
2667
adecb3f4 2668 (Of course, the exact values may differ depending on the mangling
bb20cc46 2669 scheme, sizes of types, and such.).
c7e266a6
MM
2670
2671 Under the new ABI, we do:
2672
2673 struct {
2674 __P __pfn;
2675 ptrdiff_t __delta;
2676 };
2677
2678 (We don't need DELTA2, because the vtable is always the first thing
2679 in the object.) If the function is virtual, then PFN is one plus
2680 twice the index into the vtable; otherwise, it is just a pointer to
2681 the function. */
bb20cc46 2682
8d08fdba
MS
2683/* Get the POINTER_TYPE to the METHOD_TYPE associated with this
2684 pointer to member function. TYPE_PTRMEMFUNC_P _must_ be true,
e92cc029 2685 before using this macro. */
c7e266a6
MM
2686#define TYPE_PTRMEMFUNC_FN_TYPE(NODE) \
2687 (flag_new_abi \
2688 ? (TREE_TYPE (TYPE_FIELDS (NODE))) \
2689 : (TREE_TYPE (TYPE_FIELDS (TREE_TYPE (TREE_CHAIN (TREE_CHAIN (TYPE_FIELDS (NODE))))))))
ceab47eb
MM
2690
2691/* Returns `A' for a type like `int (A::*)(double)' */
2692#define TYPE_PTRMEMFUNC_OBJECT_TYPE(NODE) \
2693 TYPE_METHOD_BASETYPE (TREE_TYPE (TYPE_PTRMEMFUNC_FN_TYPE (NODE)))
2694
38e01259 2695/* These are use to manipulate the canonical RECORD_TYPE from the
e92cc029 2696 hashed POINTER_TYPE, and can only be used on the POINTER_TYPE. */
8d08fdba
MS
2697#define TYPE_GET_PTRMEMFUNC_TYPE(NODE) ((tree)TYPE_LANG_SPECIFIC(NODE))
2698#define TYPE_SET_PTRMEMFUNC_TYPE(NODE, VALUE) (TYPE_LANG_SPECIFIC(NODE) = ((struct lang_type *)(void*)(VALUE)))
e92cc029 2699/* These are to get the delta2 and pfn fields from a TYPE_PTRMEMFUNC_P. */
e08a8f45
MM
2700#define DELTA2_FROM_PTRMEMFUNC(NODE) delta2_from_ptrmemfunc ((NODE))
2701#define PFN_FROM_PTRMEMFUNC(NODE) pfn_from_ptrmemfunc ((NODE))
8d08fdba 2702
f71f87f9
MM
2703/* For a pointer-to-member type of the form `T X::*', this is `X'. */
2704#define TYPE_PTRMEM_CLASS_TYPE(NODE) \
2705 (TYPE_PTRMEM_P ((NODE)) \
2706 ? TYPE_OFFSET_BASETYPE (TREE_TYPE ((NODE))) \
2707 : TYPE_PTRMEMFUNC_OBJECT_TYPE ((NODE)))
2708
2709/* For a pointer-to-member type of the form `T X::*', this is `T'. */
2710#define TYPE_PTRMEM_POINTED_TO_TYPE(NODE) \
2711 (TYPE_PTRMEM_P ((NODE)) \
2712 ? TREE_TYPE (TREE_TYPE (NODE)) \
2713 : TREE_TYPE (TYPE_PTRMEMFUNC_FN_TYPE ((NODE))))
2714
61a127b3
MM
2715/* For a pointer-to-member constant `X::Y' this is the RECORD_TYPE for
2716 `X'. */
f71f87f9 2717#define PTRMEM_CST_CLASS(NODE) \
da8a66fc 2718 TYPE_PTRMEM_CLASS_TYPE (TREE_TYPE (PTRMEM_CST_CHECK (NODE)))
61a127b3 2719
bb20cc46 2720/* For a pointer-to-member constant `X::Y' this is the _DECL for
61a127b3 2721 `Y'. */
da8a66fc 2722#define PTRMEM_CST_MEMBER(NODE) (((ptrmem_cst_t)PTRMEM_CST_CHECK (NODE))->member)
61a127b3 2723
faae18ab 2724/* Nonzero for VAR_DECL and FUNCTION_DECL node means that `extern' was
07c88314
MM
2725 specified in its declaration. This can also be set for an
2726 erroneously declared PARM_DECL. */
da8a66fc 2727#define DECL_THIS_EXTERN(NODE) \
07c88314 2728 DECL_LANG_FLAG_2 (VAR_FUNCTION_OR_PARM_DECL_CHECK (NODE))
8d08fdba 2729
faae18ab 2730/* Nonzero for VAR_DECL and FUNCTION_DECL node means that `static' was
07c88314
MM
2731 specified in its declaration. This can also be set for an
2732 erroneously declared PARM_DECL. */
da8a66fc 2733#define DECL_THIS_STATIC(NODE) \
07c88314 2734 DECL_LANG_FLAG_6 (VAR_FUNCTION_OR_PARM_DECL_CHECK (NODE))
faae18ab 2735
6bdb8141
JM
2736/* Nonzero if TYPE is an anonymous union or struct type. We have to use a
2737 flag for this because "A union for which objects or pointers are
2738 declared is not an anonymous union" [class.union]. */
2739#define ANON_AGGR_TYPE_P(NODE) \
8012c983 2740 (CLASS_TYPE_P (NODE) && TYPE_LANG_SPECIFIC (NODE)->anon_aggr)
6bdb8141 2741#define SET_ANON_AGGR_TYPE_P(NODE) \
8012c983 2742 (TYPE_LANG_SPECIFIC (NODE)->anon_aggr = 1)
67ffc812 2743
1e30f9b4
MM
2744/* Nonzero if TYPE is an anonymous union type. */
2745#define ANON_UNION_TYPE_P(NODE) \
2746 (TREE_CODE (NODE) == UNION_TYPE && ANON_AGGR_TYPE_P (NODE))
2747
8d08fdba
MS
2748#define UNKNOWN_TYPE LANG_TYPE
2749
2750/* Define fields and accessors for nodes representing declared names. */
2751
8012c983 2752#define TYPE_WAS_ANONYMOUS(NODE) (TYPE_LANG_SPECIFIC (NODE)->was_anonymous)
8d08fdba
MS
2753
2754/* C++: all of these are overloaded! These apply only to TYPE_DECLs. */
f84b4be9
JM
2755
2756/* The format of each node in the DECL_FRIENDLIST is as follows:
2757
2758 The TREE_PURPOSE will be the name of a function, i.e., an
2759 IDENTIFIER_NODE. The TREE_VALUE will be itself a TREE_LIST, the
2760 list of functions with that name which are friends. The
2761 TREE_PURPOSE of each node in this sublist will be error_mark_node,
2762 if the function was declared a friend individually, in which case
2763 the TREE_VALUE will be the function_decl. If, however, all
2764 functions with a given name in a class were declared to be friends,
2765 the TREE_PUROSE will be the class type, and the TREE_VALUE will be
2766 NULL_TREE. */
8d08fdba 2767#define DECL_FRIENDLIST(NODE) (DECL_INITIAL (NODE))
6a629cac
MM
2768#define FRIEND_NAME(LIST) (TREE_PURPOSE (LIST))
2769#define FRIEND_DECLS(LIST) (TREE_VALUE (LIST))
8d08fdba 2770
2036a15c
MM
2771/* The DECL_ACCESS, if non-NULL, is a TREE_LIST. The TREE_PURPOSE of
2772 each node is a type; the TREE_VALUE is the access granted for this
2773 DECL in that type. The DECL_ACCESS is set by access declarations.
2774 For example, if a member that would normally be public in a
2775 derived class is made protected, then the derived class and the
2776 protected_access_node will appear in the DECL_ACCESS for the node. */
af3b4e59
MM
2777#define DECL_ACCESS(NODE) (DECL_LANG_SPECIFIC(NODE)->decl_flags.u2.access)
2778
2779/* Nonzero if the FUNCTION_DECL is a global constructor. */
2780#define DECL_GLOBAL_CTOR_P(NODE) \
2781 (DECL_LANG_SPECIFIC ((NODE))->decl_flags.global_ctor_p)
2782
2783/* Nonzero if the FUNCTION_DECL is a global destructor. */
2784#define DECL_GLOBAL_DTOR_P(NODE) \
2785 (DECL_LANG_SPECIFIC ((NODE))->decl_flags.global_dtor_p)
2786
2787/* If DECL_GLOBAL_CTOR_P or DECL_GLOBAL_DTOR_P holds, this macro
2788 returns the initialization priority for the function. Constructors
2789 with lower numbers should be run first. Destructors should be run
2790 in the reverse order of constructors. */
2791#define GLOBAL_INIT_PRIORITY(NODE) \
2792 (DECL_LANG_SPECIFIC ((NODE))->decl_flags.u2.init_priority)
8d08fdba 2793
8d08fdba 2794/* Accessor macros for C++ template decl nodes. */
f84b4be9
JM
2795
2796/* The DECL_TEMPLATE_PARMS are a list. The TREE_PURPOSE of each node
36a117a5
MM
2797 is a INT_CST whose TREE_INT_CST_HIGH indicates the level of the
2798 template parameters, with 1 being the outermost set of template
2799 parameters. The TREE_VALUE is a vector, whose elements are the
2800 template parameters at each level. Each element in the vector is a
2801 TREE_LIST, whose TREE_VALUE is a PARM_DECL (if the parameter is a
2802 non-type parameter), or a TYPE_DECL (if the parameter is a type
2803 parameter). The TREE_PURPOSE is the default value, if any. The
2804 TEMPLATE_PARM_INDEX for the parameter is avilable as the
2805 DECL_INITIAL (for a PARM_DECL) or as the TREE_TYPE (for a
2806 TYPE_DECL). */
8d08fdba 2807#define DECL_TEMPLATE_PARMS(NODE) DECL_ARGUMENTS(NODE)
98c1c668
JM
2808#define DECL_INNERMOST_TEMPLATE_PARMS(NODE) \
2809 INNERMOST_TEMPLATE_PARMS (DECL_TEMPLATE_PARMS (NODE))
2810#define DECL_NTPARMS(NODE) \
2811 TREE_VEC_LENGTH (DECL_INNERMOST_TEMPLATE_PARMS (NODE))
8d08fdba 2812/* For function, method, class-data templates. */
17aec3eb 2813#define DECL_TEMPLATE_RESULT(NODE) DECL_RESULT_FLD(NODE)
36a117a5
MM
2814/* For a static member variable template, the
2815 DECL_TEMPLATE_INSTANTIATIONS list contains the explicitly and
2816 implicitly generated instantiations of the variable. There are no
2817 partial instantiations of static member variables, so all of these
2818 will be full instantiations.
2819
2820 For a class template the DECL_TEMPLATE_INSTANTIATIONS lists holds
2821 all instantiations and specializations of the class type, including
2822 partial instantiations and partial specializations.
2823
2824 In both cases, the TREE_PURPOSE of each node contains the arguments
2825 used; the TREE_VALUE contains the generated variable. The template
2826 arguments are always complete. For example, given:
2827
2828 template <class T> struct S1 {
2829 template <class U> struct S2 {};
2830 template <class U> struct S2<U*> {};
2831 };
2832
2833 the record for the partial specialization will contain, as its
2834 argument list, { {T}, {U*} }, and will be on the
2835 DECL_TEMPLATE_INSTANTIATIONS list for `template <class T> template
2836 <class U> struct S1<T>::S2'.
2837
2838 This list is not used for function templates. */
8d08fdba 2839#define DECL_TEMPLATE_INSTANTIATIONS(NODE) DECL_VINDEX(NODE)
36a117a5
MM
2840/* For a function template, the DECL_TEMPLATE_SPECIALIZATIONS lists
2841 contains all instantiations and specializations of the function,
2842 including partial instantiations. For a partial instantiation
2843 which is a specialization, this list holds only full
2844 specializations of the template that are instantiations of the
2845 partial instantiation. For example, given:
2846
2847 template <class T> struct S {
2848 template <class U> void f(U);
bb20cc46 2849 template <> void f(T);
36a117a5
MM
2850 };
2851
2852 the `S<int>::f<int>(int)' function will appear on the
2853 DECL_TEMPLATE_SPECIALIZATIONS list for both `template <class T>
2854 template <class U> void S<T>::f(U)' and `template <class T> void
2855 S<int>::f(T)'. In the latter case, however, it will have only the
2856 innermost set of arguments (T, in this case). The DECL_TI_TEMPLATE
2857 for the function declaration will point at the specialization, not
2858 the fully general template.
2859
2860 For a class template, this list contains the partial
2861 specializations of this template. (Full specializations are not
2862 recorded on this list.) The TREE_PURPOSE holds the innermost
2863 arguments used in the partial specialization (e.g., for `template
2864 <class T> struct S<T*, int>' this will be `T*'.) The TREE_VALUE
2865 holds the innermost template parameters for the specialization
2866 (e.g., `T' in the example above.) The TREE_TYPE is the _TYPE node
2867 for the partial specialization.
2868
2869 This list is not used for static variable templates. */
2870#define DECL_TEMPLATE_SPECIALIZATIONS(NODE) DECL_SIZE(NODE)
5566b478 2871
50714e79 2872/* Nonzero for a DECL which is actually a template parameter. */
bb20cc46 2873#define DECL_TEMPLATE_PARM_P(NODE) \
cd9f6678
MM
2874 (DECL_LANG_FLAG_0 (NODE) \
2875 && (TREE_CODE (NODE) == CONST_DECL \
2876 || TREE_CODE (NODE) == TYPE_DECL \
2877 || TREE_CODE (NODE) == TEMPLATE_DECL))
2878
2879/* Mark NODE as a template parameter. */
2880#define SET_DECL_TEMPLATE_PARM_P(NODE) \
2881 (DECL_LANG_FLAG_0 (NODE) = 1)
50714e79 2882
cd9f6678 2883/* Nonzero if NODE is a template template parameter. */
73b0fce8 2884#define DECL_TEMPLATE_TEMPLATE_PARM_P(NODE) \
50714e79 2885 (TREE_CODE (NODE) == TEMPLATE_DECL && DECL_TEMPLATE_PARM_P (NODE))
73b0fce8 2886
5566b478
MS
2887#define DECL_FUNCTION_TEMPLATE_P(NODE) \
2888 (TREE_CODE (NODE) == TEMPLATE_DECL \
2889 && TREE_CODE (DECL_TEMPLATE_RESULT (NODE)) == FUNCTION_DECL)
2890
6757edfe
MM
2891/* Nonzero for a DECL that represents a template class. */
2892#define DECL_CLASS_TEMPLATE_P(NODE) \
2893 (TREE_CODE (NODE) == TEMPLATE_DECL \
2894 && TREE_CODE (DECL_TEMPLATE_RESULT (NODE)) == TYPE_DECL \
2895 && !DECL_TEMPLATE_TEMPLATE_PARM_P (NODE))
2896
35acd3f2
MM
2897/* Nonzero if NODE which declares a type. */
2898#define DECL_DECLARES_TYPE_P(NODE) \
2899 (TREE_CODE (NODE) == TYPE_DECL || DECL_CLASS_TEMPLATE_P (NODE))
2900
9188c363
MM
2901/* Nonzero if NODE is the typedef implicitly generated for a type when
2902 the type is declared. (In C++, `struct S {};' is roughly equivalent
2903 to `struct S {}; typedef struct S S;' in C. This macro will hold
2904 for the typedef indicated in this example. Note that in C++, there
2905 is a second implicit typedef for each class, in the scope of `S'
99a6c6f4 2906 itself, so that you can say `S::S'. This macro does *not* hold for
9188c363
MM
2907 those typedefs. */
2908#define DECL_IMPLICIT_TYPEDEF_P(NODE) \
2909 (TREE_CODE ((NODE)) == TYPE_DECL && DECL_LANG_FLAG_2 ((NODE)))
2910#define SET_DECL_IMPLICIT_TYPEDEF_P(NODE) \
2911 (DECL_LANG_FLAG_2 ((NODE)) = 1)
2912
93cdc044
JM
2913/* A `primary' template is one that has its own template header. A
2914 member function of a class template is a template, but not primary.
6757edfe
MM
2915 A member template is primary. Friend templates are primary, too. */
2916
2917/* Returns the primary template corresponding to these parameters. */
2918#define DECL_PRIMARY_TEMPLATE(NODE) \
2919 (TREE_TYPE (DECL_INNERMOST_TEMPLATE_PARMS (NODE)))
2920
2921/* Returns non-zero if NODE is a primary template. */
2922#define PRIMARY_TEMPLATE_P(NODE) (DECL_PRIMARY_TEMPLATE (NODE) == NODE)
5566b478
MS
2923
2924#define CLASSTYPE_TEMPLATE_LEVEL(NODE) \
2925 (TREE_INT_CST_HIGH (TREE_PURPOSE (CLASSTYPE_TI_TEMPLATE (NODE))))
8d08fdba 2926
a0a33927
MS
2927/* Indicates whether or not (and how) a template was expanded for this
2928 FUNCTION_DECL or VAR_DECL.
2929 0=normal declaration, e.g. int min (int, int);
2930 1=implicit template instantiation
2931 2=explicit template specialization, e.g. int min<int> (int, int);
e92cc029 2932 3=explicit template instantiation, e.g. template int min<int> (int, int); */
a0a33927
MS
2933#define DECL_USE_TEMPLATE(NODE) (DECL_LANG_SPECIFIC(NODE)->decl_flags.use_template)
2934
2935#define DECL_TEMPLATE_INSTANTIATION(NODE) (DECL_USE_TEMPLATE (NODE) & 1)
2936#define CLASSTYPE_TEMPLATE_INSTANTIATION(NODE) \
2937 (CLASSTYPE_USE_TEMPLATE (NODE) & 1)
2938
2939#define DECL_TEMPLATE_SPECIALIZATION(NODE) (DECL_USE_TEMPLATE (NODE) == 2)
2940#define SET_DECL_TEMPLATE_SPECIALIZATION(NODE) (DECL_USE_TEMPLATE (NODE) = 2)
370af2d5 2941#define CLASSTYPE_TEMPLATE_SPECIALIZATION(NODE) \
a0a33927 2942 (CLASSTYPE_USE_TEMPLATE (NODE) == 2)
370af2d5 2943#define SET_CLASSTYPE_TEMPLATE_SPECIALIZATION(NODE) \
a0a33927
MS
2944 (CLASSTYPE_USE_TEMPLATE (NODE) = 2)
2945
2946#define DECL_IMPLICIT_INSTANTIATION(NODE) (DECL_USE_TEMPLATE (NODE) == 1)
2947#define SET_DECL_IMPLICIT_INSTANTIATION(NODE) (DECL_USE_TEMPLATE (NODE) = 1)
2948#define CLASSTYPE_IMPLICIT_INSTANTIATION(NODE) \
2949 (CLASSTYPE_USE_TEMPLATE(NODE) == 1)
2950#define SET_CLASSTYPE_IMPLICIT_INSTANTIATION(NODE) \
2951 (CLASSTYPE_USE_TEMPLATE(NODE) = 1)
2952
2953#define DECL_EXPLICIT_INSTANTIATION(NODE) (DECL_USE_TEMPLATE (NODE) == 3)
2954#define SET_DECL_EXPLICIT_INSTANTIATION(NODE) (DECL_USE_TEMPLATE (NODE) = 3)
2955#define CLASSTYPE_EXPLICIT_INSTANTIATION(NODE) \
2956 (CLASSTYPE_USE_TEMPLATE(NODE) == 3)
2957#define SET_CLASSTYPE_EXPLICIT_INSTANTIATION(NODE) \
2958 (CLASSTYPE_USE_TEMPLATE(NODE) = 3)
7177d104 2959
61289ca3
MM
2960/* Non-zero if DECL is a friend function which is an instantiation
2961 from the point of view of the compiler, but not from the point of
2962 view of the language. For example given:
2963 template <class T> struct S { friend void f(T) {}; };
2964 the declaration of `void f(int)' generated when S<int> is
2965 instantiated will not be a DECL_TEMPLATE_INSTANTIATION, but will be
2966 a DECL_FRIEND_PSUEDO_TEMPLATE_INSTANTIATION. */
2967#define DECL_FRIEND_PSEUDO_TEMPLATE_INSTANTIATION(DECL) \
2968 (DECL_TEMPLATE_INFO (DECL) && !DECL_USE_TEMPLATE (DECL))
2969
4c571114
MM
2970/* Non-zero if TYPE is a partial instantiation of a template class,
2971 i.e., an instantiation whose instantiation arguments involve
2972 template types. */
2973#define PARTIAL_INSTANTIATION_P(TYPE) \
8012c983 2974 (TYPE_LANG_SPECIFIC (TYPE)->is_partial_instantiation)
4c571114 2975
39c01e4c
MM
2976/* Non-zero iff we are currently processing a declaration for an
2977 entity with its own template parameter list, and which is not a
2978 full specialization. */
2979#define PROCESSING_REAL_TEMPLATE_DECL_P() \
2980 (processing_template_decl > template_class_depth (current_class_type))
2981
73aad9b9
JM
2982/* This function may be a guiding decl for a template. */
2983#define DECL_MAYBE_TEMPLATE(NODE) DECL_LANG_FLAG_4 (NODE)
fbf1c34b
MM
2984
2985/* Nonzero if this VAR_DECL or FUNCTION_DECL has already been
2986 instantiated, i.e. its definition has been generated from the
2987 pattern given in the the template. */
da8a66fc
ML
2988#define DECL_TEMPLATE_INSTANTIATED(NODE) \
2989 DECL_LANG_FLAG_1 (VAR_OR_FUNCTION_DECL_CHECK (NODE))
fbf1c34b 2990
db5ae43f 2991/* We know what we're doing with this decl now. */
e3417fcd 2992#define DECL_INTERFACE_KNOWN(NODE) DECL_LANG_FLAG_5 (NODE)
db5ae43f 2993
faae18ab
MS
2994/* This function was declared inline. This flag controls the linkage
2995 semantics of 'inline'; whether or not the function is inlined is
2996 controlled by DECL_INLINE. */
2997#define DECL_THIS_INLINE(NODE) \
2998 (DECL_LANG_SPECIFIC (NODE)->decl_flags.declared_inline)
2999
3000/* DECL_EXTERNAL must be set on a decl until the decl is actually emitted,
3001 so that assemble_external will work properly. So we have this flag to
3002 tell us whether the decl is really not external. */
3003#define DECL_NOT_REALLY_EXTERN(NODE) \
3004 (DECL_LANG_SPECIFIC (NODE)->decl_flags.not_really_extern)
db5ae43f 3005
6b5fbb55
MS
3006#define DECL_REALLY_EXTERN(NODE) \
3007 (DECL_EXTERNAL (NODE) && ! DECL_NOT_REALLY_EXTERN (NODE))
3008
eb68cb58
MM
3009/* A thunk is a stub function.
3010
3011 A thunk is an alternate entry point for an ordinary FUNCTION_DECL.
3012 The address of the ordinary FUNCTION_DECL is given by the
3013 DECL_INITIAL, which is always an ADDR_EXPR whose operand is a
3014 FUNCTION_DECL. The job of the thunk is to adjust the `this'
3015 pointer before transferring control to the FUNCTION_DECL.
3016
3017 A thunk may perform either, or both, of the following operations:
3018
3019 o Adjust the `this' pointer by a constant offset.
3020 o Adjust the `this' pointer by looking up a vcall-offset
3021 in the vtable.
3022
3023 If both operations are performed, then the constant adjument to
3024 `this' is performed first.
3025
3026 The constant adjustment is given by THUNK_DELTA. If the
3027 vcall-offset is required, the index into the vtable is given by
3028 THUNK_VCALL_OFFSET. */
3029
c0bbf652
MM
3030/* An integer indicating how many bytes should be subtracted from the
3031 `this' pointer when this function is called. */
9df2c88c 3032#define THUNK_DELTA(DECL) (DECL_CHECK (DECL)->decl.u1.i)
8926095f 3033
193833ed 3034/* A tree indicating how many bytes should be subtracted from the
c0bbf652 3035 vtable for the `this' pointer to find the vcall offset. (The vptr
27d26ee7 3036 is always located at offset zero from the f `this' pointer.) If
193833ed 3037 NULL, then there is no vcall offset. */
6462c441
MM
3038#define THUNK_VCALL_OFFSET(DECL) \
3039 (DECL_LANG_SPECIFIC (DECL)->decl_flags.u2.vcall_offset)
c0bbf652 3040
31f8e4f3
MM
3041/* Nonzero if this thunk should be generated with the vtable that
3042 references it. */
3043#define THUNK_GENERATE_WITH_VTABLE_P(DECL) \
3044 (DECL_LANG_SPECIFIC (DECL)->decl_flags.generate_with_vtable_p)
42976354 3045
ad321293
MM
3046/* These macros provide convenient access to the various _STMT nodes
3047 created when parsing template declarations. */
da8a66fc
ML
3048#define TRY_STMTS(NODE) TREE_OPERAND (TRY_BLOCK_CHECK (NODE), 0)
3049#define TRY_HANDLERS(NODE) TREE_OPERAND (TRY_BLOCK_CHECK (NODE), 1)
d7e7759d 3050
62409b39 3051/* Nonzero if this try block is a function try block. */
da8a66fc
ML
3052#define FN_TRY_BLOCK_P(NODE) TREE_LANG_FLAG_3 (TRY_BLOCK_CHECK (NODE))
3053#define HANDLER_PARMS(NODE) TREE_OPERAND (HANDLER_CHECK (NODE), 0)
3054#define HANDLER_BODY(NODE) TREE_OPERAND (HANDLER_CHECK (NODE), 1)
da8a66fc 3055#define SUBOBJECT_CLEANUP(NODE) TREE_OPERAND (SUBOBJECT_CHECK (NODE), 0)
da8a66fc 3056#define START_CATCH_TYPE(NODE) TREE_TYPE (START_CATCH_STMT_CHECK (NODE))
59026e79 3057
d9b2d9da 3058
46e8c075
MM
3059/* Nonzero if this CTOR_STMT is for the beginning of a constructor. */
3060#define CTOR_BEGIN_P(NODE) \
3061 (TREE_LANG_FLAG_0 (CTOR_STMT_CHECK (NODE)))
3062
3063/* Nonzero if this CTOR_STMT is for the end of a constructor. */
3064#define CTOR_END_P(NODE) \
3065 (!CTOR_BEGIN_P (NODE))
3066
43f887f9
MM
3067/* The parameters for a call-declarator. */
3068#define CALL_DECLARATOR_PARMS(NODE) \
3069 (TREE_PURPOSE (TREE_OPERAND ((NODE), 1)))
3070
3071/* The cv-qualifiers for a call-declarator. */
3072#define CALL_DECLARATOR_QUALS(NODE) \
3073 (TREE_VALUE (TREE_OPERAND ((NODE), 1)))
3074
3075/* The exception-specification for a call-declarator. */
3076#define CALL_DECLARATOR_EXCEPTION_SPEC(NODE) \
3077 (TREE_TYPE ((NODE)))
3078
8d08fdba 3079/* An enumeration of the kind of tags that C++ accepts. */
6eabb241 3080enum tag_types { record_type, class_type, union_type, enum_type };
8d08fdba 3081
27b8d0cd
MM
3082/* The various kinds of lvalues we distinguish. */
3083typedef enum cp_lvalue_kind {
3084 clk_none = 0, /* Things that are not an lvalue. */
3085 clk_ordinary = 1, /* An ordinary lvalue. */
3086 clk_class = 2, /* An rvalue of class-type. */
3087 clk_bitfield = 4, /* An lvalue for a bit-field. */
3088} cp_lvalue_kind;
3089
74b846e0
MM
3090/* The kinds of scopes we recognize. */
3091typedef enum scope_kind {
3092 sk_template_parms, /* A scope for template parameters. */
3093 sk_template_spec /* A scope corresponding to a template
3094 specialization. There is never anything in
3095 this scope. */
3096} scope_kind;
3097
3098/* Various kinds of template specialization, instantiation, etc. */
3099typedef enum tmpl_spec_kind {
3100 tsk_none, /* Not a template at all. */
3101 tsk_invalid_member_spec, /* An explicit member template
3102 specialization, but the enclosing
3103 classes have not all been explicitly
3104 specialized. */
3105 tsk_invalid_expl_inst, /* An explicit instantiation containing
3106 template parameter lists. */
3107 tsk_excessive_parms, /* A template declaration with too many
3108 template parameter lists. */
3109 tsk_insufficient_parms, /* A template declaration with too few
3110 parameter lists. */
3111 tsk_template, /* A template declaration. */
3112 tsk_expl_spec, /* An explicit specialization. */
3113 tsk_expl_inst /* An explicit instantiation. */
3114} tmpl_spec_kind;
3115
c35cce41
MM
3116/* The various kinds of access. BINFO_ACCESS depends on these being
3117 two bit quantities. The numerical values are important; they are
509fc277 3118 used to initialize RTTI data structures, so changing them changes
c35cce41
MM
3119 the ABI. */
3120typedef enum access_kind {
3121 ak_none = 0, /* Inaccessible. */
3122 ak_public = 1, /* Accessible, as a `public' thing. */
3123 ak_protected = 2, /* Accessible, as a `protected' thing. */
3124 ak_private = 3 /* Accessible, as a `private' thing. */
3125} access_kind;
3126
872f37f9
MM
3127/* The various kinds of special functions. If you add to this list,
3128 you should update special_function_p as well. */
3dbc07b6 3129typedef enum special_function_kind {
872f37f9
MM
3130 sfk_none = 0, /* Not a special function. This enumeral
3131 must have value zero; see
3132 special_function_p. */
3dbc07b6 3133 sfk_constructor, /* A constructor. */
9eb71d8c
MM
3134 sfk_copy_constructor, /* A copy constructor. */
3135 sfk_assignment_operator, /* An assignment operator. */
3dbc07b6 3136 sfk_destructor, /* A destructor. */
872f37f9
MM
3137 sfk_complete_destructor, /* A destructor for complete objects. */
3138 sfk_base_destructor, /* A destructor for base subobjects. */
3139 sfk_deleting_destructor, /* A destructor for complete objects that
3140 deletes the object after it has been
3141 destroyed. */
3dbc07b6
MM
3142 sfk_conversion /* A conversion operator. */
3143} special_function_kind;
3144
ad50e811
MM
3145/* The various kinds of linkage. From [basic.link],
3146
3147 A name is said to have linkage when it might denote the same
3148 object, reference, function, type, template, namespace or value
3149 as a name introduced in another scope:
3150
3151 -- When a name has external linkage, the entity it denotes can
3152 be referred to from scopes of other translation units or from
3153 other scopes of the same translation unit.
3154
3155 -- When a name has internal linkage, the entity it denotes can
3156 be referred to by names from other scopes in the same
3157 translation unit.
3158
3159 -- When a name has no linkage, the entity it denotes cannot be
3160 referred to by names from other scopes. */
3161
3162typedef enum linkage_kind {
3163 lk_none, /* No linkage. */
3164 lk_internal, /* Internal linkage. */
3165 lk_external /* External linkage. */
3166} linkage_kind;
3167
5e76004e
NS
3168/* Bitmask flags to pass to instantiate_type. */
3169typedef enum instantiate_type_flags {
3170 itf_none = 0, /* nothing special */
3171 itf_complain = 1 << 0, /* complain about errors */
19420d00
NS
3172 itf_no_attributes = 1 << 1, /* ignore attributes on comparisons */
3173 itf_ptrmem_ok = 1 << 2, /* pointers to member ok (internal use) */
5e76004e
NS
3174} instantiate_type_flags;
3175
8d08fdba
MS
3176/* Non-zero means that if a label exists, and no other identifier
3177 applies, use the value of the label. */
3178extern int flag_labels_ok;
3179
d2c192ad
JM
3180/* Nonzero means allow Microsoft extensions without a pedwarn. */
3181extern int flag_ms_extensions;
3182
8d08fdba
MS
3183/* Non-zero means warn in function declared in derived class has the
3184 same name as a virtual in the base class, but fails to match the
3185 type signature of any virtual function in the base class. */
3186extern int warn_overloaded_virtual;
3187
dc8263bc
JM
3188/* Nonzero means warn about use of multicharacter literals. */
3189extern int warn_multichar;
3190
9018ce4d
BK
3191/* Non-zero means warn if a non-templatized friend function is
3192 declared in a templatized class. This behavior is warned about with
3193 flag_guiding_decls in do_friend. */
3194extern int warn_nontemplate_friend;
3195
8d08fdba 3196/* in c-common.c */
158991b7
KG
3197extern void declare_function_name PARAMS ((void));
3198extern void decl_attributes PARAMS ((tree, tree, tree));
3199extern void init_function_format_info PARAMS ((void));
3200extern void record_function_format PARAMS ((tree, tree, int, int, int));
3f80e6ac 3201extern void check_function_format PARAMS ((int *, tree, tree, tree));
8d08fdba
MS
3202/* Print an error message for invalid operands to arith operation CODE.
3203 NOP_EXPR is used as a special case (see truthvalue_conversion). */
158991b7
KG
3204extern void binary_op_error PARAMS ((enum tree_code));
3205extern tree canonical_type_variant PARAMS ((tree));
3206extern void c_expand_expr_stmt PARAMS ((tree));
8d08fdba 3207/* Validate the expression after `case' and apply default promotions. */
158991b7 3208extern tree check_case_value PARAMS ((tree));
8d08fdba 3209/* Concatenate a list of STRING_CST nodes into one STRING_CST. */
158991b7
KG
3210extern tree combine_strings PARAMS ((tree));
3211extern void constant_expression_warning PARAMS ((tree));
3212extern tree convert_and_check PARAMS ((tree, tree));
3213extern void overflow_warning PARAMS ((tree));
3214extern void unsigned_conversion_warning PARAMS ((tree, tree));
3215extern void c_apply_type_quals_to_decl PARAMS ((int, tree));
61a127b3 3216
8d08fdba 3217/* Read the rest of the current #-directive line. */
158991b7 3218extern char *get_directive_line PARAMS ((void));
d4dfe7d6 3219#define GET_DIRECTIVE_LINE() get_directive_line ()
a32f2771 3220
8d08fdba
MS
3221/* Subroutine of build_binary_op, used for comparison operations.
3222 See if the operands have both been converted from subword integer types
3223 and, if so, perhaps change them both back to their original type. */
158991b7 3224extern tree shorten_compare PARAMS ((tree *, tree *, tree *, enum tree_code *));
8d08fdba 3225/* Prepare expr to be an argument of a TRUTH_NOT_EXPR,
e92cc029 3226 or validate its data type for an `if' or `while' statement or ?..: exp. */
158991b7
KG
3227extern tree truthvalue_conversion PARAMS ((tree));
3228extern tree type_for_mode PARAMS ((enum machine_mode, int));
3229extern tree type_for_size PARAMS ((unsigned, int));
8d08fdba 3230
51c184be 3231/* in decl{2}.c */
8d08fdba
MS
3232/* A node that is a list (length 1) of error_mark_nodes. */
3233extern tree error_mark_list;
3234
9cd64686
MM
3235/* A list of virtual function tables we must make sure to write out. */
3236extern tree pending_vtables;
3237
700f8a87 3238/* Node for "pointer to (virtual) function".
e92cc029 3239 This may be distinct from ptr_type_node so gdb can distinguish them. */
700f8a87
MS
3240#define vfunc_ptr_type_node \
3241 (flag_vtable_thunks ? vtable_entry_type : ptr_type_node)
3242
8d08fdba 3243
8d08fdba
MS
3244/* For building calls to `delete'. */
3245extern tree integer_two_node, integer_three_node;
3246
0c8feefe
MM
3247extern tree anonymous_namespace_name;
3248
b2244c65
MM
3249/* The number of function bodies which we are currently processing.
3250 (Zero if we are at namespace scope, one inside the body of a
3251 function, two inside the body of a function in a local class, etc.) */
3252extern int function_depth;
3253
51c184be 3254/* in pt.c */
5566b478 3255
830bfa74
MM
3256/* These values are used for the `STRICT' parameter to type_unfication and
3257 fn_type_unification. Their meanings are described with the
3258 documentation for fn_type_unification. */
3259
3260typedef enum unification_kind_t {
3261 DEDUCE_CALL,
3262 DEDUCE_CONV,
3263 DEDUCE_EXACT
3264} unification_kind_t;
3265
3ae18eaf
JM
3266/* Macros for operating on a template instantation level node, represented
3267 by an EXPR_WITH_FILE_LOCATION. */
3268
3269#define TINST_DECL(NODE) EXPR_WFL_NODE (NODE)
3270#define TINST_LINE(NODE) EXPR_WFL_LINENO (NODE)
3271#define TINST_FILE(NODE) EXPR_WFL_FILENAME (NODE)
8d08fdba 3272
51c184be 3273/* in class.c */
61a127b3 3274
b4c4a9ec 3275extern int current_class_depth;
8d08fdba 3276
8d08fdba
MS
3277/* Points to the name of that function. May not be the DECL_NAME
3278 of CURRENT_FUNCTION_DECL due to overloading */
3279extern tree original_function_name;
1f6e1acc
AS
3280
3281/* An array of all local classes present in this translation unit, in
3282 declaration order. */
3283extern varray_type local_classes;
8d08fdba
MS
3284\f
3285/* Here's where we control how name mangling takes place. */
3286
3287#define OPERATOR_ASSIGN_FORMAT "__a%s"
3288#define OPERATOR_FORMAT "__%s"
3289#define OPERATOR_TYPENAME_FORMAT "__op"
8d08fdba
MS
3290
3291/* Cannot use '$' up front, because this confuses gdb
3292 (names beginning with '$' are gdb-local identifiers).
3293
3294 Note that all forms in which the '$' is significant are long enough
3295 for direct indexing (meaning that if we know there is a '$'
3296 at a particular location, we can index into the string at
3297 any other location that provides distinguishing characters). */
3298
3299/* Define NO_DOLLAR_IN_LABEL in your favorite tm file if your assembler
3300 doesn't allow '$' in symbol names. */
3301#ifndef NO_DOLLAR_IN_LABEL
3302
3303#define JOINER '$'
3304
3305#define VPTR_NAME "$v"
3306#define THROW_NAME "$eh_throw"
3307#define DESTRUCTOR_DECL_PREFIX "_$_"
3308#define AUTO_VTABLE_NAME "__vtbl$me__"
3309#define AUTO_TEMP_NAME "_$tmp_"
3310#define AUTO_TEMP_FORMAT "_$tmp_%d"
3311#define VTABLE_BASE "$vb"
486837a7 3312#define VTABLE_NAME_PREFIX (flag_vtable_thunks ? "__vt_" : "_vt$")
8d08fdba
MS
3313#define VFIELD_BASE "$vf"
3314#define VFIELD_NAME "_vptr$"
3315#define VFIELD_NAME_FORMAT "_vptr$%s"
3316#define VBASE_NAME "_vb$"
3317#define VBASE_NAME_FORMAT "_vb$%s"
3318#define STATIC_NAME_FORMAT "_%s$%s"
3319#define ANON_AGGRNAME_FORMAT "$_%d"
3320
3321#else /* NO_DOLLAR_IN_LABEL */
3322
3323#ifndef NO_DOT_IN_LABEL
3324
3325#define JOINER '.'
3326
3327#define VPTR_NAME ".v"
3328#define THROW_NAME ".eh_throw"
3329#define DESTRUCTOR_DECL_PREFIX "_._"
3330#define AUTO_VTABLE_NAME "__vtbl.me__"
3331#define AUTO_TEMP_NAME "_.tmp_"
3332#define AUTO_TEMP_FORMAT "_.tmp_%d"
3333#define VTABLE_BASE ".vb"
486837a7 3334#define VTABLE_NAME_PREFIX (flag_vtable_thunks ? "__vt_" : "_vt.")
8d08fdba
MS
3335#define VFIELD_BASE ".vf"
3336#define VFIELD_NAME "_vptr."
3337#define VFIELD_NAME_FORMAT "_vptr.%s"
3338#define VBASE_NAME "_vb."
3339#define VBASE_NAME_FORMAT "_vb.%s"
3340#define STATIC_NAME_FORMAT "_%s.%s"
3341
3342#define ANON_AGGRNAME_FORMAT "._%d"
3343
3344#else /* NO_DOT_IN_LABEL */
3345
3346#define VPTR_NAME "__vptr"
3347#define VPTR_NAME_P(ID_NODE) \
3348 (!strncmp (IDENTIFIER_POINTER (ID_NODE), VPTR_NAME, sizeof (VPTR_NAME) - 1))
3349#define THROW_NAME "__eh_throw"
3350#define DESTRUCTOR_DECL_PREFIX "__destr_"
3351#define DESTRUCTOR_NAME_P(ID_NODE) \
3352 (!strncmp (IDENTIFIER_POINTER (ID_NODE), DESTRUCTOR_DECL_PREFIX, \
3353 sizeof (DESTRUCTOR_DECL_PREFIX) - 1))
3354#define IN_CHARGE_NAME "__in_chrg"
3355#define AUTO_VTABLE_NAME "__vtbl_me__"
3356#define AUTO_TEMP_NAME "__tmp_"
3357#define TEMP_NAME_P(ID_NODE) \
3358 (!strncmp (IDENTIFIER_POINTER (ID_NODE), AUTO_TEMP_NAME, \
3359 sizeof (AUTO_TEMP_NAME) - 1))
3360#define AUTO_TEMP_FORMAT "__tmp_%d"
3361#define VTABLE_BASE "__vtb"
3362#define VTABLE_NAME "__vt_"
486837a7 3363#define VTABLE_NAME_PREFIX (flag_vtable_thunks ? "__vt_" : "_vt_")
8d08fdba
MS
3364#define VTABLE_NAME_P(ID_NODE) \
3365 (!strncmp (IDENTIFIER_POINTER (ID_NODE), VTABLE_NAME, \
3366 sizeof (VTABLE_NAME) - 1))
3367#define VFIELD_BASE "__vfb"
3368#define VFIELD_NAME "__vptr_"
3369#define VFIELD_NAME_P(ID_NODE) \
3370 (!strncmp (IDENTIFIER_POINTER (ID_NODE), VFIELD_NAME, \
3371 sizeof (VFIELD_NAME) - 1))
3372#define VFIELD_NAME_FORMAT "_vptr_%s"
3373#define VBASE_NAME "__vb_"
3374#define VBASE_NAME_P(ID_NODE) \
3375 (!strncmp (IDENTIFIER_POINTER (ID_NODE), VBASE_NAME, \
3376 sizeof (VBASE_NAME) - 1))
3377#define VBASE_NAME_FORMAT "__vb_%s"
3378#define STATIC_NAME_FORMAT "__static_%s_%s"
3379
3380#define ANON_AGGRNAME_PREFIX "__anon_"
3381#define ANON_AGGRNAME_P(ID_NODE) \
3382 (!strncmp (IDENTIFIER_POINTER (ID_NODE), ANON_AGGRNAME_PREFIX, \
3383 sizeof (ANON_AGGRNAME_PREFIX) - 1))
3384#define ANON_AGGRNAME_FORMAT "__anon_%d"
3385#define ANON_PARMNAME_FORMAT "__%d"
3386#define ANON_PARMNAME_P(ID_NODE) (IDENTIFIER_POINTER (ID_NODE)[0] == '_' \
3387 && IDENTIFIER_POINTER (ID_NODE)[1] == '_' \
3388 && IDENTIFIER_POINTER (ID_NODE)[2] <= '9')
3389
3390#endif /* NO_DOT_IN_LABEL */
3391#endif /* NO_DOLLAR_IN_LABEL */
3392
3393#define THIS_NAME "this"
3394#define DESTRUCTOR_NAME_FORMAT "~%s"
3395#define FILE_FUNCTION_PREFIX_LEN 9
fc378698
MS
3396#define CTOR_NAME "__ct"
3397#define DTOR_NAME "__dt"
8d08fdba
MS
3398
3399#define IN_CHARGE_NAME "__in_chrg"
3400
3401#define VTBL_PTR_TYPE "__vtbl_ptr_type"
3402#define VTABLE_DELTA_NAME "__delta"
3403#define VTABLE_INDEX_NAME "__index"
3404#define VTABLE_PFN_NAME "__pfn"
3405#define VTABLE_DELTA2_NAME "__delta2"
3406
bb20cc46 3407#define EXCEPTION_CLEANUP_NAME "exception cleanup"
8d08fdba 3408
23656158
MM
3409/* The name used as a prefix for VTTs. When the new ABI mangling
3410 scheme is implemented, this should be removed. */
3411
3412#define VTT_NAME_PREFIX "__vtt_"
3413
3414/* The name used as a prefix for construction vtables. */
3415
3416#define CTOR_VTBL_NAME_PREFIX "__ctorvt_"
3417
8d08fdba
MS
3418#define THIS_NAME_P(ID_NODE) (strcmp(IDENTIFIER_POINTER (ID_NODE), "this") == 0)
3419
3420#if !defined(NO_DOLLAR_IN_LABEL) || !defined(NO_DOT_IN_LABEL)
3421
3422#define VPTR_NAME_P(ID_NODE) (IDENTIFIER_POINTER (ID_NODE)[0] == JOINER \
3423 && IDENTIFIER_POINTER (ID_NODE)[1] == 'v')
3424#define DESTRUCTOR_NAME_P(ID_NODE) (IDENTIFIER_POINTER (ID_NODE)[1] == JOINER \
bb20cc46 3425 && IDENTIFIER_POINTER (ID_NODE)[2] == '_')
8d08fdba
MS
3426
3427#define VTABLE_NAME_P(ID_NODE) (IDENTIFIER_POINTER (ID_NODE)[1] == 'v' \
3428 && IDENTIFIER_POINTER (ID_NODE)[2] == 't' \
3429 && IDENTIFIER_POINTER (ID_NODE)[3] == JOINER)
3430
3431#define VBASE_NAME_P(ID_NODE) (IDENTIFIER_POINTER (ID_NODE)[1] == 'v' \
3432 && IDENTIFIER_POINTER (ID_NODE)[2] == 'b' \
3433 && IDENTIFIER_POINTER (ID_NODE)[3] == JOINER)
3434
3435#define TEMP_NAME_P(ID_NODE) (!strncmp (IDENTIFIER_POINTER (ID_NODE), AUTO_TEMP_NAME, sizeof (AUTO_TEMP_NAME)-1))
3436#define VFIELD_NAME_P(ID_NODE) (!strncmp (IDENTIFIER_POINTER (ID_NODE), VFIELD_NAME, sizeof(VFIELD_NAME)-1))
3437
3438/* For anonymous aggregate types, we need some sort of name to
3439 hold on to. In practice, this should not appear, but it should
3440 not be harmful if it does. */
3441#define ANON_AGGRNAME_P(ID_NODE) (IDENTIFIER_POINTER (ID_NODE)[0] == JOINER \
3442 && IDENTIFIER_POINTER (ID_NODE)[1] == '_')
3443#define ANON_PARMNAME_FORMAT "_%d"
3444#define ANON_PARMNAME_P(ID_NODE) (IDENTIFIER_POINTER (ID_NODE)[0] == '_' \
3445 && IDENTIFIER_POINTER (ID_NODE)[1] <= '9')
3446#endif /* !defined(NO_DOLLAR_IN_LABEL) || !defined(NO_DOT_IN_LABEL) */
35680744 3447
c8298f61 3448/* Store the vbase pointer field name for type TYPE into pointer BUF. */
bb20cc46 3449#define FORMAT_VBASE_NAME(BUF,TYPE) do { \
d8e178a0 3450 char *wbuf = (char *) alloca (TYPE_ASSEMBLER_NAME_LENGTH (TYPE) \
c8298f61 3451 + sizeof (VBASE_NAME) + 1); \
d8e178a0
KG
3452 sprintf (wbuf, VBASE_NAME_FORMAT, TYPE_ASSEMBLER_NAME_STRING (TYPE)); \
3453 (BUF) = wbuf; \
c8298f61
MH
3454} while (0)
3455
35680744
MM
3456/* Returns non-zero iff NODE is a declaration for the global function
3457 `main'. */
3458#define DECL_MAIN_P(NODE) \
eb68cb58 3459 (DECL_EXTERN_C_FUNCTION_P (NODE) \
35680744
MM
3460 && DECL_NAME (NODE) != NULL_TREE \
3461 && MAIN_NAME_P (DECL_NAME (NODE)))
3462
8d08fdba 3463\f
8d08fdba
MS
3464/* Things for handling inline functions. */
3465
9bfadf57 3466/* Negative values means we know `this' to be of static type. */
8d08fdba
MS
3467
3468extern int flag_this_is_variable;
3469
a0a33927
MS
3470/* Nonzero means do emit exported implementations of functions even if
3471 they can be inlined. */
3472
3473extern int flag_implement_inlines;
3474
8d08fdba
MS
3475/* Nonzero means templates obey #pragma interface and implementation. */
3476
3477extern int flag_external_templates;
3478
3479/* Nonzero means templates are emitted where they are instantiated. */
3480
3481extern int flag_alt_external_templates;
3482
ddd5a7c1 3483/* Nonzero means implicit template instantiations are emitted. */
a0a33927
MS
3484
3485extern int flag_implicit_templates;
3486
72b7eeff
MS
3487/* Nonzero if we want to emit defined symbols with common-like linkage as
3488 weak symbols where possible, in order to conform to C++ semantics.
3489 Otherwise, emit them as local symbols. */
3490
3491extern int flag_weak;
3492
46e8c075
MM
3493/* Nonzero if we should expand functions calls inline at the tree
3494 level, rather than at the RTL level. */
3495
3496extern int flag_inline_trees;
3497
5566b478
MS
3498/* Nonzero if we're done parsing and into end-of-file activities. */
3499
3500extern int at_eof;
3501
f444e36b
MM
3502/* Functions called along with real static constructors and destructors. */
3503
3504extern tree static_ctors;
3505extern tree static_dtors;
3506
8d08fdba
MS
3507enum overload_flags { NO_SPECIAL = 0, DTOR_FLAG, OP_FLAG, TYPENAME_FLAG };
3508
8d08fdba
MS
3509/* Some macros for char-based bitfields. */
3510#define B_SET(a,x) (a[x>>3] |= (1 << (x&7)))
3511#define B_CLR(a,x) (a[x>>3] &= ~(1 << (x&7)))
3512#define B_TST(a,x) (a[x>>3] & (1 << (x&7)))
3513
3514/* These are uses as bits in flags passed to build_method_call
3515 to control its error reporting behavior.
3516
3517 LOOKUP_PROTECT means flag access violations.
3518 LOOKUP_COMPLAIN mean complain if no suitable member function
3519 matching the arguments is found.
3520 LOOKUP_NORMAL is just a combination of these two.
8d08fdba
MS
3521 LOOKUP_NONVIRTUAL means make a direct call to the member function found
3522 LOOKUP_GLOBAL means search through the space of overloaded functions,
3523 as well as the space of member functions.
6060a796 3524 LOOKUP_ONLYCONVERTING means that non-conversion constructors are not tried.
9a3b49ac
MS
3525 DIRECT_BIND means that if a temporary is created, it should be created so
3526 that it lives as long as the current variable bindings; otherwise it
3527 only lives until the end of the complete-expression.
878cd289
MS
3528 LOOKUP_SPECULATIVELY means return NULL_TREE if we cannot find what we are
3529 after. Note, LOOKUP_COMPLAIN is checked and error messages printed
3530 before LOOKUP_SPECULATIVELY is checked.
8d08fdba
MS
3531 LOOKUP_NO_CONVERSION means that user-defined conversions are not
3532 permitted. Built-in conversions are permitted.
c73964b2 3533 LOOKUP_DESTRUCTOR means explicit call to destructor.
52c11ef6
JM
3534 LOOKUP_NO_TEMP_BIND means temporaries will not be bound to references.
3535
3536 These are used in global lookup to support elaborated types and
3537 qualifiers.
bb20cc46 3538
52c11ef6
JM
3539 LOOKUP_PREFER_TYPES means not to accept objects, and possibly namespaces.
3540 LOOKUP_PREFER_NAMESPACES means not to accept objects, and possibly types.
3541 LOOKUP_PREFER_BOTH means class-or-namespace-name.
3542 LOOKUP_TEMPLATES_EXPECTED means that class templates also count
3543 as types. */
8d08fdba
MS
3544
3545#define LOOKUP_PROTECT (1)
3546#define LOOKUP_COMPLAIN (2)
3547#define LOOKUP_NORMAL (3)
8d08fdba
MS
3548#define LOOKUP_NONVIRTUAL (8)
3549#define LOOKUP_GLOBAL (16)
8d08fdba 3550#define LOOKUP_SPECULATIVELY (64)
db5ae43f 3551#define LOOKUP_ONLYCONVERTING (128)
9a3b49ac 3552#define DIRECT_BIND (256)
8d08fdba
MS
3553#define LOOKUP_NO_CONVERSION (512)
3554#define LOOKUP_DESTRUCTOR (512)
c73964b2 3555#define LOOKUP_NO_TEMP_BIND (1024)
52c11ef6
JM
3556#define LOOKUP_PREFER_TYPES (2048)
3557#define LOOKUP_PREFER_NAMESPACES (4096)
3558#define LOOKUP_PREFER_BOTH (6144)
3559#define LOOKUP_TEMPLATES_EXPECTED (8192)
3560
3561#define LOOKUP_NAMESPACES_ONLY(f) \
3562 (((f) & LOOKUP_PREFER_NAMESPACES) && !((f) & LOOKUP_PREFER_TYPES))
3563#define LOOKUP_TYPES_ONLY(f) \
3564 (!((f) & LOOKUP_PREFER_NAMESPACES) && ((f) & LOOKUP_PREFER_TYPES))
3565#define LOOKUP_QUALIFIERS_ONLY(f) ((f) & LOOKUP_PREFER_BOTH)
bb20cc46 3566
8d08fdba 3567
a4443a08
MS
3568/* These flags are used by the conversion code.
3569 CONV_IMPLICIT : Perform implicit conversions (standard and user-defined).
3570 CONV_STATIC : Perform the explicit conversions for static_cast.
3571 CONV_CONST : Perform the explicit conversions for const_cast.
3572 CONV_REINTERPRET: Perform the explicit conversions for reinterpret_cast.
6060a796 3573 CONV_PRIVATE : Perform upcasts to private bases.
8ccc31eb 3574 CONV_FORCE_TEMP : Require a new temporary when converting to the same
bb20cc46 3575 aggregate type. */
a4443a08
MS
3576
3577#define CONV_IMPLICIT 1
3578#define CONV_STATIC 2
3579#define CONV_CONST 4
3580#define CONV_REINTERPRET 8
3581#define CONV_PRIVATE 16
faf5394a 3582/* #define CONV_NONCONVERTING 32 */
8ccc31eb
MS
3583#define CONV_FORCE_TEMP 64
3584#define CONV_STATIC_CAST (CONV_IMPLICIT | CONV_STATIC | CONV_FORCE_TEMP)
a4443a08
MS
3585#define CONV_OLD_CONVERT (CONV_IMPLICIT | CONV_STATIC | CONV_CONST \
3586 | CONV_REINTERPRET)
3587#define CONV_C_CAST (CONV_IMPLICIT | CONV_STATIC | CONV_CONST \
8ccc31eb 3588 | CONV_REINTERPRET | CONV_PRIVATE | CONV_FORCE_TEMP)
a4443a08 3589
b7484fbe
MS
3590/* Used by build_expr_type_conversion to indicate which types are
3591 acceptable as arguments to the expression under consideration. */
3592
3593#define WANT_INT 1 /* integer types, including bool */
3594#define WANT_FLOAT 2 /* floating point types */
3595#define WANT_ENUM 4 /* enumerated types */
3596#define WANT_POINTER 8 /* pointer types */
3597#define WANT_NULL 16 /* null pointer constant */
b7484fbe
MS
3598#define WANT_ARITH (WANT_INT | WANT_FLOAT)
3599
3bfdc719
MM
3600/* Used with comptypes, and related functions, to guide type
3601 comparison. */
3602
3603#define COMPARE_STRICT 0 /* Just check if the types are the
3604 same. */
3605#define COMPARE_BASE 1 /* Check to see if the second type is
3606 derived from the first, or if both
3607 are pointers (or references) and
3608 the types pointed to by the second
3609 type is derived from the pointed to
3610 by the first. */
3611#define COMPARE_RELAXED 2 /* Like COMPARE_DERIVED, but in
3612 reverse. Also treat enmeration
3613 types as the same as integer types
3614 of the same width. */
3615#define COMPARE_REDECLARATION 4 /* The comparsion is being done when
3616 another declaration of an existing
3617 entity is seen. */
940ff223
JM
3618#define COMPARE_NO_ATTRIBUTES 8 /* The comparison should ignore
3619 extra-linguistic type attributes. */
3bfdc719 3620
7bdbfa05
MM
3621/* Used with push_overloaded_decl. */
3622#define PUSH_GLOBAL 0 /* Push the DECL into namespace scope,
3623 regardless of the current scope. */
3624#define PUSH_LOCAL 1 /* Push the DECL into the current
3625 scope. */
3626#define PUSH_USING 2 /* We are pushing this DECL as the
3627 result of a using declaration. */
3628
a8f73d4b 3629/* Used with start function. */
b35d4555 3630#define SF_DEFAULT 0 /* No flags. */
a8f73d4b
MM
3631#define SF_PRE_PARSED 1 /* The function declaration has
3632 already been parsed. */
3633#define SF_INCLASS_INLINE 2 /* The function is an inline, defined
3634 in the class body. */
9edc3913 3635
3bfdc719
MM
3636/* Returns nonzero iff TYPE1 and TYPE2 are the same type, or if TYPE2
3637 is derived from TYPE1, or if TYPE2 is a pointer (reference) to a
3638 class derived from the type pointed to (referred to) by TYPE1. */
3639#define same_or_base_type_p(type1, type2) \
3640 comptypes ((type1), (type2), COMPARE_BASE)
3641
f84b4be9 3642/* These macros are used to access a TEMPLATE_PARM_INDEX. */
da8a66fc
ML
3643#define TEMPLATE_PARM_INDEX_CAST(NODE) \
3644 ((template_parm_index*)TEMPLATE_PARM_INDEX_CHECK (NODE))
3645#define TEMPLATE_PARM_IDX(NODE) (TEMPLATE_PARM_INDEX_CAST (NODE)->index)
3646#define TEMPLATE_PARM_LEVEL(NODE) (TEMPLATE_PARM_INDEX_CAST (NODE)->level)
f84b4be9 3647#define TEMPLATE_PARM_DESCENDANTS(NODE) (TREE_CHAIN (NODE))
da8a66fc
ML
3648#define TEMPLATE_PARM_ORIG_LEVEL(NODE) (TEMPLATE_PARM_INDEX_CAST (NODE)->orig_level)
3649#define TEMPLATE_PARM_DECL(NODE) (TEMPLATE_PARM_INDEX_CAST (NODE)->decl)
f84b4be9 3650
bb20cc46 3651/* These macros are for accessing the fields of TEMPLATE_TYPE_PARM,
a1281f45 3652 TEMPLATE_TEMPLATE_PARM and BOUND_TEMPLATE_TEMPLATE_PARM nodes. */
f84b4be9
JM
3653#define TEMPLATE_TYPE_PARM_INDEX(NODE) (TYPE_FIELDS (NODE))
3654#define TEMPLATE_TYPE_IDX(NODE) \
3655 (TEMPLATE_PARM_IDX (TEMPLATE_TYPE_PARM_INDEX (NODE)))
3656#define TEMPLATE_TYPE_LEVEL(NODE) \
3657 (TEMPLATE_PARM_LEVEL (TEMPLATE_TYPE_PARM_INDEX (NODE)))
3658#define TEMPLATE_TYPE_ORIG_LEVEL(NODE) \
3659 (TEMPLATE_PARM_ORIG_LEVEL (TEMPLATE_TYPE_PARM_INDEX (NODE)))
3660#define TEMPLATE_TYPE_DECL(NODE) \
3661 (TEMPLATE_PARM_DECL (TEMPLATE_TYPE_PARM_INDEX (NODE)))
8d08fdba 3662
761f0855
GDR
3663/* These constants can used as bit flags in the process of tree formatting.
3664
3665 TFF_PLAIN_IDENTIFIER: unqualified part of a name.
3666 TFF_NAMESPACE_SCOPE: the complete qualified-id form of a name.
3667 TFF_CLASS_SCOPE: if possible, include the class-name part of a
3668 qualified-id. This flag may be implied in some circumstances by
3669 TFF_NAMESPACE_SCOPE.
3670 TFF_SCOPE: the combinaison of the two above.
3671 TFF_CHASE_TYPEDEF: print the original type-id instead of the typedef-name.
3672 TFF_DECL_SPECIFIERS: print decl-specifiers.
3673 TFF_CLASS_KEY_OR_ENUM: precede a class-type name (resp. enum name) with
3674 a class-key (resp. `enum').
3675 TFF_RETURN_TYPE: include function return type.
3676 TFF_FUNCTION_DEFAULT_ARGUMENTS: include function default parameter values.
3677 TFF_EXCEPTION_SPECIFICATION: show function exception specification.
3678 TFF_TEMPLATE_HEADER: show the template<...> hearder in a
3679 template-declaration.
3680 TFF_TEMPLATE_DEFAULT_ARGUMENTS: show template paramter default values.
3681 TFF_TEMPLATE_NAME: show only template-name.
3682 TFF_EXPR_IN_PARENS: Parenthesize expressions. */
3683
3684#define TFF_PLAIN_IDENTIFIER (0)
3685#define TFF_NAMESPACE_SCOPE (1)
3686#define TFF_CLASS_SCOPE (1 << 1)
3687#define TFF_CHASE_NAMESPACE_ALIAS (1 << 2)
3688#define TFF_CHASE_TYPEDEF (1 << 3)
3689#define TFF_DECL_SPECIFIERS (1 << 4)
3690#define TFF_CLASS_KEY_OR_ENUM (1 << 5)
3691#define TFF_RETURN_TYPE (1 << 6)
3692#define TFF_FUNCTION_DEFAULT_ARGUMENTS (1 << 7)
3693#define TFF_EXCEPTION_SPECIFICATION (1 << 8)
3694#define TFF_TEMPLATE_HEADER (1 << 9)
3695#define TFF_TEMPLATE_DEFAULT_ARGUMENTS (1 << 10)
3696#define TFF_TEMPLATE_NAME (1 << 11)
3697#define TFF_EXPR_IN_PARENS (1 << 12)
3698#define TFF_SCOPE (TFF_NAMESPACE_SCOPE | TFF_CLASS_SCOPE)
9e93bc9d 3699
1899c3a4
KL
3700/* Returns the TEMPLATE_DECL associated to a TEMPLATE_TEMPLATE_PARM
3701 node. */
bb20cc46 3702#define TEMPLATE_TEMPLATE_PARM_TEMPLATE_DECL(NODE) \
a1281f45 3703 ((TREE_CODE (NODE) == BOUND_TEMPLATE_TEMPLATE_PARM) \
bb20cc46 3704 ? TYPE_TI_TEMPLATE (NODE) \
1899c3a4
KL
3705 : TYPE_NAME (NODE))
3706
51c184be 3707/* in lex.c */
d7e7759d
BC
3708/* Indexed by TREE_CODE, these tables give C-looking names to
3709 operators represented by TREE_CODES. For example,
3710 opname_tab[(int) MINUS_EXPR] == "-". */
3711extern const char **opname_tab, **assignop_tab;
596ea4e5
AS
3712
3713typedef struct operator_name_info_t
3714{
3715 /* The IDENTIFIER_NODE for the operator. */
3716 tree identifier;
3717 /* The name of the operator. */
3718 const char *name;
3719 /* The mangled name of the operator. */
3720 const char *mangled_name;
3721} operator_name_info_t;
3722
3723/* A mapping from tree codes to operator name information. */
3724extern operator_name_info_t operator_name_info[];
3725/* Similar, but for assignment operators. */
3726extern operator_name_info_t assignment_operator_name_info[];
3727
51c184be 3728/* in call.c */
158991b7
KG
3729extern int check_dtor_name PARAMS ((tree, tree));
3730extern int get_arglist_len_in_bytes PARAMS ((tree));
3731
3732extern tree build_vfield_ref PARAMS ((tree, tree));
158991b7
KG
3733extern tree build_scoped_method_call PARAMS ((tree, tree, tree, tree));
3734extern tree build_addr_func PARAMS ((tree));
0c11ada6 3735extern tree build_call PARAMS ((tree, tree));
158991b7
KG
3736extern tree build_method_call PARAMS ((tree, tree, tree, tree, int));
3737extern int null_ptr_cst_p PARAMS ((tree));
3738extern tree type_decays_to PARAMS ((tree));
3739extern tree build_user_type_conversion PARAMS ((tree, tree, int));
3740extern tree build_new_function_call PARAMS ((tree, tree));
3741extern tree build_new_op PARAMS ((enum tree_code, int, tree, tree, tree));
158991b7
KG
3742extern tree build_op_delete_call PARAMS ((enum tree_code, tree, tree, int, tree));
3743extern int can_convert PARAMS ((tree, tree));
3744extern int can_convert_arg PARAMS ((tree, tree, tree));
3745extern int enforce_access PARAMS ((tree, tree));
c3f08228 3746extern tree convert_default_arg PARAMS ((tree, tree, tree, int));
158991b7
KG
3747extern tree convert_arg_to_ellipsis PARAMS ((tree));
3748extern tree build_x_va_arg PARAMS ((tree, tree));
3749extern tree convert_type_from_ellipsis PARAMS ((tree));
3750extern int is_properly_derived_from PARAMS ((tree, tree));
3751extern tree initialize_reference PARAMS ((tree, tree));
3752extern tree strip_top_quals PARAMS ((tree));
3753extern tree perform_implicit_conversion PARAMS ((tree, tree));
8d08fdba 3754
51c184be 3755/* in class.c */
158991b7
KG
3756extern tree build_vbase_path PARAMS ((enum tree_code, tree, tree, tree, int));
3757extern tree build_vtbl_ref PARAMS ((tree, tree));
3758extern tree build_vfn_ref PARAMS ((tree *, tree, tree));
3759extern tree get_vtable_decl PARAMS ((tree, int));
452a394b 3760extern void add_method PARAMS ((tree, tree, int));
158991b7 3761extern int currently_open_class PARAMS ((tree));
70adf8a9 3762extern tree currently_open_derived_class PARAMS ((tree));
158991b7
KG
3763extern tree get_vfield_offset PARAMS ((tree));
3764extern void duplicate_tag_error PARAMS ((tree));
3765extern tree finish_struct PARAMS ((tree, tree));
3766extern void finish_struct_1 PARAMS ((tree));
3767extern int resolves_to_fixed_type_p PARAMS ((tree, int *));
3768extern void init_class_processing PARAMS ((void));
3769extern int is_empty_class PARAMS ((tree));
3770extern void pushclass PARAMS ((tree, int));
3771extern void popclass PARAMS ((void));
3772extern void push_nested_class PARAMS ((tree, int));
3773extern void pop_nested_class PARAMS ((void));
3774extern void push_lang_context PARAMS ((tree));
3775extern void pop_lang_context PARAMS ((void));
5e76004e 3776extern tree instantiate_type PARAMS ((tree, tree, enum instantiate_type_flags));
158991b7 3777extern void print_class_statistics PARAMS ((void));
da3d4dfa 3778extern int first_vfun_index PARAMS ((tree));
158991b7
KG
3779extern void build_self_reference PARAMS ((void));
3780extern void warn_hidden PARAMS ((tree));
3781extern tree get_enclosing_class PARAMS ((tree));
3782int is_base_of_enclosing_class PARAMS ((tree, tree));
3783extern void unreverse_member_declarations PARAMS ((tree));
3784extern void invalidate_class_lookup_cache PARAMS ((void));
3785extern void maybe_note_name_used_in_class PARAMS ((tree, tree));
3786extern void note_name_declared_in_class PARAMS ((tree, tree));
298d6f60
MM
3787extern tree get_vtbl_decl_for_binfo PARAMS ((tree));
3788extern tree in_charge_arg_for_name PARAMS ((tree));
669ec2b4 3789extern tree get_vtt_name PARAMS ((tree));
911a71a7 3790extern tree get_primary_binfo PARAMS ((tree));
8d08fdba 3791
51c184be 3792/* in cvt.c */
158991b7
KG
3793extern tree convert_to_reference PARAMS ((tree, tree, int, int, tree));
3794extern tree convert_from_reference PARAMS ((tree));
3795extern tree convert_pointer_to_real PARAMS ((tree, tree));
3796extern tree convert_pointer_to PARAMS ((tree, tree));
3797extern tree ocp_convert PARAMS ((tree, tree, int, int));
3798extern tree cp_convert PARAMS ((tree, tree));
3799extern tree convert_to_void PARAMS ((tree, const char */*implicit context*/));
3800extern tree convert PARAMS ((tree, tree));
3801extern tree convert_force PARAMS ((tree, tree, int));
3802extern tree build_type_conversion PARAMS ((tree, tree, int));
3803extern tree build_expr_type_conversion PARAMS ((int, tree, int));
3804extern tree type_promotes_to PARAMS ((tree));
3805extern tree perform_qualification_conversions PARAMS ((tree, tree));
db9b2174 3806extern void clone_function_decl PARAMS ((tree, int));
8d08fdba 3807
51c184be 3808/* decl.c */
824b9a4c 3809/* resume_binding_level */
158991b7
KG
3810extern void set_identifier_local_value PARAMS ((tree, tree));
3811extern int global_bindings_p PARAMS ((void));
3812extern int toplevel_bindings_p PARAMS ((void));
3813extern int namespace_bindings_p PARAMS ((void));
3814extern void keep_next_level PARAMS ((int));
3815extern int kept_level_p PARAMS ((void));
74b846e0 3816extern int template_parm_scope_p PARAMS ((void));
158991b7 3817extern void set_class_shadows PARAMS ((tree));
74b846e0
MM
3818extern void begin_scope PARAMS ((scope_kind));
3819extern void finish_scope PARAMS ((void));
158991b7 3820extern void note_level_for_for PARAMS ((void));
6625cdb5 3821extern void note_level_for_eh PARAMS ((void));
158991b7
KG
3822extern void resume_level PARAMS ((struct binding_level *));
3823extern void delete_block PARAMS ((tree));
3824extern void insert_block PARAMS ((tree));
3825extern void add_block_current_level PARAMS ((tree));
3826extern void set_block PARAMS ((tree));
3827extern void pushlevel_class PARAMS ((void));
3828extern void poplevel_class PARAMS ((void));
3829extern void print_binding_stack PARAMS ((void));
3830extern void print_binding_level PARAMS ((struct binding_level *));
3831extern void push_namespace PARAMS ((tree));
3832extern void pop_namespace PARAMS ((void));
3833extern void push_nested_namespace PARAMS ((tree));
3834extern void pop_nested_namespace PARAMS ((tree));
3835extern void maybe_push_to_top_level PARAMS ((int));
3836extern void push_to_top_level PARAMS ((void));
3837extern void pop_from_top_level PARAMS ((void));
56cb9733 3838extern void push_switch PARAMS ((tree));
f2c5f623 3839extern void pop_switch PARAMS ((void));
158991b7
KG
3840extern tree identifier_type_value PARAMS ((tree));
3841extern void set_identifier_type_value PARAMS ((tree, tree));
3842extern void pop_everything PARAMS ((void));
3843extern void pushtag PARAMS ((tree, tree, int));
3844extern tree make_anon_name PARAMS ((void));
3845extern void clear_anon_tags PARAMS ((void));
3846extern int decls_match PARAMS ((tree, tree));
3847extern int duplicate_decls PARAMS ((tree, tree));
3848extern tree pushdecl PARAMS ((tree));
3849extern tree pushdecl_top_level PARAMS ((tree));
3850extern void pushdecl_class_level PARAMS ((tree));
158991b7
KG
3851extern tree pushdecl_namespace_level PARAMS ((tree));
3852extern tree push_using_decl PARAMS ((tree, tree));
3853extern tree push_using_directive PARAMS ((tree));
3854extern void push_class_level_binding PARAMS ((tree, tree));
3855extern tree implicitly_declare PARAMS ((tree));
3856extern tree lookup_label PARAMS ((tree));
3857extern tree declare_local_label PARAMS ((tree));
3b304f5b 3858extern tree define_label PARAMS ((const char *, int, tree));
6625cdb5 3859extern void check_goto PARAMS ((tree));
158991b7
KG
3860extern void define_case_label PARAMS ((void));
3861extern tree getdecls PARAMS ((void));
3862extern tree gettags PARAMS ((void));
158991b7
KG
3863extern tree binding_for_name PARAMS ((tree, tree));
3864extern tree namespace_binding PARAMS ((tree, tree));
3865extern void set_namespace_binding PARAMS ((tree, tree, tree));
3866extern tree lookup_namespace_name PARAMS ((tree, tree));
3867extern tree build_typename_type PARAMS ((tree, tree, tree, tree));
3868extern tree make_typename_type PARAMS ((tree, tree, int));
3869extern tree lookup_name_nonclass PARAMS ((tree));
3870extern tree lookup_function_nonclass PARAMS ((tree, tree));
3871extern tree lookup_name PARAMS ((tree, int));
3872extern tree lookup_name_current_level PARAMS ((tree));
3873extern tree lookup_type_current_level PARAMS ((tree));
3874extern tree lookup_name_namespace_only PARAMS ((tree));
3875extern void begin_only_namespace_names PARAMS ((void));
3876extern void end_only_namespace_names PARAMS ((void));
3877extern tree namespace_ancestor PARAMS ((tree, tree));
3878extern tree unqualified_namespace_lookup PARAMS ((tree, int, tree *));
3879extern int lookup_using_namespace PARAMS ((tree, tree, tree, tree, int, tree *));
3880extern int qualified_lookup_using_namespace PARAMS ((tree, tree, tree, int));
0c11ada6 3881extern tree build_library_fn PARAMS ((tree, tree));
0c11ada6
JM
3882extern tree build_library_fn_ptr PARAMS ((const char *, tree));
3883extern tree build_cp_library_fn_ptr PARAMS ((const char *, tree));
3884extern tree push_library_fn PARAMS ((tree, tree));
0c11ada6
JM
3885extern tree push_void_library_fn PARAMS ((tree, tree));
3886extern tree push_throw_library_fn PARAMS ((tree, tree));
158991b7
KG
3887extern void init_decl_processing PARAMS ((void));
3888extern int init_type_desc PARAMS ((void));
158991b7
KG
3889extern tree check_tag_decl PARAMS ((tree));
3890extern void shadow_tag PARAMS ((tree));
3891extern tree groktypename PARAMS ((tree));
3892extern tree start_decl PARAMS ((tree, tree, int, tree, tree));
3893extern void start_decl_1 PARAMS ((tree));
3894extern void cp_finish_decl PARAMS ((tree, tree, tree, int));
3895extern void finish_decl PARAMS ((tree, tree, tree));
3896extern void maybe_inject_for_scope_var PARAMS ((tree));
3897extern void initialize_local_var PARAMS ((tree, tree, int));
3898extern void expand_static_init PARAMS ((tree, tree));
3899extern tree start_handler_parms PARAMS ((tree, tree));
3900extern int complete_array_type PARAMS ((tree, tree, int));
3901extern tree build_ptrmemfunc_type PARAMS ((tree));
f30432d7 3902/* the grokdeclarator prototype is in decl.h */
158991b7
KG
3903extern int parmlist_is_exprlist PARAMS ((tree));
3904extern int copy_args_p PARAMS ((tree));
3905extern int grok_ctor_properties PARAMS ((tree, tree));
3906extern void grok_op_properties PARAMS ((tree, int, int));
3907extern tree xref_tag PARAMS ((tree, tree, int));
3908extern tree xref_tag_from_type PARAMS ((tree, tree, int));
3909extern void xref_basetypes PARAMS ((tree, tree, tree, tree));
3910extern tree start_enum PARAMS ((tree));
3911extern tree finish_enum PARAMS ((tree));
3912extern void build_enumerator PARAMS ((tree, tree, tree));
3913extern int start_function PARAMS ((tree, tree, tree, int));
0acf7199 3914extern tree finish_function PARAMS ((int));
158991b7
KG
3915extern tree start_method PARAMS ((tree, tree, tree));
3916extern tree finish_method PARAMS ((tree));
3917extern void hack_incomplete_structures PARAMS ((tree));
158991b7 3918extern tree maybe_build_cleanup PARAMS ((tree));
158991b7 3919extern void finish_stmt PARAMS ((void));
158991b7
KG
3920extern void replace_defarg PARAMS ((tree, tree));
3921extern void print_other_binding_stack PARAMS ((struct binding_level *));
3afb32a4 3922extern void revert_static_member_fn PARAMS ((tree));
158991b7
KG
3923extern void fixup_anonymous_aggr PARAMS ((tree));
3924extern int check_static_variable_definition PARAMS ((tree, tree));
3925extern tree compute_array_index_type PARAMS ((tree, tree));
3926extern void push_local_binding PARAMS ((tree, tree, int));
3927extern int push_class_binding PARAMS ((tree, tree));
3928extern tree check_default_argument PARAMS ((tree, tree));
3929extern tree push_overloaded_decl PARAMS ((tree, int));
3930extern void clear_identifier_class_values PARAMS ((void));
3931extern void storetags PARAMS ((tree));
3932extern int vtable_decl_p PARAMS ((tree, void *));
3933extern int vtype_decl_p PARAMS ((tree, void *));
3934extern int sigtable_decl_p PARAMS ((tree, void *));
3935typedef int (*walk_globals_pred) PARAMS ((tree, void *));
3936typedef int (*walk_globals_fn) PARAMS ((tree *, void *));
3937extern int walk_globals PARAMS ((walk_globals_pred,
0aafb128
MM
3938 walk_globals_fn,
3939 void *));
158991b7
KG
3940typedef int (*walk_namespaces_fn) PARAMS ((tree, void *));
3941extern int walk_namespaces PARAMS ((walk_namespaces_fn,
0aafb128 3942 void *));
158991b7
KG
3943extern int wrapup_globals_for_namespace PARAMS ((tree, void *));
3944extern tree cp_namespace_decls PARAMS ((tree));
3945extern tree create_implicit_typedef PARAMS ((tree, tree));
3946extern tree maybe_push_decl PARAMS ((tree));
158991b7 3947extern tree build_target_expr_with_type PARAMS ((tree, tree));
158991b7
KG
3948extern int local_variable_p PARAMS ((tree));
3949extern int nonstatic_local_decl_p PARAMS ((tree));
3950extern tree declare_global_var PARAMS ((tree, tree));
3951extern void register_dtor_fn PARAMS ((tree));
74b846e0 3952extern tmpl_spec_kind current_tmpl_spec_kind PARAMS ((int));
8d08fdba 3953
51c184be 3954/* in decl2.c */
158991b7
KG
3955extern void init_decl2 PARAMS ((void));
3956extern int check_java_method PARAMS ((tree));
3957extern int lang_decode_option PARAMS ((int, char **));
3958extern int grok_method_quals PARAMS ((tree, tree, tree));
3959extern void warn_if_unknown_interface PARAMS ((tree));
3960extern void grok_x_components PARAMS ((tree));
3961extern void maybe_retrofit_in_chrg PARAMS ((tree));
3962extern void maybe_make_one_only PARAMS ((tree));
3963extern void grokclassfn PARAMS ((tree, tree, enum overload_flags, tree));
3964extern tree grok_alignof PARAMS ((tree));
3965extern tree grok_array_decl PARAMS ((tree, tree));
3966extern tree delete_sanity PARAMS ((tree, tree, int, int));
3967extern tree check_classfn PARAMS ((tree, tree));
3968extern void check_member_template PARAMS ((tree));
3969extern tree grokfield PARAMS ((tree, tree, tree, tree, tree));
3970extern tree grokbitfield PARAMS ((tree, tree, tree));
3971extern tree groktypefield PARAMS ((tree, tree));
3972extern tree grokoptypename PARAMS ((tree, tree));
3973extern int copy_assignment_arg_p PARAMS ((tree, int));
bb20cc46 3974extern void cplus_decl_attributes PARAMS ((tree, tree, tree));
158991b7
KG
3975extern tree constructor_name_full PARAMS ((tree));
3976extern tree constructor_name PARAMS ((tree));
fd74ca0b 3977extern void setup_vtbl_ptr PARAMS ((tree, tree));
bb20cc46 3978extern void defer_fn PARAMS ((tree));
c395453c 3979extern tree get_temp_name PARAMS ((tree));
158991b7
KG
3980extern void finish_anon_union PARAMS ((tree));
3981extern tree finish_table PARAMS ((tree, tree, tree, int));
3982extern void finish_builtin_type PARAMS ((tree, const char *,
d8e178a0 3983 tree *, int, tree));
158991b7
KG
3984extern tree coerce_new_type PARAMS ((tree));
3985extern tree coerce_delete_type PARAMS ((tree));
3986extern void comdat_linkage PARAMS ((tree));
158991b7
KG
3987extern void import_export_vtable PARAMS ((tree, tree, int));
3988extern void import_export_decl PARAMS ((tree));
3989extern tree build_cleanup PARAMS ((tree));
3990extern void finish_file PARAMS ((void));
3991extern tree reparse_absdcl_as_expr PARAMS ((tree, tree));
3992extern tree reparse_absdcl_as_casts PARAMS ((tree, tree));
3993extern tree build_expr_from_tree PARAMS ((tree));
3994extern tree reparse_decl_as_expr PARAMS ((tree, tree));
3995extern tree finish_decl_parsing PARAMS ((tree));
158991b7
KG
3996extern void set_decl_namespace PARAMS ((tree, tree, int));
3997extern tree current_decl_namespace PARAMS ((void));
3998extern void push_decl_namespace PARAMS ((tree));
3999extern void pop_decl_namespace PARAMS ((void));
4000extern void push_scope PARAMS ((tree));
4001extern void pop_scope PARAMS ((tree));
4002extern void do_namespace_alias PARAMS ((tree, tree));
4003extern void do_toplevel_using_decl PARAMS ((tree));
4004extern void do_local_using_decl PARAMS ((tree));
4005extern tree do_class_using_decl PARAMS ((tree));
4006extern void do_using_directive PARAMS ((tree));
4007extern void check_default_args PARAMS ((tree));
4008extern void mark_used PARAMS ((tree));
4009extern tree handle_class_head PARAMS ((tree, tree, tree));
4010extern tree lookup_arg_dependent PARAMS ((tree, tree, tree));
4011extern void finish_static_data_member_decl PARAMS ((tree, tree, tree, int));
3ec6bad3 4012extern tree build_artificial_parm PARAMS ((tree, tree));
c395453c
MM
4013extern tree get_guard PARAMS ((tree));
4014extern tree get_guard_cond PARAMS ((tree));
4015extern tree set_guard PARAMS ((tree));
8d08fdba 4016
fc6af6e3 4017/* in parse.y */
158991b7 4018extern void cp_parse_init PARAMS ((void));
fc6af6e3 4019
824b9a4c 4020/* in errfn.c */
d8e178a0 4021/* The cp_* functions aren't suitable for ATTRIBUTE_PRINTF. */
158991b7
KG
4022extern void cp_error PARAMS ((const char *, ...));
4023extern void cp_error_at PARAMS ((const char *, ...));
4024extern void cp_warning PARAMS ((const char *, ...));
4025extern void cp_warning_at PARAMS ((const char *, ...));
4026extern void cp_pedwarn PARAMS ((const char *, ...));
4027extern void cp_pedwarn_at PARAMS ((const char *, ...));
4028extern void cp_compiler_error PARAMS ((const char *, ...));
4029extern void cp_sprintf PARAMS ((const char *, ...));
4030extern void cp_deprecated PARAMS ((const char*));
824b9a4c
MS
4031
4032/* in error.c */
158991b7 4033extern void init_error PARAMS ((void));
761f0855
GDR
4034extern const char *type_as_string PARAMS ((tree, int));
4035extern const char *decl_as_string PARAMS ((tree, int));
4036extern const char *expr_as_string PARAMS ((tree, int));
4037extern const char *context_as_string PARAMS ((tree, int));
158991b7
KG
4038extern const char *lang_decl_name PARAMS ((tree, int));
4039extern const char *cp_file_of PARAMS ((tree));
4040extern int cp_line_of PARAMS ((tree));
421844e7 4041extern const char *language_to_string PARAMS ((enum languages, int));
cb753e49 4042extern void print_instantiation_context PARAMS ((void));
bb20cc46
AJ
4043/* cp_printer is the type of a function which converts an argument into
4044 a string for digestion by printf. The cp_printer function should deal
4045 with all memory management; the functions in errfn will not free
4046 the char*s returned. See error.c for an example use of this code. */
4047typedef const char *cp_printer PARAMS ((tree, int));
4048extern cp_printer *cp_printers[256];
4049
824b9a4c 4050
51c184be 4051/* in except.c */
158991b7
KG
4052extern void init_exception_processing PARAMS ((void));
4053extern tree expand_start_catch_block PARAMS ((tree));
4054extern void expand_end_catch_block PARAMS ((tree));
4055extern void expand_builtin_throw PARAMS ((void));
4056extern tree expand_start_eh_spec PARAMS ((void));
4057extern void expand_end_eh_spec PARAMS ((tree, tree));
4058extern void expand_exception_blocks PARAMS ((void));
4059extern tree build_throw PARAMS ((tree));
4060extern void mark_all_runtime_matches PARAMS ((void));
1660cb3a 4061extern int nothrow_libfn_p PARAMS ((tree));
2bc9f1d1 4062extern void check_handlers PARAMS ((tree));
8d08fdba 4063
51c184be 4064/* in expr.c */
158991b7 4065extern void init_cplus_expand PARAMS ((void));
158991b7 4066extern int extract_init PARAMS ((tree, tree));
158991b7 4067extern tree cplus_expand_constant PARAMS ((tree));
8d08fdba 4068
bd6dd845 4069/* friend.c */
158991b7
KG
4070extern int is_friend PARAMS ((tree, tree));
4071extern void make_friend_class PARAMS ((tree, tree));
4072extern void add_friend PARAMS ((tree, tree));
158991b7 4073extern tree do_friend PARAMS ((tree, tree, tree, tree, tree, enum overload_flags, tree, int));
bd6dd845 4074
51c184be 4075/* in init.c */
158991b7 4076extern void init_init_processing PARAMS ((void));
fd74ca0b
MM
4077extern void emit_base_init PARAMS ((tree, tree));
4078extern tree expand_member_init PARAMS ((tree, tree, tree));
158991b7 4079extern tree build_aggr_init PARAMS ((tree, tree, int));
158991b7
KG
4080extern int is_aggr_type PARAMS ((tree, int));
4081extern tree get_aggr_from_typedef PARAMS ((tree, int));
4082extern tree get_type_value PARAMS ((tree));
4083extern tree build_member_call PARAMS ((tree, tree, tree));
4084extern tree build_offset_ref PARAMS ((tree, tree));
4085extern tree resolve_offset_ref PARAMS ((tree));
158991b7 4086extern tree build_new PARAMS ((tree, tree, tree, int));
158991b7
KG
4087extern tree build_vec_init PARAMS ((tree, tree, tree, tree, int));
4088extern tree build_x_delete PARAMS ((tree, int, tree));
86f45d2c 4089extern tree build_delete PARAMS ((tree, tree, special_function_kind, int, int));
158991b7 4090extern tree build_vbase_delete PARAMS ((tree, tree));
86f45d2c 4091extern tree build_vec_delete PARAMS ((tree, tree, special_function_kind, int));
158991b7
KG
4092extern tree create_temporary_var PARAMS ((tree));
4093extern void begin_init_stmts PARAMS ((tree *, tree *));
4094extern tree finish_init_stmts PARAMS ((tree, tree));
cf2e003b 4095extern void initialize_vtbl_ptrs PARAMS ((tree));
e97f22c9 4096extern tree build_java_class_ref PARAMS ((tree));
8d08fdba 4097
51c184be 4098/* in input.c */
8d08fdba 4099
51c184be 4100/* in lex.c */
158991b7
KG
4101extern char *file_name_nondirectory PARAMS ((const char *));
4102extern tree make_pointer_declarator PARAMS ((tree, tree));
4103extern tree make_reference_declarator PARAMS ((tree, tree));
4104extern tree make_call_declarator PARAMS ((tree, tree, tree, tree));
4105extern void set_quals_and_spec PARAMS ((tree, tree, tree));
158991b7
KG
4106extern void lang_init PARAMS ((void));
4107extern void lang_finish PARAMS ((void));
158991b7 4108extern void print_parse_statistics PARAMS ((void));
158991b7 4109extern void do_pending_inlines PARAMS ((void));
0e5921e8
ZW
4110extern void process_next_inline PARAMS ((struct unparsed_text *));
4111
158991b7 4112extern void yyungetc PARAMS ((int, int));
0e5921e8
ZW
4113extern void snarf_method PARAMS ((tree));
4114
158991b7
KG
4115extern void check_for_missing_semicolon PARAMS ((tree));
4116extern void note_got_semicolon PARAMS ((tree));
4117extern void note_list_got_semicolon PARAMS ((tree));
4118extern void do_pending_lang_change PARAMS ((void));
158991b7
KG
4119extern void see_typename PARAMS ((void));
4120extern tree do_identifier PARAMS ((tree, int, tree));
4121extern tree do_scoped_id PARAMS ((tree, int));
4122extern tree identifier_typedecl_value PARAMS ((tree));
158991b7
KG
4123extern tree build_lang_decl PARAMS ((enum tree_code, tree, tree));
4124extern void retrofit_lang_decl PARAMS ((tree));
0acf7199 4125extern tree copy_decl PARAMS ((tree));
158991b7
KG
4126extern void copy_lang_decl PARAMS ((tree));
4127extern tree cp_make_lang_type PARAMS ((enum tree_code));
4128extern tree make_aggr_type PARAMS ((enum tree_code));
158991b7 4129extern void compiler_error PARAMS ((const char *, ...))
d8e178a0 4130 ATTRIBUTE_PRINTF_1;
158991b7
KG
4131extern void yyerror PARAMS ((const char *));
4132extern void clear_inline_text_obstack PARAMS ((void));
4133extern void maybe_snarf_defarg PARAMS ((void));
158991b7
KG
4134extern void add_defarg_fn PARAMS ((tree));
4135extern void do_pending_defargs PARAMS ((void));
158991b7
KG
4136extern void yyhook PARAMS ((int));
4137extern int cp_type_qual_from_rid PARAMS ((tree));
8d08fdba 4138
51c184be 4139/* in method.c */
669ec2b4
JM
4140extern void init_method PARAMS ((void));
4141extern char *build_overload_name PARAMS ((tree, int, int));
4142extern tree build_static_name PARAMS ((tree, tree));
4143extern tree build_decl_overload_real PARAMS ((tree, tree, tree, tree,
bb20cc46 4144 tree, int));
158991b7
KG
4145extern void set_mangled_name_for_decl PARAMS ((tree));
4146extern tree build_typename_overload PARAMS ((tree));
669ec2b4
JM
4147extern tree build_overload_with_type PARAMS ((tree, tree));
4148extern tree build_destructor_name PARAMS ((tree));
158991b7
KG
4149extern tree build_opfncall PARAMS ((enum tree_code, int, tree, tree, tree));
4150extern tree hack_identifier PARAMS ((tree, tree));
31f8e4f3
MM
4151extern tree make_thunk PARAMS ((tree, tree, tree, int));
4152extern void use_thunk PARAMS ((tree, int));
158991b7 4153extern void synthesize_method PARAMS ((tree));
669ec2b4 4154extern tree get_id_2 PARAMS ((const char *, tree));
9eb71d8c 4155extern tree implicitly_declare_fn PARAMS ((special_function_kind, tree, int));
669ec2b4 4156extern tree get_ctor_vtbl_name PARAMS ((tree, tree));
8d08fdba 4157
46e8c075 4158/* In optimize.c */
158991b7
KG
4159extern void optimize_function PARAMS ((tree));
4160extern int calls_setjmp_p PARAMS ((tree));
db9b2174 4161extern int maybe_clone_body PARAMS ((tree));
46e8c075 4162
51c184be 4163/* in pt.c */
158991b7
KG
4164extern void init_pt PARAMS ((void));
4165extern void check_template_shadow PARAMS ((tree));
f9a7ae04 4166extern tree get_innermost_template_args PARAMS ((tree, int));
158991b7
KG
4167extern tree tsubst PARAMS ((tree, tree, int, tree));
4168extern tree tsubst_expr PARAMS ((tree, tree, int, tree));
4169extern tree tsubst_copy PARAMS ((tree, tree, int, tree));
4170extern void maybe_begin_member_template_processing PARAMS ((tree));
4171extern void maybe_end_member_template_processing PARAMS ((void));
4172extern tree finish_member_template_decl PARAMS ((tree));
4173extern void begin_template_parm_list PARAMS ((void));
4174extern void begin_specialization PARAMS ((void));
4175extern void reset_specialization PARAMS ((void));
4176extern void end_specialization PARAMS ((void));
4177extern void begin_explicit_instantiation PARAMS ((void));
4178extern void end_explicit_instantiation PARAMS ((void));
4179extern tree check_explicit_specialization PARAMS ((tree, tree, int, int));
4180extern tree process_template_parm PARAMS ((tree, tree));
4181extern tree end_template_parm_list PARAMS ((tree));
4182extern void end_template_decl PARAMS ((void));
4183extern tree current_template_args PARAMS ((void));
4184extern tree push_template_decl PARAMS ((tree));
4185extern tree push_template_decl_real PARAMS ((tree, int));
4186extern void redeclare_class_template PARAMS ((tree, tree));
4187extern tree lookup_template_class PARAMS ((tree, tree, tree, tree, int));
4188extern tree lookup_template_function PARAMS ((tree, tree));
4189extern int uses_template_parms PARAMS ((tree));
4190extern tree instantiate_class_template PARAMS ((tree));
4191extern tree instantiate_template PARAMS ((tree, tree));
4192extern void overload_template_name PARAMS ((tree));
4193extern int fn_type_unification PARAMS ((tree, tree, tree, tree, tree, unification_kind_t));
3ae18eaf 4194extern tree tinst_for_decl PARAMS ((void));
158991b7
KG
4195extern void mark_decl_instantiated PARAMS ((tree, int));
4196extern int more_specialized PARAMS ((tree, tree, tree));
4197extern void mark_class_instantiated PARAMS ((tree, int));
4198extern void do_decl_instantiation PARAMS ((tree, tree, tree));
a1bcc528 4199extern void do_type_instantiation PARAMS ((tree, tree, int));
16d53b64 4200extern tree instantiate_decl PARAMS ((tree, int));
158991b7 4201extern tree get_bindings PARAMS ((tree, tree, tree));
158991b7
KG
4202extern void pop_tinst_level PARAMS ((void));
4203extern int more_specialized_class PARAMS ((tree, tree));
4204extern int is_member_template PARAMS ((tree));
4205extern int template_parms_equal PARAMS ((tree, tree));
4206extern int comp_template_parms PARAMS ((tree, tree));
4207extern int template_class_depth PARAMS ((tree));
4208extern int is_specialization_of PARAMS ((tree, tree));
4209extern int comp_template_args PARAMS ((tree, tree));
4210extern void maybe_process_partial_specialization PARAMS ((tree));
4211extern void maybe_check_template_type PARAMS ((tree));
4212extern tree most_specialized_instantiation PARAMS ((tree, tree));
4213extern void print_candidates PARAMS ((tree));
4214extern int instantiate_pending_templates PARAMS ((void));
4215extern tree tsubst_default_argument PARAMS ((tree, tree, tree));
4216extern tree most_general_template PARAMS ((tree));
1f6e1acc 4217extern tree get_mostly_instantiated_function_type PARAMS ((tree, tree *, tree *));
cb753e49
GDR
4218extern int problematic_instantiation_changed PARAMS ((void));
4219extern void record_last_problematic_instantiation PARAMS ((void));
4220extern tree current_instantiation PARAMS ((void));
67ffc812 4221extern int processing_template_parmlist;
824b9a4c
MS
4222
4223/* in repo.c */
158991b7
KG
4224extern void repo_template_used PARAMS ((tree));
4225extern void repo_template_instantiated PARAMS ((tree, int));
4226extern void init_repo PARAMS ((const char *));
4227extern void finish_repo PARAMS ((void));
824b9a4c
MS
4228
4229/* in rtti.c */
7267d692
NS
4230extern void init_rtti_processing PARAMS((void));
4231extern tree build_typeid PARAMS((tree));
4232extern tree get_tinfo_decl PARAMS((tree));
4233extern tree get_typeid PARAMS((tree));
4234extern tree get_typeid_1 PARAMS((tree));
4235extern tree build_dynamic_cast PARAMS((tree, tree));
4236extern void synthesize_tinfo_fn PARAMS((tree));
4237extern void emit_support_tinfos PARAMS((void));
4238extern int tinfo_decl_p PARAMS((tree, void *));
4239extern int emit_tinfo_decl PARAMS((tree *, void *));
8d08fdba 4240
51c184be 4241/* in search.c */
158991b7
KG
4242extern int types_overlap_p PARAMS ((tree, tree));
4243extern tree get_vbase PARAMS ((tree, tree));
4244extern tree get_binfo PARAMS ((tree, tree, int));
4245extern int get_base_distance PARAMS ((tree, tree, int, tree *));
4246extern tree get_dynamic_cast_base_type PARAMS ((tree, tree));
70adf8a9 4247extern void type_access_control PARAMS ((tree, tree));
158991b7
KG
4248extern int accessible_p PARAMS ((tree, tree));
4249extern tree lookup_field PARAMS ((tree, tree, int, int));
4250extern int lookup_fnfields_1 PARAMS ((tree, tree));
4251extern tree lookup_fnfields PARAMS ((tree, tree, int));
4252extern tree lookup_member PARAMS ((tree, tree, int, int));
158991b7
KG
4253extern tree get_matching_virtual PARAMS ((tree, tree, int));
4254extern void get_pure_virtuals PARAMS ((tree));
4255extern tree init_vbase_pointers PARAMS ((tree, tree));
158991b7
KG
4256extern void get_vbase_types PARAMS ((tree));
4257extern void maybe_suppress_debug_info PARAMS ((tree));
4258extern void note_debug_info_needed PARAMS ((tree));
4259extern void push_class_decls PARAMS ((tree));
4260extern void pop_class_decls PARAMS ((void));
4261extern void unuse_fields PARAMS ((tree));
4262extern void print_search_statistics PARAMS ((void));
4263extern void init_search_processing PARAMS ((void));
4264extern void reinit_search_statistics PARAMS ((void));
4265extern tree current_scope PARAMS ((void));
4266extern int at_function_scope_p PARAMS ((void));
4267extern tree lookup_conversions PARAMS ((tree));
4268extern tree binfo_for_vtable PARAMS ((tree));
f9825168 4269extern tree binfo_from_vbase PARAMS ((tree));
bb20cc46 4270extern tree dfs_walk PARAMS ((tree,
d6479fe7
MM
4271 tree (*)(tree, void *),
4272 tree (*) (tree, void *),
4273 void *));
bb20cc46 4274extern tree dfs_walk_real PARAMS ((tree,
bbd15aac
MM
4275 tree (*) (tree, void *),
4276 tree (*) (tree, void *),
4277 tree (*) (tree, void *),
4278 void *));
158991b7 4279extern tree dfs_unmark PARAMS ((tree, void *));
158991b7
KG
4280extern tree markedp PARAMS ((tree, void *));
4281extern tree unmarkedp PARAMS ((tree, void *));
4282extern tree dfs_skip_nonprimary_vbases_unmarkedp PARAMS ((tree, void *));
4283extern tree dfs_skip_nonprimary_vbases_markedp PARAMS ((tree, void *));
4284extern tree dfs_unmarked_real_bases_queue_p PARAMS ((tree, void *));
4285extern tree dfs_marked_real_bases_queue_p PARAMS ((tree, void *));
158991b7 4286extern tree dfs_skip_vbases PARAMS ((tree, void *));
da3d4dfa
MM
4287extern tree marked_vtable_pathp PARAMS ((tree, void *));
4288extern tree unmarked_vtable_pathp PARAMS ((tree, void *));
158991b7
KG
4289extern tree convert_pointer_to_vbase PARAMS ((tree, tree));
4290extern tree find_vbase_instance PARAMS ((tree, tree));
a55583e9 4291extern tree binfo_for_vbase PARAMS ((tree, tree));
3ec6bad3 4292extern void fixup_all_virtual_upcast_offsets PARAMS ((tree));
8d08fdba 4293
ad321293 4294/* in semantics.c */
54f7877c 4295extern void init_cp_semantics PARAMS ((void));
158991b7
KG
4296extern void finish_expr_stmt PARAMS ((tree));
4297extern tree begin_if_stmt PARAMS ((void));
4298extern void finish_if_stmt_cond PARAMS ((tree, tree));
4299extern tree finish_then_clause PARAMS ((tree));
4300extern void begin_else_clause PARAMS ((void));
4301extern void finish_else_clause PARAMS ((tree));
4302extern void finish_if_stmt PARAMS ((void));
4303extern tree begin_while_stmt PARAMS ((void));
4304extern void finish_while_stmt_cond PARAMS ((tree, tree));
4305extern void finish_while_stmt PARAMS ((tree));
4306extern tree begin_do_stmt PARAMS ((void));
4307extern void finish_do_body PARAMS ((tree));
4308extern void finish_do_stmt PARAMS ((tree, tree));
4309extern void finish_return_stmt PARAMS ((tree));
4310extern tree begin_for_stmt PARAMS ((void));
4311extern void finish_for_init_stmt PARAMS ((tree));
4312extern void finish_for_cond PARAMS ((tree, tree));
4313extern void finish_for_expr PARAMS ((tree, tree));
35b1567d 4314extern void finish_for_stmt PARAMS ((tree));
158991b7
KG
4315extern void finish_break_stmt PARAMS ((void));
4316extern void finish_continue_stmt PARAMS ((void));
4317extern tree begin_switch_stmt PARAMS ((void));
4318extern void finish_switch_cond PARAMS ((tree, tree));
35b1567d 4319extern void finish_switch_stmt PARAMS ((tree));
158991b7
KG
4320extern void finish_case_label PARAMS ((tree, tree));
4321extern void finish_goto_stmt PARAMS ((tree));
4322extern tree begin_try_block PARAMS ((void));
4323extern void finish_try_block PARAMS ((tree));
4324extern void finish_handler_sequence PARAMS ((tree));
4325extern tree begin_function_try_block PARAMS ((void));
4326extern void finish_function_try_block PARAMS ((tree));
4327extern void finish_function_handler_sequence PARAMS ((tree));
4328extern void finish_cleanup_try_block PARAMS ((tree));
4329extern tree begin_handler PARAMS ((void));
4330extern tree finish_handler_parms PARAMS ((tree, tree));
4331extern void begin_catch_block PARAMS ((tree));
4332extern void finish_handler PARAMS ((tree, tree));
4333extern void finish_cleanup PARAMS ((tree, tree));
4334extern tree begin_compound_stmt PARAMS ((int));
4335extern tree finish_compound_stmt PARAMS ((int, tree));
4336extern void finish_asm_stmt PARAMS ((tree, tree, tree, tree, tree));
4337extern void finish_label_stmt PARAMS ((tree));
4338extern void finish_label_decl PARAMS ((tree));
4339extern void finish_subobject PARAMS ((tree));
4340extern tree finish_parenthesized_expr PARAMS ((tree));
4341extern tree begin_stmt_expr PARAMS ((void));
4342extern tree finish_stmt_expr PARAMS ((tree));
4343extern tree finish_call_expr PARAMS ((tree, tree, int));
4344extern tree finish_increment_expr PARAMS ((tree, enum tree_code));
4345extern tree finish_this_expr PARAMS ((void));
4346extern tree finish_object_call_expr PARAMS ((tree, tree, tree));
4347extern tree finish_qualified_object_call_expr PARAMS ((tree, tree, tree));
4348extern tree finish_pseudo_destructor_call_expr PARAMS ((tree, tree, tree));
4349extern tree finish_qualified_call_expr PARAMS ((tree, tree));
4350extern tree finish_label_address_expr PARAMS ((tree));
4351extern tree finish_unary_op_expr PARAMS ((enum tree_code, tree));
4352extern tree finish_id_expr PARAMS ((tree));
1f51a992
JM
4353extern void save_type_access_control PARAMS ((tree));
4354extern void decl_type_access_control PARAMS ((tree));
4355extern int begin_function_definition PARAMS ((tree, tree));
158991b7
KG
4356extern tree begin_constructor_declarator PARAMS ((tree, tree));
4357extern tree finish_declarator PARAMS ((tree, tree, tree, tree, int));
4358extern void finish_translation_unit PARAMS ((void));
4359extern tree finish_template_type_parm PARAMS ((tree, tree));
4360extern tree finish_template_template_parm PARAMS ((tree, tree));
4361extern tree finish_parmlist PARAMS ((tree, int));
4362extern tree begin_class_definition PARAMS ((tree));
4363extern tree finish_class_definition PARAMS ((tree, tree, int, int));
4364extern void finish_default_args PARAMS ((void));
4365extern void begin_inline_definitions PARAMS ((void));
4366extern void finish_inline_definitions PARAMS ((void));
4367extern tree finish_member_class_template PARAMS ((tree));
4368extern void finish_template_decl PARAMS ((tree));
4369extern tree finish_template_type PARAMS ((tree, tree, int));
4370extern void enter_scope_of PARAMS ((tree));
4371extern tree finish_base_specifier PARAMS ((tree, tree));
4372extern void finish_member_declaration PARAMS ((tree));
4373extern void check_multiple_declarators PARAMS ((void));
4374extern tree finish_typeof PARAMS ((tree));
158991b7
KG
4375extern void finish_decl_cleanup PARAMS ((tree, tree));
4376extern void finish_named_return_value PARAMS ((tree, tree));
158991b7 4377extern void expand_body PARAMS ((tree));
158991b7 4378extern void prep_stmt PARAMS ((tree));
158991b7
KG
4379extern void do_pushlevel PARAMS ((void));
4380extern tree do_poplevel PARAMS ((void));
bf3428d0 4381extern void finish_mem_initializers PARAMS ((tree));
b4c4a9ec 4382
f2c5f623 4383extern void clear_out_block PARAMS ((void));
596fd31c
MM
4384extern tree begin_global_stmt_expr PARAMS ((void));
4385extern tree finish_global_stmt_expr PARAMS ((tree));
35b1567d
BC
4386
4387
51c184be 4388/* in spew.c */
158991b7
KG
4389extern void init_spew PARAMS ((void));
4390extern int peekyylex PARAMS ((void));
4391extern int yylex PARAMS ((void));
4392extern tree arbitrate_lookup PARAMS ((tree, tree, tree));
f2d71db6 4393extern tree frob_opname PARAMS ((tree));
8d08fdba 4394
51c184be 4395/* in tree.c */
158991b7
KG
4396extern void init_tree PARAMS ((void));
4397extern int pod_type_p PARAMS ((tree));
4398extern void unshare_base_binfos PARAMS ((tree));
4399extern int member_p PARAMS ((tree));
4400extern cp_lvalue_kind real_lvalue_p PARAMS ((tree));
4401extern tree build_min PARAMS ((enum tree_code, tree, ...));
4402extern tree build_min_nt PARAMS ((enum tree_code, ...));
4403extern int lvalue_p PARAMS ((tree));
4404extern int lvalue_or_else PARAMS ((tree, const char *));
4405extern tree build_cplus_new PARAMS ((tree, tree));
4406extern tree get_target_expr PARAMS ((tree));
4407extern tree break_out_cleanups PARAMS ((tree));
4408extern tree break_out_calls PARAMS ((tree));
4409extern tree build_cplus_method_type PARAMS ((tree, tree, tree));
4410extern tree build_cplus_staticfn_type PARAMS ((tree, tree, tree));
4411extern tree build_cplus_array_type PARAMS ((tree, tree));
4412extern tree hash_tree_cons PARAMS ((tree, tree, tree));
4413extern tree hash_tree_chain PARAMS ((tree, tree));
4414extern tree hash_chainon PARAMS ((tree, tree));
4415extern tree make_binfo PARAMS ((tree, tree, tree, tree));
4416extern tree binfo_value PARAMS ((tree, tree));
4417extern tree reverse_path PARAMS ((tree));
4418extern int count_functions PARAMS ((tree));
4419extern int is_overloaded_fn PARAMS ((tree));
4420extern tree get_first_fn PARAMS ((tree));
4421extern int bound_pmf_p PARAMS ((tree));
4422extern tree ovl_cons PARAMS ((tree, tree));
4423extern int ovl_member PARAMS ((tree, tree));
4424extern tree build_overload PARAMS ((tree, tree));
4425extern tree fnaddr_from_vtable_entry PARAMS ((tree));
4426extern tree function_arg_chain PARAMS ((tree));
4427extern int promotes_to_aggr_type PARAMS ((tree, enum tree_code));
4428extern int is_aggr_type_2 PARAMS ((tree, tree));
4429extern const char *lang_printable_name PARAMS ((tree, int));
4430extern tree build_exception_variant PARAMS ((tree, tree));
1899c3a4 4431extern tree copy_template_template_parm PARAMS ((tree, tree));
158991b7
KG
4432extern void print_lang_statistics PARAMS ((void));
4433extern tree array_type_nelts_total PARAMS ((tree));
4434extern tree array_type_nelts_top PARAMS ((tree));
4435extern tree break_out_target_exprs PARAMS ((tree));
4436extern tree get_type_decl PARAMS ((tree));
4437extern tree vec_binfo_member PARAMS ((tree, tree));
bb20cc46 4438extern tree decl_namespace_context PARAMS ((tree));
158991b7
KG
4439extern tree lvalue_type PARAMS ((tree));
4440extern tree error_type PARAMS ((tree));
4441extern tree build_ptr_wrapper PARAMS ((void *));
4442extern tree build_expr_ptr_wrapper PARAMS ((void *));
4443extern tree build_int_wrapper PARAMS ((int));
4444extern tree build_srcloc_here PARAMS ((void));
4445extern int varargs_function_p PARAMS ((tree));
4446extern int really_overloaded_fn PARAMS ((tree));
4447extern int cp_tree_equal PARAMS ((tree, tree));
4448extern int can_free PARAMS ((struct obstack *, tree));
4449extern tree no_linkage_check PARAMS ((tree));
4450extern void debug_binfo PARAMS ((tree));
4451extern tree build_dummy_object PARAMS ((tree));
4452extern tree maybe_dummy_object PARAMS ((tree, tree *));
4453extern int is_dummy_object PARAMS ((tree));
ee94fce6
MM
4454extern tree walk_tree PARAMS ((tree *,
4455 walk_tree_fn,
bb20cc46 4456 void *,
ee94fce6
MM
4457 htab_t));
4458extern tree walk_tree_without_duplicates PARAMS ((tree *,
4459 walk_tree_fn,
4460 void *));
158991b7
KG
4461extern tree copy_tree_r PARAMS ((tree *, int *, void *));
4462extern int cp_valid_lang_attribute PARAMS ((tree, tree, tree, tree));
4463extern tree make_ptrmem_cst PARAMS ((tree, tree));
4464extern tree cp_build_qualified_type_real PARAMS ((tree, int, int));
4465extern void remap_save_expr PARAMS ((tree *, splay_tree, tree, int *));
adecb3f4
MM
4466#define cp_build_qualified_type(TYPE, QUALS) \
4467 cp_build_qualified_type_real ((TYPE), (QUALS), /*complain=*/1)
158991b7 4468extern tree build_shared_int_cst PARAMS ((int));
872f37f9 4469extern special_function_kind special_function_p PARAMS ((tree));
bf3428d0 4470extern int count_trees PARAMS ((tree));
7b019c19 4471extern int char_type_p PARAMS ((tree));
b2244c65
MM
4472extern void verify_stmt_tree PARAMS ((tree));
4473extern tree find_tree PARAMS ((tree, tree));
ad50e811 4474extern linkage_kind decl_linkage PARAMS ((tree));
bb20cc46 4475
51c184be 4476/* in typeck.c */
158991b7
KG
4477extern int string_conv_p PARAMS ((tree, tree, int));
4478extern tree condition_conversion PARAMS ((tree));
4479extern tree target_type PARAMS ((tree));
4480extern tree require_complete_type PARAMS ((tree));
4481extern tree complete_type PARAMS ((tree));
4482extern tree complete_type_or_else PARAMS ((tree, tree));
4483extern int type_unknown_p PARAMS ((tree));
158991b7
KG
4484extern tree commonparms PARAMS ((tree, tree));
4485extern tree original_type PARAMS ((tree));
158991b7
KG
4486extern int comp_except_specs PARAMS ((tree, tree, int));
4487extern int comptypes PARAMS ((tree, tree, int));
4488extern int comp_target_types PARAMS ((tree, tree, int));
4489extern int compparms PARAMS ((tree, tree));
4490extern int comp_target_types PARAMS ((tree, tree, int));
4491extern int comp_cv_qualification PARAMS ((tree, tree));
4492extern int comp_cv_qual_signature PARAMS ((tree, tree));
4493extern tree unsigned_type PARAMS ((tree));
4494extern tree signed_type PARAMS ((tree));
4495extern tree signed_or_unsigned_type PARAMS ((int, tree));
4496extern tree expr_sizeof PARAMS ((tree));
4497extern tree c_sizeof PARAMS ((tree));
4498extern tree c_sizeof_nowarn PARAMS ((tree));
4499extern tree c_alignof PARAMS ((tree));
4500extern tree inline_conversion PARAMS ((tree));
4501extern tree decay_conversion PARAMS ((tree));
158991b7
KG
4502extern tree build_object_ref PARAMS ((tree, tree, tree));
4503extern tree build_component_ref_1 PARAMS ((tree, tree, int));
4504extern tree build_component_ref PARAMS ((tree, tree, tree, int));
4505extern tree build_x_component_ref PARAMS ((tree, tree, tree, int));
4506extern tree build_x_indirect_ref PARAMS ((tree, const char *));
4507extern tree build_indirect_ref PARAMS ((tree, const char *));
4508extern tree build_array_ref PARAMS ((tree, tree));
4509extern tree build_x_function_call PARAMS ((tree, tree, tree));
4510extern tree get_member_function_from_ptrfunc PARAMS ((tree *, tree));
4511extern tree build_function_call_real PARAMS ((tree, tree, int, int));
4512extern tree build_function_call PARAMS ((tree, tree));
4513extern tree build_function_call_maybe PARAMS ((tree, tree));
4514extern tree convert_arguments PARAMS ((tree, tree, tree, int));
4515extern tree build_x_binary_op PARAMS ((enum tree_code, tree, tree));
158991b7 4516extern tree build_x_unary_op PARAMS ((enum tree_code, tree));
158991b7
KG
4517extern tree unary_complex_lvalue PARAMS ((enum tree_code, tree));
4518extern int mark_addressable PARAMS ((tree));
4519extern tree build_x_conditional_expr PARAMS ((tree, tree, tree));
4520extern tree build_conditional_expr PARAMS ((tree, tree, tree));
4521extern tree build_x_compound_expr PARAMS ((tree));
4522extern tree build_compound_expr PARAMS ((tree));
4523extern tree build_static_cast PARAMS ((tree, tree));
4524extern tree build_reinterpret_cast PARAMS ((tree, tree));
4525extern tree build_const_cast PARAMS ((tree, tree));
4526extern tree build_c_cast PARAMS ((tree, tree));
4527extern tree build_x_modify_expr PARAMS ((tree, enum tree_code, tree));
4528extern tree build_modify_expr PARAMS ((tree, enum tree_code, tree));
c3f08228 4529extern tree dubious_conversion_warnings PARAMS ((tree, tree, const char *, tree, int));
158991b7 4530extern tree convert_for_initialization PARAMS ((tree, tree, tree, int, const char *, tree, int));
158991b7
KG
4531extern int comp_ptr_ttypes PARAMS ((tree, tree));
4532extern int ptr_reasonably_similar PARAMS ((tree, tree));
4533extern tree build_ptrmemfunc PARAMS ((tree, tree, int));
158991b7
KG
4534extern int cp_type_quals PARAMS ((tree));
4535extern int cp_has_mutable_p PARAMS ((tree));
4536extern int at_least_as_qualified_p PARAMS ((tree, tree));
4537extern int more_qualified_p PARAMS ((tree, tree));
4538extern tree build_ptrmemfunc1 PARAMS ((tree, tree, tree, tree, tree));
4539extern void expand_ptrmemfunc_cst PARAMS ((tree, tree *, tree *, tree *, tree *));
4540extern tree delta2_from_ptrmemfunc PARAMS ((tree));
4541extern tree pfn_from_ptrmemfunc PARAMS ((tree));
4542extern tree type_after_usual_arithmetic_conversions PARAMS ((tree, tree));
4543extern tree composite_pointer_type PARAMS ((tree, tree, tree, tree,
9c0758dd 4544 const char*));
158991b7 4545extern tree check_return_expr PARAMS ((tree));
ab76ca54
MM
4546#define cp_build_binary_op(code, arg1, arg2) \
4547 build_binary_op(code, arg1, arg2, 1)
8d08fdba 4548
51c184be 4549/* in typeck2.c */
158991b7
KG
4550extern tree error_not_base_type PARAMS ((tree, tree));
4551extern tree binfo_or_else PARAMS ((tree, tree));
4552extern void readonly_error PARAMS ((tree, const char *, int));
4553extern int abstract_virtuals_error PARAMS ((tree, tree));
4554extern void incomplete_type_error PARAMS ((tree, tree));
1b493b81
ZW
4555extern void friendly_abort PARAMS ((int, const char *,
4556 int, const char *))
b370501f 4557 ATTRIBUTE_NORETURN;
1b493b81
ZW
4558
4559#define my_friendly_abort(N) \
4560 friendly_abort (N, __FILE__, __LINE__, __FUNCTION__)
50e60bc3 4561#define my_friendly_assert(EXP, N) (void) \
1b493b81
ZW
4562 (((EXP) == 0) ? (friendly_abort (N, __FILE__, __LINE__, __FUNCTION__), 0) : 0)
4563
158991b7
KG
4564extern tree store_init_value PARAMS ((tree, tree));
4565extern tree digest_init PARAMS ((tree, tree, tree *));
4566extern tree build_scoped_ref PARAMS ((tree, tree));
4567extern tree build_x_arrow PARAMS ((tree));
4568extern tree build_m_component_ref PARAMS ((tree, tree));
4569extern tree build_functional_cast PARAMS ((tree, tree));
158991b7
KG
4570extern void check_for_new_type PARAMS ((const char *, flagged_type_tree));
4571extern tree add_exception_specifier PARAMS ((tree, tree, int));
8d08fdba 4572
51c184be 4573/* in xref.c */
158991b7
KG
4574extern void GNU_xref_begin PARAMS ((const char *));
4575extern void GNU_xref_end PARAMS ((int));
4576extern void GNU_xref_file PARAMS ((const char *));
4577extern void GNU_xref_start_scope PARAMS ((HOST_WIDE_INT));
4578extern void GNU_xref_end_scope PARAMS ((HOST_WIDE_INT, HOST_WIDE_INT, int, int));
4579extern void GNU_xref_ref PARAMS ((tree, const char *));
4580extern void GNU_xref_decl PARAMS ((tree, tree));
4581extern void GNU_xref_call PARAMS ((tree, const char *));
4582extern void GNU_xref_function PARAMS ((tree, tree));
4583extern void GNU_xref_assign PARAMS ((tree));
4584extern void GNU_xref_hier PARAMS ((tree, tree, int, int, int));
4585extern void GNU_xref_member PARAMS ((tree, tree));
8d08fdba 4586
1f6e1acc
AS
4587/* in mangle.c */
4588extern void init_mangle PARAMS ((void));
4589extern tree mangle_decl PARAMS ((tree));
4590extern const char *mangle_type_string PARAMS ((tree));
4591extern tree mangle_type PARAMS ((tree));
4592extern tree mangle_typeinfo_for_type PARAMS ((tree));
4593extern tree mangle_typeinfo_string_for_type PARAMS ((tree));
4594extern tree mangle_vtbl_for_type PARAMS ((tree));
4595extern tree mangle_vtt_for_type PARAMS ((tree));
4596extern tree mangle_ctor_vtbl_for_type PARAMS ((tree, tree));
bb20cc46 4597extern tree mangle_thunk PARAMS ((tree, tree, tree));
1f6e1acc
AS
4598extern tree mangle_conv_op_name_for_type PARAMS ((tree));
4599extern tree mangle_guard_variable PARAMS ((tree));
4600
0a7394bc
MM
4601/* in dump.c */
4602extern int cp_dump_tree PARAMS ((dump_info_p, tree));
4603
8d08fdba
MS
4604/* -- end of C++ */
4605
4606#endif /* not _CP_TREE_H */
This page took 1.800792 seconds and 5 git commands to generate.