]> gcc.gnu.org Git - gcc.git/blame - gcc/cp/cp-tree.h
class.c (finish_struct_methods): Remove unncessary code.
[gcc.git] / gcc / cp / cp-tree.h
CommitLineData
8d08fdba 1/* Definitions for C++ parsing and type checking.
b2f29cd9 2 Copyright (C) 1987, 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999,
b0bc6e8e 3 2000, 2001, 2002, 2003, 2004 Free Software Foundation, Inc.
06ceef4e 4 Contributed by Michael Tiemann (tiemann@cygnus.com)
8d08fdba 5
f5adbb8d 6This file is part of GCC.
8d08fdba 7
f5adbb8d 8GCC is free software; you can redistribute it and/or modify
8d08fdba
MS
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
f5adbb8d 13GCC is distributed in the hope that it will be useful,
8d08fdba
MS
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
f5adbb8d 19along with GCC; 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
8c6ae51f
GK
23#ifndef GCC_CP_TREE_H
24#define GCC_CP_TREE_H
25
17211ab5 26#include "ggc.h"
99dccabc 27#include "function.h"
ee94fce6 28#include "hashtab.h"
46e8c075 29#include "splay-tree.h"
58c42dc2 30#include "vec.h"
9cd64686 31#include "varray.h"
d7e7759d 32#include "c-common.h"
aed81407 33#include "name-lookup.h"
7cb32822
NB
34struct diagnostic_context;
35
cfdd0551 36/* Usage of TREE_LANG_FLAG_?:
809e3e7f 37 0: IDENTIFIER_MARKED (IDENTIFIER_NODEs)
cfdd0551
PB
38 NEW_EXPR_USE_GLOBAL (in NEW_EXPR).
39 DELETE_EXPR_USE_GLOBAL (in DELETE_EXPR).
8e1daa34 40 COMPOUND_EXPR_OVERLOADED (in COMPOUND_EXPR).
b26caacd 41 TREE_INDIRECT_USING (in NAMESPACE_DECL).
27b8d0cd 42 ICS_USER_FLAG (in _CONV)
f1dedc31 43 CLEANUP_P (in TRY_BLOCK)
e1376b00 44 AGGR_INIT_VIA_CTOR_P (in AGGR_INIT_EXPR)
19420d00 45 PTRMEM_OK_P (in ADDR_EXPR, OFFSET_REF)
39703eb9 46 DECL_PRETTY_FUNCTION_P (in VAR_DECL)
6d80c4b9 47 KOENIG_LOOKUP_P (in CALL_EXPR)
325c3691
RH
48 STATEMENT_LIST_NO_SCOPE (in STATEMENT_LIST).
49 EXPR_STMT_STMT_EXPR_RESULT (in EXPR_STMT)
5882f0f3 50 BIND_EXPR_TRY_BLOCK (in BIND_EXPR)
4bb0968f 51 1: IDENTIFIER_VIRTUAL_P.
cfdd0551 52 TI_PENDING_TEMPLATE_FLAG.
cfdd0551
PB
53 TEMPLATE_PARMS_FOR_INLINE.
54 DELETE_EXPR_USE_VEC (in DELETE_EXPR).
55 (TREE_CALLS_NEW) (in _EXPR or _REF) (commented-out).
4c6b7393 56 TYPE_BASE_CONVS_MAY_REQUIRE_CODE_P (in _TYPE).
27b8d0cd 57 ICS_ELLIPSIS_FLAG (in _CONV)
17bbb839 58 DECL_INITIALIZED_P (in VAR_DECL)
cfdd0551 59 2: IDENTIFIER_OPNAME_P.
3f16a8f3 60 TYPE_POLYMORPHIC_P (in _TYPE)
27b8d0cd 61 ICS_THIS_FLAG (in _CONV)
39703eb9 62 DECL_INITIALIZED_BY_CONSTANT_EXPRESSION_P (in VAR_DECL)
325c3691 63 STATEMENT_LIST_TRY_BLOCK (in STATEMENT_LIST)
cfdd0551 64 3: TYPE_USES_VIRTUAL_BASECLASSES (in a class TYPE).
cfdd0551 65 (TREE_REFERENCE_EXPR) (in NON_LVALUE_EXPR) (commented-out).
27b8d0cd 66 ICS_BAD_FLAG (in _CONV)
62409b39 67 FN_TRY_BLOCK_P (in TRY_BLOCK)
298d6f60 68 IDENTIFIER_CTOR_OR_DTOR_P (in IDENTIFIER_NODE)
5882f0f3 69 BIND_EXPR_BODY_BLOCK (in BIND_EXPR)
809e3e7f 70 4: TREE_HAS_CONSTRUCTOR (in INDIRECT_REF, SAVE_EXPR, CONSTRUCTOR,
cfdd0551 71 or FIELD_DECL).
421844e7 72 IDENTIFIER_TYPENAME_P (in IDENTIFIER_NODE)
0e5921e8 73 5: C_IS_RESERVED_WORD (in IDENTIFIER_NODE)
d35543c0 74 DECL_VTABLE_OR_VTT_P (in VAR_DECL)
dbbf88d1 75 6: For future expansion
cfdd0551
PB
76
77 Usage of TYPE_LANG_FLAG_?:
5552b43c 78 0: TYPE_DEPENDENT_P
cfdd0551
PB
79 1: TYPE_HAS_CONSTRUCTOR.
80 2: TYPE_HAS_DESTRUCTOR.
ea419909 81 3: TYPE_FOR_JAVA.
834c6dff 82 4: TYPE_HAS_NONTRIVIAL_DESTRUCTOR
cfdd0551 83 5: IS_AGGR_TYPE.
5552b43c 84 6: TYPE_DEPENDENT_P_VALID
cfdd0551
PB
85
86 Usage of DECL_LANG_FLAG_?:
87 0: DECL_ERROR_REPORTED (in VAR_DECL).
833aa4c4 88 DECL_TEMPLATE_PARM_P (in PARM_DECL, CONST_DECL, TYPE_DECL, or TEMPLATE_DECL)
cd9f6678 89 DECL_LOCAL_FUNCTION_P (in FUNCTION_DECL)
721c3b42 90 DECL_MUTABLE_P (in FIELD_DECL)
cfdd0551 91 1: C_TYPEDEF_EXPLICITLY_SIGNED (in TYPE_DECL).
fbf1c34b 92 DECL_TEMPLATE_INSTANTIATED (in a VAR_DECL or a FUNCTION_DECL)
cfdd0551 93 2: DECL_THIS_EXTERN (in VAR_DECL or FUNCTION_DECL).
9188c363 94 DECL_IMPLICIT_TYPEDEF_P (in a TYPE_DECL)
cfdd0551 95 3: DECL_IN_AGGR_P.
17bbb839 96 4: DECL_C_BIT_FIELD (in a FIELD_DECL)
772f8889 97 DECL_VAR_MARKED_P (in a VAR_DECL)
a3d87771 98 DECL_SELF_REFERENCE_P (in a TYPE_DECL)
878cbb73 99 DECL_INVALID_OVERRIDER_P (in a FUNCTION_DECL)
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 106
7ddedda4
MM
107 TYPE_ALIAS_SET
108 This field is used by TYPENAME_TYPEs, TEMPLATE_TYPE_PARMs, and so
109 forth as a substitute for the mark bits provided in `lang_type'.
110 At present, only the six low-order bits are used.
111
95b4aca6 112 TYPE_LANG_SLOT_1
7ddedda4 113 For an ENUMERAL_TYPE, this is ENUM_TEMPLATE_INFO.
6d0a3f67 114 For a FUNCTION_TYPE or METHOD_TYPE, this is TYPE_RAISES_EXCEPTIONS
0aafb128 115
9df2c88c 116 BINFO_VIRTUALS
bb5e8a7f
MM
117 For a binfo, this is a TREE_LIST. There is an entry for each
118 virtual function declared either in BINFO or its direct and
119 indirect primary bases.
120
121 The BV_DELTA of each node gives the amount by which to adjust the
122 `this' pointer when calling the function. If the method is an
4639c5c6 123 overridden version of a base class method, then it is assumed
bb5e8a7f
MM
124 that, prior to adjustment, the this pointer points to an object
125 of the base class.
174eceea 126
5e19c053 127 The BV_VCALL_INDEX of each node, if non-NULL, gives the vtable
548502d3 128 index of the vcall offset for this entry.
c0bbf652 129
5e19c053 130 The BV_FN is the declaration for the virtual function itself.
5e19c053 131
c35cce41 132 BINFO_VTABLE
3461fba7 133 This is an expression with POINTER_TYPE that gives the value
c35cce41 134 to which the vptr should be initialized. Use get_vtbl_decl_for_binfo
3461fba7 135 to extract the VAR_DECL for the complete vtable.
c35cce41 136
0fa5e05c 137 DECL_ARGUMENTS
bb20cc46 138 For a VAR_DECL this is DECL_ANON_UNION_ELEMS.
051e6fd7
MM
139
140 DECL_VINDEX
141 This field is NULL for a non-virtual function. For a virtual
142 function, it is eventually set to an INTEGER_CST indicating the
143 index in the vtable at which this function can be found. When
144 a virtual function is declared, but before it is known what
4639c5c6 145 function is overridden, this field is the error_mark_node.
051e6fd7 146
bb20cc46 147 Temporarily, it may be set to a TREE_LIST whose TREE_VALUE is
051e6fd7
MM
148 the virtual function this one overrides, and whose TREE_CHAIN is
149 the old DECL_VINDEX. */
cfdd0551 150
00a17e31 151/* Language-specific tree checkers. */
da8a66fc 152
086e3095
NS
153#define VAR_OR_FUNCTION_DECL_CHECK(NODE) \
154 TREE_CHECK2(NODE,VAR_DECL,FUNCTION_DECL)
155
156#define VAR_FUNCTION_OR_PARM_DECL_CHECK(NODE) \
157 TREE_CHECK3(NODE,VAR_DECL,FUNCTION_DECL,PARM_DECL)
158
159#define VAR_TEMPL_TYPE_OR_FUNCTION_DECL_CHECK(NODE) \
160 TREE_CHECK4(NODE,VAR_DECL,FUNCTION_DECL,TYPE_DECL,TEMPLATE_DECL)
161
086e3095
NS
162#define BOUND_TEMPLATE_TEMPLATE_PARM_TYPE_CHECK(NODE) \
163 TREE_CHECK(NODE,BOUND_TEMPLATE_TEMPLATE_PARM)
d7e7759d 164
bbd15aac 165\f
8d08fdba
MS
166/* Language-dependent contents of an identifier. */
167
e2500fed 168struct lang_identifier GTY(())
8d08fdba 169{
e2500fed 170 struct c_common_identifier c_common;
af6fd53f
GDR
171 cxx_binding *namespace_bindings;
172 cxx_binding *bindings;
8d08fdba 173 tree class_template_info;
85209a3c 174 tree label_value;
8d08fdba
MS
175};
176
0e5921e8
ZW
177/* In an IDENTIFIER_NODE, nonzero if this identifier is actually a
178 keyword. C_RID_CODE (node) is then the RID_* value of the keyword,
179 and C_RID_YYCODE is the token number wanted by Yacc. */
180
98e40e83 181#define C_IS_RESERVED_WORD(ID) TREE_LANG_FLAG_5 (ID)
0e5921e8 182
da8a66fc
ML
183#define LANG_IDENTIFIER_CAST(NODE) \
184 ((struct lang_identifier*)IDENTIFIER_NODE_CHECK (NODE))
185
e2500fed 186typedef struct template_parm_index_s GTY(())
f84b4be9 187{
2bf105ab 188 struct tree_common common;
f84b4be9
JM
189 HOST_WIDE_INT index;
190 HOST_WIDE_INT level;
191 HOST_WIDE_INT orig_level;
192 tree decl;
193} template_parm_index;
194
e2500fed 195struct ptrmem_cst GTY(())
61a127b3 196{
2bf105ab 197 struct tree_common common;
bb20cc46 198 /* This isn't used, but the middle-end expects all constants to have
87e3dbc9 199 this field. */
98e40e83 200 rtx rtl;
61a127b3 201 tree member;
e2500fed
GK
202};
203typedef struct ptrmem_cst * ptrmem_cst_t;
61a127b3 204
30394414 205#define IDENTIFIER_GLOBAL_VALUE(NODE) \
98e40e83 206 namespace_binding ((NODE), global_namespace)
2c73f9f5 207#define SET_IDENTIFIER_GLOBAL_VALUE(NODE, VAL) \
98e40e83 208 set_namespace_binding ((NODE), global_namespace, (VAL))
30394414 209#define IDENTIFIER_NAMESPACE_VALUE(NODE) \
98e40e83 210 namespace_binding ((NODE), current_namespace)
2c73f9f5 211#define SET_IDENTIFIER_NAMESPACE_VALUE(NODE, VAL) \
98e40e83 212 set_namespace_binding ((NODE), current_namespace, (VAL))
30394414 213
d7e7759d 214#define CLEANUP_P(NODE) TREE_LANG_FLAG_0 (TRY_BLOCK_CHECK (NODE))
d7e7759d 215
5882f0f3
RH
216#define BIND_EXPR_TRY_BLOCK(NODE) \
217 TREE_LANG_FLAG_0 (BIND_EXPR_CHECK (NODE))
325c3691
RH
218
219/* Used to mark the block around the member initializers and cleanups. */
5882f0f3
RH
220#define BIND_EXPR_BODY_BLOCK(NODE) \
221 TREE_LANG_FLAG_3 (BIND_EXPR_CHECK (NODE))
325c3691
RH
222
223#define STATEMENT_LIST_NO_SCOPE(NODE) \
224 TREE_LANG_FLAG_0 (STATEMENT_LIST_CHECK (NODE))
225#define STATEMENT_LIST_TRY_BLOCK(NODE) \
226 TREE_LANG_FLAG_2 (STATEMENT_LIST_CHECK (NODE))
227
228/* Marks the result of a statement expression. */
229#define EXPR_STMT_STMT_EXPR_RESULT(NODE) \
230 TREE_LANG_FLAG_0 (EXPR_STMT_CHECK (NODE))
231
d7e7759d
BC
232/* Returns nonzero iff TYPE1 and TYPE2 are the same type, in the usual
233 sense of `same'. */
98e40e83
GS
234#define same_type_p(TYPE1, TYPE2) \
235 comptypes ((TYPE1), (TYPE2), COMPARE_STRICT)
d7e7759d
BC
236
237/* Returns nonzero iff TYPE1 and TYPE2 are the same type, ignoring
238 top-level qualifiers. */
98e40e83
GS
239#define same_type_ignoring_top_level_qualifiers_p(TYPE1, TYPE2) \
240 same_type_p (TYPE_MAIN_VARIANT (TYPE1), TYPE_MAIN_VARIANT (TYPE2))
d7e7759d 241
838dfd8a 242/* Nonzero if we are presently building a statement tree, rather
d7e7759d 243 than expanding each statement as we encounter it. */
325c3691 244#define building_stmt_tree() (cur_stmt_list != NULL_TREE)
d7e7759d 245
838dfd8a 246/* Returns nonzero iff NODE is a declaration for the global function
d7e7759d
BC
247 `main'. */
248#define DECL_MAIN_P(NODE) \
249 (DECL_EXTERN_C_FUNCTION_P (NODE) \
250 && DECL_NAME (NODE) != NULL_TREE \
251 && MAIN_NAME_P (DECL_NAME (NODE)))
252
00a17e31 253/* The overloaded FUNCTION_DECL. */
98e40e83
GS
254#define OVL_FUNCTION(NODE) \
255 (((struct tree_overload*)OVERLOAD_CHECK (NODE))->function)
256#define OVL_CHAIN(NODE) TREE_CHAIN (NODE)
00a17e31 257/* Polymorphic access to FUNCTION and CHAIN. */
2c73f9f5 258#define OVL_CURRENT(NODE) \
98e40e83 259 ((TREE_CODE (NODE) == OVERLOAD) ? OVL_FUNCTION (NODE) : (NODE))
2c73f9f5 260#define OVL_NEXT(NODE) \
98e40e83 261 ((TREE_CODE (NODE) == OVERLOAD) ? TREE_CHAIN (NODE) : NULL_TREE)
2c73f9f5
ML
262/* If set, this was imported in a using declaration.
263 This is not to confuse with being used somewhere, which
00a17e31 264 is not important for this node. */
98e40e83 265#define OVL_USED(NODE) TREE_USED (NODE)
2c73f9f5 266
e2500fed 267struct tree_overload GTY(())
2c73f9f5 268{
2bf105ab 269 struct tree_common common;
2c73f9f5
ML
270 tree function;
271};
272
50ad9642 273/* Returns true iff NODE is a BASELINK. */
4bb0968f 274#define BASELINK_P(NODE) \
50ad9642
MM
275 (TREE_CODE (NODE) == BASELINK)
276/* The BINFO indicating the base from which the BASELINK_FUNCTIONS came. */
4ba126e4 277#define BASELINK_BINFO(NODE) \
5dae1114 278 (((struct tree_baselink*) BASELINK_CHECK (NODE))->binfo)
50ad9642
MM
279/* The functions referred to by the BASELINK; either a FUNCTION_DECL,
280 a TEMPLATE_DECL, an OVERLOAD, or a TEMPLATE_ID_EXPR. */
da15dae6 281#define BASELINK_FUNCTIONS(NODE) \
5dae1114 282 (((struct tree_baselink*) BASELINK_CHECK (NODE))->functions)
4ba126e4
MM
283/* The BINFO in which the search for the functions indicated by this baselink
284 began. This base is used to determine the accessibility of functions
285 selected by overload resolution. */
286#define BASELINK_ACCESS_BINFO(NODE) \
5dae1114 287 (((struct tree_baselink*) BASELINK_CHECK (NODE))->access_binfo)
4ba126e4
MM
288/* For a type-conversion operator, the BASELINK_OPTYPE indicates the type
289 to which the conversion should occur. This value is important if
290 the BASELINK_FUNCTIONS include a template conversion operator --
291 the BASELINK_OPTYPE can be used to determine what type the user
292 requested. */
293#define BASELINK_OPTYPE(NODE) \
50ad9642 294 (TREE_CHAIN (BASELINK_CHECK (NODE)))
4bb0968f 295
5dae1114
MM
296struct tree_baselink GTY(())
297{
298 struct tree_common common;
299 tree binfo;
300 tree functions;
301 tree access_binfo;
302};
303
b3445994
MM
304/* The different kinds of ids that we ecounter. */
305
306typedef enum cp_id_kind
307{
308 /* Not an id at all. */
309 CP_ID_KIND_NONE,
310 /* An unqualified-id that is not a template-id. */
311 CP_ID_KIND_UNQUALIFIED,
cd0be382 312 /* An unqualified-id that is a dependent name. */
10b1d5e7 313 CP_ID_KIND_UNQUALIFIED_DEPENDENT,
b3445994
MM
314 /* An unqualified template-id. */
315 CP_ID_KIND_TEMPLATE_ID,
316 /* A qualified-id. */
317 CP_ID_KIND_QUALIFIED
318} cp_id_kind;
319
8d08fdba
MS
320/* Macros for access to language-specific slots in an identifier. */
321
30394414 322#define IDENTIFIER_NAMESPACE_BINDINGS(NODE) \
da8a66fc 323 (LANG_IDENTIFIER_CAST (NODE)->namespace_bindings)
8d08fdba 324#define IDENTIFIER_TEMPLATE(NODE) \
da8a66fc 325 (LANG_IDENTIFIER_CAST (NODE)->class_template_info)
8d08fdba 326
af6fd53f
GDR
327/* The IDENTIFIER_BINDING is the innermost cxx_binding for the
328 identifier. It's PREVIOUS is the next outermost binding. Each
147135cc 329 VALUE field is a DECL for the associated declaration. Thus,
f181d4ae
MM
330 name lookup consists simply of pulling off the node at the front
331 of the list (modulo oddities for looking up the names of types,
147135cc 332 and such.) You can use SCOPE field to determine the scope
ed3cf953 333 that bound the name. */
f181d4ae 334#define IDENTIFIER_BINDING(NODE) \
da8a66fc 335 (LANG_IDENTIFIER_CAST (NODE)->bindings)
f181d4ae 336
2c73f9f5
ML
337/* TREE_TYPE only indicates on local and class scope the current
338 type. For namespace scope, the presence of a type in any namespace
339 is indicated with global_type_node, and the real type behind must
00a17e31 340 be found through lookup. */
98e40e83
GS
341#define IDENTIFIER_TYPE_VALUE(NODE) identifier_type_value (NODE)
342#define REAL_IDENTIFIER_TYPE_VALUE(NODE) TREE_TYPE (NODE)
343#define SET_IDENTIFIER_TYPE_VALUE(NODE,TYPE) (TREE_TYPE (NODE) = (TYPE))
2c73f9f5 344#define IDENTIFIER_HAS_TYPE_VALUE(NODE) (IDENTIFIER_TYPE_VALUE (NODE) ? 1 : 0)
8d08fdba 345
98e40e83 346#define IDENTIFIER_LABEL_VALUE(NODE) \
85209a3c 347 (LANG_IDENTIFIER_CAST (NODE)->label_value)
98e40e83 348#define SET_IDENTIFIER_LABEL_VALUE(NODE, VALUE) \
85209a3c 349 IDENTIFIER_LABEL_VALUE (NODE) = (VALUE)
8d08fdba 350
cbb40945
NS
351/* Nonzero if this identifier is used as a virtual function name somewhere
352 (optimizes searches). */
98e40e83 353#define IDENTIFIER_VIRTUAL_P(NODE) TREE_LANG_FLAG_1 (NODE)
8d08fdba 354
f71f87f9
MM
355/* Nonzero if this identifier is the prefix for a mangled C++ operator
356 name. */
98e40e83 357#define IDENTIFIER_OPNAME_P(NODE) TREE_LANG_FLAG_2 (NODE)
8d08fdba 358
4c571114
MM
359/* Nonzero if this identifier is the name of a type-conversion
360 operator. */
421844e7 361#define IDENTIFIER_TYPENAME_P(NODE) \
98e40e83 362 TREE_LANG_FLAG_4 (NODE)
8d08fdba 363
298d6f60
MM
364/* Nonzero if this identifier is the name of a constructor or
365 destructor. */
366#define IDENTIFIER_CTOR_OR_DTOR_P(NODE) \
367 TREE_LANG_FLAG_3 (NODE)
368
8d08fdba 369/* In a RECORD_TYPE or UNION_TYPE, nonzero if any component is read-only. */
5552b43c
MM
370#define C_TYPE_FIELDS_READONLY(TYPE) \
371 (LANG_TYPE_CLASS_CHECK (TYPE)->fields_readonly)
e1cd6e56 372
e1cd6e56 373/* Store a value in that field. */
98e40e83
GS
374#define C_SET_EXP_ORIGINAL_CODE(EXP, CODE) \
375 (TREE_COMPLEXITY (EXP) = (int)(CODE))
8d08fdba 376
a723baf1
MM
377/* The tokens stored in the default argument. */
378
379#define DEFARG_TOKENS(NODE) \
380 (((struct tree_default_arg *)DEFAULT_ARG_CHECK (NODE))->tokens)
381
382struct tree_default_arg GTY (())
383{
384 struct tree_common common;
385 struct cp_token_cache *tokens;
386};
387
e2500fed 388enum cp_tree_node_structure_enum {
e2500fed
GK
389 TS_CP_GENERIC,
390 TS_CP_IDENTIFIER,
391 TS_CP_TPI,
392 TS_CP_PTRMEM,
393 TS_CP_BINDING,
394 TS_CP_OVERLOAD,
5dae1114 395 TS_CP_BASELINK,
e2500fed 396 TS_CP_WRAPPER,
a723baf1 397 TS_CP_DEFAULT_ARG,
e2500fed
GK
398 LAST_TS_CP_ENUM
399};
400
401/* The resulting tree type. */
36a5eadd
GK
402union lang_tree_node GTY((desc ("cp_tree_node_structure (&%h)"),
403 chain_next ("(union lang_tree_node *)TREE_CHAIN (&%h.generic)")))
e2500fed 404{
e2500fed
GK
405 union tree_node GTY ((tag ("TS_CP_GENERIC"),
406 desc ("tree_node_structure (&%h)"))) generic;
407 struct template_parm_index_s GTY ((tag ("TS_CP_TPI"))) tpi;
408 struct ptrmem_cst GTY ((tag ("TS_CP_PTRMEM"))) ptrmem;
e2500fed 409 struct tree_overload GTY ((tag ("TS_CP_OVERLOAD"))) overload;
5dae1114 410 struct tree_baselink GTY ((tag ("TS_CP_BASELINK"))) baselink;
a723baf1 411 struct tree_default_arg GTY ((tag ("TS_CP_DEFAULT_ARG"))) default_arg;
e2500fed
GK
412 struct lang_identifier GTY ((tag ("TS_CP_IDENTIFIER"))) identifier;
413};
414
415\f
7f4edbcb
BS
416enum cp_tree_index
417{
e2d0a11c
MM
418 CPTI_JAVA_BYTE_TYPE,
419 CPTI_JAVA_SHORT_TYPE,
420 CPTI_JAVA_INT_TYPE,
421 CPTI_JAVA_LONG_TYPE,
422 CPTI_JAVA_FLOAT_TYPE,
423 CPTI_JAVA_DOUBLE_TYPE,
424 CPTI_JAVA_CHAR_TYPE,
425 CPTI_JAVA_BOOLEAN_TYPE,
426
7f4edbcb
BS
427 CPTI_WCHAR_DECL,
428 CPTI_VTABLE_ENTRY_TYPE,
429 CPTI_DELTA_TYPE,
c7e266a6 430 CPTI_VTABLE_INDEX_TYPE,
b3ab27f3 431 CPTI_CLEANUP_TYPE,
3ec6bad3 432 CPTI_VTT_PARM_TYPE,
7f4edbcb 433
db1147b2 434 CPTI_TI_DESC_TYPE,
7f4edbcb 435 CPTI_BLTN_DESC_TYPE,
7f4edbcb 436 CPTI_PTR_DESC_TYPE,
db1147b2 437 CPTI_ARY_DESC_TYPE,
7f4edbcb 438 CPTI_FUNC_DESC_TYPE,
db1147b2
NS
439 CPTI_ENUM_DESC_TYPE,
440 CPTI_CLASS_DESC_TYPE,
441 CPTI_SI_CLASS_DESC_TYPE,
442 CPTI_VMI_CLASS_DESC_TYPE,
387769ed 443 CPTI_PTM_DESC_TYPE,
db1147b2 444 CPTI_BASE_DESC_TYPE,
bb20cc46 445
7f4edbcb 446 CPTI_CLASS_TYPE,
7f4edbcb 447 CPTI_UNKNOWN_TYPE,
7f4edbcb
BS
448 CPTI_VTBL_TYPE,
449 CPTI_VTBL_PTR_TYPE,
450 CPTI_STD,
2854d3c6 451 CPTI_ABI,
7f4edbcb 452 CPTI_TYPE_INFO_TYPE,
d689a8f1 453 CPTI_TYPE_INFO_PTR_TYPE,
a723baf1 454 CPTI_TYPE_INFO_REF_TYPE,
7f4edbcb
BS
455 CPTI_ABORT_FNDECL,
456 CPTI_GLOBAL_DELETE_FNDECL,
4b054b80 457 CPTI_AGGR_TAG,
7f4edbcb 458
9cd64686 459 CPTI_CTOR_IDENTIFIER,
9eb71d8c 460 CPTI_COMPLETE_CTOR_IDENTIFIER,
d43829f9
MM
461 CPTI_BASE_CTOR_IDENTIFIER,
462 CPTI_DTOR_IDENTIFIER,
db9b2174 463 CPTI_COMPLETE_DTOR_IDENTIFIER,
d43829f9
MM
464 CPTI_BASE_DTOR_IDENTIFIER,
465 CPTI_DELETING_DTOR_IDENTIFIER,
9cd64686 466 CPTI_DELTA_IDENTIFIER,
9cd64686 467 CPTI_IN_CHARGE_IDENTIFIER,
3ec6bad3 468 CPTI_VTT_PARM_IDENTIFIER,
9cd64686
MM
469 CPTI_NELTS_IDENTIFIER,
470 CPTI_THIS_IDENTIFIER,
471 CPTI_PFN_IDENTIFIER,
9cd64686 472 CPTI_VPTR_IDENTIFIER,
1f6e1acc 473 CPTI_STD_IDENTIFIER,
9cd64686
MM
474
475 CPTI_LANG_NAME_C,
476 CPTI_LANG_NAME_CPLUSPLUS,
477 CPTI_LANG_NAME_JAVA,
478
479 CPTI_EMPTY_EXCEPT_SPEC,
480 CPTI_NULL,
481 CPTI_JCLASS,
9cd64686 482 CPTI_TERMINATE,
52a11cbf 483 CPTI_CALL_UNEXPECTED,
f0105ed3 484 CPTI_ATEXIT,
db4283a0 485 CPTI_DSO_HANDLE,
059fa5e7 486 CPTI_DCAST,
9cd64686 487
9aad8f83 488 CPTI_KEYED_CLASSES,
548502d3 489
7f4edbcb
BS
490 CPTI_MAX
491};
8d08fdba 492
e2500fed 493extern GTY(()) tree cp_global_trees[CPTI_MAX];
7f4edbcb 494
4d8a1dd6
MM
495#define java_byte_type_node cp_global_trees[CPTI_JAVA_BYTE_TYPE]
496#define java_short_type_node cp_global_trees[CPTI_JAVA_SHORT_TYPE]
497#define java_int_type_node cp_global_trees[CPTI_JAVA_INT_TYPE]
498#define java_long_type_node cp_global_trees[CPTI_JAVA_LONG_TYPE]
499#define java_float_type_node cp_global_trees[CPTI_JAVA_FLOAT_TYPE]
500#define java_double_type_node cp_global_trees[CPTI_JAVA_DOUBLE_TYPE]
501#define java_char_type_node cp_global_trees[CPTI_JAVA_CHAR_TYPE]
502#define java_boolean_type_node cp_global_trees[CPTI_JAVA_BOOLEAN_TYPE]
503
7f4edbcb
BS
504#define wchar_decl_node cp_global_trees[CPTI_WCHAR_DECL]
505#define vtable_entry_type cp_global_trees[CPTI_VTABLE_ENTRY_TYPE]
c7e266a6 506/* The type used to represent an offset by which to adjust the `this'
c4372ef4 507 pointer in pointer-to-member types. */
7f4edbcb 508#define delta_type_node cp_global_trees[CPTI_DELTA_TYPE]
c7e266a6
MM
509/* The type used to represent an index into the vtable. */
510#define vtable_index_type cp_global_trees[CPTI_VTABLE_INDEX_TYPE]
db1147b2
NS
511
512#define ti_desc_type_node cp_global_trees[CPTI_TI_DESC_TYPE]
513#define bltn_desc_type_node cp_global_trees[CPTI_BLTN_DESC_TYPE]
514#define ptr_desc_type_node cp_global_trees[CPTI_PTR_DESC_TYPE]
db1147b2
NS
515#define ary_desc_type_node cp_global_trees[CPTI_ARY_DESC_TYPE]
516#define func_desc_type_node cp_global_trees[CPTI_FUNC_DESC_TYPE]
517#define enum_desc_type_node cp_global_trees[CPTI_ENUM_DESC_TYPE]
518#define class_desc_type_node cp_global_trees[CPTI_CLASS_DESC_TYPE]
519#define si_class_desc_type_node cp_global_trees[CPTI_SI_CLASS_DESC_TYPE]
520#define vmi_class_desc_type_node cp_global_trees[CPTI_VMI_CLASS_DESC_TYPE]
387769ed 521#define ptm_desc_type_node cp_global_trees[CPTI_PTM_DESC_TYPE]
db1147b2
NS
522#define base_desc_type_node cp_global_trees[CPTI_BASE_DESC_TYPE]
523
7f4edbcb 524#define class_type_node cp_global_trees[CPTI_CLASS_TYPE]
7f4edbcb 525#define unknown_type_node cp_global_trees[CPTI_UNKNOWN_TYPE]
7f4edbcb
BS
526#define vtbl_type_node cp_global_trees[CPTI_VTBL_TYPE]
527#define vtbl_ptr_type_node cp_global_trees[CPTI_VTBL_PTR_TYPE]
528#define std_node cp_global_trees[CPTI_STD]
2854d3c6 529#define abi_node cp_global_trees[CPTI_ABI]
7f4edbcb 530#define type_info_type_node cp_global_trees[CPTI_TYPE_INFO_TYPE]
d689a8f1 531#define type_info_ptr_type cp_global_trees[CPTI_TYPE_INFO_PTR_TYPE]
a723baf1 532#define type_info_ref_type cp_global_trees[CPTI_TYPE_INFO_REF_TYPE]
7f4edbcb
BS
533#define abort_fndecl cp_global_trees[CPTI_ABORT_FNDECL]
534#define global_delete_fndecl cp_global_trees[CPTI_GLOBAL_DELETE_FNDECL]
4b054b80 535#define current_aggr cp_global_trees[CPTI_AGGR_TAG]
ea419909 536
9cd64686
MM
537/* We cache these tree nodes so as to call get_identifier less
538 frequently. */
539
9eb71d8c 540/* The name of a constructor that takes an in-charge parameter to
db9b2174 541 decide whether or not to construct virtual base classes. */
9cd64686 542#define ctor_identifier cp_global_trees[CPTI_CTOR_IDENTIFIER]
9eb71d8c
MM
543/* The name of a constructor that constructs virtual base classes. */
544#define complete_ctor_identifier cp_global_trees[CPTI_COMPLETE_CTOR_IDENTIFIER]
d43829f9
MM
545/* The name of a constructor that does not construct virtual base classes. */
546#define base_ctor_identifier cp_global_trees[CPTI_BASE_CTOR_IDENTIFIER]
db9b2174
MM
547/* The name of a destructor that takes an in-charge parameter to
548 decide whether or not to destroy virtual base classes and whether
549 or not to delete the object. */
d43829f9 550#define dtor_identifier cp_global_trees[CPTI_DTOR_IDENTIFIER]
db9b2174
MM
551/* The name of a destructor that destroys virtual base classes. */
552#define complete_dtor_identifier cp_global_trees[CPTI_COMPLETE_DTOR_IDENTIFIER]
d43829f9
MM
553/* The name of a destructor that does not destroy virtual base
554 classes. */
555#define base_dtor_identifier cp_global_trees[CPTI_BASE_DTOR_IDENTIFIER]
556/* The name of a destructor that destroys virtual base classes, and
557 then deletes the entire object. */
558#define deleting_dtor_identifier cp_global_trees[CPTI_DELETING_DTOR_IDENTIFIER]
9cd64686 559#define delta_identifier cp_global_trees[CPTI_DELTA_IDENTIFIER]
9cd64686 560#define in_charge_identifier cp_global_trees[CPTI_IN_CHARGE_IDENTIFIER]
3ec6bad3
MM
561/* The name of the parameter that contains a pointer to the VTT to use
562 for this subobject constructor or destructor. */
563#define vtt_parm_identifier cp_global_trees[CPTI_VTT_PARM_IDENTIFIER]
9cd64686
MM
564#define nelts_identifier cp_global_trees[CPTI_NELTS_IDENTIFIER]
565#define this_identifier cp_global_trees[CPTI_THIS_IDENTIFIER]
566#define pfn_identifier cp_global_trees[CPTI_PFN_IDENTIFIER]
9cd64686 567#define vptr_identifier cp_global_trees[CPTI_VPTR_IDENTIFIER]
1f6e1acc
AS
568/* The name of the std namespace. */
569#define std_identifier cp_global_trees[CPTI_STD_IDENTIFIER]
9cd64686
MM
570#define lang_name_c cp_global_trees[CPTI_LANG_NAME_C]
571#define lang_name_cplusplus cp_global_trees[CPTI_LANG_NAME_CPLUSPLUS]
572#define lang_name_java cp_global_trees[CPTI_LANG_NAME_JAVA]
573
574/* Exception specifier used for throw(). */
575#define empty_except_spec cp_global_trees[CPTI_EMPTY_EXCEPT_SPEC]
576
577/* The node for `__null'. */
578#define null_node cp_global_trees[CPTI_NULL]
579
00a17e31 580/* If non-NULL, a POINTER_TYPE equivalent to (java::lang::Class*). */
9cd64686
MM
581#define jclass_node cp_global_trees[CPTI_JCLASS]
582
9cd64686
MM
583/* The declaration for `std::terminate'. */
584#define terminate_node cp_global_trees[CPTI_TERMINATE]
585
52a11cbf
RH
586/* The declaration for "__cxa_call_unexpected". */
587#define call_unexpected_node cp_global_trees[CPTI_CALL_UNEXPECTED]
588
db4283a0 589/* A pointer to `std::atexit'. */
f0105ed3
MM
590#define atexit_node cp_global_trees[CPTI_ATEXIT]
591
db4283a0
MM
592/* A pointer to `__dso_handle'. */
593#define dso_handle_node cp_global_trees[CPTI_DSO_HANDLE]
594
059fa5e7
NS
595/* The declaration of the dynamic_cast runtime. */
596#define dynamic_cast_node cp_global_trees[CPTI_DCAST]
597
b3ab27f3
MM
598/* The type of a destructor. */
599#define cleanup_type cp_global_trees[CPTI_CLEANUP_TYPE]
600
3ec6bad3
MM
601/* The type of the vtt parameter passed to subobject constructors and
602 destructors. */
603#define vtt_parm_type cp_global_trees[CPTI_VTT_PARM_TYPE]
604
9aad8f83
MA
605/* A TREE_LIST of the dynamic classes whose vtables may have to be
606 emitted in this translation unit. */
548502d3 607
9aad8f83 608#define keyed_classes cp_global_trees[CPTI_KEYED_CLASSES]
548502d3 609
dbbf88d1
NS
610/* Node to indicate default access. This must be distinct from the
611 access nodes in tree.h. */
612
613#define access_default_node null_node
614
9cd64686
MM
615/* Global state. */
616
e2500fed 617struct saved_scope GTY(())
ee8fc32b 618{
f44b0c8e 619 VEC(cxx_saved_binding) *old_bindings;
9cd64686 620 tree old_namespace;
ee8fc32b 621 tree decl_ns_list;
fc0e7bf5
MM
622 tree class_name;
623 tree class_type;
9cd64686 624 tree access_specifier;
a8f73d4b 625 tree function_decl;
9cd64686 626 varray_type lang_base;
9cd64686 627 tree lang_name;
9cd64686 628 tree template_parms;
89b578be 629 struct cp_binding_level *x_previous_class_level;
6f80451c 630 tree x_saved_tree;
fc0e7bf5
MM
631
632 HOST_WIDE_INT x_processing_template_decl;
9cd64686 633 int x_processing_specialization;
a723baf1 634 bool x_processing_explicit_instantiation;
a8f73d4b 635 int need_pop_function_context;
fc0e7bf5 636
ae499cce 637 struct stmt_tree_s x_stmt_tree;
fc0e7bf5 638
e2500fed
GK
639 struct cp_binding_level *class_bindings;
640 struct cp_binding_level *bindings;
fc0e7bf5
MM
641
642 struct saved_scope *prev;
9cd64686
MM
643};
644
645/* The current open namespace. */
646
647#define current_namespace scope_chain->old_namespace
648
00a17e31 649/* The stack for namespaces of current declarations. */
ee8fc32b
JM
650
651#define decl_namespace_list scope_chain->decl_ns_list
652
9cd64686
MM
653/* IDENTIFIER_NODE: name of current class */
654
655#define current_class_name scope_chain->class_name
656
657/* _TYPE: the type of the current class */
658
659#define current_class_type scope_chain->class_type
660
661/* When parsing a class definition, the access specifier most recently
662 given by the user, or, if no access specifier was given, the
663 default value appropriate for the kind of class (i.e., struct,
664 class, or union). */
665
666#define current_access_specifier scope_chain->access_specifier
667
668/* Pointer to the top of the language name stack. */
669
9cd64686
MM
670#define current_lang_base scope_chain->lang_base
671#define current_lang_name scope_chain->lang_name
672
673/* Parsing a function declarator leaves a list of parameter names
674 or a chain or parameter decls here. */
675
9cd64686
MM
676#define current_template_parms scope_chain->template_parms
677
678#define processing_template_decl scope_chain->x_processing_template_decl
679#define processing_specialization scope_chain->x_processing_specialization
680#define processing_explicit_instantiation scope_chain->x_processing_explicit_instantiation
681
89b578be
MM
682/* The cached class binding level, from the most recently exited
683 class, or NULL if none. */
9cd64686 684
89b578be 685#define previous_class_level scope_chain->x_previous_class_level
9cd64686 686
70adf8a9
JM
687/* A list of private types mentioned, for deferred access checking. */
688
e2500fed 689extern GTY(()) struct saved_scope *scope_chain;
9cd64686 690
8012c983
MM
691/* Global state pertinent to the current function. */
692
e2500fed 693struct language_function GTY(())
8012c983 694{
e2500fed 695 struct c_language_function base;
ae499cce 696
4519c0a8 697 tree x_dtor_label;
4519c0a8
MM
698 tree x_current_class_ptr;
699 tree x_current_class_ref;
52a11cbf 700 tree x_eh_spec_block;
2c146a76 701 tree x_in_charge_parm;
e0fff4b3 702 tree x_vtt_parm;
0d97bf4c 703 tree x_return_value;
4519c0a8 704
8012c983
MM
705 int returns_value;
706 int returns_null;
efe49da0 707 int returns_abnormally;
8012c983 708 int in_function_try_handler;
1f5a253a 709 int in_base_initializer;
8012c983 710
b2dd096b 711 /* True if this function can throw an exception. */
1c62e7b2 712 BOOL_BITFIELD can_throw : 1;
b2dd096b 713
6625cdb5
JM
714 struct named_label_use_list *x_named_label_uses;
715 struct named_label_list *x_named_labels;
e2500fed 716 struct cp_binding_level *bindings;
8e4ce833 717 varray_type x_local_names;
8012c983
MM
718};
719
99dccabc 720/* The current C++-specific per-function global variables. */
8012c983 721
e2500fed 722#define cp_function_chain (cfun->language)
8012c983
MM
723
724/* In a destructor, the point at which all derived class destroying
725 has been done, just before any base class destroying will be done. */
726
4519c0a8 727#define dtor_label cp_function_chain->x_dtor_label
8012c983 728
8012c983
MM
729/* When we're processing a member function, current_class_ptr is the
730 PARM_DECL for the `this' pointer. The current_class_ref is an
731 expression for `*this'. */
732
a8f73d4b 733#define current_class_ptr \
01d939e8 734 (cfun ? cp_function_chain->x_current_class_ptr : NULL_TREE)
a8f73d4b 735#define current_class_ref \
01d939e8 736 (cfun ? cp_function_chain->x_current_class_ref : NULL_TREE)
8012c983 737
52a11cbf 738/* The EH_SPEC_BLOCK for the exception-specifiers for the current
2c146a76
MM
739 function, if any. */
740
52a11cbf 741#define current_eh_spec_block cp_function_chain->x_eh_spec_block
2c146a76 742
2c146a76 743/* The `__in_chrg' parameter for the current function. Only used for
e0fff4b3 744 constructors and destructors. */
2c146a76
MM
745
746#define current_in_charge_parm cp_function_chain->x_in_charge_parm
747
e0fff4b3
JM
748/* The `__vtt_parm' parameter for the current function. Only used for
749 constructors and destructors. */
750
751#define current_vtt_parm cp_function_chain->x_vtt_parm
752
8012c983
MM
753/* Set to 0 at beginning of a function definition, set to 1 if
754 a return statement that specifies a return value is seen. */
755
756#define current_function_returns_value cp_function_chain->returns_value
757
758/* Set to 0 at beginning of a function definition, set to 1 if
759 a return statement with no argument is seen. */
760
761#define current_function_returns_null cp_function_chain->returns_null
762
efe49da0
JM
763/* Set to 0 at beginning of a function definition, set to 1 if
764 a call to a noreturn function is seen. */
765
766#define current_function_returns_abnormally \
767 cp_function_chain->returns_abnormally
768
4de8668e 769/* Nonzero if we are processing a base initializer. Zero elsewhere. */
1f5a253a
NS
770#define in_base_initializer cp_function_chain->in_base_initializer
771
8012c983
MM
772#define in_function_try_handler cp_function_chain->in_function_try_handler
773
0d97bf4c
JM
774/* Expression always returned from function, or error_mark_node
775 otherwise, for use by the automatic named return value optimization. */
776
777#define current_function_return_value \
778 (cp_function_chain->x_return_value)
779
4546865e
MM
780/* True if NAME is the IDENTIFIER_NODE for an overloaded "operator
781 new" or "operator delete". */
782#define NEW_DELETE_OPNAME_P(NAME) \
783 ((NAME) == ansi_opname (NEW_EXPR) \
784 || (NAME) == ansi_opname (VEC_NEW_EXPR) \
785 || (NAME) == ansi_opname (DELETE_EXPR) \
786 || (NAME) == ansi_opname (VEC_DELETE_EXPR))
787
596ea4e5
AS
788#define ansi_opname(CODE) \
789 (operator_name_info[(int) (CODE)].identifier)
790#define ansi_assopname(CODE) \
791 (assignment_operator_name_info[(int) (CODE)].identifier)
8d08fdba 792
a723baf1
MM
793/* True if NODE is an erroneous expression. */
794
795#define error_operand_p(NODE) \
796 ((NODE) == error_mark_node \
797 || ((NODE) && TREE_TYPE ((NODE)) == error_mark_node))
798
8d08fdba
MS
799/* INTERFACE_ONLY nonzero means that we are in an "interface"
800 section of the compiler. INTERFACE_UNKNOWN nonzero means
801 we cannot trust the value of INTERFACE_ONLY. If INTERFACE_UNKNOWN
802 is zero and INTERFACE_ONLY is zero, it means that we are responsible
803 for exporting definitions that others might need. */
804extern int interface_only, interface_unknown;
8d08fdba
MS
805\f
806/* C++ language-specific tree codes. */
807#define DEFTREECODE(SYM, NAME, TYPE, LENGTH) SYM,
808enum cplus_tree_code {
c7d87c0a 809 CP_DUMMY_TREE_CODE = LAST_C_TREE_CODE,
e92cc029 810#include "cp-tree.def"
8d08fdba
MS
811 LAST_CPLUS_TREE_CODE
812};
813#undef DEFTREECODE
814
009ed910
SB
815#define cp_stmt_codes \
816 CTOR_INITIALIZER, TRY_BLOCK, HANDLER, \
5a508662
RH
817 EH_SPEC_BLOCK, USING_STMT, TAG_DEFN, \
818 IF_STMT, CLEANUP_STMT
009ed910 819
fcad5cf5 820enum languages { lang_c, lang_cplusplus, lang_java };
8d08fdba
MS
821
822/* Macros to make error reporting functions' lives easier. */
823#define TYPE_IDENTIFIER(NODE) (DECL_NAME (TYPE_NAME (NODE)))
1951a1b6
JM
824#define TYPE_LINKAGE_IDENTIFIER(NODE) \
825 (TYPE_IDENTIFIER (TYPE_MAIN_VARIANT (NODE)))
8d08fdba
MS
826#define TYPE_NAME_STRING(NODE) (IDENTIFIER_POINTER (TYPE_IDENTIFIER (NODE)))
827#define TYPE_NAME_LENGTH(NODE) (IDENTIFIER_LENGTH (TYPE_IDENTIFIER (NODE)))
828
1951a1b6
JM
829/* Nonzero if NODE has no name for linkage purposes. */
830#define TYPE_ANONYMOUS_P(NODE) \
831 (TAGGED_TYPE_P (NODE) && ANON_AGGRNAME_P (TYPE_LINKAGE_IDENTIFIER (NODE)))
832
a4443a08 833/* The _DECL for this _TYPE. */
d2e5ee5c 834#define TYPE_MAIN_DECL(NODE) (TYPE_STUB_DECL (TYPE_MAIN_VARIANT (NODE)))
a4443a08 835
c92366fb 836/* Nonzero if T is a class (or struct or union) type. Also nonzero
83233dca
MM
837 for template type parameters, typename types, and instantiated
838 template template parameters. Despite its name,
b80c4d77
MM
839 this macro has nothing to do with the definition of aggregate given
840 in the standard. Think of this macro as MAYBE_CLASS_TYPE_P. */
98e40e83
GS
841#define IS_AGGR_TYPE(T) \
842 (TREE_CODE (T) == TEMPLATE_TYPE_PARM \
843 || TREE_CODE (T) == TYPENAME_TYPE \
844 || TREE_CODE (T) == TYPEOF_TYPE \
845 || TREE_CODE (T) == BOUND_TEMPLATE_TEMPLATE_PARM \
846 || TYPE_LANG_FLAG_5 (T))
7ddedda4 847
bb20cc46
AJ
848/* Set IS_AGGR_TYPE for T to VAL. T must be a class, struct, or
849 union type. */
7ddedda4
MM
850#define SET_IS_AGGR_TYPE(T, VAL) \
851 (TYPE_LANG_FLAG_5 (T) = (VAL))
c92366fb 852
b80c4d77
MM
853/* Nonzero if T is a class type. Zero for template type parameters,
854 typename types, and so forth. */
98e40e83
GS
855#define CLASS_TYPE_P(T) \
856 (IS_AGGR_TYPE_CODE (TREE_CODE (T)) && IS_AGGR_TYPE (T))
c92366fb 857
98e40e83 858#define IS_AGGR_TYPE_CODE(T) ((T) == RECORD_TYPE || (T) == UNION_TYPE)
98e40e83
GS
859#define TAGGED_TYPE_P(T) \
860 (CLASS_TYPE_P (T) || TREE_CODE (T) == ENUMERAL_TYPE)
1951a1b6 861#define IS_OVERLOAD_TYPE(T) TAGGED_TYPE_P (T)
8d08fdba 862
00a17e31 863/* True if this a "Java" type, defined in 'extern "Java"'. */
98e40e83 864#define TYPE_FOR_JAVA(NODE) TYPE_LANG_FLAG_3 (NODE)
ea419909 865
5552b43c
MM
866/* True if this type is dependent. This predicate is only valid if
867 TYPE_DEPENDENT_P_VALID is true. */
868#define TYPE_DEPENDENT_P(NODE) TYPE_LANG_FLAG_0 (NODE)
869
870/* True if dependent_type_p has been called for this type, with the
871 result that TYPE_DEPENDENT_P is valid. */
872#define TYPE_DEPENDENT_P_VALID(NODE) TYPE_LANG_FLAG_6(NODE)
873
91063b51
MM
874/* Nonzero if this type is const-qualified. */
875#define CP_TYPE_CONST_P(NODE) \
89d684bb 876 ((cp_type_quals (NODE) & TYPE_QUAL_CONST) != 0)
91063b51
MM
877
878/* Nonzero if this type is volatile-qualified. */
879#define CP_TYPE_VOLATILE_P(NODE) \
89d684bb 880 ((cp_type_quals (NODE) & TYPE_QUAL_VOLATILE) != 0)
91063b51 881
174bcdb9 882/* Nonzero if this type is restrict-qualified. */
91063b51 883#define CP_TYPE_RESTRICT_P(NODE) \
89d684bb 884 ((cp_type_quals (NODE) & TYPE_QUAL_RESTRICT) != 0)
91063b51
MM
885
886/* Nonzero if this type is const-qualified, but not
887 volatile-qualified. Other qualifiers are ignored. This macro is
888 used to test whether or not it is OK to bind an rvalue to a
889 reference. */
890#define CP_TYPE_CONST_NON_VOLATILE_P(NODE) \
89d684bb 891 ((cp_type_quals (NODE) & (TYPE_QUAL_CONST | TYPE_QUAL_VOLATILE)) \
91063b51
MM
892 == TYPE_QUAL_CONST)
893
e0fff4b3 894#define FUNCTION_ARG_CHAIN(NODE) \
98e40e83 895 TREE_CHAIN (TYPE_ARG_TYPES (TREE_TYPE (NODE)))
e0fff4b3
JM
896
897/* Given a FUNCTION_DECL, returns the first TREE_LIST out of TYPE_ARG_TYPES
898 which refers to a user-written parameter. */
899#define FUNCTION_FIRST_USER_PARMTYPE(NODE) \
98e40e83 900 skip_artificial_parms_for ((NODE), TYPE_ARG_TYPES (TREE_TYPE (NODE)))
e0fff4b3
JM
901
902/* Similarly, but for DECL_ARGUMENTS. */
903#define FUNCTION_FIRST_USER_PARM(NODE) \
98e40e83 904 skip_artificial_parms_for ((NODE), DECL_ARGUMENTS (NODE))
e0fff4b3 905
98e40e83 906#define PROMOTES_TO_AGGR_TYPE(NODE, CODE) \
8d08fdba 907 (((CODE) == TREE_CODE (NODE) \
98e40e83 908 && IS_AGGR_TYPE (TREE_TYPE (NODE))) \
8d08fdba
MS
909 || IS_AGGR_TYPE (NODE))
910
2db1ab2d
NS
911/* Nonzero iff TYPE is derived from PARENT. Ignores accessibility and
912 ambiguity issues. */
98e40e83 913#define DERIVED_FROM_P(PARENT, TYPE) \
c44e68a5 914 (lookup_base ((TYPE), (PARENT), ba_any, NULL) != NULL_TREE)
2db1ab2d
NS
915/* Nonzero iff TYPE is uniquely derived from PARENT. Ignores
916 accessibility. */
98e40e83 917#define UNIQUELY_DERIVED_FROM_P(PARENT, TYPE) \
9cefd2ca 918 (lookup_base ((TYPE), (PARENT), ba_ignore | ba_quiet, NULL) != NULL_TREE)
2db1ab2d
NS
919/* Nonzero iff TYPE is accessible in the current scope and uniquely
920 derived from PARENT. */
98e40e83 921#define ACCESSIBLY_UNIQUELY_DERIVED_P(PARENT, TYPE) \
9cefd2ca 922 (lookup_base ((TYPE), (PARENT), ba_check | ba_quiet, NULL) != NULL_TREE)
2db1ab2d 923/* Nonzero iff TYPE is publicly & uniquely derived from PARENT. */
98e40e83 924#define PUBLICLY_UNIQUELY_DERIVED_P(PARENT, TYPE) \
9cefd2ca
JM
925 (lookup_base ((TYPE), (PARENT), ba_not_special | ba_quiet, NULL) \
926 != NULL_TREE)
8d08fdba 927\f
e2500fed
GK
928/* This is a few header flags for 'struct lang_type'. Actually,
929 all but the first are used only for lang_type_class; they
930 are put in this structure to save space. */
a3bf324c 931struct lang_type_header GTY(())
e2500fed 932{
1c62e7b2
KG
933 BOOL_BITFIELD is_lang_type_class : 1;
934
935 BOOL_BITFIELD has_type_conversion : 1;
936 BOOL_BITFIELD has_init_ref : 1;
937 BOOL_BITFIELD has_default_ctor : 1;
938 BOOL_BITFIELD uses_multiple_inheritance : 1;
939 BOOL_BITFIELD const_needs_init : 1;
940 BOOL_BITFIELD ref_needs_init : 1;
941 BOOL_BITFIELD has_const_assign_ref : 1;
e2500fed
GK
942};
943
58c42dc2
NS
944DEF_VEC_P (tree);
945
7ddedda4
MM
946/* This structure provides additional information above and beyond
947 what is provide in the ordinary tree_type. In the past, we used it
948 for the types of class types, template parameters types, typename
949 types, and so forth. However, there can be many (tens to hundreds
950 of thousands) of template parameter types in a compilation, and
951 there's no need for this additional information in that case.
952 Therefore, we now use this data structure only for class types.
953
954 In the past, it was thought that there would be relatively few
955 class types. However, in the presence of heavy use of templates,
956 many (i.e., thousands) of classes can easily be generated.
957 Therefore, we should endeavor to keep the size of this structure to
958 a minimum. */
e2500fed 959struct lang_type_class GTY(())
8d08fdba 960{
e2500fed
GK
961 struct lang_type_header h;
962
8012c983
MM
963 unsigned char align;
964
5b0cec3b
MM
965 unsigned has_mutable : 1;
966 unsigned com_interface : 1;
967 unsigned non_pod_class : 1;
968 unsigned nearly_empty_p : 1;
46ccf50a 969 unsigned user_align : 1;
8012c983 970 unsigned has_assign_ref : 1;
834c6dff
MM
971 unsigned has_new : 1;
972 unsigned has_array_new : 1;
8012c983
MM
973
974 unsigned gets_delete : 2;
8012c983
MM
975 unsigned interface_only : 1;
976 unsigned interface_unknown : 1;
8fbc5ae7 977 unsigned contains_empty_class_p : 1;
560ad596
MM
978 unsigned anon_aggr : 1;
979 unsigned non_zero_init : 1;
980 unsigned empty_p : 1;
8012c983
MM
981
982 unsigned marks: 6;
dbc957f1 983 unsigned vec_new_uses_cookie : 1;
8012c983
MM
984 unsigned declared_class : 1;
985
986 unsigned being_defined : 1;
987 unsigned redefined : 1;
988 unsigned debug_requested : 1;
989 unsigned use_template : 2;
560ad596 990 unsigned fields_readonly : 1;
8012c983
MM
991 unsigned ptrmemfunc_flag : 1;
992 unsigned was_anonymous : 1;
993
508a1c9c
MM
994 unsigned lazy_default_ctor : 1;
995 unsigned lazy_copy_ctor : 1;
8012c983
MM
996 unsigned has_const_init_ref : 1;
997 unsigned has_complex_init_ref : 1;
998 unsigned has_complex_assign_ref : 1;
8012c983 999 unsigned non_aggregate : 1;
60c87482 1000 unsigned java_interface : 1;
94e6e4c4 1001
8012c983
MM
1002 /* When adding a flag here, consider whether or not it ought to
1003 apply to a template instance if it applies to the template. If
1004 so, make sure to copy it in instantiate_class_template! */
1005
5b0cec3b
MM
1006 /* There are some bits left to fill out a 32-bit word. Keep track
1007 of this by updating the size of this bitfield whenever you add or
8012c983 1008 remove a flag. */
508a1c9c 1009 unsigned dummy : 9;
bb20cc46 1010
911a71a7 1011 tree primary_base;
c35cce41 1012 tree vfields;
548502d3
MM
1013 tree vcall_indices;
1014 tree vtables;
a82d6da5 1015 tree typeinfo_var;
58c42dc2 1016 VEC (tree) *vbases;
5e0c54e5 1017 binding_table nested_udts;
17bbb839 1018 tree as_base;
c35cce41
MM
1019 tree pure_virtuals;
1020 tree friend_classes;
aaaa46d2 1021 VEC (tree) * GTY((reorder ("resort_type_method_vec"))) methods;
9aad8f83 1022 tree key_method;
7088fca9 1023 tree decl_list;
c35cce41 1024 tree template_info;
6a629cac 1025 tree befriending_classes;
8d08fdba
MS
1026};
1027
e2500fed
GK
1028struct lang_type_ptrmem GTY(())
1029{
1030 struct lang_type_header h;
1031 tree record;
1032};
1033
1034struct lang_type GTY(())
1035{
1036 union lang_type_u
1037 {
165b54c3 1038 struct lang_type_header GTY((skip (""))) h;
e2500fed
GK
1039 struct lang_type_class GTY((tag ("1"))) c;
1040 struct lang_type_ptrmem GTY((tag ("0"))) ptrmem;
1041 } GTY((desc ("%h.h.is_lang_type_class"))) u;
1042};
1043
1044#if defined ENABLE_TREE_CHECKING && (GCC_VERSION >= 2007)
1045
de94b46c 1046#define LANG_TYPE_CLASS_CHECK(NODE) __extension__ \
e2500fed
GK
1047({ struct lang_type *lt = TYPE_LANG_SPECIFIC (NODE); \
1048 if (! lt->u.h.is_lang_type_class) \
1049 lang_check_failed (__FILE__, __LINE__, __FUNCTION__); \
1050 &lt->u.c; })
1051
de94b46c 1052#define LANG_TYPE_PTRMEM_CHECK(NODE) __extension__ \
e2500fed
GK
1053({ struct lang_type *lt = TYPE_LANG_SPECIFIC (NODE); \
1054 if (lt->u.h.is_lang_type_class) \
1055 lang_check_failed (__FILE__, __LINE__, __FUNCTION__); \
1056 &lt->u.ptrmem; })
1057
1058#else
1059
1060#define LANG_TYPE_CLASS_CHECK(NODE) (&TYPE_LANG_SPECIFIC (NODE)->u.c)
1061#define LANG_TYPE_PTRMEM_CHECK(NODE) (&TYPE_LANG_SPECIFIC (NODE)->u.ptrmem)
1062
1063#endif /* ENABLE_TREE_CHECKING */
1064
a0a33927
MS
1065/* Indicates whether or not (and how) a template was expanded for this class.
1066 0=no information yet/non-template class
1067 1=implicit template instantiation
1068 2=explicit template specialization
1069 3=explicit template instantiation */
e2500fed
GK
1070#define CLASSTYPE_USE_TEMPLATE(NODE) \
1071 (LANG_TYPE_CLASS_CHECK (NODE)->use_template)
8d08fdba
MS
1072
1073/* Fields used for storing information before the class is defined.
1074 After the class is defined, these fields hold other information. */
1075
1076/* List of friends which were defined inline in this class definition. */
98e40e83 1077#define CLASSTYPE_INLINE_FRIENDS(NODE) CLASSTYPE_PURE_VIRTUALS (NODE)
8d08fdba 1078
834c6dff 1079/* Nonzero for _CLASSTYPE means that operator delete is defined. */
e2500fed 1080#define TYPE_GETS_DELETE(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->gets_delete)
a28e3c7f
MS
1081#define TYPE_GETS_REG_DELETE(NODE) (TYPE_GETS_DELETE (NODE) & 1)
1082
834c6dff 1083/* Nonzero if `new NODE[x]' should cause the allocation of extra
dbc957f1
MM
1084 storage to indicate how many array elements are in use. */
1085#define TYPE_VEC_NEW_USES_COOKIE(NODE) \
1086 (CLASS_TYPE_P (NODE) \
e2500fed 1087 && LANG_TYPE_CLASS_CHECK (NODE)->vec_new_uses_cookie)
8d08fdba 1088
8d08fdba
MS
1089/* Nonzero means that this _CLASSTYPE node defines ways of converting
1090 itself to other types. */
98e40e83 1091#define TYPE_HAS_CONVERSION(NODE) \
e2500fed 1092 (LANG_TYPE_CLASS_CHECK (NODE)->h.has_type_conversion)
8d08fdba 1093
508a1c9c
MM
1094/* Nonzero means that NODE (a class type) has a default constructor --
1095 but that it has not yet been declared. */
1096#define CLASSTYPE_LAZY_DEFAULT_CTOR(NODE) \
1097 (LANG_TYPE_CLASS_CHECK (NODE)->lazy_default_ctor)
1098
1099/* Nonzero means that NODE (a class type) has a copy constructor --
1100 but that it has not yet been declared. */
1101#define CLASSTYPE_LAZY_COPY_CTOR(NODE) \
1102 (LANG_TYPE_CLASS_CHECK (NODE)->lazy_copy_ctor)
1103
8d08fdba 1104/* Nonzero means that this _CLASSTYPE node overloads operator=(X&). */
e2500fed 1105#define TYPE_HAS_ASSIGN_REF(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->has_assign_ref)
aaaa46d2
MM
1106
1107/* True iff the class type NODE has an "operator =" whose parameter
1108 has a parameter of type "const X&". */
98e40e83 1109#define TYPE_HAS_CONST_ASSIGN_REF(NODE) \
e2500fed 1110 (LANG_TYPE_CLASS_CHECK (NODE)->h.has_const_assign_ref)
8d08fdba
MS
1111
1112/* Nonzero means that this _CLASSTYPE node has an X(X&) constructor. */
e2500fed 1113#define TYPE_HAS_INIT_REF(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->h.has_init_ref)
98e40e83 1114#define TYPE_HAS_CONST_INIT_REF(NODE) \
e2500fed 1115 (LANG_TYPE_CLASS_CHECK (NODE)->has_const_init_ref)
8d08fdba 1116
834c6dff
MM
1117/* Nonzero if this class defines an overloaded operator new. (An
1118 operator new [] doesn't count.) */
1119#define TYPE_HAS_NEW_OPERATOR(NODE) \
e2500fed 1120 (LANG_TYPE_CLASS_CHECK (NODE)->has_new)
834c6dff
MM
1121
1122/* Nonzero if this class defines an overloaded operator new[]. */
1123#define TYPE_HAS_ARRAY_NEW_OPERATOR(NODE) \
e2500fed 1124 (LANG_TYPE_CLASS_CHECK (NODE)->has_array_new)
834c6dff 1125
8d08fdba
MS
1126/* Nonzero means that this type is being defined. I.e., the left brace
1127 starting the definition of this type has been seen. */
e2500fed 1128#define TYPE_BEING_DEFINED(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->being_defined)
8d08fdba
MS
1129/* Nonzero means that this type has been redefined. In this case, if
1130 convenient, don't reprocess any methods that appear in its redefinition. */
e2500fed 1131#define TYPE_REDEFINED(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->redefined)
8d08fdba 1132
8d08fdba
MS
1133/* Nonzero means that this _CLASSTYPE (or one of its ancestors) uses
1134 multiple inheritance. If this is 0 for the root of a type
1135 hierarchy, then we can use more efficient search techniques. */
98e40e83 1136#define TYPE_USES_MULTIPLE_INHERITANCE(NODE) \
e2500fed 1137 (LANG_TYPE_CLASS_CHECK (NODE)->h.uses_multiple_inheritance)
8d08fdba
MS
1138
1139/* Nonzero means that this _CLASSTYPE (or one of its ancestors) uses
1140 virtual base classes. If this is 0 for the root of a type
1141 hierarchy, then we can use more efficient search techniques. */
98e40e83 1142#define TYPE_USES_VIRTUAL_BASECLASSES(NODE) (TREE_LANG_FLAG_3 (NODE))
8d08fdba 1143
9aad8f83
MA
1144/* The member function with which the vtable will be emitted:
1145 the first noninline non-pure-virtual member function. NULL_TREE
1146 if there is no key function or if this is a class template */
1147#define CLASSTYPE_KEY_METHOD(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->key_method)
1148
61a127b3 1149/* Vector member functions defined in this class. Each element is
03017874
MM
1150 either a FUNCTION_DECL, a TEMPLATE_DECL, or an OVERLOAD. All
1151 functions with the same name end up in the same slot. The first
61a127b3 1152 two elements are for constructors, and destructors, respectively.
5dd236e2
NS
1153 All template conversion operators to innermost template dependent
1154 types are overloaded on the next slot, if they exist. Note, the
1155 names for these functions will not all be the same. The
1156 non-template conversion operators & templated conversions to
1157 non-innermost template types are next, followed by ordinary member
1158 functions. There may be empty entries at the end of the vector.
1159 The conversion operators are unsorted. The ordinary member
1160 functions are sorted, once the class is complete. */
e2500fed 1161#define CLASSTYPE_METHOD_VEC(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->methods)
8d08fdba 1162
7088fca9
KL
1163/* For class templates, this is a TREE_LIST of all member data,
1164 functions, types, and friends in the order of declaration.
1165 The TREE_PURPOSE of each TREE_LIST is NULL_TREE for a friend,
1166 and the RECORD_TYPE for the class template otherwise. */
1167#define CLASSTYPE_DECL_LIST(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->decl_list)
1168
db9b2174
MM
1169/* The slot in the CLASSTYPE_METHOD_VEC where constructors go. */
1170#define CLASSTYPE_CONSTRUCTOR_SLOT 0
1171
1172/* The slot in the CLASSTYPE_METHOD_VEC where destructors go. */
1173#define CLASSTYPE_DESTRUCTOR_SLOT 1
1174
1175/* The first slot in the CLASSTYPE_METHOD_VEC where conversion
1176 operators can appear. */
1177#define CLASSTYPE_FIRST_CONVERSION_SLOT 2
1178
1179/* A FUNCTION_DECL or OVERLOAD for the constructors for NODE. These
1180 are the constructors that take an in-charge parameter. */
1181#define CLASSTYPE_CONSTRUCTORS(NODE) \
aaaa46d2 1182 (VEC_index (tree, CLASSTYPE_METHOD_VEC (NODE), CLASSTYPE_CONSTRUCTOR_SLOT))
db9b2174 1183
52682a1b 1184/* A FUNCTION_DECL for the destructor for NODE. These are the
db9b2174
MM
1185 destructors that take an in-charge parameter. */
1186#define CLASSTYPE_DESTRUCTORS(NODE) \
aaaa46d2 1187 (VEC_index (tree, CLASSTYPE_METHOD_VEC (NODE), CLASSTYPE_DESTRUCTOR_SLOT))
e1cd6e56 1188
8d08fdba 1189/* Mark bits for depth-first and breath-first searches. */
7ddedda4
MM
1190
1191/* Get the value of the Nth mark bit. */
ba793d6e 1192#define CLASSTYPE_MARKED_N(NODE, N) \
e2500fed 1193 (((CLASS_TYPE_P (NODE) ? LANG_TYPE_CLASS_CHECK (NODE)->marks \
98e40e83 1194 : ((unsigned) TYPE_ALIAS_SET (NODE))) & (1 << (N))) != 0)
7ddedda4
MM
1195
1196/* Set the Nth mark bit. */
ba793d6e
MM
1197#define SET_CLASSTYPE_MARKED_N(NODE, N) \
1198 (CLASS_TYPE_P (NODE) \
e2500fed 1199 ? (void) (LANG_TYPE_CLASS_CHECK (NODE)->marks |= (1 << (N))) \
ba793d6e 1200 : (void) (TYPE_ALIAS_SET (NODE) |= (1 << (N))))
7ddedda4
MM
1201
1202/* Clear the Nth mark bit. */
ba793d6e
MM
1203#define CLEAR_CLASSTYPE_MARKED_N(NODE, N) \
1204 (CLASS_TYPE_P (NODE) \
e2500fed 1205 ? (void) (LANG_TYPE_CLASS_CHECK (NODE)->marks &= ~(1 << (N))) \
ba793d6e 1206 : (void) (TYPE_ALIAS_SET (NODE) &= ~(1 << (N))))
7ddedda4
MM
1207
1208/* Get the value of the mark bits. */
98e40e83
GS
1209#define CLASSTYPE_MARKED(NODE) CLASSTYPE_MARKED_N (NODE, 0)
1210#define CLASSTYPE_MARKED2(NODE) CLASSTYPE_MARKED_N (NODE, 1)
1211#define CLASSTYPE_MARKED3(NODE) CLASSTYPE_MARKED_N (NODE, 2)
1212#define CLASSTYPE_MARKED4(NODE) CLASSTYPE_MARKED_N (NODE, 3)
1213#define CLASSTYPE_MARKED5(NODE) CLASSTYPE_MARKED_N (NODE, 4)
1214#define CLASSTYPE_MARKED6(NODE) CLASSTYPE_MARKED_N (NODE, 5)
7ddedda4 1215
8d08fdba 1216/* Macros to modify the above flags */
98e40e83
GS
1217#define SET_CLASSTYPE_MARKED(NODE) SET_CLASSTYPE_MARKED_N (NODE, 0)
1218#define CLEAR_CLASSTYPE_MARKED(NODE) CLEAR_CLASSTYPE_MARKED_N (NODE, 0)
1219#define SET_CLASSTYPE_MARKED2(NODE) SET_CLASSTYPE_MARKED_N (NODE, 1)
1220#define CLEAR_CLASSTYPE_MARKED2(NODE) CLEAR_CLASSTYPE_MARKED_N (NODE, 1)
1221#define SET_CLASSTYPE_MARKED3(NODE) SET_CLASSTYPE_MARKED_N (NODE, 2)
1222#define CLEAR_CLASSTYPE_MARKED3(NODE) CLEAR_CLASSTYPE_MARKED_N (NODE, 2)
1223#define SET_CLASSTYPE_MARKED4(NODE) SET_CLASSTYPE_MARKED_N (NODE, 3)
1224#define CLEAR_CLASSTYPE_MARKED4(NODE) CLEAR_CLASSTYPE_MARKED_N (NODE, 3)
1225#define SET_CLASSTYPE_MARKED5(NODE) SET_CLASSTYPE_MARKED_N (NODE, 4)
1226#define CLEAR_CLASSTYPE_MARKED5(NODE) CLEAR_CLASSTYPE_MARKED_N (NODE, 4)
1227#define SET_CLASSTYPE_MARKED6(NODE) SET_CLASSTYPE_MARKED_N (NODE, 5)
1228#define CLEAR_CLASSTYPE_MARKED6(NODE) CLEAR_CLASSTYPE_MARKED_N (NODE, 5)
8d08fdba 1229
5e0c54e5
GDR
1230/* A dictionary of the nested user-defined-types (class-types, or enums)
1231 found within this class. This table includes nested member class
1232 templates. */
1233#define CLASSTYPE_NESTED_UTDS(NODE) \
1234 (LANG_TYPE_CLASS_CHECK (NODE)->nested_udts)
8d08fdba 1235
3ef397c1 1236/* Nonzero if NODE has a primary base class, i.e., a base class with
0811ea8f 1237 which it shares the virtual function table pointer. */
3ef397c1 1238#define CLASSTYPE_HAS_PRIMARY_BASE_P(NODE) \
911a71a7 1239 (CLASSTYPE_PRIMARY_BINFO (NODE) != NULL_TREE)
3ef397c1
MM
1240
1241/* If non-NULL, this is the binfo for the primary base class, i.e.,
1242 the base class which contains the virtual function table pointer
1243 for this class. */
5e19c053 1244#define CLASSTYPE_PRIMARY_BINFO(NODE) \
e2500fed 1245 (LANG_TYPE_CLASS_CHECK (NODE)->primary_base)
3ef397c1 1246
58c42dc2 1247/* A vector of BINFOs for the direct and indirect virtual base classes
c35cce41
MM
1248 that this type uses in a post-order depth-first left-to-right
1249 order. (In other words, these bases appear in the order that they
dbbf88d1 1250 should be initialized.) */
e2500fed 1251#define CLASSTYPE_VBASECLASSES(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->vbases)
23381155 1252
17bbb839
MM
1253/* The type corresponding to NODE when NODE is used as a base class,
1254 i.e., NODE without virtual base classes. */
1255
1256#define CLASSTYPE_AS_BASE(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->as_base)
1257
00bfffa4
JM
1258/* True iff NODE is the CLASSTYPE_AS_BASE version of some type. */
1259
1260#define IS_FAKE_BASE_TYPE(NODE) \
1261 (TREE_CODE (NODE) == RECORD_TYPE \
1262 && TYPE_CONTEXT (NODE) && CLASS_TYPE_P (TYPE_CONTEXT (NODE)) \
1263 && CLASSTYPE_AS_BASE (TYPE_CONTEXT (NODE)) == (NODE))
1264
2d926395
MM
1265/* These are the size and alignment of the type without its virtual
1266 base classes, for when we use this type as a base itself. */
17bbb839
MM
1267#define CLASSTYPE_SIZE(NODE) TYPE_SIZE (CLASSTYPE_AS_BASE (NODE))
1268#define CLASSTYPE_SIZE_UNIT(NODE) TYPE_SIZE_UNIT (CLASSTYPE_AS_BASE (NODE))
1269#define CLASSTYPE_ALIGN(NODE) TYPE_ALIGN (CLASSTYPE_AS_BASE (NODE))
1270#define CLASSTYPE_USER_ALIGN(NODE) TYPE_USER_ALIGN (CLASSTYPE_AS_BASE (NODE))
8d08fdba 1271
1b50716d
MM
1272/* The alignment of NODE, without its virtual bases, in bytes. */
1273#define CLASSTYPE_ALIGN_UNIT(NODE) \
1274 (CLASSTYPE_ALIGN (NODE) / BITS_PER_UNIT)
1275
60c87482 1276/* True if this a Java interface type, declared with
00a17e31 1277 '__attribute__ ((java_interface))'. */
e2500fed 1278#define TYPE_JAVA_INTERFACE(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->java_interface)
60c87482 1279
8d08fdba
MS
1280/* A cons list of virtual functions which cannot be inherited by
1281 derived classes. When deriving from this type, the derived
1282 class must provide its own definition for each of these functions. */
e2500fed 1283#define CLASSTYPE_PURE_VIRTUALS(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->pure_virtuals)
8d08fdba 1284
8d08fdba 1285/* Nonzero means that this type has an X() constructor. */
98e40e83 1286#define TYPE_HAS_DEFAULT_CONSTRUCTOR(NODE) \
e2500fed 1287 (LANG_TYPE_CLASS_CHECK (NODE)->h.has_default_ctor)
8d08fdba 1288
f4f206f4 1289/* Nonzero means that this type contains a mutable member. */
e2500fed 1290#define CLASSTYPE_HAS_MUTABLE(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->has_mutable)
a7a7710d
NS
1291#define TYPE_HAS_MUTABLE_P(NODE) (cp_has_mutable_p (NODE))
1292
94e6e4c4 1293/* Nonzero means that this class type is a non-POD class. */
e2500fed 1294#define CLASSTYPE_NON_POD_P(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->non_pod_class)
52fb2769 1295
94e6e4c4
AO
1296/* Nonzero means that this class contains pod types whose default
1297 initialization is not a zero initialization (namely, pointers to
1298 data members). */
e2500fed
GK
1299#define CLASSTYPE_NON_ZERO_INIT_P(NODE) \
1300 (LANG_TYPE_CLASS_CHECK (NODE)->non_zero_init)
94e6e4c4 1301
58731fd1
MM
1302/* Nonzero if this class is "empty" in the sense of the C++ ABI. */
1303#define CLASSTYPE_EMPTY_P(NODE) \
1304 (LANG_TYPE_CLASS_CHECK (NODE)->empty_p)
1305
f9c528ea
MM
1306/* Nonzero if this class is "nearly empty", i.e., contains only a
1307 virtual function table pointer. */
1308#define CLASSTYPE_NEARLY_EMPTY_P(NODE) \
e2500fed 1309 (LANG_TYPE_CLASS_CHECK (NODE)->nearly_empty_p)
f9c528ea 1310
5ec1192e
MM
1311/* Nonzero if this class contains an empty subobject. */
1312#define CLASSTYPE_CONTAINS_EMPTY_CLASS_P(NODE) \
1313 (LANG_TYPE_CLASS_CHECK (NODE)->contains_empty_class_p)
1314
6a629cac 1315/* A list of class types of which this type is a friend. The
ea4e080b
MM
1316 TREE_VALUE is normally a TYPE, but will be a TEMPLATE_DECL in the
1317 case of a template friend. */
98e40e83 1318#define CLASSTYPE_FRIEND_CLASSES(NODE) \
e2500fed 1319 (LANG_TYPE_CLASS_CHECK (NODE)->friend_classes)
8d08fdba 1320
6a629cac
MM
1321/* A list of the classes which grant friendship to this class. */
1322#define CLASSTYPE_BEFRIENDING_CLASSES(NODE) \
e2500fed 1323 (LANG_TYPE_CLASS_CHECK (NODE)->befriending_classes)
6a629cac 1324
8d08fdba 1325/* Say whether this node was declared as a "class" or a "struct". */
98e40e83 1326#define CLASSTYPE_DECLARED_CLASS(NODE) \
e2500fed 1327 (LANG_TYPE_CLASS_CHECK (NODE)->declared_class)
8d08fdba 1328
6eb35968
DE
1329/* Nonzero if this class has const members
1330 which have no specified initialization. */
1331#define CLASSTYPE_READONLY_FIELDS_NEED_INIT(NODE) \
1332 (TYPE_LANG_SPECIFIC (NODE) \
1333 ? LANG_TYPE_CLASS_CHECK (NODE)->h.const_needs_init : 0)
1334#define SET_CLASSTYPE_READONLY_FIELDS_NEED_INIT(NODE, VALUE) \
1335 (LANG_TYPE_CLASS_CHECK (NODE)->h.const_needs_init = (VALUE))
1336
1337/* Nonzero if this class has ref members
1338 which have no specified initialization. */
1339#define CLASSTYPE_REF_FIELDS_NEED_INIT(NODE) \
1340 (TYPE_LANG_SPECIFIC (NODE) \
1341 ? LANG_TYPE_CLASS_CHECK (NODE)->h.ref_needs_init : 0)
1342#define SET_CLASSTYPE_REF_FIELDS_NEED_INIT(NODE, VALUE) \
1343 (LANG_TYPE_CLASS_CHECK (NODE)->h.ref_needs_init = (VALUE))
8d08fdba
MS
1344
1345/* Nonzero if this class is included from a header file which employs
1346 `#pragma interface', and it is not included in its implementation file. */
98e40e83 1347#define CLASSTYPE_INTERFACE_ONLY(NODE) \
e2500fed 1348 (LANG_TYPE_CLASS_CHECK (NODE)->interface_only)
8d08fdba 1349
97458258
MM
1350/* True if we have already determined whether or not vtables, VTTs,
1351 typeinfo, and other similar per-class data should be emitted in
1352 this translation unit. This flag does not indicate whether or not
1353 these items should be emitted; it only indicates that we know one
1354 way or the other. */
1355#define CLASSTYPE_INTERFACE_KNOWN(NODE) \
e2500fed 1356 (LANG_TYPE_CLASS_CHECK (NODE)->interface_unknown == 0)
a692ad2e 1357/* The opposite of CLASSTYPE_INTERFACE_KNOWN. */
97458258 1358#define CLASSTYPE_INTERFACE_UNKNOWN(NODE) \
e2500fed 1359 (LANG_TYPE_CLASS_CHECK (NODE)->interface_unknown)
97458258
MM
1360
1361#define SET_CLASSTYPE_INTERFACE_UNKNOWN_X(NODE,X) \
e2500fed 1362 (LANG_TYPE_CLASS_CHECK (NODE)->interface_unknown = !!(X))
97458258 1363#define SET_CLASSTYPE_INTERFACE_UNKNOWN(NODE) \
e2500fed 1364 (LANG_TYPE_CLASS_CHECK (NODE)->interface_unknown = 1)
97458258 1365#define SET_CLASSTYPE_INTERFACE_KNOWN(NODE) \
e2500fed 1366 (LANG_TYPE_CLASS_CHECK (NODE)->interface_unknown = 0)
8d08fdba
MS
1367
1368/* Nonzero if a _DECL node requires us to output debug info for this class. */
98e40e83 1369#define CLASSTYPE_DEBUG_REQUESTED(NODE) \
e2500fed 1370 (LANG_TYPE_CLASS_CHECK (NODE)->debug_requested)
8d08fdba
MS
1371\f
1372/* Additional macros for inheritance information. */
1373
ca107ded 1374/* The BINFO_INHERITANCE_CHAIN is used opposite to the description in
dbbf88d1
NS
1375 gcc/tree.h. In particular if D is non-virtually derived from B
1376 then the BINFO for B (in D) will have a BINFO_INHERITANCE_CHAIN
1377 pointing to D. If D is virtually derived, its
1378 BINFO_INHERITANCE_CHAIN will point to the most derived binfo. In
1379 tree.h, this pointer is described as pointing in other
1380 direction. The binfos of virtual bases are shared. */
623fe76a 1381
8d08fdba 1382/* Nonzero means that this class is on a path leading to a new vtable. */
809e3e7f 1383#define BINFO_VTABLE_PATH_MARKED(NODE) BINFO_FLAG_1 (NODE)
dbbf88d1
NS
1384
1385/* Nonzero means B (a BINFO) has its own vtable. Any copies will not
9bcb9aae 1386 have this flag set. */
809e3e7f 1387#define BINFO_NEW_VTABLE_MARKED(B) (BINFO_FLAG_2 (B))
23656158
MM
1388
1389/* Any subobject that needs a new vtable must have a vptr and must not
9965d119
NS
1390 be a non-virtual primary base (since it would then use the vtable from a
1391 derived class and never become non-primary.) */
dbbf88d1
NS
1392#define SET_BINFO_NEW_VTABLE_MARKED(B) \
1393 (BINFO_NEW_VTABLE_MARKED (B) = 1, \
98e40e83 1394 my_friendly_assert (!BINFO_PRIMARY_P (B) \
809e3e7f 1395 || BINFO_VIRTUAL_P (B), 20000517), \
23656158
MM
1396 my_friendly_assert (CLASSTYPE_VFIELDS (BINFO_TYPE (B)) != NULL_TREE, \
1397 20000517))
8d08fdba 1398
809e3e7f 1399/* Nonzero if this BINFO is a primary base class. */
174eceea 1400
9965d119 1401#define BINFO_PRIMARY_P(NODE) \
911a71a7 1402 (BINFO_PRIMARY_BASE_OF (NODE) != NULL_TREE)
99a6c6f4 1403
3ec6bad3
MM
1404/* The index in the VTT where this subobject's sub-VTT can be found.
1405 NULL_TREE if there is no sub-VTT. */
95b4aca6 1406#define BINFO_SUBVTT_INDEX(NODE) BINFO_LANG_SLOT(NODE, 0)
3ec6bad3
MM
1407
1408/* The index in the VTT where the vptr for this subobject can be
1409 found. NULL_TREE if there is no secondary vptr in the VTT. */
95b4aca6 1410#define BINFO_VPTR_INDEX(NODE) BINFO_LANG_SLOT(NODE, 1)
3ec6bad3 1411
911a71a7
MM
1412/* The binfo of which NODE is a primary base. (This is different from
1413 BINFO_INHERITANCE_CHAIN for virtual base because a virtual base is
1414 sometimes a primary base for a class for which it is not an
1415 immediate base.) */
95b4aca6 1416#define BINFO_PRIMARY_BASE_OF(NODE) BINFO_LANG_SLOT(NODE, 2)
1824b90d
NS
1417
1418/* C++ binfos have 3 additional entries. */
1419
95b4aca6 1420#define BINFO_LANG_SLOTS (3)
911a71a7 1421
dbbf88d1
NS
1422/* Nonzero if this binfo is for a dependent base - one that should not
1423 be searched. */
809e3e7f 1424#define BINFO_DEPENDENT_BASE_P(NODE) BINFO_FLAG_3 (NODE)
dbbf88d1 1425
9965d119
NS
1426/* Nonzero if this binfo has lost its primary base binfo (because that
1427 is a nearly-empty virtual base that has been taken by some other
aba649ba 1428 base in the complete hierarchy. */
809e3e7f 1429#define BINFO_LOST_PRIMARY_P(NODE) BINFO_FLAG_4 (NODE)
db3d8cde 1430
911a71a7
MM
1431/* Nonzero if this binfo is an indirect primary base, i.e. a virtual
1432 base that is a primary base of some of other class in the
1433 hierarchy. */
809e3e7f 1434#define BINFO_INDIRECT_PRIMARY_P(NODE) BINFO_FLAG_5 (NODE)
911a71a7 1435
72c4a2a6
JM
1436/* Used by various search routines. */
1437#define IDENTIFIER_MARKED(NODE) TREE_LANG_FLAG_0 (NODE)
8d08fdba 1438\f
548502d3
MM
1439/* A TREE_LIST of the vcall indices associated with the class NODE.
1440 The TREE_PURPOSE of each node is a FUNCTION_DECL for a virtual
1441 function. The TREE_VALUE is the index into the virtual table where
1442 the vcall offset for that function is stored, when NODE is a
1443 virtual base. */
1444#define CLASSTYPE_VCALL_INDICES(NODE) \
1445 (LANG_TYPE_CLASS_CHECK (NODE)->vcall_indices)
1446
1447/* The various vtables for the class NODE. The primary vtable will be
1448 first, followed by the construction vtables and VTT, if any. */
1449#define CLASSTYPE_VTABLES(NODE) \
1450 (LANG_TYPE_CLASS_CHECK (NODE)->vtables)
1451
a82d6da5
MM
1452/* The std::type_info variable representing this class, or NULL if no
1453 such variable has been created. This field is only set for the
1454 TYPE_MAIN_VARIANT of the class. */
1455#define CLASSTYPE_TYPEINFO_VAR(NODE) \
1456 (LANG_TYPE_CLASS_CHECK (NODE)->typeinfo_var)
1457
8d08fdba
MS
1458/* Accessor macros for the vfield slots in structures. */
1459
03fc215c
NS
1460/* List of virtual table fields that this type contains (both the primary
1461 and secondaries). The TREE_VALUE is the class type where the vtable
1462 field was introduced. For a vtable field inherited from the primary
1463 base, or introduced by this class, the TREE_PURPOSE is NULL. For
1464 other vtable fields (those from non-primary bases), the
1465 TREE_PURPOSE is the BINFO of the base through which the vtable was
1466 inherited. */
e2500fed 1467#define CLASSTYPE_VFIELDS(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->vfields)
8026246f 1468
03fc215c
NS
1469/* Get the BINFO that introduced this vtable into the hierarchy (will
1470 be NULL for those created at this level, or from a primary
1471 hierarchy). */
8d08fdba
MS
1472#define VF_BINFO_VALUE(NODE) TREE_PURPOSE (NODE)
1473
03fc215c
NS
1474/* Get the TYPE that introduced this vtable into the hierarchy (always
1475 non-NULL). */
8d08fdba
MS
1476#define VF_BASETYPE_VALUE(NODE) TREE_VALUE (NODE)
1477
00a17e31 1478/* Accessor macros for the BINFO_VIRTUALS list. */
c0bbf652
MM
1479
1480/* The number of bytes by which to adjust the `this' pointer when
03fc215c 1481 calling this virtual function. Subtract this value from the this
00a17e31 1482 pointer. Always non-NULL, might be constant zero though. */
5e19c053 1483#define BV_DELTA(NODE) (TREE_PURPOSE (NODE))
c0bbf652
MM
1484
1485/* If non-NULL, the vtable index at which to find the vcall offset
03fc215c
NS
1486 when calling this virtual function. Add the value at that vtable
1487 index to the this pointer. */
5e19c053 1488#define BV_VCALL_INDEX(NODE) (TREE_TYPE (NODE))
c0bbf652
MM
1489
1490/* The function to call. */
5e19c053
MM
1491#define BV_FN(NODE) (TREE_VALUE (NODE))
1492
8d08fdba 1493\f
8d08fdba 1494/* For FUNCTION_TYPE or METHOD_TYPE, a list of the exceptions that
193306f7 1495 this type can raise. Each TREE_VALUE is a _TYPE. The TREE_VALUE
66a6250f
JM
1496 will be NULL_TREE to indicate a throw specification of `()', or
1497 no exceptions allowed. */
95b4aca6 1498#define TYPE_RAISES_EXCEPTIONS(NODE) TYPE_LANG_SLOT_1 (NODE)
a9aedbc2 1499
7f477e81
NS
1500/* For FUNCTION_TYPE or METHOD_TYPE, return 1 iff it is declared `throw()'. */
1501#define TYPE_NOTHROW_P(NODE) \
1502 (TYPE_RAISES_EXCEPTIONS (NODE) \
1503 && TREE_VALUE (TYPE_RAISES_EXCEPTIONS (NODE)) == NULL_TREE)
1504
e92cc029 1505/* The binding level associated with the namespace. */
3ebc5c52 1506#define NAMESPACE_LEVEL(NODE) \
98e40e83 1507 (DECL_LANG_SPECIFIC (NODE)->decl_flags.u.level)
8d08fdba 1508\f
6a629cac
MM
1509
1510/* If a DECL has DECL_LANG_SPECIFIC, it is either a lang_decl_flags or
b0d06515
MM
1511 a lang_decl (which has lang_decl_flags as its initial prefix).
1512 This macro is nonzero for tree nodes whose DECL_LANG_SPECIFIC is
1513 the full lang_decl, and not just lang_decl_flags. */
1514#define CAN_HAVE_FULL_LANG_DECL_P(NODE) \
98e40e83
GS
1515 (!(TREE_CODE (NODE) == VAR_DECL \
1516 || TREE_CODE (NODE) == CONST_DECL \
1517 || TREE_CODE (NODE) == FIELD_DECL \
1518 || TREE_CODE (NODE) == USING_DECL))
6a629cac 1519
e2500fed 1520struct lang_decl_flags GTY(())
8d08fdba 1521{
e60a8c26 1522 ENUM_BITFIELD(languages) language : 8;
8d08fdba
MS
1523
1524 unsigned operator_attr : 1;
1525 unsigned constructor_attr : 1;
0d9eb3ba 1526 unsigned destructor_attr : 1;
8d08fdba
MS
1527 unsigned friend_attr : 1;
1528 unsigned static_function : 1;
fee7654e 1529 unsigned pure_virtual : 1;
454fa7a7 1530 unsigned has_in_charge_parm_p : 1;
5daf7c0a 1531 unsigned has_vtt_parm_p : 1;
d60f72ae 1532
56e770bf 1533 unsigned deferred : 1;
a0a33927 1534 unsigned use_template : 2;
db5ae43f 1535 unsigned nonconverting : 1;
faae18ab 1536 unsigned not_really_extern : 1;
cdcb673e 1537 unsigned needs_final_overrider : 1;
3febd123 1538 unsigned initialized_in_class : 1;
e2500fed 1539 unsigned assignment_operator_p : 1;
31ed8fea 1540
af3b4e59
MM
1541 unsigned global_ctor_p : 1;
1542 unsigned global_dtor_p : 1;
cc057ef3 1543 unsigned anticipated_p : 1;
5dd236e2 1544 unsigned template_conv_p : 1;
e2500fed
GK
1545 unsigned u1sel : 1;
1546 unsigned u2sel : 1;
1547 unsigned can_be_full : 1;
4977bab6 1548 unsigned this_thunk_p : 1;
8d08fdba 1549
e2500fed 1550 union lang_decl_u {
e00853fd
NS
1551 /* In a FUNCTION_DECL for which DECL_THUNK_P does not hold,
1552 VAR_DECL, TYPE_DECL, or TEMPLATE_DECL, this is
1553 DECL_TEMPLATE_INFO. */
e2500fed 1554 tree GTY ((tag ("0"))) template_info;
3ebc5c52
MM
1555
1556 /* In a NAMESPACE_DECL, this is NAMESPACE_LEVEL. */
e2500fed 1557 struct cp_binding_level * GTY ((tag ("1"))) level;
e00853fd
NS
1558
1559 /* In a FUNCTION_DECL for which DECL_THUNK_P holds, this is
1560 THUNK_ALIAS. */
1561 tree GTY ((tag ("2"))) thunk_alias;
e2500fed 1562 } GTY ((desc ("%1.u1sel"))) u;
af3b4e59 1563
e2500fed 1564 union lang_decl_u2 {
af3b4e59 1565 /* This is DECL_ACCESS. */
e2500fed 1566 tree GTY ((tag ("0"))) access;
af3b4e59 1567
8e4ce833 1568 /* For VAR_DECL in function, this is DECL_DISCRIMINATOR. */
17211ab5 1569 int GTY ((tag ("1"))) discriminator;
8e4ce833 1570
6462c441 1571 /* In a FUNCTION_DECL for which DECL_THUNK_P holds, this is
4977bab6
ZW
1572 THUNK_VIRTUAL_OFFSET. */
1573 tree GTY((tag ("2"))) virtual_offset;
e2500fed 1574 } GTY ((desc ("%1.u2sel"))) u2;
8d08fdba
MS
1575};
1576
17211ab5
GK
1577/* sorted_fields is sorted based on a pointer, so we need to be able
1578 to resort it if pointers get rearranged. */
1579
e2500fed 1580struct lang_decl GTY(())
8d08fdba
MS
1581{
1582 struct lang_decl_flags decl_flags;
1583
e2500fed
GK
1584 union lang_decl_u4
1585 {
1586 struct full_lang_decl
1587 {
07fa4878
NS
1588 /* For a non-thunk function decl, this is a tree list of
1589 friendly classes. For a thunk function decl, it is the
1590 thunked to function decl. */
e2500fed
GK
1591 tree befriending_classes;
1592
e93ee644
MM
1593 /* For a non-virtual FUNCTION_DECL, this is
1594 DECL_FRIEND_CONTEXT. For a virtual FUNCTION_DECL for which
4977bab6
ZW
1595 DECL_THIS_THUNK_P does not hold, this is DECL_THUNKS. Both
1596 this pointer and result pointer adjusting thunks are
1597 chained here. This pointer thunks to return pointer thunks
9bcb9aae 1598 will be chained on the return pointer thunk. */
e2500fed 1599 tree context;
bb5e8a7f 1600
e2500fed
GK
1601 /* In a FUNCTION_DECL, this is DECL_CLONED_FUNCTION. */
1602 tree cloned_function;
1603
14b4829d 1604 /* In a FUNCTION_DECL for which THUNK_P holds, this is
4977bab6
ZW
1605 THUNK_FIXED_OFFSET. */
1606 HOST_WIDE_INT fixed_offset;
14b4829d 1607
e2500fed
GK
1608 /* In an overloaded operator, this is the value of
1609 DECL_OVERLOADED_OPERATOR_P. */
1610 enum tree_code operator_code;
1611
1612 unsigned u3sel : 1;
1613 unsigned pending_inline_p : 1;
1614
1615 union lang_decl_u3
1616 {
d07605f5 1617 struct sorted_fields_type * GTY ((tag ("0"), reorder ("resort_sorted_fields")))
17211ab5 1618 sorted_fields;
a723baf1 1619 struct cp_token_cache * GTY ((tag ("2"))) pending_inline_info;
e2500fed
GK
1620 struct language_function * GTY ((tag ("1")))
1621 saved_language_function;
1622 } GTY ((desc ("%1.u3sel + %1.pending_inline_p"))) u;
1623 } GTY ((tag ("1"))) f;
1624 } GTY ((desc ("%1.decl_flags.can_be_full"))) u;
1625};
9188c363 1626
e2500fed 1627#if defined ENABLE_TREE_CHECKING && (GCC_VERSION >= 2007)
9188c363 1628
de94b46c 1629#define LANG_DECL_U2_CHECK(NODE, TF) __extension__ \
e2500fed
GK
1630({ struct lang_decl *lt = DECL_LANG_SPECIFIC (NODE); \
1631 if (lt->decl_flags.u2sel != TF) \
1632 lang_check_failed (__FILE__, __LINE__, __FUNCTION__); \
1633 &lt->decl_flags.u2; })
db9b2174 1634
e2500fed
GK
1635#else
1636
1637#define LANG_DECL_U2_CHECK(NODE, TF) \
1638 (&DECL_LANG_SPECIFIC (NODE)->decl_flags.u2)
1639
1640#endif /* ENABLE_TREE_CHECKING */
8d08fdba 1641
d7e7759d
BC
1642/* DECL_NEEDED_P holds of a declaration when we need to emit its
1643 definition. This is true when the back-end tells us that
1644 the symbol has been referenced in the generated code. If, however,
1645 we are not generating code, then it is also true when a symbol has
1646 just been used somewhere, even if it's not really needed. We need
1647 anything that isn't comdat, but we don't know for sure whether or
1648 not something is comdat until end-of-file. */
98e40e83
GS
1649#define DECL_NEEDED_P(DECL) \
1650 ((at_eof && TREE_PUBLIC (DECL) && !DECL_COMDAT (DECL)) \
1f2c9ba5
AP
1651 || (DECL_ASSEMBLER_NAME_SET_P (DECL) \
1652 && TREE_SYMBOL_REFERENCED (DECL_ASSEMBLER_NAME (DECL))) \
8cd2462c 1653 || (((flag_syntax_only || flag_unit_at_a_time) && TREE_USED (DECL))))
d7e7759d 1654
5d2ed28c
MM
1655/* For a FUNCTION_DECL or a VAR_DECL, the language linkage for the
1656 declaration. Some entities (like a member function in a local
1657 class, or a local variable) do not have linkage at all, and this
1658 macro should not be used in those cases.
1659
1660 Implementation note: A FUNCTION_DECL without DECL_LANG_SPECIFIC was
1661 created by language-independent code, and has C linkage. Most
1662 VAR_DECLs have C++ linkage, and do not have DECL_LANG_SPECIFIC, but
1663 we do create DECL_LANG_SPECIFIC for variables with non-C++ linkage. */
1664#define DECL_LANGUAGE(NODE) \
1665 (DECL_LANG_SPECIFIC (NODE) \
98e40e83 1666 ? DECL_LANG_SPECIFIC (NODE)->decl_flags.language \
5d2ed28c
MM
1667 : (TREE_CODE (NODE) == FUNCTION_DECL \
1668 ? lang_c : lang_cplusplus))
1669
1670/* Set the language linkage for NODE to LANGUAGE. */
1671#define SET_DECL_LANGUAGE(NODE, LANGUAGE) \
98e40e83 1672 (DECL_LANG_SPECIFIC (NODE)->decl_flags.language = (LANGUAGE))
8d08fdba
MS
1673
1674/* For FUNCTION_DECLs: nonzero means that this function is a constructor. */
98e40e83
GS
1675#define DECL_CONSTRUCTOR_P(NODE) \
1676 (DECL_LANG_SPECIFIC (NODE)->decl_flags.constructor_attr)
aa45967f 1677
db9b2174
MM
1678/* Nonzero if NODE (a FUNCTION_DECL) is a constructor for a complete
1679 object. */
1680#define DECL_COMPLETE_CONSTRUCTOR_P(NODE) \
bb20cc46 1681 (DECL_CONSTRUCTOR_P (NODE) \
db9b2174
MM
1682 && DECL_NAME (NODE) == complete_ctor_identifier)
1683
1684/* Nonzero if NODE (a FUNCTION_DECL) is a constructor for a base
1685 object. */
1686#define DECL_BASE_CONSTRUCTOR_P(NODE) \
1687 (DECL_CONSTRUCTOR_P (NODE) \
1688 && DECL_NAME (NODE) == base_ctor_identifier)
1689
1690/* Nonzero if NODE (a FUNCTION_DECL) is a constructor, but not either the
1691 specialized in-charge constructor or the specialized not-in-charge
1692 constructor. */
1693#define DECL_MAYBE_IN_CHARGE_CONSTRUCTOR_P(NODE) \
1694 (DECL_CONSTRUCTOR_P (NODE) && !DECL_CLONED_FUNCTION_P (NODE))
1695
454fa7a7
MM
1696/* Nonzero if NODE (a FUNCTION_DECL) is a copy constructor. */
1697#define DECL_COPY_CONSTRUCTOR_P(NODE) \
271e6f02 1698 (DECL_CONSTRUCTOR_P (NODE) && copy_fn_p (NODE) > 0)
454fa7a7 1699
1f6e1acc 1700/* Nonzero if NODE is a destructor. */
aa45967f 1701#define DECL_DESTRUCTOR_P(NODE) \
0d9eb3ba 1702 (DECL_LANG_SPECIFIC (NODE)->decl_flags.destructor_attr)
aa45967f 1703
db9b2174
MM
1704/* Nonzero if NODE (a FUNCTION_DECL) is a destructor, but not the
1705 specialized in-charge constructor, in-charge deleting constructor,
1706 or the the base destructor. */
1707#define DECL_MAYBE_IN_CHARGE_DESTRUCTOR_P(NODE) \
1708 (DECL_DESTRUCTOR_P (NODE) && !DECL_CLONED_FUNCTION_P (NODE))
1709
298d6f60
MM
1710/* Nonzero if NODE (a FUNCTION_DECL) is a destructor for a complete
1711 object. */
1712#define DECL_COMPLETE_DESTRUCTOR_P(NODE) \
bb20cc46 1713 (DECL_DESTRUCTOR_P (NODE) \
298d6f60
MM
1714 && DECL_NAME (NODE) == complete_dtor_identifier)
1715
1716/* Nonzero if NODE (a FUNCTION_DECL) is a destructor for a base
1717 object. */
1718#define DECL_BASE_DESTRUCTOR_P(NODE) \
1719 (DECL_DESTRUCTOR_P (NODE) \
1720 && DECL_NAME (NODE) == base_dtor_identifier)
1721
1722/* Nonzero if NODE (a FUNCTION_DECL) is a destructor for a complete
872f37f9 1723 object that deletes the object after it has been destroyed. */
298d6f60 1724#define DECL_DELETING_DESTRUCTOR_P(NODE) \
bb20cc46 1725 (DECL_DESTRUCTOR_P (NODE) \
298d6f60
MM
1726 && DECL_NAME (NODE) == deleting_dtor_identifier)
1727
db9b2174
MM
1728/* Nonzero if NODE (a FUNCTION_DECL) is a cloned constructor or
1729 destructor. */
94350948 1730#define DECL_CLONED_FUNCTION_P(NODE) \
31d95fc6
MM
1731 ((TREE_CODE (NODE) == FUNCTION_DECL \
1732 || TREE_CODE (NODE) == TEMPLATE_DECL) \
1733 && DECL_LANG_SPECIFIC (NODE) \
94350948 1734 && DECL_CLONED_FUNCTION (NODE) != NULL_TREE)
db9b2174
MM
1735
1736/* If DECL_CLONED_FUNCTION_P holds, this is the function that was
1737 cloned. */
1738#define DECL_CLONED_FUNCTION(NODE) \
e2500fed 1739 (DECL_LANG_SPECIFIC (NODE)->u.f.cloned_function)
db9b2174 1740
8e4ce833
JJ
1741/* Nonzero if NODE has DECL_DISCRIMINATOR and not DECL_ACCESS. */
1742#define DECL_DISCRIMINATOR_P(NODE) \
1743 (TREE_CODE (NODE) == VAR_DECL \
1744 && DECL_FUNCTION_SCOPE_P (NODE))
1745
1746/* Discriminator for name mangling. */
e2500fed 1747#define DECL_DISCRIMINATOR(NODE) (LANG_DECL_U2_CHECK (NODE, 1)->discriminator)
8e4ce833 1748
838dfd8a 1749/* Nonzero if the VTT parm has been added to NODE. */
e0fff4b3
JM
1750#define DECL_HAS_VTT_PARM_P(NODE) \
1751 (DECL_LANG_SPECIFIC (NODE)->decl_flags.has_vtt_parm_p)
3ec6bad3 1752
838dfd8a 1753/* Nonzero if NODE is a FUNCTION_DECL for which a VTT parameter is
3ec6bad3
MM
1754 required. */
1755#define DECL_NEEDS_VTT_PARM_P(NODE) \
1756 (TYPE_USES_VIRTUAL_BASECLASSES (DECL_CONTEXT (NODE)) \
1757 && (DECL_BASE_CONSTRUCTOR_P (NODE) \
1758 || DECL_BASE_DESTRUCTOR_P (NODE)))
1759
838dfd8a 1760/* Nonzero if NODE is a user-defined conversion operator. */
421844e7 1761#define DECL_CONV_FN_P(NODE) \
5838eb91 1762 (DECL_NAME (NODE) && IDENTIFIER_TYPENAME_P (DECL_NAME (NODE)))
711734a9 1763
ca90f3e1
MM
1764/* If FN is a conversion operator, the type to which it converts.
1765 Otherwise, NULL_TREE. */
1766#define DECL_CONV_FN_TYPE(FN) \
1767 (DECL_CONV_FN_P (FN) ? TREE_TYPE (DECL_NAME (FN)) : NULL_TREE)
1768
838dfd8a 1769/* Nonzero if NODE, which is a TEMPLATE_DECL, is a template
5dd236e2
NS
1770 conversion operator to a type dependent on the innermost template
1771 args. */
1772#define DECL_TEMPLATE_CONV_FN_P(NODE) \
1773 (DECL_LANG_SPECIFIC (NODE)->decl_flags.template_conv_p)
1774
596ea4e5
AS
1775/* Set the overloaded operator code for NODE to CODE. */
1776#define SET_OVERLOADED_OPERATOR_CODE(NODE, CODE) \
e2500fed 1777 (DECL_LANG_SPECIFIC (NODE)->u.f.operator_code = (CODE))
596ea4e5
AS
1778
1779/* If NODE is an overloaded operator, then this returns the TREE_CODE
34cd5ae7 1780 associated with the overloaded operator.
596ea4e5
AS
1781 DECL_ASSIGNMENT_OPERATOR_P must also be checked to determine
1782 whether or not NODE is an assignment operator. If NODE is not an
1783 overloaded operator, ERROR_MARK is returned. Since the numerical
1784 value of ERROR_MARK is zero, this macro can be used as a predicate
1785 to test whether or not NODE is an overloaded operator. */
bb20cc46 1786#define DECL_OVERLOADED_OPERATOR_P(NODE) \
98e40e83 1787 (IDENTIFIER_OPNAME_P (DECL_NAME (NODE)) \
e2500fed 1788 ? DECL_LANG_SPECIFIC (NODE)->u.f.operator_code : ERROR_MARK)
596ea4e5 1789
838dfd8a 1790/* Nonzero if NODE is an assignment operator. */
596ea4e5
AS
1791#define DECL_ASSIGNMENT_OPERATOR_P(NODE) \
1792 (DECL_LANG_SPECIFIC (NODE)->decl_flags.assignment_operator_p)
f71f87f9 1793
454fa7a7
MM
1794/* For FUNCTION_DECLs: nonzero means that this function is a
1795 constructor or a destructor with an extra in-charge parameter to
1796 control whether or not virtual bases are constructed. */
1797#define DECL_HAS_IN_CHARGE_PARM_P(NODE) \
1798 (DECL_LANG_SPECIFIC (NODE)->decl_flags.has_in_charge_parm_p)
8d08fdba 1799
834c6dff
MM
1800/* Nonzero if NODE is an overloaded `operator delete[]' function. */
1801#define DECL_ARRAY_DELETE_OPERATOR_P(NODE) \
596ea4e5 1802 (DECL_OVERLOADED_OPERATOR_P (NODE) == VEC_DELETE_EXPR)
834c6dff 1803
8d08fdba
MS
1804/* Nonzero for _DECL means that this decl appears in (or will appear
1805 in) as a member in a RECORD_TYPE or UNION_TYPE node. It is also for
1806 detecting circularity in case members are multiply defined. In the
1807 case of a VAR_DECL, it is also used to determine how program storage
1808 should be allocated. */
98e40e83 1809#define DECL_IN_AGGR_P(NODE) (DECL_LANG_FLAG_3 (NODE))
8d08fdba 1810
17bbb839
MM
1811/* Nonzero for a VAR_DECL means that the variable's initialization has
1812 been processed. */
1813#define DECL_INITIALIZED_P(NODE) \
1814 (TREE_LANG_FLAG_1 (VAR_DECL_CHECK (NODE)))
1815
39703eb9
MM
1816/* Nonzero for a VAR_DECL that was initialized with a
1817 constant-expression. */
1818#define DECL_INITIALIZED_BY_CONSTANT_EXPRESSION_P(NODE) \
1819 (TREE_LANG_FLAG_2 (VAR_DECL_CHECK (NODE)))
1820
3febd123 1821/* Nonzero if the DECL was initialized in the class definition itself,
649fc72d 1822 rather than outside the class. This is used for both static member
9bcb9aae 1823 VAR_DECLS, and FUNTION_DECLS that are defined in the class. */
3febd123
NS
1824#define DECL_INITIALIZED_IN_CLASS_P(DECL) \
1825 (DECL_LANG_SPECIFIC (DECL)->decl_flags.initialized_in_class)
6ba89f8e 1826
8d08fdba
MS
1827/* Nonzero for FUNCTION_DECL means that this decl is just a
1828 friend declaration, and should not be added to the list of
1829 member functions for this class. */
98e40e83 1830#define DECL_FRIEND_P(NODE) (DECL_LANG_SPECIFIC (NODE)->decl_flags.friend_attr)
8d08fdba 1831
6a629cac
MM
1832/* A TREE_LIST of the types which have befriended this FUNCTION_DECL. */
1833#define DECL_BEFRIENDING_CLASSES(NODE) \
e2500fed 1834 (DECL_LANG_SPECIFIC (NODE)->u.f.befriending_classes)
6a629cac 1835
8d08fdba
MS
1836/* Nonzero for FUNCTION_DECL means that this decl is a static
1837 member function. */
98e40e83
GS
1838#define DECL_STATIC_FUNCTION_P(NODE) \
1839 (DECL_LANG_SPECIFIC (NODE)->decl_flags.static_function)
8d08fdba 1840
8857f91e
MM
1841/* Nonzero for FUNCTION_DECL means that this decl is a non-static
1842 member function. */
1843#define DECL_NONSTATIC_MEMBER_FUNCTION_P(NODE) \
1844 (TREE_CODE (TREE_TYPE (NODE)) == METHOD_TYPE)
1845
8926095f
MS
1846/* Nonzero for FUNCTION_DECL means that this decl is a member function
1847 (static or non-static). */
1848#define DECL_FUNCTION_MEMBER_P(NODE) \
8857f91e 1849 (DECL_NONSTATIC_MEMBER_FUNCTION_P (NODE) || DECL_STATIC_FUNCTION_P (NODE))
8926095f 1850
8d08fdba
MS
1851/* Nonzero for FUNCTION_DECL means that this member function
1852 has `this' as const X *const. */
0d9eb3ba
MM
1853#define DECL_CONST_MEMFUNC_P(NODE) \
1854 (DECL_NONSTATIC_MEMBER_FUNCTION_P (NODE) \
bb20cc46 1855 && CP_TYPE_CONST_P (TREE_TYPE (TREE_VALUE \
0d9eb3ba 1856 (TYPE_ARG_TYPES (TREE_TYPE (NODE))))))
8d08fdba 1857
1f6e1acc
AS
1858/* Nonzero for FUNCTION_DECL means that this member function
1859 has `this' as volatile X *const. */
1860#define DECL_VOLATILE_MEMFUNC_P(NODE) \
1861 (DECL_NONSTATIC_MEMBER_FUNCTION_P (NODE) \
1862 && CP_TYPE_VOLATILE_P (TREE_TYPE (TREE_VALUE \
1863 (TYPE_ARG_TYPES (TREE_TYPE (NODE))))))
1864
d6479fe7 1865/* Nonzero for a DECL means that this member is a non-static member. */
bb20cc46
AJ
1866#define DECL_NONSTATIC_MEMBER_P(NODE) \
1867 ((TREE_CODE (NODE) == FUNCTION_DECL \
d6479fe7
MM
1868 && DECL_NONSTATIC_MEMBER_FUNCTION_P (NODE)) \
1869 || TREE_CODE (NODE) == FIELD_DECL)
1870
8d08fdba
MS
1871/* Nonzero for _DECL means that this member object type
1872 is mutable. */
721c3b42 1873#define DECL_MUTABLE_P(NODE) (DECL_LANG_FLAG_0 (NODE))
8d08fdba 1874
db5ae43f
MS
1875/* Nonzero for _DECL means that this constructor is a non-converting
1876 constructor. */
98e40e83
GS
1877#define DECL_NONCONVERTING_P(NODE) \
1878 (DECL_LANG_SPECIFIC (NODE)->decl_flags.nonconverting)
db5ae43f 1879
fee7654e
MM
1880/* Nonzero for FUNCTION_DECL means that this member function is a pure
1881 virtual function. */
98e40e83
GS
1882#define DECL_PURE_VIRTUAL_P(NODE) \
1883 (DECL_LANG_SPECIFIC (NODE)->decl_flags.pure_virtual)
8d08fdba 1884
cdcb673e
MH
1885/* Nonzero for FUNCTION_DECL means that this member function
1886 must be overridden by derived classes. */
98e40e83
GS
1887#define DECL_NEEDS_FINAL_OVERRIDER_P(NODE) \
1888 (DECL_LANG_SPECIFIC (NODE)->decl_flags.needs_final_overrider)
cdcb673e 1889
58ec3cc5
MM
1890/* True (in a FUNCTION_DECL) if NODE is a virtual function that is an
1891 invalid overrider for a function from a base class. Once we have
1892 complained about an invalid overrider we avoid complaining about it
1893 again. */
1894#define DECL_INVALID_OVERRIDER_P(NODE) \
1895 (DECL_LANG_FLAG_4 (NODE))
1896
4977bab6 1897/* The thunks associated with NODE, a FUNCTION_DECL. */
bb5e8a7f 1898#define DECL_THUNKS(NODE) \
e93ee644 1899 (DECL_LANG_SPECIFIC (NODE)->u.f.context)
bb5e8a7f 1900
eb68cb58
MM
1901/* Nonzero if NODE is a thunk, rather than an ordinary function. */
1902#define DECL_THUNK_P(NODE) \
1903 (TREE_CODE (NODE) == FUNCTION_DECL \
1904 && DECL_LANG_FLAG_7 (NODE))
1905
4977bab6
ZW
1906/* Nonzero if NODE is a this pointer adjusting thunk. */
1907#define DECL_THIS_THUNK_P(NODE) \
1908 (DECL_THUNK_P (NODE) && DECL_LANG_SPECIFIC (NODE)->decl_flags.this_thunk_p)
1909
1910/* Nonzero if NODE is a result pointer adjusting thunk. */
1911#define DECL_RESULT_THUNK_P(NODE) \
1912 (DECL_THUNK_P (NODE) && !DECL_LANG_SPECIFIC (NODE)->decl_flags.this_thunk_p)
1913
eb68cb58
MM
1914/* Nonzero if NODE is a FUNCTION_DECL, but not a thunk. */
1915#define DECL_NON_THUNK_FUNCTION_P(NODE) \
1916 (TREE_CODE (NODE) == FUNCTION_DECL && !DECL_THUNK_P (NODE))
1917
1918/* Nonzero if NODE is `extern "C"'. */
1919#define DECL_EXTERN_C_P(NODE) \
1920 (DECL_LANGUAGE (NODE) == lang_c)
1921
1922/* Nonzero if NODE is an `extern "C"' function. */
1923#define DECL_EXTERN_C_FUNCTION_P(NODE) \
1924 (DECL_NON_THUNK_FUNCTION_P (NODE) && DECL_EXTERN_C_P (NODE))
1925
1926/* Set DECL_THUNK_P for node. */
4977bab6 1927#define SET_DECL_THUNK_P(NODE, THIS_ADJUSTING) \
e2500fed 1928 (DECL_LANG_FLAG_7 (NODE) = 1, \
4977bab6
ZW
1929 DECL_LANG_SPECIFIC (NODE)->u.f.u3sel = 1, \
1930 DECL_LANG_SPECIFIC (NODE)->decl_flags.this_thunk_p = (THIS_ADJUSTING))
eb68cb58 1931
f9817201
MM
1932/* Nonzero if this DECL is the __PRETTY_FUNCTION__ variable in a
1933 template function. */
1934#define DECL_PRETTY_FUNCTION_P(NODE) \
39703eb9 1935 (TREE_LANG_FLAG_0 (VAR_DECL_CHECK (NODE)))
f9817201 1936
8926095f 1937/* The _TYPE context in which this _DECL appears. This field holds the
00a17e31 1938 class where a virtual function instance is actually defined. */
4f1c5b7d
MM
1939#define DECL_CLASS_CONTEXT(NODE) \
1940 (DECL_CLASS_SCOPE_P (NODE) ? DECL_CONTEXT (NODE) : NULL_TREE)
1941
1942/* For a non-member friend function, the class (if any) in which this
1943 friend was defined. For example, given:
bb20cc46 1944
4f1c5b7d
MM
1945 struct S { friend void f (); };
1946
1947 the DECL_FRIEND_CONTEXT for `f' will be `S'. */
1948#define DECL_FRIEND_CONTEXT(NODE) \
1949 ((DECL_FRIEND_P (NODE) && !DECL_FUNCTION_MEMBER_P (NODE)) \
e2500fed 1950 ? DECL_LANG_SPECIFIC (NODE)->u.f.context \
4f1c5b7d
MM
1951 : NULL_TREE)
1952
1953/* Set the DECL_FRIEND_CONTEXT for NODE to CONTEXT. */
1954#define SET_DECL_FRIEND_CONTEXT(NODE, CONTEXT) \
e2500fed 1955 (DECL_LANG_SPECIFIC (NODE)->u.f.context = (CONTEXT))
cb0dbb9a 1956
00a17e31 1957/* NULL_TREE in DECL_CONTEXT represents the global namespace. */
cb0dbb9a
JM
1958#define CP_DECL_CONTEXT(NODE) \
1959 (DECL_CONTEXT (NODE) ? DECL_CONTEXT (NODE) : global_namespace)
1960#define FROB_CONTEXT(NODE) ((NODE) == global_namespace ? NULL_TREE : (NODE))
8d08fdba 1961
42c7b807 1962/* 1 iff NODE has namespace scope, including the global namespace. */
4f71f630
MM
1963#define DECL_NAMESPACE_SCOPE_P(NODE) \
1964 (!DECL_TEMPLATE_PARM_P (NODE) \
1965 && TREE_CODE (CP_DECL_CONTEXT (NODE)) == NAMESPACE_DECL)
42c7b807
JM
1966
1967/* 1 iff NODE is a class member. */
6eb3bb27 1968#define DECL_CLASS_SCOPE_P(NODE) \
4f1c5b7d 1969 (DECL_CONTEXT (NODE) && TYPE_P (DECL_CONTEXT (NODE)))
42c7b807 1970
2642b9bf
JM
1971/* 1 iff NODE is function-local. */
1972#define DECL_FUNCTION_SCOPE_P(NODE) \
1973 (DECL_CONTEXT (NODE) \
1974 && TREE_CODE (DECL_CONTEXT (NODE)) == FUNCTION_DECL)
1f6e1acc 1975
d35543c0
JH
1976/* 1 iff VAR_DECL node NODE is virtual table or VTT. */
1977#define DECL_VTABLE_OR_VTT_P(NODE) TREE_LANG_FLAG_5 (VAR_DECL_CHECK (NODE))
1978
881c6935
JM
1979/* 1 iff NODE is function-local, but for types. */
1980#define LOCAL_CLASS_P(NODE) \
495d26d6 1981 (decl_function_context (TYPE_MAIN_DECL (NODE)) != NULL_TREE)
881c6935 1982
2c73f9f5 1983/* For a NAMESPACE_DECL: the list of using namespace directives
30394414 1984 The PURPOSE is the used namespace, the value is the namespace
00a17e31 1985 that is the common ancestor. */
da8a66fc 1986#define DECL_NAMESPACE_USING(NODE) DECL_VINDEX (NAMESPACE_DECL_CHECK (NODE))
30394414
JM
1987
1988/* In a NAMESPACE_DECL, the DECL_INITIAL is used to record all users
00a17e31 1989 of a namespace, to record the transitive closure of using namespace. */
da8a66fc 1990#define DECL_NAMESPACE_USERS(NODE) DECL_INITIAL (NAMESPACE_DECL_CHECK (NODE))
30394414 1991
86098eb8
JM
1992/* In a NAMESPACE_DECL, the list of namespaces which have associated
1993 themselves with this one. */
1994#define DECL_NAMESPACE_ASSOCIATIONS(NODE) \
1995 (NAMESPACE_DECL_CHECK (NODE)->decl.saved_tree)
1996
3e3f722c
ML
1997/* In a NAMESPACE_DECL, points to the original namespace if this is
1998 a namespace alias. */
da8a66fc
ML
1999#define DECL_NAMESPACE_ALIAS(NODE) \
2000 DECL_ABSTRACT_ORIGIN (NAMESPACE_DECL_CHECK (NODE))
3e3f722c
ML
2001#define ORIGINAL_NAMESPACE(NODE) \
2002 (DECL_NAMESPACE_ALIAS (NODE) ? DECL_NAMESPACE_ALIAS (NODE) : (NODE))
2003
838dfd8a 2004/* Nonzero if NODE is the std namespace. */
1f6e1acc
AS
2005#define DECL_NAMESPACE_STD_P(NODE) \
2006 (TREE_CODE (NODE) == NAMESPACE_DECL \
2007 && CP_DECL_CONTEXT (NODE) == global_namespace \
2008 && DECL_NAME (NODE) == std_identifier)
2009
0aafb128
MM
2010/* In a non-local VAR_DECL with static storage duration, this is the
2011 initialization priority. If this value is zero, the NODE will be
2012 initialized at the DEFAULT_INIT_PRIORITY. */
9df2c88c 2013#define DECL_INIT_PRIORITY(NODE) (VAR_DECL_CHECK (NODE)->decl.u2.i)
0aafb128 2014
9df2c88c 2015/* In a TREE_LIST concatenating using directives, indicate indirect
30394414 2016 directives */
da8a66fc 2017#define TREE_INDIRECT_USING(NODE) (TREE_LIST_CHECK (NODE)->common.lang_flag_0)
8d08fdba 2018
d2ad151f 2019/* In a VAR_DECL for a variable declared in a for statement,
e92cc029 2020 this is the shadowed (local) variable. */
17aec3eb 2021#define DECL_SHADOWED_FOR_VAR(NODE) DECL_RESULT_FLD(VAR_DECL_CHECK (NODE))
d2ad151f 2022
59026e79
MM
2023/* In a FUNCTION_DECL, this is nonzero if this function was defined in
2024 the class definition. We have saved away the text of the function,
2025 but have not yet processed it. */
2026#define DECL_PENDING_INLINE_P(NODE) \
e2500fed 2027 (DECL_LANG_SPECIFIC (NODE)->u.f.pending_inline_p)
bb20cc46 2028
59026e79
MM
2029/* If DECL_PENDING_INLINE_P holds, this is the saved text of the
2030 function. */
2031#define DECL_PENDING_INLINE_INFO(NODE) \
e2500fed 2032 (DECL_LANG_SPECIFIC (NODE)->u.f.u.pending_inline_info)
f90cdf34 2033
6c73ad72 2034/* For a TYPE_DECL: if this structure has many fields, we'll sort them
00a17e31 2035 and put them into a TREE_VEC. */
da8a66fc 2036#define DECL_SORTED_FIELDS(NODE) \
e2500fed 2037 (DECL_LANG_SPECIFIC (TYPE_DECL_CHECK (NODE))->u.f.u.sorted_fields)
8d08fdba 2038
56e770bf
MM
2039/* True if on the deferred_fns (see decl2.c) list. */
2040#define DECL_DEFERRED_FN(DECL) \
98e40e83 2041 (DECL_LANG_SPECIFIC (DECL)->decl_flags.deferred)
8926095f 2042
7c355bca
ML
2043/* For a VAR_DECL, FUNCTION_DECL, TYPE_DECL or TEMPLATE_DECL:
2044 template-specific information. */
3ebc5c52 2045#define DECL_TEMPLATE_INFO(NODE) \
98e40e83
GS
2046 (DECL_LANG_SPECIFIC (VAR_TEMPL_TYPE_OR_FUNCTION_DECL_CHECK (NODE)) \
2047 ->decl_flags.u.template_info)
ed44da02 2048
772f8889
MM
2049/* For a VAR_DECL, indicates that the variable has been processed.
2050 This flag is set and unset throughout the code; it is always
2051 used for a temporary purpose. */
2052#define DECL_VAR_MARKED_P(NODE) \
2053 (DECL_LANG_FLAG_4 (VAR_DECL_CHECK (NODE)))
2054
ed44da02 2055/* Template information for a RECORD_TYPE or UNION_TYPE. */
da8a66fc 2056#define CLASSTYPE_TEMPLATE_INFO(NODE) \
95b4aca6 2057 (LANG_TYPE_CLASS_CHECK (RECORD_OR_UNION_CHECK (NODE))->template_info)
ed44da02
MM
2058
2059/* Template information for an ENUMERAL_TYPE. Although an enumeration may
2060 not be a primary template, it may be declared within the scope of a
2061 primary template and the enumeration constants may depend on
2062 non-type template parameters. */
95b4aca6
NS
2063#define ENUM_TEMPLATE_INFO(NODE) \
2064 (TYPE_LANG_SLOT_1 (ENUMERAL_TYPE_CHECK (NODE)))
ed44da02 2065
11e74ea6
KL
2066/* Template information for a template template parameter. */
2067#define TEMPLATE_TEMPLATE_PARM_TEMPLATE_INFO(NODE) \
e2500fed 2068 (LANG_TYPE_CLASS_CHECK (BOUND_TEMPLATE_TEMPLATE_PARM_TYPE_CHECK (NODE)) \
11e74ea6 2069 ->template_info)
7ddedda4 2070
ed44da02 2071/* Template information for an ENUMERAL_, RECORD_, or UNION_TYPE. */
7ddedda4
MM
2072#define TYPE_TEMPLATE_INFO(NODE) \
2073 (TREE_CODE (NODE) == ENUMERAL_TYPE \
9076e292 2074 ? ENUM_TEMPLATE_INFO (NODE) : \
a1281f45 2075 (TREE_CODE (NODE) == BOUND_TEMPLATE_TEMPLATE_PARM \
9076e292
JM
2076 ? TEMPLATE_TEMPLATE_PARM_TEMPLATE_INFO (NODE) : \
2077 (TYPE_LANG_SPECIFIC (NODE) \
2078 ? CLASSTYPE_TEMPLATE_INFO (NODE) \
2079 : NULL_TREE)))
ed44da02
MM
2080
2081/* Set the template information for an ENUMERAL_, RECORD_, or
2082 UNION_TYPE to VAL. */
bb20cc46
AJ
2083#define SET_TYPE_TEMPLATE_INFO(NODE, VAL) \
2084 (TREE_CODE (NODE) == ENUMERAL_TYPE \
98e40e83
GS
2085 ? (ENUM_TEMPLATE_INFO (NODE) = (VAL)) \
2086 : (CLASSTYPE_TEMPLATE_INFO (NODE) = (VAL)))
ed44da02 2087
5566b478
MS
2088#define TI_TEMPLATE(NODE) (TREE_PURPOSE (NODE))
2089#define TI_ARGS(NODE) (TREE_VALUE (NODE))
824b9a4c 2090#define TI_PENDING_TEMPLATE_FLAG(NODE) TREE_LANG_FLAG_1 (NODE)
ed44da02 2091
b5ac18ea
MM
2092/* We use TREE_VECs to hold template arguments. If there is only one
2093 level of template arguments, then the TREE_VEC contains the
2094 arguments directly. If there is more than one level of template
2095 arguments, then each entry in the TREE_VEC is itself a TREE_VEC,
2096 containing the template arguments for a single level. The first
2097 entry in the outer TREE_VEC is the outermost level of template
bb20cc46 2098 parameters; the last is the innermost.
b5ac18ea
MM
2099
2100 It is incorrect to ever form a template argument vector containing
2101 only one level of arguments, but which is a TREE_VEC containing as
2102 its only entry the TREE_VEC for that level. */
2103
838dfd8a 2104/* Nonzero if the template arguments is actually a vector of vectors,
b5ac18ea 2105 rather than just a vector. */
bf12d54d
NS
2106#define TMPL_ARGS_HAVE_MULTIPLE_LEVELS(NODE) \
2107 (NODE && TREE_VEC_ELT (NODE, 0) \
b5ac18ea
MM
2108 && TREE_CODE (TREE_VEC_ELT (NODE, 0)) == TREE_VEC)
2109
2110/* The depth of a template argument vector. When called directly by
2111 the parser, we use a TREE_LIST rather than a TREE_VEC to represent
2112 template arguments. In fact, we may even see NULL_TREE if there
2113 are no template arguments. In both of those cases, there is only
2114 one level of template arguments. */
2115#define TMPL_ARGS_DEPTH(NODE) \
2116 (TMPL_ARGS_HAVE_MULTIPLE_LEVELS (NODE) ? TREE_VEC_LENGTH (NODE) : 1)
2117
27631dae 2118/* The LEVELth level of the template ARGS. The outermost level of
f9a7ae04 2119 args is level 1, not level 0. */
b5ac18ea 2120#define TMPL_ARGS_LEVEL(ARGS, LEVEL) \
bb20cc46 2121 (TMPL_ARGS_HAVE_MULTIPLE_LEVELS (ARGS) \
98e40e83 2122 ? TREE_VEC_ELT (ARGS, (LEVEL) - 1) : (ARGS))
b5ac18ea
MM
2123
2124/* Set the LEVELth level of the template ARGS to VAL. This macro does
2125 not work with single-level argument vectors. */
2126#define SET_TMPL_ARGS_LEVEL(ARGS, LEVEL, VAL) \
98e40e83 2127 (TREE_VEC_ELT (ARGS, (LEVEL) - 1) = (VAL))
b5ac18ea
MM
2128
2129/* Accesses the IDXth parameter in the LEVELth level of the ARGS. */
2130#define TMPL_ARG(ARGS, LEVEL, IDX) \
2131 (TREE_VEC_ELT (TMPL_ARGS_LEVEL (ARGS, LEVEL), IDX))
2132
2133/* Set the IDXth element in the LEVELth level of ARGS to VAL. This
2134 macro does not work with single-level argument vectors. */
2135#define SET_TMPL_ARG(ARGS, LEVEL, IDX, VAL) \
2136 (TREE_VEC_ELT (TREE_VEC_ELT ((ARGS), (LEVEL) - 1), (IDX)) = (VAL))
2137
2138/* Given a single level of template arguments in NODE, return the
2139 number of arguments. */
bb20cc46 2140#define NUM_TMPL_ARGS(NODE) \
bf12d54d 2141 (TREE_VEC_LENGTH (NODE))
b5ac18ea 2142
f9a7ae04
MM
2143/* Returns the innermost level of template arguments in ARGS. */
2144#define INNERMOST_TEMPLATE_ARGS(NODE) \
2145 (get_innermost_template_args ((NODE), 1))
2146
b5ac18ea
MM
2147/* The number of levels of template parameters given by NODE. */
2148#define TMPL_PARMS_DEPTH(NODE) \
ad6b1795 2149 ((HOST_WIDE_INT) TREE_INT_CST_LOW (TREE_PURPOSE (NODE)))
b5ac18ea 2150
36a117a5
MM
2151/* The TEMPLATE_DECL instantiated or specialized by NODE. This
2152 TEMPLATE_DECL will be the immediate parent, not the most general
2153 template. For example, in:
2154
2155 template <class T> struct S { template <class U> void f(U); }
2156
2157 the FUNCTION_DECL for S<int>::f<double> will have, as its
bb20cc46 2158 DECL_TI_TEMPLATE, `template <class U> S<int>::f<U>'.
36a117a5
MM
2159
2160 As a special case, for a member friend template of a template
10b1d5e7
MM
2161 class, this value will not be a TEMPLATE_DECL, but rather an
2162 IDENTIFIER_NODE or OVERLOAD indicating the name of the template and
2163 any explicit template arguments provided. For example, in:
36a117a5
MM
2164
2165 template <class T> struct S { friend void f<int>(int, double); }
2166
10b1d5e7 2167 the DECL_TI_TEMPLATE will be an IDENTIFIER_NODE for `f' and the
bb20cc46 2168 DECL_TI_ARGS will be {int}. */
5566b478 2169#define DECL_TI_TEMPLATE(NODE) TI_TEMPLATE (DECL_TEMPLATE_INFO (NODE))
ed44da02 2170
36a117a5
MM
2171/* The template arguments used to obtain this decl from the most
2172 general form of DECL_TI_TEMPLATE. For the example given for
2173 DECL_TI_TEMPLATE, the DECL_TI_ARGS will be {int, double}. These
2174 are always the full set of arguments required to instantiate this
2175 declaration from the most general template specialized here. */
5566b478
MS
2176#define DECL_TI_ARGS(NODE) TI_ARGS (DECL_TEMPLATE_INFO (NODE))
2177#define CLASSTYPE_TI_TEMPLATE(NODE) TI_TEMPLATE (CLASSTYPE_TEMPLATE_INFO (NODE))
2178#define CLASSTYPE_TI_ARGS(NODE) TI_ARGS (CLASSTYPE_TEMPLATE_INFO (NODE))
bb20cc46 2179#define ENUM_TI_TEMPLATE(NODE) \
ed44da02
MM
2180 TI_TEMPLATE (ENUM_TEMPLATE_INFO (NODE))
2181#define ENUM_TI_ARGS(NODE) \
2182 TI_ARGS (ENUM_TEMPLATE_INFO (NODE))
2183
ca099ac8 2184/* For a template instantiation TYPE, returns the TYPE corresponding
353b4fc0
MM
2185 to the primary template. Otherwise returns TYPE itself. */
2186#define CLASSTYPE_PRIMARY_TEMPLATE_TYPE(TYPE) \
2187 ((CLASSTYPE_USE_TEMPLATE ((TYPE)) && !CLASSTYPE_TEMPLATE_SPECIALIZATION ((TYPE))) \
2188 ? TREE_TYPE (DECL_TEMPLATE_RESULT (DECL_PRIMARY_TEMPLATE \
2189 (CLASSTYPE_TI_TEMPLATE ((TYPE))))) \
2190 : (TYPE))
ca099ac8 2191
ed44da02
MM
2192/* Like DECL_TI_TEMPLATE, but for an ENUMERAL_, RECORD_, or UNION_TYPE. */
2193#define TYPE_TI_TEMPLATE(NODE) \
2194 (TI_TEMPLATE (TYPE_TEMPLATE_INFO (NODE)))
2195
59026e79 2196/* Like DECL_TI_ARGS, but for an ENUMERAL_, RECORD_, or UNION_TYPE. */
ed44da02
MM
2197#define TYPE_TI_ARGS(NODE) \
2198 (TI_ARGS (TYPE_TEMPLATE_INFO (NODE)))
2199
98e40e83 2200#define INNERMOST_TEMPLATE_PARMS(NODE) TREE_VALUE (NODE)
5566b478 2201
6ba89f8e
MM
2202/* Nonzero if the NODE corresponds to the template parameters for a
2203 member template, whose inline definition is being processed after
2204 the class definition is complete. */
cae40af6
JM
2205#define TEMPLATE_PARMS_FOR_INLINE(NODE) TREE_LANG_FLAG_1 (NODE)
2206
59026e79 2207/* In a FUNCTION_DECL, the saved language-specific per-function data. */
e2500fed
GK
2208#define DECL_SAVED_FUNCTION_DATA(NODE) \
2209 (DECL_LANG_SPECIFIC (FUNCTION_DECL_CHECK (NODE)) \
2210 ->u.f.u.saved_language_function)
59026e79 2211
a2982c1b
RK
2212#define NEW_EXPR_USE_GLOBAL(NODE) \
2213 TREE_LANG_FLAG_0 (NEW_EXPR_CHECK (NODE))
2214#define DELETE_EXPR_USE_GLOBAL(NODE) \
2215 TREE_LANG_FLAG_0 (DELETE_EXPR_CHECK (NODE))
2216#define DELETE_EXPR_USE_VEC(NODE) \
2217 TREE_LANG_FLAG_1 (DELETE_EXPR_CHECK (NODE))
8d08fdba 2218
8e1daa34
NS
2219/* Indicates that this is a non-dependent COMPOUND_EXPR which will
2220 resolve to a function call. */
a2982c1b
RK
2221#define COMPOUND_EXPR_OVERLOADED(NODE) \
2222 TREE_LANG_FLAG_0 (COMPOUND_EXPR_CHECK (NODE))
8e1daa34 2223
6d80c4b9
MM
2224/* In a CALL_EXPR appearing in a template, true if Koenig lookup
2225 should be performed at instantiation time. */
a2982c1b 2226#define KOENIG_LOOKUP_P(NODE) TREE_LANG_FLAG_0 (CALL_EXPR_CHECK (NODE))
6d80c4b9 2227
e1376b00
MM
2228/* Nonzero if this AGGR_INIT_EXPR provides for initialization via a
2229 constructor call, rather than an ordinary function call. */
da8a66fc
ML
2230#define AGGR_INIT_VIA_CTOR_P(NODE) \
2231 TREE_LANG_FLAG_0 (AGGR_INIT_EXPR_CHECK (NODE))
e1376b00 2232
6757edfe
MM
2233/* The TYPE_MAIN_DECL for a class template type is a TYPE_DECL, not a
2234 TEMPLATE_DECL. This macro determines whether or not a given class
2235 type is really a template type, as opposed to an instantiation or
2236 specialization of one. */
2237#define CLASSTYPE_IS_TEMPLATE(NODE) \
2238 (CLASSTYPE_TEMPLATE_INFO (NODE) \
2239 && !CLASSTYPE_USE_TEMPLATE (NODE) \
2240 && PRIMARY_TEMPLATE_P (CLASSTYPE_TI_TEMPLATE (NODE)))
2241
45869a6c
MM
2242/* The name used by the user to name the typename type. Typically,
2243 this is an IDENTIFIER_NODE, and the same as the DECL_NAME on the
2244 corresponding TYPE_DECL. However, this may also be a
2245 TEMPLATE_ID_EXPR if we had something like `typename X::Y<T>'. */
a2982c1b 2246#define TYPENAME_TYPE_FULLNAME(NODE) (TYPENAME_TYPE_CHECK (NODE))->type.values
ca40b399 2247
cfdd0551 2248/* Nonzero in INTEGER_CST means that this int is negative by dint of
8d08fdba 2249 using a twos-complement negated operand. */
da8a66fc 2250#define TREE_NEGATED_INT(NODE) TREE_LANG_FLAG_0 (INTEGER_CST_CHECK (NODE))
8d08fdba 2251
4c6b7393
MM
2252/* Nonzero in any kind of _TYPE where conversions to base-classes may
2253 involve pointer arithmetic. If this is zero, then converting to
2254 a base-class never requires changing the value of the pointer. */
2255#define TYPE_BASE_CONVS_MAY_REQUIRE_CODE_P(NODE) (TREE_LANG_FLAG_1 (NODE))
8d08fdba 2256
4c6b7393 2257/* [class.virtual]
8d08fdba 2258
4c6b7393
MM
2259 A class that declares or inherits a virtual function is called a
2260 polymorphic class. */
2261#define TYPE_POLYMORPHIC_P(NODE) (TREE_LANG_FLAG_2 (NODE))
8d08fdba 2262
bbd15aac 2263/* Nonzero if this class has a virtual function table pointer. */
bb20cc46
AJ
2264#define TYPE_CONTAINS_VPTR_P(NODE) \
2265 (TYPE_POLYMORPHIC_P (NODE) \
3461fba7 2266 || TYPE_USES_VIRTUAL_BASECLASSES (NODE))
bbd15aac 2267
d2ad151f 2268/* This flag is true of a local VAR_DECL if it was declared in a for
e92cc029 2269 statement, but we are no longer in the scope of the for. */
da8a66fc 2270#define DECL_DEAD_FOR_LOCAL(NODE) DECL_LANG_FLAG_7 (VAR_DECL_CHECK (NODE))
d2ad151f
PB
2271
2272/* This flag is set on a VAR_DECL that is a DECL_DEAD_FOR_LOCAL
2273 if we already emitted a warning about using it. */
da8a66fc 2274#define DECL_ERROR_REPORTED(NODE) DECL_LANG_FLAG_0 (VAR_DECL_CHECK (NODE))
d2ad151f 2275
cd9f6678
MM
2276/* Nonzero if NODE is a FUNCTION_DECL (for a function with global
2277 scope) declared in a local scope. */
2278#define DECL_LOCAL_FUNCTION_P(NODE) \
2279 DECL_LANG_FLAG_0 (FUNCTION_DECL_CHECK (NODE))
935d1834
ZW
2280
2281/* Nonzero if NODE is a FUNCTION_DECL for a built-in function, and we have
2282 not yet seen a prototype for that function. */
cc057ef3 2283#define DECL_ANTICIPATED(NODE) \
97ba1e3c 2284 (DECL_LANG_SPECIFIC (DECL_CHECK (NODE))->decl_flags.anticipated_p)
cd9f6678 2285
8d08fdba 2286/* Record whether a typedef for type `int' was actually `signed int'. */
98e40e83 2287#define C_TYPEDEF_EXPLICITLY_SIGNED(EXP) DECL_LANG_FLAG_1 (EXP)
8d08fdba 2288
838dfd8a 2289/* Returns nonzero if DECL has external linkage, as specified by the
ad50e811
MM
2290 language standard. (This predicate may hold even when the
2291 corresponding entity is not actually given external linkage in the
2292 object file; see decl_linkage for details.) */
2293#define DECL_EXTERNAL_LINKAGE_P(DECL) \
2294 (decl_linkage (DECL) == lk_external)
2295
2986ae00 2296#define INTEGRAL_CODE_P(CODE) \
98e40e83 2297 ((CODE) == INTEGER_TYPE || (CODE) == ENUMERAL_TYPE || (CODE) == BOOLEAN_TYPE)
a7a64a77
MM
2298
2299/* [basic.fundamental]
2300
2301 Types bool, char, wchar_t, and the signed and unsigned integer types
bb20cc46 2302 are collectively called integral types.
a7a64a77
MM
2303
2304 Note that INTEGRAL_TYPE_P, as defined in tree.h, allows enumeration
2305 types as well, which is incorrect in C++. */
bb20cc46 2306#define CP_INTEGRAL_TYPE_P(TYPE) \
98e40e83
GS
2307 (TREE_CODE (TYPE) == BOOLEAN_TYPE \
2308 || TREE_CODE (TYPE) == INTEGER_TYPE)
a7a64a77 2309
14d22dd6
MM
2310/* Returns true if TYPE is an integral or enumeration name. */
2311#define INTEGRAL_OR_ENUMERATION_TYPE_P(TYPE) \
2312 (CP_INTEGRAL_TYPE_P (TYPE) || TREE_CODE (TYPE) == ENUMERAL_TYPE)
2313
a7a64a77
MM
2314/* [basic.fundamental]
2315
2316 Integral and floating types are collectively called arithmetic
2317 types. */
2318#define ARITHMETIC_TYPE_P(TYPE) \
2319 (CP_INTEGRAL_TYPE_P (TYPE) || TREE_CODE (TYPE) == REAL_TYPE)
2986ae00 2320
5f261ba9
MM
2321/* [basic.types]
2322
2323 Arithmetic types, enumeration types, pointer types, and
2324 pointer-to-member types, are collectively called scalar types. */
2325#define SCALAR_TYPE_P(TYPE) \
2326 (ARITHMETIC_TYPE_P (TYPE) \
2327 || TREE_CODE (TYPE) == ENUMERAL_TYPE \
2328 || TYPE_PTR_P (TYPE) \
a5ac359a 2329 || TYPE_PTR_TO_MEMBER_P (TYPE))
5f261ba9 2330
8e3df2de
MM
2331/* [dcl.init.aggr]
2332
2333 An aggregate is an array or a class with no user-declared
2334 constructors, no private or protected non-static data members, no
dbe85b80
JM
2335 base classes, and no virtual functions.
2336
2337 As an extension, we also treat vectors as aggregates. */
8e3df2de
MM
2338#define CP_AGGREGATE_TYPE_P(TYPE) \
2339 (TREE_CODE (TYPE) == ARRAY_TYPE \
dbe85b80 2340 || TREE_CODE (TYPE) == VECTOR_TYPE \
8e3df2de
MM
2341 || (CLASS_TYPE_P (TYPE) \
2342 && !CLASSTYPE_NON_AGGREGATE (TYPE)))
2343
2344/* Nonzero for a class type means that the class type has a
2345 user-declared constructor. */
98e40e83 2346#define TYPE_HAS_CONSTRUCTOR(NODE) (TYPE_LANG_FLAG_1 (NODE))
8d08fdba
MS
2347
2348/* When appearing in an INDIRECT_REF, it means that the tree structure
2349 underneath is actually a call to a constructor. This is needed
2350 when the constructor must initialize local storage (which can
2351 be automatically destroyed), rather than allowing it to allocate
2352 space from the heap.
2353
2354 When appearing in a SAVE_EXPR, it means that underneath
2355 is a call to a constructor.
2356
92a62aad
MM
2357 When appearing in a CONSTRUCTOR, the expression is a
2358 compound literal.
8d08fdba
MS
2359
2360 When appearing in a FIELD_DECL, it means that this field
2361 has been duly initialized in its constructor. */
98e40e83 2362#define TREE_HAS_CONSTRUCTOR(NODE) (TREE_LANG_FLAG_4 (NODE))
8d08fdba 2363
92a62aad
MM
2364/* True if NODE is a brace-enclosed initializer. */
2365#define BRACE_ENCLOSED_INITIALIZER_P(NODE) \
2366 (TREE_CODE (NODE) == CONSTRUCTOR && !TREE_TYPE (NODE))
2367
8452b1d3
JM
2368#define EMPTY_CONSTRUCTOR_P(NODE) (TREE_CODE (NODE) == CONSTRUCTOR \
2369 && CONSTRUCTOR_ELTS (NODE) == NULL_TREE \
2370 && ! TREE_HAS_CONSTRUCTOR (NODE))
a3203465 2371
8d08fdba 2372/* Nonzero for _TYPE means that the _TYPE defines a destructor. */
98e40e83 2373#define TYPE_HAS_DESTRUCTOR(NODE) (TYPE_LANG_FLAG_2 (NODE))
8d08fdba 2374
f30432d7
MS
2375/* Nonzero means that an object of this type can not be initialized using
2376 an initializer list. */
2377#define CLASSTYPE_NON_AGGREGATE(NODE) \
e2500fed 2378 (LANG_TYPE_CLASS_CHECK (NODE)->non_aggregate)
f30432d7
MS
2379#define TYPE_NON_AGGREGATE_CLASS(NODE) \
2380 (IS_AGGR_TYPE (NODE) && CLASSTYPE_NON_AGGREGATE (NODE))
2381
8d08fdba 2382/* Nonzero if there is a user-defined X::op=(x&) for this class. */
e2500fed 2383#define TYPE_HAS_COMPLEX_ASSIGN_REF(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->has_complex_assign_ref)
e2500fed 2384#define TYPE_HAS_COMPLEX_INIT_REF(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->has_complex_init_ref)
8d08fdba 2385
834c6dff 2386/* Nonzero if TYPE has a trivial destructor. From [class.dtor]:
bb20cc46 2387
834c6dff
MM
2388 A destructor is trivial if it is an implicitly declared
2389 destructor and if:
2390
2391 - all of the direct base classes of its class have trivial
bb20cc46 2392 destructors,
834c6dff
MM
2393
2394 - for all of the non-static data members of its class that are
bb20cc46 2395 of class type (or array thereof), each such class has a
834c6dff
MM
2396 trivial destructor. */
2397#define TYPE_HAS_TRIVIAL_DESTRUCTOR(NODE) \
2398 (!TYPE_HAS_NONTRIVIAL_DESTRUCTOR (NODE))
2399
2400/* Nonzero for _TYPE node means that this type does not have a trivial
2401 destructor. Therefore, destroying an object of this type will
2402 involve a call to a destructor. This can apply to objects of
2403 ARRAY_TYPE is the type of the elements needs a destructor. */
2404#define TYPE_HAS_NONTRIVIAL_DESTRUCTOR(NODE) \
98e40e83 2405 (TYPE_LANG_FLAG_4 (NODE))
8d08fdba 2406
0830ae44 2407/* Nonzero for class type means that copy initialization of this type can use
e8abc66f
MS
2408 a bitwise copy. */
2409#define TYPE_HAS_TRIVIAL_INIT_REF(NODE) \
2410 (TYPE_HAS_INIT_REF (NODE) && ! TYPE_HAS_COMPLEX_INIT_REF (NODE))
2411
2412/* Nonzero for class type means that assignment of this type can use
2413 a bitwise copy. */
2414#define TYPE_HAS_TRIVIAL_ASSIGN_REF(NODE) \
2415 (TYPE_HAS_ASSIGN_REF (NODE) && ! TYPE_HAS_COMPLEX_ASSIGN_REF (NODE))
2416
a5ac359a
MM
2417/* Returns true if NODE is a pointer-to-data-member. */
2418#define TYPE_PTRMEM_P(NODE) \
2419 (TREE_CODE (NODE) == OFFSET_TYPE)
2420#define TYPE_PTR_P(NODE) \
2421 (TREE_CODE (NODE) == POINTER_TYPE)
2422#define TYPE_PTROB_P(NODE) \
2423 (TYPE_PTR_P (NODE) \
2424 && TREE_CODE (TREE_TYPE (NODE)) != FUNCTION_TYPE \
2425 && TREE_CODE (TREE_TYPE (NODE)) != METHOD_TYPE \
c11b6f21
MS
2426 && TREE_CODE (TREE_TYPE (NODE)) != VOID_TYPE)
2427#define TYPE_PTROBV_P(NODE) \
2428 (TYPE_PTR_P (NODE) && TREE_CODE (TREE_TYPE (NODE)) != FUNCTION_TYPE)
2429#define TYPE_PTRFN_P(NODE) \
2430 (TREE_CODE (NODE) == POINTER_TYPE \
2431 && TREE_CODE (TREE_TYPE (NODE)) == FUNCTION_TYPE)
742a37d5
JM
2432#define TYPE_REFFN_P(NODE) \
2433 (TREE_CODE (NODE) == REFERENCE_TYPE \
2434 && TREE_CODE (TREE_TYPE (NODE)) == FUNCTION_TYPE)
c11b6f21 2435
8d08fdba 2436/* Nonzero for _TYPE node means that this type is a pointer to member
e92cc029 2437 function type. */
83e9506e 2438#define TYPE_PTRMEMFUNC_P(NODE) \
98e40e83
GS
2439 (TREE_CODE (NODE) == RECORD_TYPE \
2440 && TYPE_LANG_SPECIFIC (NODE) \
83e9506e
RH
2441 && TYPE_PTRMEMFUNC_FLAG (NODE))
2442
e08a8f45 2443#define TYPE_PTRMEMFUNC_FLAG(NODE) \
e2500fed 2444 (LANG_TYPE_CLASS_CHECK (NODE)->ptrmemfunc_flag)
e08a8f45 2445
a5ac359a
MM
2446/* Returns true if NODE is a pointer-to-member. */
2447#define TYPE_PTR_TO_MEMBER_P(NODE) \
2448 (TYPE_PTRMEM_P (NODE) || TYPE_PTRMEMFUNC_P (NODE))
2449
19420d00
NS
2450/* Indicates when overload resolution may resolve to a pointer to
2451 member function. [expr.unary.op]/3 */
a2982c1b
RK
2452#define PTRMEM_OK_P(NODE) \
2453 TREE_LANG_FLAG_0 (TREE_CHECK2 ((NODE), ADDR_EXPR, OFFSET_REF))
19420d00 2454
8d08fdba
MS
2455/* Get the POINTER_TYPE to the METHOD_TYPE associated with this
2456 pointer to member function. TYPE_PTRMEMFUNC_P _must_ be true,
e92cc029 2457 before using this macro. */
c7e266a6 2458#define TYPE_PTRMEMFUNC_FN_TYPE(NODE) \
1f84ec23 2459 (TREE_TYPE (TYPE_FIELDS (NODE)))
ceab47eb
MM
2460
2461/* Returns `A' for a type like `int (A::*)(double)' */
2462#define TYPE_PTRMEMFUNC_OBJECT_TYPE(NODE) \
2463 TYPE_METHOD_BASETYPE (TREE_TYPE (TYPE_PTRMEMFUNC_FN_TYPE (NODE)))
2464
38e01259 2465/* These are use to manipulate the canonical RECORD_TYPE from the
e92cc029 2466 hashed POINTER_TYPE, and can only be used on the POINTER_TYPE. */
98e40e83 2467#define TYPE_GET_PTRMEMFUNC_TYPE(NODE) \
e2500fed
GK
2468 (TYPE_LANG_SPECIFIC (NODE) ? LANG_TYPE_PTRMEM_CHECK (NODE)->record : NULL)
2469#define TYPE_SET_PTRMEMFUNC_TYPE(NODE, VALUE) \
2470 do { \
2471 if (TYPE_LANG_SPECIFIC (NODE) == NULL) \
2472 { \
2473 TYPE_LANG_SPECIFIC (NODE) = \
2474 ggc_alloc_cleared (sizeof (struct lang_type_ptrmem)); \
2475 TYPE_LANG_SPECIFIC (NODE)->u.ptrmem.h.is_lang_type_class = 0; \
2476 } \
2477 TYPE_LANG_SPECIFIC (NODE)->u.ptrmem.record = (VALUE); \
2478 } while (0)
530ec96d 2479/* Returns the pfn field from a TYPE_PTRMEMFUNC_P. */
e08a8f45 2480#define PFN_FROM_PTRMEMFUNC(NODE) pfn_from_ptrmemfunc ((NODE))
8d08fdba 2481
24272dc0
MM
2482/* For a pointer-to-member type of the form `T X::*', this is `X'.
2483 For a type like `void (X::*)() const', this type is `X', not `const
2484 X'. To get at the `const X' you have to look at the
2485 TYPE_PTRMEM_POINTED_TO_TYPE; there, the first parameter will have
2486 type `const X*'. */
f71f87f9 2487#define TYPE_PTRMEM_CLASS_TYPE(NODE) \
98e40e83 2488 (TYPE_PTRMEM_P (NODE) \
a5ac359a 2489 ? TYPE_OFFSET_BASETYPE (NODE) \
98e40e83 2490 : TYPE_PTRMEMFUNC_OBJECT_TYPE (NODE))
f71f87f9
MM
2491
2492/* For a pointer-to-member type of the form `T X::*', this is `T'. */
2493#define TYPE_PTRMEM_POINTED_TO_TYPE(NODE) \
98e40e83 2494 (TYPE_PTRMEM_P (NODE) \
a5ac359a 2495 ? TREE_TYPE (NODE) \
98e40e83 2496 : TREE_TYPE (TYPE_PTRMEMFUNC_FN_TYPE (NODE)))
f71f87f9 2497
61a127b3
MM
2498/* For a pointer-to-member constant `X::Y' this is the RECORD_TYPE for
2499 `X'. */
f71f87f9 2500#define PTRMEM_CST_CLASS(NODE) \
da8a66fc 2501 TYPE_PTRMEM_CLASS_TYPE (TREE_TYPE (PTRMEM_CST_CHECK (NODE)))
61a127b3 2502
bb20cc46 2503/* For a pointer-to-member constant `X::Y' this is the _DECL for
61a127b3 2504 `Y'. */
da8a66fc 2505#define PTRMEM_CST_MEMBER(NODE) (((ptrmem_cst_t)PTRMEM_CST_CHECK (NODE))->member)
61a127b3 2506
a2982c1b
RK
2507/* The expression in question for a TYPEOF_TYPE. */
2508#define TYPEOF_TYPE_EXPR(NODE) (TYPEOF_TYPE_CHECK (NODE))->type.values
2509
faae18ab 2510/* Nonzero for VAR_DECL and FUNCTION_DECL node means that `extern' was
07c88314
MM
2511 specified in its declaration. This can also be set for an
2512 erroneously declared PARM_DECL. */
da8a66fc 2513#define DECL_THIS_EXTERN(NODE) \
07c88314 2514 DECL_LANG_FLAG_2 (VAR_FUNCTION_OR_PARM_DECL_CHECK (NODE))
8d08fdba 2515
faae18ab 2516/* Nonzero for VAR_DECL and FUNCTION_DECL node means that `static' was
07c88314
MM
2517 specified in its declaration. This can also be set for an
2518 erroneously declared PARM_DECL. */
da8a66fc 2519#define DECL_THIS_STATIC(NODE) \
07c88314 2520 DECL_LANG_FLAG_6 (VAR_FUNCTION_OR_PARM_DECL_CHECK (NODE))
faae18ab 2521
6bdb8141
JM
2522/* Nonzero if TYPE is an anonymous union or struct type. We have to use a
2523 flag for this because "A union for which objects or pointers are
2524 declared is not an anonymous union" [class.union]. */
2525#define ANON_AGGR_TYPE_P(NODE) \
e2500fed 2526 (CLASS_TYPE_P (NODE) && LANG_TYPE_CLASS_CHECK (NODE)->anon_aggr)
6bdb8141 2527#define SET_ANON_AGGR_TYPE_P(NODE) \
e2500fed 2528 (LANG_TYPE_CLASS_CHECK (NODE)->anon_aggr = 1)
67ffc812 2529
1e30f9b4
MM
2530/* Nonzero if TYPE is an anonymous union type. */
2531#define ANON_UNION_TYPE_P(NODE) \
2532 (TREE_CODE (NODE) == UNION_TYPE && ANON_AGGR_TYPE_P (NODE))
2533
8d08fdba
MS
2534#define UNKNOWN_TYPE LANG_TYPE
2535
2536/* Define fields and accessors for nodes representing declared names. */
2537
e2500fed 2538#define TYPE_WAS_ANONYMOUS(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->was_anonymous)
8d08fdba
MS
2539
2540/* C++: all of these are overloaded! These apply only to TYPE_DECLs. */
f84b4be9
JM
2541
2542/* The format of each node in the DECL_FRIENDLIST is as follows:
2543
2544 The TREE_PURPOSE will be the name of a function, i.e., an
436f8a4c
MM
2545 IDENTIFIER_NODE. The TREE_VALUE will be itself a TREE_LIST, whose
2546 TREE_VALUEs are friends with the given name. */
8d08fdba 2547#define DECL_FRIENDLIST(NODE) (DECL_INITIAL (NODE))
6a629cac
MM
2548#define FRIEND_NAME(LIST) (TREE_PURPOSE (LIST))
2549#define FRIEND_DECLS(LIST) (TREE_VALUE (LIST))
8d08fdba 2550
2036a15c
MM
2551/* The DECL_ACCESS, if non-NULL, is a TREE_LIST. The TREE_PURPOSE of
2552 each node is a type; the TREE_VALUE is the access granted for this
2553 DECL in that type. The DECL_ACCESS is set by access declarations.
2554 For example, if a member that would normally be public in a
2555 derived class is made protected, then the derived class and the
2556 protected_access_node will appear in the DECL_ACCESS for the node. */
e2500fed 2557#define DECL_ACCESS(NODE) (LANG_DECL_U2_CHECK (NODE, 0)->access)
af3b4e59
MM
2558
2559/* Nonzero if the FUNCTION_DECL is a global constructor. */
2560#define DECL_GLOBAL_CTOR_P(NODE) \
98e40e83 2561 (DECL_LANG_SPECIFIC (NODE)->decl_flags.global_ctor_p)
af3b4e59
MM
2562
2563/* Nonzero if the FUNCTION_DECL is a global destructor. */
2564#define DECL_GLOBAL_DTOR_P(NODE) \
98e40e83 2565 (DECL_LANG_SPECIFIC (NODE)->decl_flags.global_dtor_p)
af3b4e59 2566
8d08fdba 2567/* Accessor macros for C++ template decl nodes. */
f84b4be9
JM
2568
2569/* The DECL_TEMPLATE_PARMS are a list. The TREE_PURPOSE of each node
4890c2f4 2570 is a INT_CST whose TREE_INT_CST_LOW indicates the level of the
36a117a5
MM
2571 template parameters, with 1 being the outermost set of template
2572 parameters. The TREE_VALUE is a vector, whose elements are the
2573 template parameters at each level. Each element in the vector is a
2574 TREE_LIST, whose TREE_VALUE is a PARM_DECL (if the parameter is a
2575 non-type parameter), or a TYPE_DECL (if the parameter is a type
2576 parameter). The TREE_PURPOSE is the default value, if any. The
34cd5ae7 2577 TEMPLATE_PARM_INDEX for the parameter is available as the
36a117a5
MM
2578 DECL_INITIAL (for a PARM_DECL) or as the TREE_TYPE (for a
2579 TYPE_DECL). */
98e40e83 2580#define DECL_TEMPLATE_PARMS(NODE) DECL_ARGUMENTS (NODE)
98c1c668
JM
2581#define DECL_INNERMOST_TEMPLATE_PARMS(NODE) \
2582 INNERMOST_TEMPLATE_PARMS (DECL_TEMPLATE_PARMS (NODE))
2583#define DECL_NTPARMS(NODE) \
2584 TREE_VEC_LENGTH (DECL_INNERMOST_TEMPLATE_PARMS (NODE))
8d08fdba 2585/* For function, method, class-data templates. */
98e40e83 2586#define DECL_TEMPLATE_RESULT(NODE) DECL_RESULT_FLD (NODE)
36a117a5
MM
2587/* For a static member variable template, the
2588 DECL_TEMPLATE_INSTANTIATIONS list contains the explicitly and
2589 implicitly generated instantiations of the variable. There are no
2590 partial instantiations of static member variables, so all of these
2591 will be full instantiations.
2592
2593 For a class template the DECL_TEMPLATE_INSTANTIATIONS lists holds
2594 all instantiations and specializations of the class type, including
2595 partial instantiations and partial specializations.
2596
2597 In both cases, the TREE_PURPOSE of each node contains the arguments
2598 used; the TREE_VALUE contains the generated variable. The template
2599 arguments are always complete. For example, given:
2600
2601 template <class T> struct S1 {
2602 template <class U> struct S2 {};
2603 template <class U> struct S2<U*> {};
2604 };
2605
2606 the record for the partial specialization will contain, as its
2607 argument list, { {T}, {U*} }, and will be on the
2608 DECL_TEMPLATE_INSTANTIATIONS list for `template <class T> template
2609 <class U> struct S1<T>::S2'.
2610
2611 This list is not used for function templates. */
98e40e83 2612#define DECL_TEMPLATE_INSTANTIATIONS(NODE) DECL_VINDEX (NODE)
36a117a5
MM
2613/* For a function template, the DECL_TEMPLATE_SPECIALIZATIONS lists
2614 contains all instantiations and specializations of the function,
2615 including partial instantiations. For a partial instantiation
2616 which is a specialization, this list holds only full
2617 specializations of the template that are instantiations of the
2618 partial instantiation. For example, given:
2619
2620 template <class T> struct S {
2621 template <class U> void f(U);
bb20cc46 2622 template <> void f(T);
36a117a5
MM
2623 };
2624
2625 the `S<int>::f<int>(int)' function will appear on the
2626 DECL_TEMPLATE_SPECIALIZATIONS list for both `template <class T>
2627 template <class U> void S<T>::f(U)' and `template <class T> void
2628 S<int>::f(T)'. In the latter case, however, it will have only the
2629 innermost set of arguments (T, in this case). The DECL_TI_TEMPLATE
2630 for the function declaration will point at the specialization, not
2631 the fully general template.
2632
2633 For a class template, this list contains the partial
2634 specializations of this template. (Full specializations are not
2635 recorded on this list.) The TREE_PURPOSE holds the innermost
2636 arguments used in the partial specialization (e.g., for `template
2637 <class T> struct S<T*, int>' this will be `T*'.) The TREE_VALUE
2638 holds the innermost template parameters for the specialization
2639 (e.g., `T' in the example above.) The TREE_TYPE is the _TYPE node
2640 for the partial specialization.
2641
2642 This list is not used for static variable templates. */
98e40e83 2643#define DECL_TEMPLATE_SPECIALIZATIONS(NODE) DECL_SIZE (NODE)
5566b478 2644
50714e79 2645/* Nonzero for a DECL which is actually a template parameter. */
bb20cc46 2646#define DECL_TEMPLATE_PARM_P(NODE) \
cd9f6678
MM
2647 (DECL_LANG_FLAG_0 (NODE) \
2648 && (TREE_CODE (NODE) == CONST_DECL \
833aa4c4 2649 || TREE_CODE (NODE) == PARM_DECL \
cd9f6678
MM
2650 || TREE_CODE (NODE) == TYPE_DECL \
2651 || TREE_CODE (NODE) == TEMPLATE_DECL))
2652
2653/* Mark NODE as a template parameter. */
2654#define SET_DECL_TEMPLATE_PARM_P(NODE) \
2655 (DECL_LANG_FLAG_0 (NODE) = 1)
50714e79 2656
cd9f6678 2657/* Nonzero if NODE is a template template parameter. */
73b0fce8 2658#define DECL_TEMPLATE_TEMPLATE_PARM_P(NODE) \
50714e79 2659 (TREE_CODE (NODE) == TEMPLATE_DECL && DECL_TEMPLATE_PARM_P (NODE))
73b0fce8 2660
b0bc6e8e
KL
2661/* Nonzero if NODE is a TEMPLATE_DECL representing an
2662 UNBOUND_CLASS_TEMPLATE tree node. */
2663#define DECL_UNBOUND_CLASS_TEMPLATE_P(NODE) \
2664 (TREE_CODE (NODE) == TEMPLATE_DECL && !DECL_TEMPLATE_RESULT (NODE))
2665
5566b478
MS
2666#define DECL_FUNCTION_TEMPLATE_P(NODE) \
2667 (TREE_CODE (NODE) == TEMPLATE_DECL \
b0bc6e8e 2668 && !DECL_UNBOUND_CLASS_TEMPLATE_P (NODE) \
5566b478
MS
2669 && TREE_CODE (DECL_TEMPLATE_RESULT (NODE)) == FUNCTION_DECL)
2670
6757edfe
MM
2671/* Nonzero for a DECL that represents a template class. */
2672#define DECL_CLASS_TEMPLATE_P(NODE) \
2673 (TREE_CODE (NODE) == TEMPLATE_DECL \
b0bc6e8e 2674 && !DECL_UNBOUND_CLASS_TEMPLATE_P (NODE) \
6757edfe
MM
2675 && TREE_CODE (DECL_TEMPLATE_RESULT (NODE)) == TYPE_DECL \
2676 && !DECL_TEMPLATE_TEMPLATE_PARM_P (NODE))
2677
35acd3f2
MM
2678/* Nonzero if NODE which declares a type. */
2679#define DECL_DECLARES_TYPE_P(NODE) \
2680 (TREE_CODE (NODE) == TYPE_DECL || DECL_CLASS_TEMPLATE_P (NODE))
2681
9188c363 2682/* Nonzero if NODE is the typedef implicitly generated for a type when
a3d87771
MM
2683 the type is declared. In C++, `struct S {};' is roughly
2684 equivalent to `struct S {}; typedef struct S S;' in C.
2685 DECL_IMPLICIT_TYPEDEF_P will hold for the typedef indicated in this
2686 example. In C++, there is a second implicit typedef for each
2687 class, in the scope of `S' itself, so that you can say `S::S'.
2688 DECL_SELF_REFERENCE_P will hold for that second typedef. */
9188c363 2689#define DECL_IMPLICIT_TYPEDEF_P(NODE) \
98e40e83 2690 (TREE_CODE (NODE) == TYPE_DECL && DECL_LANG_FLAG_2 (NODE))
9188c363 2691#define SET_DECL_IMPLICIT_TYPEDEF_P(NODE) \
98e40e83 2692 (DECL_LANG_FLAG_2 (NODE) = 1)
a3d87771
MM
2693#define DECL_SELF_REFERENCE_P(NODE) \
2694 (TREE_CODE (NODE) == TYPE_DECL && DECL_LANG_FLAG_4 (NODE))
2695#define SET_DECL_SELF_REFERENCE_P(NODE) \
2696 (DECL_LANG_FLAG_4 (NODE) = 1)
9188c363 2697
93cdc044
JM
2698/* A `primary' template is one that has its own template header. A
2699 member function of a class template is a template, but not primary.
6757edfe
MM
2700 A member template is primary. Friend templates are primary, too. */
2701
2702/* Returns the primary template corresponding to these parameters. */
2703#define DECL_PRIMARY_TEMPLATE(NODE) \
2704 (TREE_TYPE (DECL_INNERMOST_TEMPLATE_PARMS (NODE)))
2705
838dfd8a 2706/* Returns nonzero if NODE is a primary template. */
98e40e83 2707#define PRIMARY_TEMPLATE_P(NODE) (DECL_PRIMARY_TEMPLATE (NODE) == (NODE))
5566b478
MS
2708
2709#define CLASSTYPE_TEMPLATE_LEVEL(NODE) \
4890c2f4 2710 (TREE_INT_CST_LOW (TREE_PURPOSE (CLASSTYPE_TI_TEMPLATE (NODE))))
8d08fdba 2711
a0a33927
MS
2712/* Indicates whether or not (and how) a template was expanded for this
2713 FUNCTION_DECL or VAR_DECL.
2714 0=normal declaration, e.g. int min (int, int);
2715 1=implicit template instantiation
2716 2=explicit template specialization, e.g. int min<int> (int, int);
e92cc029 2717 3=explicit template instantiation, e.g. template int min<int> (int, int); */
98e40e83 2718#define DECL_USE_TEMPLATE(NODE) (DECL_LANG_SPECIFIC (NODE)->decl_flags.use_template)
a0a33927
MS
2719
2720#define DECL_TEMPLATE_INSTANTIATION(NODE) (DECL_USE_TEMPLATE (NODE) & 1)
2721#define CLASSTYPE_TEMPLATE_INSTANTIATION(NODE) \
2722 (CLASSTYPE_USE_TEMPLATE (NODE) & 1)
2723
2724#define DECL_TEMPLATE_SPECIALIZATION(NODE) (DECL_USE_TEMPLATE (NODE) == 2)
2725#define SET_DECL_TEMPLATE_SPECIALIZATION(NODE) (DECL_USE_TEMPLATE (NODE) = 2)
370af2d5 2726#define CLASSTYPE_TEMPLATE_SPECIALIZATION(NODE) \
a0a33927 2727 (CLASSTYPE_USE_TEMPLATE (NODE) == 2)
370af2d5 2728#define SET_CLASSTYPE_TEMPLATE_SPECIALIZATION(NODE) \
a0a33927
MS
2729 (CLASSTYPE_USE_TEMPLATE (NODE) = 2)
2730
2731#define DECL_IMPLICIT_INSTANTIATION(NODE) (DECL_USE_TEMPLATE (NODE) == 1)
2732#define SET_DECL_IMPLICIT_INSTANTIATION(NODE) (DECL_USE_TEMPLATE (NODE) = 1)
2733#define CLASSTYPE_IMPLICIT_INSTANTIATION(NODE) \
98e40e83 2734 (CLASSTYPE_USE_TEMPLATE (NODE) == 1)
a0a33927 2735#define SET_CLASSTYPE_IMPLICIT_INSTANTIATION(NODE) \
98e40e83 2736 (CLASSTYPE_USE_TEMPLATE (NODE) = 1)
a0a33927
MS
2737
2738#define DECL_EXPLICIT_INSTANTIATION(NODE) (DECL_USE_TEMPLATE (NODE) == 3)
2739#define SET_DECL_EXPLICIT_INSTANTIATION(NODE) (DECL_USE_TEMPLATE (NODE) = 3)
2740#define CLASSTYPE_EXPLICIT_INSTANTIATION(NODE) \
98e40e83 2741 (CLASSTYPE_USE_TEMPLATE (NODE) == 3)
a0a33927 2742#define SET_CLASSTYPE_EXPLICIT_INSTANTIATION(NODE) \
98e40e83 2743 (CLASSTYPE_USE_TEMPLATE (NODE) = 3)
7177d104 2744
838dfd8a 2745/* Nonzero if DECL is a friend function which is an instantiation
61289ca3
MM
2746 from the point of view of the compiler, but not from the point of
2747 view of the language. For example given:
2748 template <class T> struct S { friend void f(T) {}; };
2749 the declaration of `void f(int)' generated when S<int> is
2750 instantiated will not be a DECL_TEMPLATE_INSTANTIATION, but will be
2751 a DECL_FRIEND_PSUEDO_TEMPLATE_INSTANTIATION. */
2752#define DECL_FRIEND_PSEUDO_TEMPLATE_INSTANTIATION(DECL) \
2753 (DECL_TEMPLATE_INFO (DECL) && !DECL_USE_TEMPLATE (DECL))
2754
838dfd8a 2755/* Nonzero iff we are currently processing a declaration for an
39c01e4c
MM
2756 entity with its own template parameter list, and which is not a
2757 full specialization. */
2758#define PROCESSING_REAL_TEMPLATE_DECL_P() \
f60a10e7 2759 (processing_template_decl > template_class_depth (current_scope ()))
39c01e4c 2760
fbf1c34b
MM
2761/* Nonzero if this VAR_DECL or FUNCTION_DECL has already been
2762 instantiated, i.e. its definition has been generated from the
2763 pattern given in the the template. */
da8a66fc
ML
2764#define DECL_TEMPLATE_INSTANTIATED(NODE) \
2765 DECL_LANG_FLAG_1 (VAR_OR_FUNCTION_DECL_CHECK (NODE))
fbf1c34b 2766
db5ae43f 2767/* We know what we're doing with this decl now. */
e3417fcd 2768#define DECL_INTERFACE_KNOWN(NODE) DECL_LANG_FLAG_5 (NODE)
db5ae43f 2769
faae18ab
MS
2770/* DECL_EXTERNAL must be set on a decl until the decl is actually emitted,
2771 so that assemble_external will work properly. So we have this flag to
2772 tell us whether the decl is really not external. */
2773#define DECL_NOT_REALLY_EXTERN(NODE) \
2774 (DECL_LANG_SPECIFIC (NODE)->decl_flags.not_really_extern)
db5ae43f 2775
6b5fbb55
MS
2776#define DECL_REALLY_EXTERN(NODE) \
2777 (DECL_EXTERNAL (NODE) && ! DECL_NOT_REALLY_EXTERN (NODE))
2778
eb68cb58
MM
2779/* A thunk is a stub function.
2780
2781 A thunk is an alternate entry point for an ordinary FUNCTION_DECL.
2782 The address of the ordinary FUNCTION_DECL is given by the
2783 DECL_INITIAL, which is always an ADDR_EXPR whose operand is a
4977bab6
ZW
2784 FUNCTION_DECL. The job of the thunk is to either adjust the this
2785 pointer before transferring control to the FUNCTION_DECL, or call
2786 FUNCTION_DECL and then adjust the result value. Note, the result
2787 pointer adjusting thunk must perform a call to the thunked
2788 function, (or be implemented via passing some invisible parameter
2789 to the thunked function, which is modified to perform the
2790 adjustment just before returning).
2791
eb68cb58
MM
2792 A thunk may perform either, or both, of the following operations:
2793
4977bab6
ZW
2794 o Adjust the this or result pointer by a constant offset.
2795 o Adjust the this or result pointer by looking up a vcall or vbase offset
eb68cb58
MM
2796 in the vtable.
2797
4977bab6
ZW
2798 A this pointer adjusting thunk converts from a base to a derived
2799 class, and hence adds the offsets. A result pointer adjusting thunk
2800 converts from a derived class to a base, and hence subtracts the
2801 offsets. If both operations are performed, then the constant
34cd5ae7 2802 adjustment is performed first for this pointer adjustment and last
4977bab6 2803 for the result pointer adjustment.
eb68cb58 2804
4977bab6 2805 The constant adjustment is given by THUNK_FIXED_OFFSET. If the
e00853fd
NS
2806 vcall or vbase offset is required, THUNK_VIRTUAL_OFFSET is
2807 used. For this pointer adjusting thunks, it is the vcall offset
2808 into the vtable. For result pointer adjusting thunks it is the
2809 binfo of the virtual base to convert to. Use that binfo's vbase
2810 offset.
2811
2812 It is possible to have equivalent covariant thunks. These are
2813 distinct virtual covariant thunks whose vbase offsets happen to
2814 have the same value. THUNK_ALIAS is used to pick one as the
2815 canonical thunk, which will get all the this pointer adjusting
2816 thunks attached to it. */
eb68cb58 2817
c0bbf652 2818/* An integer indicating how many bytes should be subtracted from the
4977bab6
ZW
2819 this or result pointer when this function is called. */
2820#define THUNK_FIXED_OFFSET(DECL) \
07fa4878
NS
2821 (DECL_LANG_SPECIFIC (VAR_OR_FUNCTION_DECL_CHECK (DECL))->u.f.fixed_offset)
2822
2823/* A tree indicating how to perform the virtual adjustment. For a this
2824 adjusting thunk it is the number of bytes to be added to the vtable
2825 to find the vcall offset. For a result adjusting thunk, it is the
3cfabe60
NS
2826 binfo of the relevant virtual base. If NULL, then there is no
2827 virtual adjust. (The vptr is always located at offset zero from
2828 the this or result pointer.) (If the covariant type is within the
bb885938 2829 class hierarchy being laid out, the vbase index is not yet known
3cfabe60
NS
2830 at the point we need to create the thunks, hence the need to use
2831 binfos.) */
2832
4977bab6 2833#define THUNK_VIRTUAL_OFFSET(DECL) \
e00853fd 2834 (LANG_DECL_U2_CHECK (FUNCTION_DECL_CHECK (DECL), 0)->virtual_offset)
07fa4878 2835
f4f206f4 2836/* A thunk which is equivalent to another thunk. */
e00853fd
NS
2837#define THUNK_ALIAS(DECL) \
2838 (DECL_LANG_SPECIFIC (FUNCTION_DECL_CHECK (DECL))->decl_flags.u.thunk_alias)
bb885938 2839
07fa4878
NS
2840/* For thunk NODE, this is the FUNCTION_DECL thunked to. */
2841#define THUNK_TARGET(NODE) \
2842 (DECL_LANG_SPECIFIC (NODE)->u.f.befriending_classes)
c0bbf652 2843
ad321293
MM
2844/* These macros provide convenient access to the various _STMT nodes
2845 created when parsing template declarations. */
da8a66fc
ML
2846#define TRY_STMTS(NODE) TREE_OPERAND (TRY_BLOCK_CHECK (NODE), 0)
2847#define TRY_HANDLERS(NODE) TREE_OPERAND (TRY_BLOCK_CHECK (NODE), 1)
d7e7759d 2848
52a11cbf
RH
2849#define EH_SPEC_STMTS(NODE) TREE_OPERAND (EH_SPEC_BLOCK_CHECK (NODE), 0)
2850#define EH_SPEC_RAISES(NODE) TREE_OPERAND (EH_SPEC_BLOCK_CHECK (NODE), 1)
2851
9da99f7d
NS
2852#define USING_STMT_NAMESPACE(NODE) TREE_OPERAND (USING_STMT_CHECK (NODE), 0)
2853
62409b39 2854/* Nonzero if this try block is a function try block. */
da8a66fc
ML
2855#define FN_TRY_BLOCK_P(NODE) TREE_LANG_FLAG_3 (TRY_BLOCK_CHECK (NODE))
2856#define HANDLER_PARMS(NODE) TREE_OPERAND (HANDLER_CHECK (NODE), 0)
2857#define HANDLER_BODY(NODE) TREE_OPERAND (HANDLER_CHECK (NODE), 1)
1a6025b4 2858#define HANDLER_TYPE(NODE) TREE_TYPE (HANDLER_CHECK (NODE))
46e8c075 2859
5a508662
RH
2860/* CLEANUP_STMT accessors. The statement(s) covered, the cleanup to run
2861 and the VAR_DECL for which this cleanup exists. */
2862#define CLEANUP_BODY(NODE) TREE_OPERAND (CLEANUP_STMT_CHECK (NODE), 0)
2863#define CLEANUP_EXPR(NODE) TREE_OPERAND (CLEANUP_STMT_CHECK (NODE), 1)
2864#define CLEANUP_DECL(NODE) TREE_OPERAND (CLEANUP_STMT_CHECK (NODE), 2)
2865
2866/* IF_STMT accessors. These give access to the condition of the if
2867 statement, the then block of the if statement, and the else block
2868 of the if statement if it exists. */
2869#define IF_COND(NODE) TREE_OPERAND (IF_STMT_CHECK (NODE), 0)
2870#define THEN_CLAUSE(NODE) TREE_OPERAND (IF_STMT_CHECK (NODE), 1)
2871#define ELSE_CLAUSE(NODE) TREE_OPERAND (IF_STMT_CHECK (NODE), 2)
2872
8d08fdba 2873/* An enumeration of the kind of tags that C++ accepts. */
a723baf1
MM
2874enum tag_types {
2875 none_type = 0, /* Not a tag type. */
2876 record_type, /* "struct" types. */
2877 class_type, /* "class" types. */
2878 union_type, /* "union" types. */
2879 enum_type, /* "enum" types. */
2880 typename_type /* "typename" types. */
2881};
8d08fdba 2882
27b8d0cd
MM
2883/* The various kinds of lvalues we distinguish. */
2884typedef enum cp_lvalue_kind {
2885 clk_none = 0, /* Things that are not an lvalue. */
2886 clk_ordinary = 1, /* An ordinary lvalue. */
2887 clk_class = 2, /* An rvalue of class-type. */
e0d1297c 2888 clk_bitfield = 4, /* An lvalue for a bit-field. */
f4f206f4 2889 clk_packed = 8 /* An lvalue for a packed field. */
27b8d0cd
MM
2890} cp_lvalue_kind;
2891
74b846e0
MM
2892/* Various kinds of template specialization, instantiation, etc. */
2893typedef enum tmpl_spec_kind {
2894 tsk_none, /* Not a template at all. */
2895 tsk_invalid_member_spec, /* An explicit member template
2896 specialization, but the enclosing
2897 classes have not all been explicitly
2898 specialized. */
2899 tsk_invalid_expl_inst, /* An explicit instantiation containing
2900 template parameter lists. */
2901 tsk_excessive_parms, /* A template declaration with too many
2902 template parameter lists. */
2903 tsk_insufficient_parms, /* A template declaration with too few
2904 parameter lists. */
2905 tsk_template, /* A template declaration. */
2906 tsk_expl_spec, /* An explicit specialization. */
2907 tsk_expl_inst /* An explicit instantiation. */
2908} tmpl_spec_kind;
2909
c35cce41
MM
2910/* The various kinds of access. BINFO_ACCESS depends on these being
2911 two bit quantities. The numerical values are important; they are
509fc277 2912 used to initialize RTTI data structures, so changing them changes
9bcb9aae 2913 the ABI. */
c35cce41
MM
2914typedef enum access_kind {
2915 ak_none = 0, /* Inaccessible. */
2916 ak_public = 1, /* Accessible, as a `public' thing. */
2917 ak_protected = 2, /* Accessible, as a `protected' thing. */
2918 ak_private = 3 /* Accessible, as a `private' thing. */
2919} access_kind;
2920
872f37f9
MM
2921/* The various kinds of special functions. If you add to this list,
2922 you should update special_function_p as well. */
3dbc07b6 2923typedef enum special_function_kind {
872f37f9
MM
2924 sfk_none = 0, /* Not a special function. This enumeral
2925 must have value zero; see
2926 special_function_p. */
3dbc07b6 2927 sfk_constructor, /* A constructor. */
9eb71d8c
MM
2928 sfk_copy_constructor, /* A copy constructor. */
2929 sfk_assignment_operator, /* An assignment operator. */
3dbc07b6 2930 sfk_destructor, /* A destructor. */
872f37f9
MM
2931 sfk_complete_destructor, /* A destructor for complete objects. */
2932 sfk_base_destructor, /* A destructor for base subobjects. */
2933 sfk_deleting_destructor, /* A destructor for complete objects that
2934 deletes the object after it has been
2935 destroyed. */
3dbc07b6
MM
2936 sfk_conversion /* A conversion operator. */
2937} special_function_kind;
2938
ad50e811
MM
2939/* The various kinds of linkage. From [basic.link],
2940
2941 A name is said to have linkage when it might denote the same
2942 object, reference, function, type, template, namespace or value
2943 as a name introduced in another scope:
2944
2945 -- When a name has external linkage, the entity it denotes can
2946 be referred to from scopes of other translation units or from
2947 other scopes of the same translation unit.
2948
2949 -- When a name has internal linkage, the entity it denotes can
2950 be referred to by names from other scopes in the same
2951 translation unit.
2952
2953 -- When a name has no linkage, the entity it denotes cannot be
2954 referred to by names from other scopes. */
2955
2956typedef enum linkage_kind {
2957 lk_none, /* No linkage. */
2958 lk_internal, /* Internal linkage. */
2959 lk_external /* External linkage. */
2960} linkage_kind;
2961
c2ea3a40
NS
2962/* Bitmask flags to control type substitution. */
2963typedef enum tsubst_flags_t {
2964 tf_none = 0, /* nothing special */
2965 tf_error = 1 << 0, /* give error messages */
2966 tf_warning = 1 << 1, /* give warnings too */
8f4b394d
MM
2967 tf_ignore_bad_quals = 1 << 2, /* ignore bad cvr qualifiers */
2968 tf_keep_type_decl = 1 << 3, /* retain typedef type decls
4f2b0fb2 2969 (make_typename_type use) */
42eaed49
NS
2970 tf_ptrmem_ok = 1 << 4, /* pointers to member ok (internal
2971 instantiate_type use) */
a5bcc582 2972 tf_user = 1 << 5, /* found template must be a user template
42eaed49 2973 (lookup_template_class use) */
325c3691 2974 tf_conv = 1 << 6 /* We are determining what kind of
84583208
MM
2975 conversion might be permissible,
2976 not actually performing the
2977 conversion. */
c2ea3a40 2978} tsubst_flags_t;
5e76004e 2979
00a17e31 2980/* The kind of checking we can do looking in a class hierarchy. */
338d90b8 2981typedef enum base_access {
2db1ab2d 2982 ba_any = 0, /* Do not check access, allow an ambiguous base,
338d90b8 2983 prefer a non-virtual base */
2db1ab2d
NS
2984 ba_ignore = 1, /* Do not check access */
2985 ba_check = 2, /* Check access */
2986 ba_not_special = 3, /* Do not consider special privilege
00a17e31 2987 current_class_type might give. */
de94b46c 2988 ba_quiet = 4 /* Do not issue error messages (bit mask). */
338d90b8
NS
2989} base_access;
2990
8d241e0b
KL
2991/* The various kinds of access check during parsing. */
2992typedef enum deferring_kind {
2993 dk_no_deferred = 0, /* Check access immediately */
2994 dk_deferred = 1, /* Deferred check */
2995 dk_no_check = 2 /* No access check */
2996} deferring_kind;
2997
aba649ba 2998/* The kind of base we can find, looking in a class hierarchy.
00a17e31 2999 Values <0 indicate we failed. */
338d90b8
NS
3000typedef enum base_kind {
3001 bk_inaccessible = -3, /* The base is inaccessible */
3002 bk_ambig = -2, /* The base is ambiguous */
3003 bk_not_base = -1, /* It is not a base */
3004 bk_same_type = 0, /* It is the same type */
3005 bk_proper_base = 1, /* It is a proper base */
3006 bk_via_virtual = 2 /* It is a proper base, but via a virtual
3007 path. This might not be the canonical
00a17e31 3008 binfo. */
338d90b8
NS
3009} base_kind;
3010
51c184be 3011/* in decl{2}.c */
8d08fdba 3012/* A node that is a list (length 1) of error_mark_nodes. */
e2500fed 3013extern GTY(()) tree error_mark_list;
8d08fdba 3014
700f8a87 3015/* Node for "pointer to (virtual) function".
e92cc029 3016 This may be distinct from ptr_type_node so gdb can distinguish them. */
c4372ef4 3017#define vfunc_ptr_type_node vtable_entry_type
700f8a87 3018
8d08fdba 3019
8d08fdba 3020/* For building calls to `delete'. */
e2500fed
GK
3021extern GTY(()) tree integer_two_node;
3022extern GTY(()) tree integer_three_node;
8d08fdba 3023
b2244c65
MM
3024/* The number of function bodies which we are currently processing.
3025 (Zero if we are at namespace scope, one inside the body of a
3026 function, two inside the body of a function in a local class, etc.) */
3027extern int function_depth;
3028
51c184be 3029/* in pt.c */
5566b478 3030
62e4a758 3031/* These values are used for the `STRICT' parameter to type_unification and
830bfa74
MM
3032 fn_type_unification. Their meanings are described with the
3033 documentation for fn_type_unification. */
3034
3035typedef enum unification_kind_t {
3036 DEDUCE_CALL,
3037 DEDUCE_CONV,
62e4a758
NS
3038 DEDUCE_EXACT,
3039 DEDUCE_ORDER
830bfa74
MM
3040} unification_kind_t;
3041
6de9cd9a 3042/* Macros for operating on a template instantiation level node. */
3ae18eaf 3043
6de9cd9a 3044#define TINST_DECL(NODE) TREE_OPERAND (NODE, 0)
8d08fdba 3045
51c184be 3046/* in class.c */
61a127b3 3047
b4c4a9ec 3048extern int current_class_depth;
8d08fdba 3049
1f6e1acc
AS
3050/* An array of all local classes present in this translation unit, in
3051 declaration order. */
e2500fed 3052extern GTY(()) varray_type local_classes;
8d08fdba
MS
3053\f
3054/* Here's where we control how name mangling takes place. */
3055
8d08fdba
MS
3056/* Cannot use '$' up front, because this confuses gdb
3057 (names beginning with '$' are gdb-local identifiers).
3058
3059 Note that all forms in which the '$' is significant are long enough
3060 for direct indexing (meaning that if we know there is a '$'
3061 at a particular location, we can index into the string at
3062 any other location that provides distinguishing characters). */
3063
3064/* Define NO_DOLLAR_IN_LABEL in your favorite tm file if your assembler
3065 doesn't allow '$' in symbol names. */
3066#ifndef NO_DOLLAR_IN_LABEL
3067
3068#define JOINER '$'
3069
3070#define VPTR_NAME "$v"
3071#define THROW_NAME "$eh_throw"
8d08fdba
MS
3072#define AUTO_VTABLE_NAME "__vtbl$me__"
3073#define AUTO_TEMP_NAME "_$tmp_"
3074#define AUTO_TEMP_FORMAT "_$tmp_%d"
3075#define VTABLE_BASE "$vb"
c4372ef4 3076#define VTABLE_NAME_PREFIX "__vt_"
8d08fdba
MS
3077#define VFIELD_BASE "$vf"
3078#define VFIELD_NAME "_vptr$"
3079#define VFIELD_NAME_FORMAT "_vptr$%s"
8d08fdba
MS
3080#define STATIC_NAME_FORMAT "_%s$%s"
3081#define ANON_AGGRNAME_FORMAT "$_%d"
3082
3083#else /* NO_DOLLAR_IN_LABEL */
3084
3085#ifndef NO_DOT_IN_LABEL
3086
3087#define JOINER '.'
3088
3089#define VPTR_NAME ".v"
3090#define THROW_NAME ".eh_throw"
8d08fdba
MS
3091#define AUTO_VTABLE_NAME "__vtbl.me__"
3092#define AUTO_TEMP_NAME "_.tmp_"
3093#define AUTO_TEMP_FORMAT "_.tmp_%d"
3094#define VTABLE_BASE ".vb"
c4372ef4 3095#define VTABLE_NAME_PREFIX "__vt_"
8d08fdba
MS
3096#define VFIELD_BASE ".vf"
3097#define VFIELD_NAME "_vptr."
3098#define VFIELD_NAME_FORMAT "_vptr.%s"
8d08fdba
MS
3099#define STATIC_NAME_FORMAT "_%s.%s"
3100
3101#define ANON_AGGRNAME_FORMAT "._%d"
3102
3103#else /* NO_DOT_IN_LABEL */
3104
3105#define VPTR_NAME "__vptr"
3106#define VPTR_NAME_P(ID_NODE) \
3107 (!strncmp (IDENTIFIER_POINTER (ID_NODE), VPTR_NAME, sizeof (VPTR_NAME) - 1))
3108#define THROW_NAME "__eh_throw"
8d08fdba
MS
3109#define IN_CHARGE_NAME "__in_chrg"
3110#define AUTO_VTABLE_NAME "__vtbl_me__"
3111#define AUTO_TEMP_NAME "__tmp_"
3112#define TEMP_NAME_P(ID_NODE) \
3113 (!strncmp (IDENTIFIER_POINTER (ID_NODE), AUTO_TEMP_NAME, \
3114 sizeof (AUTO_TEMP_NAME) - 1))
3115#define AUTO_TEMP_FORMAT "__tmp_%d"
3116#define VTABLE_BASE "__vtb"
3117#define VTABLE_NAME "__vt_"
c4372ef4 3118#define VTABLE_NAME_PREFIX "__vt_"
8d08fdba
MS
3119#define VTABLE_NAME_P(ID_NODE) \
3120 (!strncmp (IDENTIFIER_POINTER (ID_NODE), VTABLE_NAME, \
3121 sizeof (VTABLE_NAME) - 1))
3122#define VFIELD_BASE "__vfb"
3123#define VFIELD_NAME "__vptr_"
3124#define VFIELD_NAME_P(ID_NODE) \
3125 (!strncmp (IDENTIFIER_POINTER (ID_NODE), VFIELD_NAME, \
3126 sizeof (VFIELD_NAME) - 1))
dc8ad298 3127#define VFIELD_NAME_FORMAT "__vptr_%s"
8d08fdba
MS
3128#define STATIC_NAME_FORMAT "__static_%s_%s"
3129
3130#define ANON_AGGRNAME_PREFIX "__anon_"
3131#define ANON_AGGRNAME_P(ID_NODE) \
3132 (!strncmp (IDENTIFIER_POINTER (ID_NODE), ANON_AGGRNAME_PREFIX, \
3133 sizeof (ANON_AGGRNAME_PREFIX) - 1))
3134#define ANON_AGGRNAME_FORMAT "__anon_%d"
8d08fdba
MS
3135
3136#endif /* NO_DOT_IN_LABEL */
3137#endif /* NO_DOLLAR_IN_LABEL */
3138
3139#define THIS_NAME "this"
fc378698
MS
3140#define CTOR_NAME "__ct"
3141#define DTOR_NAME "__dt"
8d08fdba
MS
3142
3143#define IN_CHARGE_NAME "__in_chrg"
3144
3145#define VTBL_PTR_TYPE "__vtbl_ptr_type"
3146#define VTABLE_DELTA_NAME "__delta"
8d08fdba 3147#define VTABLE_PFN_NAME "__pfn"
8d08fdba 3148
bb20cc46 3149#define EXCEPTION_CLEANUP_NAME "exception cleanup"
8d08fdba 3150
8d08fdba
MS
3151#if !defined(NO_DOLLAR_IN_LABEL) || !defined(NO_DOT_IN_LABEL)
3152
3153#define VPTR_NAME_P(ID_NODE) (IDENTIFIER_POINTER (ID_NODE)[0] == JOINER \
3154 && IDENTIFIER_POINTER (ID_NODE)[1] == 'v')
8d08fdba
MS
3155
3156#define VTABLE_NAME_P(ID_NODE) (IDENTIFIER_POINTER (ID_NODE)[1] == 'v' \
3157 && IDENTIFIER_POINTER (ID_NODE)[2] == 't' \
3158 && IDENTIFIER_POINTER (ID_NODE)[3] == JOINER)
3159
98e40e83
GS
3160#define TEMP_NAME_P(ID_NODE) \
3161 (!strncmp (IDENTIFIER_POINTER (ID_NODE), AUTO_TEMP_NAME, sizeof (AUTO_TEMP_NAME)-1))
3162#define VFIELD_NAME_P(ID_NODE) \
3163 (!strncmp (IDENTIFIER_POINTER (ID_NODE), VFIELD_NAME, sizeof(VFIELD_NAME)-1))
8d08fdba
MS
3164
3165/* For anonymous aggregate types, we need some sort of name to
3166 hold on to. In practice, this should not appear, but it should
3167 not be harmful if it does. */
3168#define ANON_AGGRNAME_P(ID_NODE) (IDENTIFIER_POINTER (ID_NODE)[0] == JOINER \
3169 && IDENTIFIER_POINTER (ID_NODE)[1] == '_')
8d08fdba 3170#endif /* !defined(NO_DOLLAR_IN_LABEL) || !defined(NO_DOT_IN_LABEL) */
35680744 3171
838dfd8a 3172/* Returns nonzero iff NODE is a declaration for the global function
35680744
MM
3173 `main'. */
3174#define DECL_MAIN_P(NODE) \
eb68cb58 3175 (DECL_EXTERN_C_FUNCTION_P (NODE) \
35680744
MM
3176 && DECL_NAME (NODE) != NULL_TREE \
3177 && MAIN_NAME_P (DECL_NAME (NODE)))
3178
8d08fdba 3179\f
5566b478
MS
3180/* Nonzero if we're done parsing and into end-of-file activities. */
3181
3182extern int at_eof;
3183
170b020f
MM
3184/* A list of namespace-scope objects which have constructors or
3185 destructors which reside in the global scope. The decl is stored
3186 in the TREE_VALUE slot and the initializer is stored in the
3187 TREE_PURPOSE slot. */
3188extern GTY(()) tree static_aggregates;
3189
f444e36b
MM
3190/* Functions called along with real static constructors and destructors. */
3191
e2500fed
GK
3192extern GTY(()) tree static_ctors;
3193extern GTY(()) tree static_dtors;
f444e36b 3194
8d08fdba
MS
3195enum overload_flags { NO_SPECIAL = 0, DTOR_FLAG, OP_FLAG, TYPENAME_FLAG };
3196
8d08fdba 3197/* Some macros for char-based bitfields. */
98e40e83
GS
3198#define B_SET(A,X) ((A)[(X)>>3] |= (1 << ((X)&7)))
3199#define B_CLR(A,X) ((A)[(X)>>3] &= ~(1 << ((X)&7)))
3200#define B_TST(A,X) ((A)[(X)>>3] & (1 << ((X)&7)))
8d08fdba 3201
9f880ef9 3202/* These are uses as bits in flags passed to build_new_method_call
8d08fdba
MS
3203 to control its error reporting behavior.
3204
3205 LOOKUP_PROTECT means flag access violations.
3206 LOOKUP_COMPLAIN mean complain if no suitable member function
3207 matching the arguments is found.
3208 LOOKUP_NORMAL is just a combination of these two.
8d08fdba
MS
3209 LOOKUP_NONVIRTUAL means make a direct call to the member function found
3210 LOOKUP_GLOBAL means search through the space of overloaded functions,
3211 as well as the space of member functions.
6060a796 3212 LOOKUP_ONLYCONVERTING means that non-conversion constructors are not tried.
9a3b49ac
MS
3213 DIRECT_BIND means that if a temporary is created, it should be created so
3214 that it lives as long as the current variable bindings; otherwise it
46af705a
JDA
3215 only lives until the end of the complete-expression. It also forces
3216 direct-initialization in cases where other parts of the compiler have
3217 already generated a temporary, such as reference initialization and the
3218 catch parameter.
8d08fdba
MS
3219 LOOKUP_NO_CONVERSION means that user-defined conversions are not
3220 permitted. Built-in conversions are permitted.
c73964b2 3221 LOOKUP_DESTRUCTOR means explicit call to destructor.
52c11ef6
JM
3222 LOOKUP_NO_TEMP_BIND means temporaries will not be bound to references.
3223
3224 These are used in global lookup to support elaborated types and
3225 qualifiers.
bb20cc46 3226
52c11ef6
JM
3227 LOOKUP_PREFER_TYPES means not to accept objects, and possibly namespaces.
3228 LOOKUP_PREFER_NAMESPACES means not to accept objects, and possibly types.
eea9800f 3229 LOOKUP_PREFER_BOTH means class-or-namespace-name. */
8d08fdba 3230
644d1951
NS
3231#define LOOKUP_PROTECT (1 << 0)
3232#define LOOKUP_COMPLAIN (1 << 1)
3233#define LOOKUP_NORMAL (LOOKUP_PROTECT | LOOKUP_COMPLAIN)
3234#define LOOKUP_NONVIRTUAL (1 << 2)
3235#define LOOKUP_GLOBAL (1 << 3)
3236#define LOOKUP_ONLYCONVERTING (1 << 4)
3237#define DIRECT_BIND (1 << 5)
3238#define LOOKUP_NO_CONVERSION (1 << 6)
3239#define LOOKUP_DESTRUCTOR (1 << 7)
3240#define LOOKUP_NO_TEMP_BIND (1 << 8)
3241#define LOOKUP_PREFER_TYPES (1 << 9)
3242#define LOOKUP_PREFER_NAMESPACES (1 << 10)
3243#define LOOKUP_PREFER_BOTH (LOOKUP_PREFER_TYPES | LOOKUP_PREFER_NAMESPACES)
3244#define LOOKUP_CONSTRUCTOR_CALLABLE (1 << 11)
52c11ef6 3245
98e40e83
GS
3246#define LOOKUP_NAMESPACES_ONLY(F) \
3247 (((F) & LOOKUP_PREFER_NAMESPACES) && !((F) & LOOKUP_PREFER_TYPES))
3248#define LOOKUP_TYPES_ONLY(F) \
3249 (!((F) & LOOKUP_PREFER_NAMESPACES) && ((F) & LOOKUP_PREFER_TYPES))
3250#define LOOKUP_QUALIFIERS_ONLY(F) ((F) & LOOKUP_PREFER_BOTH)
bb20cc46 3251
8d08fdba 3252
a4443a08
MS
3253/* These flags are used by the conversion code.
3254 CONV_IMPLICIT : Perform implicit conversions (standard and user-defined).
3255 CONV_STATIC : Perform the explicit conversions for static_cast.
3256 CONV_CONST : Perform the explicit conversions for const_cast.
3257 CONV_REINTERPRET: Perform the explicit conversions for reinterpret_cast.
6060a796 3258 CONV_PRIVATE : Perform upcasts to private bases.
8ccc31eb 3259 CONV_FORCE_TEMP : Require a new temporary when converting to the same
bb20cc46 3260 aggregate type. */
a4443a08
MS
3261
3262#define CONV_IMPLICIT 1
3263#define CONV_STATIC 2
3264#define CONV_CONST 4
3265#define CONV_REINTERPRET 8
3266#define CONV_PRIVATE 16
faf5394a 3267/* #define CONV_NONCONVERTING 32 */
8ccc31eb
MS
3268#define CONV_FORCE_TEMP 64
3269#define CONV_STATIC_CAST (CONV_IMPLICIT | CONV_STATIC | CONV_FORCE_TEMP)
a4443a08
MS
3270#define CONV_OLD_CONVERT (CONV_IMPLICIT | CONV_STATIC | CONV_CONST \
3271 | CONV_REINTERPRET)
3272#define CONV_C_CAST (CONV_IMPLICIT | CONV_STATIC | CONV_CONST \
8ccc31eb 3273 | CONV_REINTERPRET | CONV_PRIVATE | CONV_FORCE_TEMP)
a4443a08 3274
b7484fbe
MS
3275/* Used by build_expr_type_conversion to indicate which types are
3276 acceptable as arguments to the expression under consideration. */
3277
3278#define WANT_INT 1 /* integer types, including bool */
3279#define WANT_FLOAT 2 /* floating point types */
3280#define WANT_ENUM 4 /* enumerated types */
3281#define WANT_POINTER 8 /* pointer types */
3282#define WANT_NULL 16 /* null pointer constant */
b7484fbe
MS
3283#define WANT_ARITH (WANT_INT | WANT_FLOAT)
3284
3bfdc719
MM
3285/* Used with comptypes, and related functions, to guide type
3286 comparison. */
3287
3288#define COMPARE_STRICT 0 /* Just check if the types are the
3289 same. */
3290#define COMPARE_BASE 1 /* Check to see if the second type is
c8a209ca
NS
3291 derived from the first. */
3292#define COMPARE_DERIVED 2 /* Like COMPARE_BASE, but in
3293 reverse. */
34cd5ae7 3294#define COMPARE_REDECLARATION 4 /* The comparison is being done when
3bfdc719
MM
3295 another declaration of an existing
3296 entity is seen. */
3297
7bdbfa05
MM
3298/* Used with push_overloaded_decl. */
3299#define PUSH_GLOBAL 0 /* Push the DECL into namespace scope,
3300 regardless of the current scope. */
3301#define PUSH_LOCAL 1 /* Push the DECL into the current
3302 scope. */
3303#define PUSH_USING 2 /* We are pushing this DECL as the
3304 result of a using declaration. */
3305
a8f73d4b 3306/* Used with start function. */
b35d4555 3307#define SF_DEFAULT 0 /* No flags. */
a8f73d4b
MM
3308#define SF_PRE_PARSED 1 /* The function declaration has
3309 already been parsed. */
3310#define SF_INCLASS_INLINE 2 /* The function is an inline, defined
3311 in the class body. */
9edc3913 3312
3bfdc719
MM
3313/* Returns nonzero iff TYPE1 and TYPE2 are the same type, or if TYPE2
3314 is derived from TYPE1, or if TYPE2 is a pointer (reference) to a
3315 class derived from the type pointed to (referred to) by TYPE1. */
98e40e83
GS
3316#define same_or_base_type_p(TYPE1, TYPE2) \
3317 comptypes ((TYPE1), (TYPE2), COMPARE_BASE)
3bfdc719 3318
f84b4be9 3319/* These macros are used to access a TEMPLATE_PARM_INDEX. */
da8a66fc
ML
3320#define TEMPLATE_PARM_INDEX_CAST(NODE) \
3321 ((template_parm_index*)TEMPLATE_PARM_INDEX_CHECK (NODE))
3322#define TEMPLATE_PARM_IDX(NODE) (TEMPLATE_PARM_INDEX_CAST (NODE)->index)
3323#define TEMPLATE_PARM_LEVEL(NODE) (TEMPLATE_PARM_INDEX_CAST (NODE)->level)
f84b4be9 3324#define TEMPLATE_PARM_DESCENDANTS(NODE) (TREE_CHAIN (NODE))
da8a66fc
ML
3325#define TEMPLATE_PARM_ORIG_LEVEL(NODE) (TEMPLATE_PARM_INDEX_CAST (NODE)->orig_level)
3326#define TEMPLATE_PARM_DECL(NODE) (TEMPLATE_PARM_INDEX_CAST (NODE)->decl)
f84b4be9 3327
bb20cc46 3328/* These macros are for accessing the fields of TEMPLATE_TYPE_PARM,
a1281f45 3329 TEMPLATE_TEMPLATE_PARM and BOUND_TEMPLATE_TEMPLATE_PARM nodes. */
a2982c1b
RK
3330#define TEMPLATE_TYPE_PARM_INDEX(NODE) \
3331 (TREE_CHECK3 ((NODE), TEMPLATE_TYPE_PARM, TEMPLATE_TEMPLATE_PARM, \
3332 BOUND_TEMPLATE_TEMPLATE_PARM))->type.values
f84b4be9
JM
3333#define TEMPLATE_TYPE_IDX(NODE) \
3334 (TEMPLATE_PARM_IDX (TEMPLATE_TYPE_PARM_INDEX (NODE)))
3335#define TEMPLATE_TYPE_LEVEL(NODE) \
3336 (TEMPLATE_PARM_LEVEL (TEMPLATE_TYPE_PARM_INDEX (NODE)))
3337#define TEMPLATE_TYPE_ORIG_LEVEL(NODE) \
3338 (TEMPLATE_PARM_ORIG_LEVEL (TEMPLATE_TYPE_PARM_INDEX (NODE)))
3339#define TEMPLATE_TYPE_DECL(NODE) \
3340 (TEMPLATE_PARM_DECL (TEMPLATE_TYPE_PARM_INDEX (NODE)))
8d08fdba 3341
761f0855
GDR
3342/* These constants can used as bit flags in the process of tree formatting.
3343
3344 TFF_PLAIN_IDENTIFIER: unqualified part of a name.
749ced52 3345 TFF_SCOPE: include the class and namespace scope of the name.
761f0855
GDR
3346 TFF_CHASE_TYPEDEF: print the original type-id instead of the typedef-name.
3347 TFF_DECL_SPECIFIERS: print decl-specifiers.
3348 TFF_CLASS_KEY_OR_ENUM: precede a class-type name (resp. enum name) with
3349 a class-key (resp. `enum').
3350 TFF_RETURN_TYPE: include function return type.
3351 TFF_FUNCTION_DEFAULT_ARGUMENTS: include function default parameter values.
3352 TFF_EXCEPTION_SPECIFICATION: show function exception specification.
aab8454a 3353 TFF_TEMPLATE_HEADER: show the template<...> header in a
761f0855 3354 template-declaration.
761f0855 3355 TFF_TEMPLATE_NAME: show only template-name.
303357a7
GB
3356 TFF_EXPR_IN_PARENS: parenthesize expressions.
3357 TFF_NO_FUNCTION_ARGUMENTS: don't show function arguments. */
761f0855
GDR
3358
3359#define TFF_PLAIN_IDENTIFIER (0)
749ced52
ZW
3360#define TFF_SCOPE (1)
3361#define TFF_CHASE_TYPEDEF (1 << 1)
3362#define TFF_DECL_SPECIFIERS (1 << 2)
3363#define TFF_CLASS_KEY_OR_ENUM (1 << 3)
3364#define TFF_RETURN_TYPE (1 << 4)
3365#define TFF_FUNCTION_DEFAULT_ARGUMENTS (1 << 5)
3366#define TFF_EXCEPTION_SPECIFICATION (1 << 6)
3367#define TFF_TEMPLATE_HEADER (1 << 7)
3368#define TFF_TEMPLATE_NAME (1 << 8)
3369#define TFF_EXPR_IN_PARENS (1 << 9)
303357a7 3370#define TFF_NO_FUNCTION_ARGUMENTS (1 << 10)
9e93bc9d 3371
1899c3a4
KL
3372/* Returns the TEMPLATE_DECL associated to a TEMPLATE_TEMPLATE_PARM
3373 node. */
bb20cc46 3374#define TEMPLATE_TEMPLATE_PARM_TEMPLATE_DECL(NODE) \
a1281f45 3375 ((TREE_CODE (NODE) == BOUND_TEMPLATE_TEMPLATE_PARM) \
bb20cc46 3376 ? TYPE_TI_TEMPLATE (NODE) \
1899c3a4
KL
3377 : TYPE_NAME (NODE))
3378
51c184be 3379/* in lex.c */
f5e99456 3380
b2f29cd9 3381extern void init_reswords (void);
f5e99456 3382
d7e7759d
BC
3383/* Indexed by TREE_CODE, these tables give C-looking names to
3384 operators represented by TREE_CODES. For example,
3385 opname_tab[(int) MINUS_EXPR] == "-". */
3386extern const char **opname_tab, **assignop_tab;
596ea4e5 3387
17211ab5 3388typedef struct operator_name_info_t GTY(())
596ea4e5
AS
3389{
3390 /* The IDENTIFIER_NODE for the operator. */
3391 tree identifier;
3392 /* The name of the operator. */
3393 const char *name;
3394 /* The mangled name of the operator. */
3395 const char *mangled_name;
3fa3c4bd
MM
3396 /* The arity of the operator. */
3397 int arity;
596ea4e5
AS
3398} operator_name_info_t;
3399
3400/* A mapping from tree codes to operator name information. */
17211ab5
GK
3401extern GTY(()) operator_name_info_t operator_name_info
3402 [(int) LAST_CPLUS_TREE_CODE];
596ea4e5 3403/* Similar, but for assignment operators. */
17211ab5
GK
3404extern GTY(()) operator_name_info_t assignment_operator_name_info
3405 [(int) LAST_CPLUS_TREE_CODE];
596ea4e5 3406
3c01e5df
MM
3407/* A type-qualifier, or bitmask therefore, using the TYPE_QUAL
3408 constants. */
3409
3410typedef int cp_cv_quals;
3411
62d1db17
MM
3412/* A storage class. */
3413
3414typedef enum cp_storage_class {
3415 /* sc_none must be zero so that zeroing a cp_decl_specifier_seq
3416 sets the storage_class field to sc_none. */
3417 sc_none = 0,
3418 sc_auto,
3419 sc_register,
3420 sc_static,
3421 sc_extern,
5e7752d2 3422 sc_mutable
62d1db17
MM
3423} cp_storage_class;
3424
3425/* An individual decl-specifier. */
3426
3427typedef enum cp_decl_spec {
3428 ds_first,
3429 ds_signed = ds_first,
3430 ds_unsigned,
3431 ds_short,
3432 ds_long,
3433 ds_const,
3434 ds_volatile,
3435 ds_restrict,
3436 ds_inline,
3437 ds_virtual,
3438 ds_explicit,
3439 ds_friend,
3440 ds_typedef,
3441 ds_complex,
3442 ds_thread,
3443 ds_last
3444} cp_decl_spec;
3445
3446/* A decl-specifier-seq. */
3447
3448typedef struct cp_decl_specifier_seq {
3449 /* The number of times each of the keywords has been seen. */
3450 unsigned specs[(int) ds_last];
3451 /* The primary type, if any, given by the decl-specifier-seq.
3452 Modifiers, like "short", "const", and "unsigned" are not
3453 reflected here. This field will be a TYPE, unless a typedef-name
3454 was used, in which case it will be a TYPE_DECL. */
3455 tree type;
3456 /* The attributes, if any, provided with the specifier sequence. */
3457 tree attributes;
3458 /* If non-NULL, a built-in type that the user attempted to redefine
3459 to some other type. */
3460 tree redefined_builtin_type;
3461 /* The storage class specified -- or sc_none if no storage class was
3462 explicitly specified. */
3463 cp_storage_class storage_class;
3464 /* True iff TYPE_SPEC indicates a user-defined type. */
3465 BOOL_BITFIELD user_defined_type_p : 1;
3466 /* True iff multiple types were (erroneously) specified for this
3467 decl-specifier-seq. */
3468 BOOL_BITFIELD multiple_types_p : 1;
3469 /* True iff multiple storage classes were (erroneously) specified
3470 for this decl-specifier-seq. */
3471 BOOL_BITFIELD multiple_storage_classes_p : 1;
3472 /* True iff at least one decl-specifier was found. */
3473 BOOL_BITFIELD any_specifiers_p : 1;
3474 /* True iff "int" was explicitly provided. */
3475 BOOL_BITFIELD explicit_int_p : 1;
3476 /* True iff "char" was explicitly provided. */
3477 BOOL_BITFIELD explicit_char_p : 1;
3478} cp_decl_specifier_seq;
3479
058b15c1
MM
3480/* The various kinds of declarators. */
3481
3482typedef enum cp_declarator_kind {
3483 cdk_id,
3484 cdk_function,
3485 cdk_array,
3486 cdk_pointer,
3487 cdk_reference,
3488 cdk_ptrmem,
3489 cdk_error
3490} cp_declarator_kind;
3491
3492/* A declarator. */
3493
3494typedef struct cp_declarator cp_declarator;
3495
3496typedef struct cp_parameter_declarator cp_parameter_declarator;
3497
3498/* A parameter, before it has been semantically analyzed. */
3499struct cp_parameter_declarator {
3500 /* The next parameter, or NULL_TREE if none. */
3501 cp_parameter_declarator *next;
3502 /* The decl-specifiers-seq for the parameter. */
62d1db17 3503 cp_decl_specifier_seq decl_specifiers;
058b15c1
MM
3504 /* The declarator for the parameter. */
3505 cp_declarator *declarator;
3506 /* The default-argument expression, or NULL_TREE, if none. */
3507 tree default_argument;
3508 /* True iff this is the first parameter in the list and the
3509 parameter sequence ends with an ellipsis. */
3510 bool ellipsis_p;
3511};
3512
3513/* A declarator. */
3514struct cp_declarator {
3515 /* The kind of declarator. */
3516 cp_declarator_kind kind;
3517 /* Attributes that apply to this declarator. */
3518 tree attributes;
3519 /* For all but cdk_id and cdk_error, the contained declarator. For
3520 cdk_id and cdk_error, guaranteed to be NULL. */
3521 cp_declarator *declarator;
3522 union {
3523 /* For identifiers. */
3524 struct {
3525 /* The name of the function -- an IDENTIFIER_NODE, BIT_NOT_EXPR,
3526 TEMPLATE_ID_EXPR, or SCOPE_REF. */
3527 tree name;
3528 /* If this is the name of a function, what kind of special
3529 function (if any). */
3530 special_function_kind sfk;
3531 } id;
3532 /* For functions. */
3533 struct {
3534 /* The parameters to the function. */
3535 cp_parameter_declarator *parameters;
3536 /* The cv-qualifiers for the function. */
3c01e5df 3537 cp_cv_quals qualifiers;
058b15c1
MM
3538 /* The exception-specification for the function. */
3539 tree exception_specification;
3540 } function;
3541 /* For arrays. */
3542 struct {
3543 /* The bounds to the array. */
3544 tree bounds;
3545 } array;
3546 /* For cdk_pointer, cdk_reference, and cdk_ptrmem. */
3547 struct {
3548 /* The cv-qualifiers for the pointer. */
3c01e5df 3549 cp_cv_quals qualifiers;
058b15c1
MM
3550 /* For cdk_ptrmem, the class type containing the member. */
3551 tree class_type;
3552 } pointer;
3553 } u;
3554};
3555
3556/* An erroneous declarator. */
3557extern cp_declarator *cp_error_declarator;
3558
3559/* A parameter list indicating for a function with no parameters,
3560 e.g "int f(void)". */
3561extern cp_parameter_declarator *no_parameters;
3562
51c184be 3563/* in call.c */
94be8403 3564extern bool check_dtor_name (tree, tree);
158991b7 3565
b2f29cd9 3566extern tree build_vfield_ref (tree, tree);
b2f29cd9 3567extern tree build_conditional_expr (tree, tree, tree);
94be8403
GDR
3568extern tree build_addr_func (tree);
3569extern tree build_call (tree, tree);
94be8403
GDR
3570extern bool null_ptr_cst_p (tree);
3571extern bool sufficient_parms_p (tree);
3572extern tree type_decays_to (tree);
3573extern tree build_user_type_conversion (tree, tree, int);
3574extern tree build_new_function_call (tree, tree);
125e6594 3575extern tree build_operator_new_call (tree, tree, tree *, tree *);
94be8403
GDR
3576extern tree build_new_method_call (tree, tree, tree, tree, int);
3577extern tree build_special_member_call (tree, tree, tree, tree, int);
ec835fb2 3578extern tree build_new_op (enum tree_code, int, tree, tree, tree, bool *);
5bd61841 3579extern tree build_op_delete_call (enum tree_code, tree, tree, bool, tree);
94be8403
GDR
3580extern bool can_convert (tree, tree);
3581extern bool can_convert_arg (tree, tree, tree);
3582extern bool can_convert_arg_bad (tree, tree, tree);
3583extern bool enforce_access (tree, tree);
3584extern tree convert_default_arg (tree, tree, tree, int);
3585extern tree convert_arg_to_ellipsis (tree);
3586extern tree build_x_va_arg (tree, tree);
3587extern tree cxx_type_promotes_to (tree);
3588extern tree type_passed_as (tree);
3589extern tree convert_for_arg_passing (tree, tree);
b2f29cd9 3590extern tree cp_convert_parm_for_inlining (tree, tree, tree);
94be8403 3591extern bool is_properly_derived_from (tree, tree);
7e99327d 3592extern tree initialize_reference (tree, tree, tree, tree *);
aa6e8ed3 3593extern tree make_temporary_var_for_ref_to_temp (tree, tree);
94be8403
GDR
3594extern tree strip_top_quals (tree);
3595extern tree perform_implicit_conversion (tree, tree);
3fe18f1d 3596extern tree perform_direct_initialization_if_possible (tree, tree);
94be8403 3597extern tree in_charge_arg_for_name (tree);
d522060b 3598extern tree build_cxx_call (tree, tree);
5bd61841
MM
3599#ifdef ENABLE_CHECKING
3600extern void validate_conversion_obstack (void);
3601#endif /* ENABLE_CHECKING */
8d08fdba 3602
51c184be 3603/* in class.c */
b2f29cd9
NN
3604extern tree build_base_path (enum tree_code, tree, tree, int);
3605extern tree convert_to_base (tree, tree, bool);
22ed7e5f 3606extern tree convert_to_base_statically (tree, tree);
b2f29cd9
NN
3607extern tree build_vtbl_ref (tree, tree);
3608extern tree build_vfn_ref (tree, tree);
3609extern tree get_vtable_decl (tree, int);
17211ab5 3610extern void resort_type_method_vec
b2f29cd9 3611 (void *, void *, gt_pointer_operator, void *);
aaaa46d2 3612extern void add_method (tree, tree);
b2f29cd9
NN
3613extern int currently_open_class (tree);
3614extern tree currently_open_derived_class (tree);
b2f29cd9
NN
3615extern tree finish_struct (tree, tree);
3616extern void finish_struct_1 (tree);
3617extern int resolves_to_fixed_type_p (tree, int *);
3618extern void init_class_processing (void);
3619extern int is_empty_class (tree);
29370796 3620extern void pushclass (tree);
b2f29cd9 3621extern void popclass (void);
14d22dd6 3622extern void push_nested_class (tree);
b2f29cd9
NN
3623extern void pop_nested_class (void);
3624extern int current_lang_depth (void);
3625extern void push_lang_context (tree);
3626extern void pop_lang_context (void);
3627extern tree instantiate_type (tree, tree, tsubst_flags_t);
3628extern void print_class_statistics (void);
3629extern void cxx_print_statistics (void);
848eed92
GDR
3630extern void cxx_print_xnode (FILE *, tree, int);
3631extern void cxx_print_decl (FILE *, tree, int);
3632extern void cxx_print_type (FILE *, tree, int);
3633extern void cxx_print_identifier (FILE *, tree, int);
b2f29cd9
NN
3634extern void cxx_print_error_function (struct diagnostic_context *,
3635 const char *);
3636extern void build_self_reference (void);
3637extern int same_signature_p (tree, tree);
3638extern void warn_hidden (tree);
3639extern void maybe_add_class_template_decl_list (tree, tree, int);
3640extern tree get_enclosing_class (tree);
b2f29cd9
NN
3641extern void unreverse_member_declarations (tree);
3642extern void invalidate_class_lookup_cache (void);
3643extern void maybe_note_name_used_in_class (tree, tree);
3644extern void note_name_declared_in_class (tree, tree);
3645extern tree get_vtbl_decl_for_binfo (tree);
3646extern tree get_vtt_name (tree);
3647extern tree get_primary_binfo (tree);
bb885938
NS
3648extern void debug_class (tree);
3649extern void debug_thunks (tree);
0f59171d 3650extern tree cp_fold_obj_type_ref (tree, tree);
8d08fdba 3651
51c184be 3652/* in cvt.c */
b746c5dc
GDR
3653extern tree convert_to_reference (tree, tree, int, int, tree);
3654extern tree convert_from_reference (tree);
3655extern tree convert_lvalue (tree, tree);
f7b9026e 3656extern tree force_rvalue (tree);
b746c5dc
GDR
3657extern tree ocp_convert (tree, tree, int, int);
3658extern tree cp_convert (tree, tree);
3659extern tree convert_to_void (tree, const char */*implicit context*/);
3660extern tree convert_force (tree, tree, int);
7993382e 3661extern tree build_type_conversion (tree, tree);
b746c5dc
GDR
3662extern tree build_expr_type_conversion (int, tree, bool);
3663extern tree type_promotes_to (tree);
3664extern tree perform_qualification_conversions (tree, tree);
b2f29cd9
NN
3665extern void clone_function_decl (tree, int);
3666extern void adjust_clone_args (tree);
8d08fdba 3667
51c184be 3668/* decl.c */
9dcf6e73 3669extern tree poplevel (int, int, int);
b2f29cd9 3670extern void insert_block (tree);
b2f29cd9
NN
3671extern tree pushdecl (tree);
3672extern void cxx_init_decl_processing (void);
e2500fed 3673enum cp_tree_node_structure_enum cp_tree_node_structure
b2f29cd9 3674 (union lang_tree_node *);
b2f29cd9
NN
3675extern bool cxx_mark_addressable (tree);
3676extern void cxx_push_function_context (struct function *);
3677extern void cxx_pop_function_context (struct function *);
3678extern void cxx_mark_function_context (struct function *);
00e8de68 3679extern void maybe_push_cleanup_level (tree);
b2f29cd9 3680extern void finish_scope (void);
b2f29cd9
NN
3681extern void delete_block (tree);
3682extern void add_block_current_level (tree);
b2f29cd9
NN
3683extern void push_switch (tree);
3684extern void pop_switch (void);
b2f29cd9
NN
3685extern void pushtag (tree, tree, int);
3686extern tree make_anon_name (void);
3687extern void clear_anon_tags (void);
3688extern int decls_match (tree, tree);
b1a19c7c 3689extern tree duplicate_decls (tree, tree);
b2f29cd9 3690extern tree pushdecl_top_level (tree);
170b020f 3691extern tree pushdecl_top_level_and_finish (tree, tree);
b2f29cd9 3692extern tree push_using_decl (tree, tree);
b2f29cd9 3693extern tree declare_local_label (tree);
5b030314 3694extern tree define_label (location_t, tree);
b2f29cd9
NN
3695extern void check_goto (tree);
3696extern void define_case_label (void);
b2f29cd9
NN
3697extern tree make_typename_type (tree, tree, tsubst_flags_t);
3698extern tree make_unbound_class_template (tree, tree, tsubst_flags_t);
5f261ba9 3699extern tree check_for_out_of_scope_variable (tree);
b2f29cd9
NN
3700extern tree build_library_fn (tree, tree);
3701extern tree build_library_fn_ptr (const char *, tree);
3702extern tree build_cp_library_fn_ptr (const char *, tree);
3703extern tree push_library_fn (tree, tree);
3704extern tree push_void_library_fn (tree, tree);
3705extern tree push_throw_library_fn (tree, tree);
3706extern int init_type_desc (void);
62d1db17
MM
3707extern tree check_tag_decl (cp_decl_specifier_seq *);
3708extern tree shadow_tag (cp_decl_specifier_seq *);
3709extern tree groktypename (cp_decl_specifier_seq *, const cp_declarator *);
3710extern tree start_decl (const cp_declarator *, cp_decl_specifier_seq *, int, tree, tree);
b2f29cd9
NN
3711extern void start_decl_1 (tree);
3712extern void cp_finish_decl (tree, tree, tree, int);
3713extern void finish_decl (tree, tree, tree);
b2f29cd9
NN
3714extern int complete_array_type (tree, tree, int);
3715extern tree build_ptrmemfunc_type (tree);
9e259dd1 3716extern tree build_ptrmem_type (tree, tree);
f30432d7 3717/* the grokdeclarator prototype is in decl.h */
b2f29cd9 3718extern int copy_fn_p (tree);
058b15c1 3719extern tree get_scope_of_declarator (const cp_declarator *);
b2f29cd9
NN
3720extern void grok_special_member_properties (tree);
3721extern int grok_ctor_properties (tree, tree);
4b0d3cbe 3722extern bool grok_op_properties (tree, int, bool);
38b305d0 3723extern tree xref_tag (enum tag_types, tree, bool, bool);
b2f29cd9
NN
3724extern tree xref_tag_from_type (tree, tree, int);
3725extern void xref_basetypes (tree, tree);
3726extern tree start_enum (tree);
3727extern void finish_enum (tree);
3728extern void build_enumerator (tree, tree, tree);
058b15c1 3729extern void start_preparsed_function (tree, tree, int);
62d1db17 3730extern int start_function (cp_decl_specifier_seq *, const cp_declarator *, tree);
b2f29cd9
NN
3731extern tree begin_function_body (void);
3732extern void finish_function_body (tree);
3733extern tree finish_function (int);
62d1db17 3734extern tree start_method (cp_decl_specifier_seq *, const cp_declarator *, tree);
b2f29cd9
NN
3735extern tree finish_method (tree);
3736extern void maybe_register_incomplete_var (tree);
3737extern void complete_vars (tree);
3738extern void finish_stmt (void);
3739extern void print_other_binding_stack (struct cp_binding_level *);
3740extern void revert_static_member_fn (tree);
3741extern void fixup_anonymous_aggr (tree);
3742extern int check_static_variable_definition (tree, tree);
3743extern tree compute_array_index_type (tree, tree);
b2f29cd9 3744extern tree check_default_argument (tree, tree);
b2f29cd9
NN
3745extern int vtable_decl_p (tree, void *);
3746extern int vtype_decl_p (tree, void *);
3747extern int sigtable_decl_p (tree, void *);
848eed92
GDR
3748typedef bool (*walk_globals_pred) (tree, void *);
3749typedef bool (*walk_globals_fn) (tree *, void *);
3750extern bool walk_globals (walk_globals_pred, walk_globals_fn, void *);
3751extern bool walk_vtables (walk_globals_pred, walk_globals_fn, void *);
b2f29cd9
NN
3752typedef int (*walk_namespaces_fn) (tree, void *);
3753extern int walk_namespaces (walk_namespaces_fn,
3754 void *);
3755extern int wrapup_globals_for_namespace (tree, void *);
b2f29cd9
NN
3756extern tree create_implicit_typedef (tree, tree);
3757extern tree maybe_push_decl (tree);
a6f86b51 3758extern tree force_target_expr (tree, tree);
b2f29cd9
NN
3759extern tree build_target_expr_with_type (tree, tree);
3760extern int local_variable_p (tree);
3761extern int nonstatic_local_decl_p (tree);
3762extern tree declare_global_var (tree, tree);
3763extern void register_dtor_fn (tree);
3764extern tmpl_spec_kind current_tmpl_spec_kind (int);
bb885938 3765extern tree cp_fname_init (const char *, tree *);
560ad596 3766extern tree check_elaborated_type_specifier (enum tag_types, tree, bool);
a5e6b29b 3767extern void warn_extern_redeclared_static (tree, tree);
6de9cd9a 3768extern bool cp_missing_noreturn_ok_p (tree);
47aa0df4 3769
594bb0e7 3770extern bool have_extern_spec;
8d08fdba 3771
51c184be 3772/* in decl2.c */
848eed92 3773extern bool check_java_method (tree);
3c01e5df 3774extern cp_cv_quals grok_method_quals (tree, tree, cp_cv_quals);
848eed92
GDR
3775extern void maybe_retrofit_in_chrg (tree);
3776extern void maybe_make_one_only (tree);
3c01e5df 3777extern void grokclassfn (tree, tree, enum overload_flags, cp_cv_quals);
848eed92 3778extern tree grok_array_decl (tree, tree);
0e8c9b28 3779extern tree delete_sanity (tree, tree, bool, int);
44021471 3780extern tree check_classfn (tree, tree, tree);
848eed92 3781extern void check_member_template (tree);
62d1db17
MM
3782extern tree grokfield (const cp_declarator *, cp_decl_specifier_seq *, tree, tree, tree);
3783extern tree grokbitfield (const cp_declarator *, cp_decl_specifier_seq *, tree);
b2f29cd9 3784extern tree groktypefield (tree, tree);
848eed92 3785extern void cplus_decl_attributes (tree *, tree, int);
848eed92
GDR
3786extern void finish_anon_union (tree);
3787extern tree finish_table (tree, tree, tree, int);
3788extern tree coerce_new_type (tree);
3789extern tree coerce_delete_type (tree);
3790extern void comdat_linkage (tree);
3791extern void import_export_vtable (tree, tree, int);
3792extern void import_export_decl (tree);
3793extern void import_export_tinfo (tree, tree, bool);
c38e9817 3794extern tree build_cleanup (tree);
4ba126e4 3795extern tree build_offset_ref_call_from_tree (tree, tree);
848eed92
GDR
3796extern void check_default_args (tree);
3797extern void mark_used (tree);
848eed92
GDR
3798extern void finish_static_data_member_decl (tree, tree, tree, int);
3799extern tree cp_build_parm_decl (tree, tree);
3800extern tree build_artificial_parm (tree, tree);
3801extern tree get_guard (tree);
3802extern tree get_guard_cond (tree);
3803extern tree set_guard (tree);
25c84396 3804extern tree cxx_callgraph_analyze_expr (tree *, int *, tree);
8d08fdba 3805
749ced52 3806/* XXX Not i18n clean. */
acd8e2d0
NS
3807#define cp_deprecated(STR) \
3808 do { \
3809 if (warn_deprecated) \
3810 warning ("%s is deprecated, please see the documentation for details", \
3811 (STR)); \
98e40e83 3812 } while (0)
824b9a4c
MS
3813
3814/* in error.c */
b2f29cd9
NN
3815extern void init_error (void);
3816extern const char *type_as_string (tree, int);
3817extern const char *decl_as_string (tree, int);
3818extern const char *expr_as_string (tree, int);
3819extern const char *context_as_string (tree, int);
3820extern const char *lang_decl_name (tree, int);
4e3f84b7 3821extern const char *language_to_string (enum languages);
b2f29cd9 3822extern void print_instantiation_context (void);
824b9a4c 3823
51c184be 3824/* in except.c */
b2f29cd9
NN
3825extern void init_exception_processing (void);
3826extern tree expand_start_catch_block (tree);
3827extern void expand_end_catch_block (void);
3828extern void expand_builtin_throw (void);
b2f29cd9
NN
3829extern void expand_exception_blocks (void);
3830extern tree build_exc_ptr (void);
3831extern tree build_throw (tree);
3832extern void mark_all_runtime_matches (void);
3833extern int nothrow_libfn_p (tree);
3834extern void check_handlers (tree);
3835extern void choose_personality_routine (enum languages);
6cad4e17 3836extern tree eh_type_info (tree);
8d08fdba 3837
51c184be 3838/* in expr.c */
b2f29cd9 3839extern rtx cxx_expand_expr (tree, rtx,
0fab64a3
MM
3840 enum machine_mode,
3841 int, rtx *);
b2f29cd9 3842extern tree cplus_expand_constant (tree);
8d08fdba 3843
bd6dd845 3844/* friend.c */
b2f29cd9 3845extern int is_friend (tree, tree);
19db77ce
KL
3846extern void make_friend_class (tree, tree, bool);
3847extern void add_friend (tree, tree, bool);
3c01e5df 3848extern tree do_friend (tree, tree, tree, tree, enum overload_flags, cp_cv_quals, int);
bd6dd845 3849
51c184be 3850/* in init.c */
1f5a253a 3851extern tree expand_member_init (tree);
2282d28d 3852extern void emit_mem_initializers (tree);
b2f29cd9
NN
3853extern tree build_aggr_init (tree, tree, int);
3854extern tree build_init (tree, tree, int);
3855extern int is_aggr_type (tree, int);
b2f29cd9 3856extern tree get_type_value (tree);
1cb8292f 3857extern tree build_zero_init (tree, tree, bool);
a5ac359a 3858extern tree build_offset_ref (tree, tree, bool);
058b15c1 3859extern tree build_new (tree, tree, tree, tree, int);
a48cccea 3860extern tree build_vec_init (tree, tree, tree, int);
b2f29cd9
NN
3861extern tree build_x_delete (tree, int, tree);
3862extern tree build_delete (tree, tree, special_function_kind, int, int);
3863extern void push_base_cleanups (void);
3864extern tree build_vbase_delete (tree, tree);
3865extern tree build_vec_delete (tree, tree, special_function_kind, int);
3866extern tree create_temporary_var (tree);
b2f29cd9
NN
3867extern void initialize_vtbl_ptrs (tree);
3868extern tree build_java_class_ref (tree);
8d08fdba 3869
51c184be 3870/* in lex.c */
b2f29cd9 3871extern void cxx_dup_lang_specific_decl (tree);
b2f29cd9
NN
3872extern void print_parse_statistics (void);
3873extern void do_pending_inlines (void);
3874extern void yyungetc (int, int);
3875extern void snarf_method (tree);
3876
b2f29cd9 3877extern void see_typename (void);
b3445994
MM
3878extern tree unqualified_name_lookup_error (tree);
3879extern tree unqualified_fn_lookup_error (tree);
b2f29cd9
NN
3880extern tree build_lang_decl (enum tree_code, tree, tree);
3881extern void retrofit_lang_decl (tree);
3882extern tree copy_decl (tree);
3883extern tree copy_type (tree);
3884extern tree cxx_make_type (enum tree_code);
3885extern tree make_aggr_type (enum tree_code);
3886extern void yyerror (const char *);
3887extern void yyhook (int);
3888extern int cp_type_qual_from_rid (tree);
4bfec483 3889extern bool cxx_init (void);
b2f29cd9 3890extern void cxx_finish (void);
8d08fdba 3891
51c184be 3892/* in method.c */
4977bab6 3893extern void init_method (void);
4977bab6 3894extern tree make_thunk (tree, bool, tree, tree);
07fa4878 3895extern void finish_thunk (tree);
4977bab6
ZW
3896extern void use_thunk (tree, bool);
3897extern void synthesize_method (tree);
3898extern tree implicitly_declare_fn (special_function_kind, tree, bool);
508a1c9c 3899extern tree lazily_declare_fn (special_function_kind, tree);
4977bab6 3900extern tree skip_artificial_parms_for (tree, tree);
8d08fdba 3901
46e8c075 3902/* In optimize.c */
4977bab6 3903extern bool maybe_clone_body (tree);
46e8c075 3904
51c184be 3905/* in pt.c */
b2f29cd9
NN
3906extern void check_template_shadow (tree);
3907extern tree get_innermost_template_args (tree, int);
b2f29cd9
NN
3908extern void maybe_begin_member_template_processing (tree);
3909extern void maybe_end_member_template_processing (void);
3910extern tree finish_member_template_decl (tree);
3911extern void begin_template_parm_list (void);
3912extern void begin_specialization (void);
3913extern void reset_specialization (void);
3914extern void end_specialization (void);
3915extern void begin_explicit_instantiation (void);
3916extern void end_explicit_instantiation (void);
3917extern tree check_explicit_specialization (tree, tree, int, int);
058b15c1 3918extern tree process_template_parm (tree, tree, bool);
b2f29cd9
NN
3919extern tree end_template_parm_list (tree);
3920extern void end_template_decl (void);
3921extern tree current_template_args (void);
3922extern tree push_template_decl (tree);
3923extern tree push_template_decl_real (tree, int);
3924extern void redeclare_class_template (tree, tree);
3925extern tree lookup_template_class (tree, tree, tree, tree, int, tsubst_flags_t);
3926extern tree lookup_template_function (tree, tree);
3927extern int uses_template_parms (tree);
d43f603d 3928extern int uses_template_parms_level (tree, int);
b2f29cd9 3929extern tree instantiate_class_template (tree);
3e4a3562 3930extern tree instantiate_template (tree, tree, tsubst_flags_t);
b2f29cd9
NN
3931extern int fn_type_unification (tree, tree, tree, tree, tree, unification_kind_t, int);
3932extern tree tinst_for_decl (void);
3933extern void mark_decl_instantiated (tree, int);
3934extern int more_specialized (tree, tree, int, int);
3935extern void mark_class_instantiated (tree, int);
eb8845be 3936extern void do_decl_instantiation (tree, tree);
b2f29cd9 3937extern void do_type_instantiation (tree, tree, tsubst_flags_t);
415c974c 3938extern tree instantiate_decl (tree, int, int);
b2f29cd9
NN
3939extern int push_tinst_level (tree);
3940extern void pop_tinst_level (void);
55ece1b3 3941extern int more_specialized_class (tree, tree, tree);
b2f29cd9
NN
3942extern int is_member_template (tree);
3943extern int comp_template_parms (tree, tree);
3944extern int template_class_depth (tree);
3945extern int is_specialization_of (tree, tree);
d43f603d 3946extern bool is_specialization_of_friend (tree, tree);
b2f29cd9
NN
3947extern int comp_template_args (tree, tree);
3948extern void maybe_process_partial_specialization (tree);
3949extern void maybe_check_template_type (tree);
3950extern tree most_specialized_instantiation (tree);
3951extern void print_candidates (tree);
3952extern int instantiate_pending_templates (void);
3953extern tree tsubst_default_argument (tree, tree, tree);
b3445994 3954extern tree tsubst_copy_and_build (tree, tree, tsubst_flags_t, tree, bool);
b2f29cd9
NN
3955extern tree most_general_template (tree);
3956extern tree get_mostly_instantiated_function_type (tree);
3957extern int problematic_instantiation_changed (void);
3958extern void record_last_problematic_instantiation (void);
3959extern tree current_instantiation (void);
a723baf1 3960extern tree maybe_get_template_decl_from_type_decl (tree);
67ffc812 3961extern int processing_template_parmlist;
1fb3244a 3962extern bool dependent_type_p (tree);
d17811fd 3963extern bool any_dependent_template_arguments_p (tree);
1fb3244a 3964extern bool dependent_template_p (tree);
d17811fd 3965extern bool dependent_template_id_p (tree, tree);
1fb3244a 3966extern bool type_dependent_expression_p (tree);
d17811fd 3967extern bool any_type_dependent_arguments_p (tree);
14d22dd6
MM
3968extern bool value_dependent_expression_p (tree);
3969extern tree resolve_typename_type (tree, bool);
d58b7c2d 3970extern tree template_for_substitution (tree);
d17811fd
MM
3971extern tree build_non_dependent_expr (tree);
3972extern tree build_non_dependent_args (tree);
b3445994 3973extern bool reregister_specialization (tree, tree, tree);
9baa27a9 3974extern tree fold_non_dependent_expr (tree);
824b9a4c
MS
3975
3976/* in repo.c */
848eed92
GDR
3977extern void repo_template_used (tree);
3978extern void repo_template_instantiated (tree, bool);
3979extern void init_repo (const char *);
3980extern void finish_repo (void);
824b9a4c
MS
3981
3982/* in rtti.c */
9bcb9aae 3983/* A varray of all tinfo decls that haven't been emitted yet. */
a260bce6
MA
3984extern GTY(()) varray_type unemitted_tinfo_decls;
3985
848eed92
GDR
3986extern void init_rtti_processing (void);
3987extern tree build_typeid (tree);
3988extern tree get_tinfo_decl (tree);
3989extern tree get_typeid (tree);
3990extern tree build_dynamic_cast (tree, tree);
3991extern void emit_support_tinfos (void);
a260bce6 3992extern bool emit_tinfo_decl (tree);
8d08fdba 3993
51c184be 3994/* in search.c */
bd16cb25 3995extern bool accessible_base_p (tree, tree);
b2f29cd9
NN
3996extern tree lookup_base (tree, tree, base_access, base_kind *);
3997extern int types_overlap_p (tree, tree);
b2f29cd9 3998extern tree get_dynamic_cast_base_type (tree, tree);
b2f29cd9 3999extern int accessible_p (tree, tree);
75135253 4000extern tree lookup_field_1 (tree, tree, bool);
86ac0575 4001extern tree lookup_field (tree, tree, int, bool);
b2f29cd9
NN
4002extern int lookup_fnfields_1 (tree, tree);
4003extern tree lookup_fnfields (tree, tree, int);
86ac0575 4004extern tree lookup_member (tree, tree, int, bool);
b2f29cd9
NN
4005extern int look_for_overrides (tree, tree);
4006extern void get_pure_virtuals (tree);
b2f29cd9
NN
4007extern void maybe_suppress_debug_info (tree);
4008extern void note_debug_info_needed (tree);
b2f29cd9 4009extern void print_search_statistics (void);
b2f29cd9
NN
4010extern void reinit_search_statistics (void);
4011extern tree current_scope (void);
4012extern int at_function_scope_p (void);
5f261ba9 4013extern bool at_class_scope_p (void);
afb0918a 4014extern bool at_namespace_scope_p (void);
b2f29cd9
NN
4015extern tree context_for_name_lookup (tree);
4016extern tree lookup_conversions (tree);
4017extern tree binfo_for_vtable (tree);
4018extern tree binfo_from_vbase (tree);
58c42dc2 4019extern tree binfo_for_vbase (tree, tree);
b2f29cd9
NN
4020extern tree look_for_overrides_here (tree, tree);
4021extern int check_final_overrider (tree, tree);
4022extern tree dfs_walk (tree,
dbbf88d1
NS
4023 tree (*) (tree, void *),
4024 tree (*) (tree, int, void *),
4025 void *);
b2f29cd9 4026extern tree dfs_walk_real (tree,
dbbf88d1
NS
4027 tree (*) (tree, void *),
4028 tree (*) (tree, void *),
4029 tree (*) (tree, int, void *),
4030 void *);
b2f29cd9 4031extern tree dfs_unmark (tree, void *);
dbbf88d1
NS
4032extern tree markedp (tree, int, void *);
4033extern tree unmarkedp (tree, int, void *);
b2f29cd9 4034extern tree binfo_via_virtual (tree, tree);
4ba126e4 4035extern tree build_baselink (tree, tree, tree, tree);
9e259dd1
MM
4036extern tree adjust_result_of_qualified_name_lookup
4037 (tree, tree, tree);
dbbf88d1
NS
4038extern tree copied_binfo (tree, tree);
4039extern tree original_binfo (tree, tree);
4040
ad321293 4041/* in semantics.c */
8d241e0b 4042extern void push_deferring_access_checks (deferring_kind);
cf22909c
KL
4043extern void resume_deferring_access_checks (void);
4044extern void stop_deferring_access_checks (void);
4045extern void pop_deferring_access_checks (void);
4046extern tree get_deferred_access_checks (void);
4047extern void pop_to_parent_deferring_access_checks (void);
4048extern void perform_deferred_access_checks (void);
4049extern void perform_or_defer_access_check (tree, tree);
b2f29cd9 4050extern void init_cp_semantics (void);
350fae66 4051extern void add_decl_expr (tree);
b2f29cd9
NN
4052extern tree finish_expr_stmt (tree);
4053extern tree begin_if_stmt (void);
4054extern void finish_if_stmt_cond (tree, tree);
4055extern tree finish_then_clause (tree);
325c3691 4056extern void begin_else_clause (tree);
b2f29cd9 4057extern void finish_else_clause (tree);
325c3691 4058extern void finish_if_stmt (tree);
b2f29cd9
NN
4059extern tree begin_while_stmt (void);
4060extern void finish_while_stmt_cond (tree, tree);
4061extern void finish_while_stmt (tree);
4062extern tree begin_do_stmt (void);
4063extern void finish_do_body (tree);
4064extern void finish_do_stmt (tree, tree);
4065extern tree finish_return_stmt (tree);
4066extern tree begin_for_stmt (void);
4067extern void finish_for_init_stmt (tree);
4068extern void finish_for_cond (tree, tree);
4069extern void finish_for_expr (tree, tree);
4070extern void finish_for_stmt (tree);
4071extern tree finish_break_stmt (void);
4072extern tree finish_continue_stmt (void);
4073extern tree begin_switch_stmt (void);
4074extern void finish_switch_cond (tree, tree);
4075extern void finish_switch_stmt (tree);
4076extern tree finish_case_label (tree, tree);
4077extern tree finish_goto_stmt (tree);
4078extern tree begin_try_block (void);
4079extern void finish_try_block (tree);
4080extern tree begin_eh_spec_block (void);
4081extern void finish_eh_spec_block (tree, tree);
4082extern void finish_handler_sequence (tree);
4083extern tree begin_function_try_block (void);
4084extern void finish_function_try_block (tree);
4085extern void finish_function_handler_sequence (tree);
4086extern void finish_cleanup_try_block (tree);
4087extern tree begin_handler (void);
4088extern void finish_handler_parms (tree, tree);
4089extern void begin_catch_block (tree);
4090extern void finish_handler (tree);
4091extern void finish_cleanup (tree, tree);
325c3691
RH
4092
4093enum {
4094 BCS_NO_SCOPE = 1,
4095 BCS_TRY_BLOCK = 2,
4096 BCS_FN_BODY = 4
4097};
4098extern tree begin_compound_stmt (unsigned int);
4099
4100extern void finish_compound_stmt (tree);
6de9cd9a 4101extern tree finish_asm_stmt (int, tree, tree, tree, tree);
b2f29cd9
NN
4102extern tree finish_label_stmt (tree);
4103extern void finish_label_decl (tree);
4104extern void finish_subobject (tree);
4105extern tree finish_parenthesized_expr (tree);
a3f10e50 4106extern tree finish_non_static_data_member (tree, tree, tree);
b2f29cd9 4107extern tree begin_stmt_expr (void);
325c3691 4108extern tree finish_stmt_expr_expr (tree, tree);
303b7406 4109extern tree finish_stmt_expr (tree, bool);
b3445994 4110extern tree perform_koenig_lookup (tree, tree);
6d80c4b9 4111extern tree finish_call_expr (tree, tree, bool, bool);
b2f29cd9
NN
4112extern tree finish_increment_expr (tree, enum tree_code);
4113extern tree finish_this_expr (void);
a723baf1 4114extern tree finish_pseudo_destructor_expr (tree, tree, tree);
b2f29cd9 4115extern tree finish_unary_op_expr (enum tree_code, tree);
a723baf1 4116extern tree finish_compound_literal (tree, tree);
5f261ba9 4117extern tree finish_fname (tree);
b2f29cd9
NN
4118extern void finish_translation_unit (void);
4119extern tree finish_template_type_parm (tree, tree);
4120extern tree finish_template_template_parm (tree, tree);
b2f29cd9 4121extern tree begin_class_definition (tree);
b2f29cd9 4122extern void finish_default_args (void);
b2f29cd9
NN
4123extern void finish_template_decl (tree);
4124extern tree finish_template_type (tree, tree, int);
dbbf88d1 4125extern tree finish_base_specifier (tree, tree, bool);
b2f29cd9
NN
4126extern void finish_member_declaration (tree);
4127extern void check_multiple_declarators (void);
22038b2c 4128extern void qualified_name_lookup_error (tree, tree);
b3445994
MM
4129extern tree finish_id_expression (tree, tree, tree,
4130 cp_id_kind *, tree *,
4131 bool, bool, bool *,
4132 const char **);
b2f29cd9 4133extern tree finish_typeof (tree);
b2f29cd9
NN
4134extern void finish_decl_cleanup (tree, tree);
4135extern void finish_eh_cleanup (tree);
4136extern void expand_body (tree);
4985cde3 4137extern void cxx_expand_function_start (void);
b2f29cd9
NN
4138extern void finish_mem_initializers (tree);
4139extern void setup_vtbl_ptr (tree, tree);
4140extern void clear_out_block (void);
8ba658ee 4141extern tree check_template_template_default_arg (tree);
8cd2462c 4142extern void expand_or_defer_fn (tree);
ee76b931
MM
4143extern void check_accessibility_of_qualified_id (tree, tree, tree);
4144extern tree finish_qualified_id_expr (tree, tree, bool, bool);
9eeb200f 4145extern void simplify_aggr_init_expr (tree *);
6de9cd9a 4146extern void finalize_nrv (tree *, tree, tree);
35b1567d 4147
51c184be 4148/* in tree.c */
b2f29cd9
NN
4149extern void lang_check_failed (const char *, int,
4150 const char *);
4151extern tree stabilize_expr (tree, tree *);
6de9cd9a
DN
4152extern void stabilize_call (tree, tree *);
4153extern bool stabilize_init (tree, tree *);
b2f29cd9
NN
4154extern tree cxx_unsave_expr_now (tree);
4155extern tree cxx_maybe_build_cleanup (tree);
4156extern void init_tree (void);
4157extern int pod_type_p (tree);
4158extern int zero_init_p (tree);
4159extern tree canonical_type_variant (tree);
48b45647
NS
4160extern tree copy_binfo (tree, tree, tree,
4161 tree *, int);
b2f29cd9 4162extern int member_p (tree);
d18a8251 4163extern cp_lvalue_kind real_lvalue_p (tree);
25a1a39e 4164extern int lvalue_or_else (tree, const char *);
8e1daa34 4165extern tree build_min (enum tree_code, tree, ...);
b2f29cd9 4166extern tree build_min_nt (enum tree_code, ...);
8e1daa34 4167extern tree build_min_non_dep (enum tree_code, tree, ...);
b2f29cd9
NN
4168extern tree build_cplus_new (tree, tree);
4169extern tree get_target_expr (tree);
b2f29cd9
NN
4170extern tree build_cplus_staticfn_type (tree, tree, tree);
4171extern tree build_cplus_array_type (tree, tree);
4172extern tree hash_tree_cons (tree, tree, tree);
4173extern tree hash_tree_chain (tree, tree);
4174extern tree hash_chainon (tree, tree);
b2f29cd9
NN
4175extern int count_functions (tree);
4176extern int is_overloaded_fn (tree);
4177extern tree get_first_fn (tree);
4178extern int bound_pmf_p (tree);
4179extern tree ovl_cons (tree, tree);
4180extern tree build_overload (tree, tree);
4181extern tree function_arg_chain (tree);
4182extern int promotes_to_aggr_type (tree, enum tree_code);
b2f29cd9
NN
4183extern const char *cxx_printable_name (tree, int);
4184extern tree build_exception_variant (tree, tree);
4185extern tree bind_template_template_parm (tree, tree);
4186extern tree array_type_nelts_total (tree);
4187extern tree array_type_nelts_top (tree);
4188extern tree break_out_target_exprs (tree);
4189extern tree get_type_decl (tree);
4190extern tree vec_binfo_member (tree, tree);
4191extern tree decl_namespace_context (tree);
4192extern tree lvalue_type (tree);
4193extern tree error_type (tree);
b2f29cd9
NN
4194extern int varargs_function_p (tree);
4195extern int really_overloaded_fn (tree);
c8a209ca 4196extern bool cp_tree_equal (tree, tree);
b2f29cd9
NN
4197extern tree no_linkage_check (tree);
4198extern void debug_binfo (tree);
4199extern tree build_dummy_object (tree);
4200extern tree maybe_dummy_object (tree, tree *);
4201extern int is_dummy_object (tree);
349ae713 4202extern const struct attribute_spec cxx_attribute_table[];
b2f29cd9 4203extern tree make_ptrmem_cst (tree, tree);
e9525111 4204extern tree cp_build_type_attribute_variant (tree, tree);
b2f29cd9 4205extern tree cp_build_qualified_type_real (tree, int, tsubst_flags_t);
adecb3f4 4206#define cp_build_qualified_type(TYPE, QUALS) \
c2ea3a40 4207 cp_build_qualified_type_real ((TYPE), (QUALS), tf_error | tf_warning)
b2f29cd9
NN
4208extern tree build_shared_int_cst (int);
4209extern special_function_kind special_function_p (tree);
50ad9642 4210extern bool name_p (tree);
b2f29cd9
NN
4211extern int count_trees (tree);
4212extern int char_type_p (tree);
4213extern void verify_stmt_tree (tree);
4214extern tree find_tree (tree, tree);
4215extern linkage_kind decl_linkage (tree);
4216extern tree cp_walk_subtrees (tree*, int*, walk_tree_fn,
4217 void*, void*);
4218extern int cp_cannot_inline_tree_fn (tree*);
4219extern tree cp_add_pending_fn_decls (void*,tree);
4220extern int cp_is_overload_p (tree);
4221extern int cp_auto_var_in_fn_p (tree,tree);
18c6ada9 4222extern void cp_update_decl_after_saving (tree, void *);
bb20cc46 4223
51c184be 4224/* in typeck.c */
b2f29cd9
NN
4225extern int string_conv_p (tree, tree, int);
4226extern tree cp_truthvalue_conversion (tree);
4227extern tree condition_conversion (tree);
4228extern tree target_type (tree);
4229extern tree require_complete_type (tree);
4230extern tree complete_type (tree);
4231extern tree complete_type_or_diagnostic (tree, tree, int);
23b4deba 4232#define complete_type_or_else(T,V) (complete_type_or_diagnostic ((T), (V), 0))
b2f29cd9
NN
4233extern int type_unknown_p (tree);
4234extern tree commonparms (tree, tree);
4235extern tree original_type (tree);
acd8e2d0 4236extern bool comp_except_specs (tree, tree, bool);
c8a209ca 4237extern bool comptypes (tree, tree, int);
acd8e2d0 4238extern bool compparms (tree, tree);
b2f29cd9
NN
4239extern int comp_cv_qualification (tree, tree);
4240extern int comp_cv_qual_signature (tree, tree);
7a18b933
NS
4241extern tree cxx_sizeof_or_alignof_expr (tree, enum tree_code);
4242extern tree cxx_sizeof_or_alignof_type (tree, enum tree_code, bool);
ea793912 4243#define cxx_sizeof_nowarn(T) cxx_sizeof_or_alignof_type (T, SIZEOF_EXPR, false)
b2f29cd9
NN
4244extern tree inline_conversion (tree);
4245extern tree decay_conversion (tree);
0a72704b 4246extern tree perform_integral_promotions (tree);
50ad9642
MM
4247extern tree build_class_member_access_expr (tree, tree, tree, bool);
4248extern tree finish_class_member_access_expr (tree, tree);
b2f29cd9
NN
4249extern tree build_x_indirect_ref (tree, const char *);
4250extern tree build_indirect_ref (tree, const char *);
4251extern tree build_array_ref (tree, tree);
4252extern tree get_member_function_from_ptrfunc (tree *, tree);
b2f29cd9 4253extern tree convert_arguments (tree, tree, tree, int);
ec835fb2
MM
4254extern tree build_x_binary_op (enum tree_code, tree, tree,
4255 bool *);
b2f29cd9
NN
4256extern tree build_x_unary_op (enum tree_code, tree);
4257extern tree unary_complex_lvalue (enum tree_code, tree);
4258extern tree build_x_conditional_expr (tree, tree, tree);
c7b62f14 4259extern tree build_x_compound_expr_from_list (tree, const char *);
d17811fd 4260extern tree build_x_compound_expr (tree, tree);
c7b62f14 4261extern tree build_compound_expr (tree, tree);
b2f29cd9
NN
4262extern tree build_static_cast (tree, tree);
4263extern tree build_reinterpret_cast (tree, tree);
4264extern tree build_const_cast (tree, tree);
4265extern tree build_c_cast (tree, tree);
4266extern tree build_x_modify_expr (tree, enum tree_code, tree);
4267extern tree build_modify_expr (tree, enum tree_code, tree);
4268extern tree dubious_conversion_warnings (tree, tree, const char *, tree, int);
4269extern tree convert_for_initialization (tree, tree, tree, int, const char *, tree, int);
4270extern int comp_ptr_ttypes (tree, tree);
4271extern int ptr_reasonably_similar (tree, tree);
4272extern tree build_ptrmemfunc (tree, tree, int);
4273extern int cp_type_quals (tree);
acd8e2d0
NS
4274extern bool cp_has_mutable_p (tree);
4275extern bool at_least_as_qualified_p (tree, tree);
4276extern bool more_qualified_p (tree, tree);
b2f29cd9
NN
4277extern tree build_ptrmemfunc1 (tree, tree, tree);
4278extern void expand_ptrmemfunc_cst (tree, tree *, tree *);
4279extern tree pfn_from_ptrmemfunc (tree);
4280extern tree type_after_usual_arithmetic_conversions (tree, tree);
4281extern tree composite_pointer_type (tree, tree, tree, tree,
4282 const char*);
4283extern tree merge_types (tree, tree);
4284extern tree check_return_expr (tree);
ab76ca54
MM
4285#define cp_build_binary_op(code, arg1, arg2) \
4286 build_binary_op(code, arg1, arg2, 1)
ea793912
GDR
4287#define cxx_sizeof(T) cxx_sizeof_or_alignof_type (T, SIZEOF_EXPR, true)
4288#define cxx_alignof(T) cxx_sizeof_or_alignof_type (T, ALIGNOF_EXPR, true)
50ad9642 4289extern tree build_ptrmemfunc_access_expr (tree, tree);
7993382e
MM
4290extern tree build_address (tree);
4291extern tree build_nop (tree, tree);
ee76b931 4292extern tree non_reference (tree);
b3dd05b1 4293extern tree lookup_anon_field (tree, tree);
c8b2e872 4294extern bool invalid_nonstatic_memfn_p (tree);
8d08fdba 4295
51c184be 4296/* in typeck2.c */
b2f29cd9
NN
4297extern void require_complete_eh_spec_types (tree, tree);
4298extern void cxx_incomplete_type_diagnostic (tree, tree, int);
23b4deba 4299#undef cxx_incomplete_type_error
b2f29cd9 4300extern void cxx_incomplete_type_error (tree, tree);
23b4deba
AO
4301#define cxx_incomplete_type_error(V,T) \
4302 (cxx_incomplete_type_diagnostic ((V), (T), 0))
b2f29cd9
NN
4303extern tree error_not_base_type (tree, tree);
4304extern tree binfo_or_else (tree, tree);
4305extern void readonly_error (tree, const char *, int);
7fb213d8 4306extern void complete_type_check_abstract (tree);
b2f29cd9
NN
4307extern int abstract_virtuals_error (tree, tree);
4308
4309extern tree store_init_value (tree, tree);
4310extern tree digest_init (tree, tree, tree *);
4311extern tree build_scoped_ref (tree, tree, tree *);
4312extern tree build_x_arrow (tree);
4313extern tree build_m_component_ref (tree, tree);
4314extern tree build_functional_cast (tree, tree);
b2f29cd9
NN
4315extern tree add_exception_specifier (tree, tree, int);
4316extern tree merge_exception_specifiers (tree, tree);
8d08fdba 4317
1f6e1acc 4318/* in mangle.c */
b2f29cd9
NN
4319extern void init_mangle (void);
4320extern void mangle_decl (tree);
4321extern const char *mangle_type_string (tree);
4322extern tree mangle_type (tree);
4323extern tree mangle_typeinfo_for_type (tree);
4324extern tree mangle_typeinfo_string_for_type (tree);
4325extern tree mangle_vtbl_for_type (tree);
4326extern tree mangle_vtt_for_type (tree);
4327extern tree mangle_ctor_vtbl_for_type (tree, tree);
4328extern tree mangle_thunk (tree, int, tree, tree);
4329extern tree mangle_conv_op_name_for_type (tree);
4330extern tree mangle_guard_variable (tree);
4331extern tree mangle_ref_init_variable (tree);
1f6e1acc 4332
0a7394bc 4333/* in dump.c */
2bd3ecad 4334extern bool cp_dump_tree (void *, tree);
0a7394bc 4335
6de9cd9a
DN
4336/* in cp-simplify.c */
4337extern int cp_gimplify_expr (tree *, tree *, tree *);
5a508662 4338extern void cp_genericize (tree);
6de9cd9a 4339
8d08fdba
MS
4340/* -- end of C++ */
4341
5f1989e6
KG
4342/* In order for the format checking to accept the C++ frontend
4343 diagnostic framework extensions, you must include this file before
4344 toplev.h, not after. */
4345#define GCC_DIAG_STYLE __gcc_cxxdiag__
4346#if GCC_VERSION >= 3004
4347#define ATTRIBUTE_GCC_CXXDIAG(m, n) __attribute__ ((__format__ (GCC_DIAG_STYLE, m, n))) ATTRIBUTE_NONNULL(m)
4348#else
4349#define ATTRIBUTE_GCC_CXXDIAG(m, n) ATTRIBUTE_NONNULL(m)
4350#endif
4351
4352extern void cp_error_at (const char *, ...) ATTRIBUTE_GCC_CXXDIAG(1, 2);
4353extern void cp_warning_at (const char *, ...) ATTRIBUTE_GCC_CXXDIAG(1, 2);
4354extern void cp_pedwarn_at (const char *, ...) ATTRIBUTE_GCC_CXXDIAG(1, 2);
4355
88657302 4356#endif /* ! GCC_CP_TREE_H */
This page took 2.695681 seconds and 5 git commands to generate.