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