]> git.ipfire.org Git - thirdparty/gcc.git/blame - gcc/cp/cp-tree.h
PR c++/33506
[thirdparty/gcc.git] / gcc / cp / cp-tree.h
CommitLineData
471086d6 1/* Definitions for C++ parsing and type checking.
42283c76 2 Copyright (C) 1987, 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999,
aa139c3f 3 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007
4 Free Software Foundation, Inc.
b278476e 5 Contributed by Michael Tiemann (tiemann@cygnus.com)
471086d6 6
6f0d25a6 7This file is part of GCC.
471086d6 8
6f0d25a6 9GCC is free software; you can redistribute it and/or modify
471086d6 10it under the terms of the GNU General Public License as published by
aa139c3f 11the Free Software Foundation; either version 3, or (at your option)
471086d6 12any later version.
13
6f0d25a6 14GCC is distributed in the hope that it will be useful,
471086d6 15but WITHOUT ANY WARRANTY; without even the implied warranty of
16MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17GNU General Public License for more details.
18
19You should have received a copy of the GNU General Public License
aa139c3f 20along with GCC; see the file COPYING3. If not see
21<http://www.gnu.org/licenses/>. */
471086d6 22
4bd2e31d 23#ifndef GCC_CP_TREE_H
24#define GCC_CP_TREE_H
25
573aba85 26#include "ggc.h"
54c2eeba 27#include "function.h"
39adccd6 28#include "hashtab.h"
31236dcd 29#include "splay-tree.h"
97c118b9 30#include "vec.h"
1e4853c2 31#include "varray.h"
92915e1c 32#include "c-common.h"
8546e572 33#include "name-lookup.h"
6c7ff025 34struct diagnostic_context;
35
c5c6781c 36/* Usage of TREE_LANG_FLAG_?:
57c28194 37 0: IDENTIFIER_MARKED (IDENTIFIER_NODEs)
c5c6781c 38 NEW_EXPR_USE_GLOBAL (in NEW_EXPR).
39 DELETE_EXPR_USE_GLOBAL (in DELETE_EXPR).
b6691ff5 40 COMPOUND_EXPR_OVERLOADED (in COMPOUND_EXPR).
358afcdb 41 TREE_INDIRECT_USING (in NAMESPACE_DECL).
b48733fd 42 CLEANUP_P (in TRY_BLOCK)
fd1d7ba7 43 AGGR_INIT_VIA_CTOR_P (in AGGR_INIT_EXPR)
30efa7ed 44 PTRMEM_OK_P (in ADDR_EXPR, OFFSET_REF)
a9aacc0c 45 PAREN_STRING_LITERAL (in STRING_CST)
878870b4 46 DECL_PRETTY_FUNCTION_P (in VAR_DECL)
cbce34a5 47 KOENIG_LOOKUP_P (in CALL_EXPR)
2363ef00 48 STATEMENT_LIST_NO_SCOPE (in STATEMENT_LIST).
49 EXPR_STMT_STMT_EXPR_RESULT (in EXPR_STMT)
57f08f11 50 STMT_EXPR_NO_SCOPE (in STMT_EXPR)
632f8185 51 BIND_EXPR_TRY_BLOCK (in BIND_EXPR)
e2ae55f2 52 TYPENAME_IS_ENUM_P (in TYPENAME_TYPE)
729f89ff 53 REFERENCE_REF_P (in INDIRECT_EXPR)
fbb01da7 54 QUALIFIED_NAME_IS_TEMPLATE (in SCOPE_REF)
8487df40 55 OMP_ATOMIC_DEPENDENT_P (in OMP_ATOMIC)
56 OMP_FOR_GIMPLIFYING_P (in OMP_FOR)
7276a1d0 57 BASELINK_QUALIFIED_P (in BASELINK)
25b3017b 58 TARGET_EXPR_IMPLICIT_P (in TARGET_EXPR)
855ed7a1 59 TEMPLATE_PARM_PARAMETER_PACK (in TEMPLATE_PARM_INDEX)
63949b38 60 TYPE_REF_IS_RVALUE (in REFERENCE_TYPE)
2fdd6488 61 ATTR_IS_DEPENDENT (in the TREE_LIST for an attribute)
caa6fdce 62 1: IDENTIFIER_VIRTUAL_P (in IDENTIFIER_NODE)
c5c6781c 63 TI_PENDING_TEMPLATE_FLAG.
c5c6781c 64 TEMPLATE_PARMS_FOR_INLINE.
65 DELETE_EXPR_USE_VEC (in DELETE_EXPR).
66 (TREE_CALLS_NEW) (in _EXPR or _REF) (commented-out).
a3786328 67 ICS_ELLIPSIS_FLAG (in _CONV)
23ed74d8 68 DECL_INITIALIZED_P (in VAR_DECL)
e2ae55f2 69 TYPENAME_IS_CLASS_P (in TYPENAME_TYPE)
d1725120 70 STMT_IS_FULL_EXPR_P (in _STMT)
caa6fdce 71 2: IDENTIFIER_OPNAME_P (in IDENTIFIER_NODE)
a3786328 72 ICS_THIS_FLAG (in _CONV)
878870b4 73 DECL_INITIALIZED_BY_CONSTANT_EXPRESSION_P (in VAR_DECL)
2363ef00 74 STATEMENT_LIST_TRY_BLOCK (in STATEMENT_LIST)
8826a863 75 TYPENAME_IS_RESOLVING_P (in TYPE_NAME_TYPE)
1f0b839e 76 3: (TREE_REFERENCE_EXPR) (in NON_LVALUE_EXPR) (commented-out).
a3786328 77 ICS_BAD_FLAG (in _CONV)
0a8302dc 78 FN_TRY_BLOCK_P (in TRY_BLOCK)
f04596da 79 IDENTIFIER_CTOR_OR_DTOR_P (in IDENTIFIER_NODE)
632f8185 80 BIND_EXPR_BODY_BLOCK (in BIND_EXPR)
a6b4af6d 81 DECL_NON_TRIVIALLY_INITIALIZED_P (in VAR_DECL)
57c28194 82 4: TREE_HAS_CONSTRUCTOR (in INDIRECT_REF, SAVE_EXPR, CONSTRUCTOR,
653e5405 83 or FIELD_DECL).
f0edcca6 84 IDENTIFIER_TYPENAME_P (in IDENTIFIER_NODE)
caa6fdce 85 DECL_TINFO_P (in VAR_DECL)
518796ad 86 5: C_IS_RESERVED_WORD (in IDENTIFIER_NODE)
8efca15a 87 DECL_VTABLE_OR_VTT_P (in VAR_DECL)
caa6fdce 88 6: IDENTIFIER_REPO_CHOSEN (in IDENTIFIER_NODE)
4fc9a8ec 89 DECL_CONSTRUCTION_VTABLE_P (in VAR_DECL)
ee086965 90 TYPE_MARKED_P (in _TYPE)
c5c6781c 91
92 Usage of TYPE_LANG_FLAG_?:
7f77d1f0 93 0: TYPE_DEPENDENT_P
c5c6781c 94 1: TYPE_HAS_CONSTRUCTOR.
ed36f1cf 95 2: Unused
6ce4a0c3 96 3: TYPE_FOR_JAVA.
89e923d8 97 4: TYPE_HAS_NONTRIVIAL_DESTRUCTOR
c5c6781c 98 5: IS_AGGR_TYPE.
7f77d1f0 99 6: TYPE_DEPENDENT_P_VALID
c5c6781c 100
101 Usage of DECL_LANG_FLAG_?:
102 0: DECL_ERROR_REPORTED (in VAR_DECL).
1f062702 103 DECL_TEMPLATE_PARM_P (in PARM_DECL, CONST_DECL, TYPE_DECL, or TEMPLATE_DECL)
ce23987e 104 DECL_LOCAL_FUNCTION_P (in FUNCTION_DECL)
a484e8db 105 DECL_MUTABLE_P (in FIELD_DECL)
094fb0d8 106 DECL_DEPENDENT_P (in USING_DECL)
c5c6781c 107 1: C_TYPEDEF_EXPLICITLY_SIGNED (in TYPE_DECL).
4012c20a 108 DECL_TEMPLATE_INSTANTIATED (in a VAR_DECL or a FUNCTION_DECL)
38d89ee9 109 DECL_MEMBER_TEMPLATE_P (in TEMPLATE_DECL)
d95d815d 110 FUNCTION_PARAMETER_PACK_P (in PARM_DECL)
c5c6781c 111 2: DECL_THIS_EXTERN (in VAR_DECL or FUNCTION_DECL).
70a658bd 112 DECL_IMPLICIT_TYPEDEF_P (in a TYPE_DECL)
c5c6781c 113 3: DECL_IN_AGGR_P.
23ed74d8 114 4: DECL_C_BIT_FIELD (in a FIELD_DECL)
8b2afb7a 115 DECL_ANON_UNION_VAR_P (in a VAR_DECL)
56e75739 116 DECL_SELF_REFERENCE_P (in a TYPE_DECL)
415bd54e 117 DECL_INVALID_OVERRIDER_P (in a FUNCTION_DECL)
c5c6781c 118 5: DECL_INTERFACE_KNOWN.
119 6: DECL_THIS_STATIC (in VAR_DECL or FUNCTION_DECL).
6078f68f 120 DECL_FIELD_IS_BASE (in FIELD_DECL)
c5c6781c 121 7: DECL_DEAD_FOR_LOCAL (in VAR_DECL).
021a57f4 122 DECL_THUNK_P (in a member FUNCTION_DECL)
e4e283ec 123
124 Usage of language-independent fields in a language-dependent manner:
d0ceae4d 125
e4e283ec 126 TYPE_ALIAS_SET
127 This field is used by TYPENAME_TYPEs, TEMPLATE_TYPE_PARMs, and so
128 forth as a substitute for the mark bits provided in `lang_type'.
129 At present, only the six low-order bits are used.
130
3cb98335 131 TYPE_LANG_SLOT_1
e4e283ec 132 For an ENUMERAL_TYPE, this is ENUM_TEMPLATE_INFO.
8cbe13ee 133 For a FUNCTION_TYPE or METHOD_TYPE, this is TYPE_RAISES_EXCEPTIONS
cec1f6a6 134
ab7943b9 135 BINFO_VIRTUALS
641985fa 136 For a binfo, this is a TREE_LIST. There is an entry for each
137 virtual function declared either in BINFO or its direct and
138 indirect primary bases.
139
140 The BV_DELTA of each node gives the amount by which to adjust the
141 `this' pointer when calling the function. If the method is an
e18c26dd 142 overridden version of a base class method, then it is assumed
641985fa 143 that, prior to adjustment, the this pointer points to an object
144 of the base class.
8fcde9a9 145
fc475736 146 The BV_VCALL_INDEX of each node, if non-NULL, gives the vtable
ac13e8d9 147 index of the vcall offset for this entry.
7b4abb45 148
fc475736 149 The BV_FN is the declaration for the virtual function itself.
fc475736 150
59751e6c 151 BINFO_VTABLE
5ad590ad 152 This is an expression with POINTER_TYPE that gives the value
59751e6c 153 to which the vptr should be initialized. Use get_vtbl_decl_for_binfo
5ad590ad 154 to extract the VAR_DECL for the complete vtable.
59751e6c 155
74c333de 156 DECL_ARGUMENTS
50cd3f45 157 For a VAR_DECL this is DECL_ANON_UNION_ELEMS.
d0d8836b 158
159 DECL_VINDEX
160 This field is NULL for a non-virtual function. For a virtual
161 function, it is eventually set to an INTEGER_CST indicating the
162 index in the vtable at which this function can be found. When
163 a virtual function is declared, but before it is known what
e18c26dd 164 function is overridden, this field is the error_mark_node.
d0d8836b 165
50cd3f45 166 Temporarily, it may be set to a TREE_LIST whose TREE_VALUE is
d0d8836b 167 the virtual function this one overrides, and whose TREE_CHAIN is
168 the old DECL_VINDEX. */
c5c6781c 169
c0af329c 170/* Language-specific tree checkers. */
ad46fc6a 171
36066e37 172#define VAR_OR_FUNCTION_DECL_CHECK(NODE) \
173 TREE_CHECK2(NODE,VAR_DECL,FUNCTION_DECL)
174
175#define VAR_FUNCTION_OR_PARM_DECL_CHECK(NODE) \
176 TREE_CHECK3(NODE,VAR_DECL,FUNCTION_DECL,PARM_DECL)
177
178#define VAR_TEMPL_TYPE_OR_FUNCTION_DECL_CHECK(NODE) \
179 TREE_CHECK4(NODE,VAR_DECL,FUNCTION_DECL,TYPE_DECL,TEMPLATE_DECL)
180
36066e37 181#define BOUND_TEMPLATE_TEMPLATE_PARM_TYPE_CHECK(NODE) \
182 TREE_CHECK(NODE,BOUND_TEMPLATE_TEMPLATE_PARM)
92915e1c 183
d409f4c9 184#if defined ENABLE_TREE_CHECKING && (GCC_VERSION >= 2007)
185#define NON_THUNK_FUNCTION_CHECK(NODE) __extension__ \
9f627b1a 186({ __typeof(NODE) const __t = (NODE); \
d409f4c9 187 if (TREE_CODE (__t) != FUNCTION_DECL && \
074ab442 188 TREE_CODE (__t) != TEMPLATE_DECL && __t->decl_common.lang_specific \
5ded8c6f 189 && __t->decl_common.lang_specific->decl_flags.thunk_p) \
d409f4c9 190 tree_check_failed (__t, __FILE__, __LINE__, __FUNCTION__, 0); \
191 __t; })
192#define THUNK_FUNCTION_CHECK(NODE) __extension__ \
9f627b1a 193({ __typeof (NODE) const __t = (NODE); \
5ded8c6f 194 if (TREE_CODE (__t) != FUNCTION_DECL || !__t->decl_common.lang_specific \
195 || !__t->decl_common.lang_specific->decl_flags.thunk_p) \
074ab442 196 tree_check_failed (__t, __FILE__, __LINE__, __FUNCTION__, 0); \
d409f4c9 197 __t; })
198#else
199#define NON_THUNK_FUNCTION_CHECK(NODE) (NODE)
200#define THUNK_FUNCTION_CHECK(NODE) (NODE)
201#endif
b53fb33d 202\f
471086d6 203/* Language-dependent contents of an identifier. */
204
1f3233d1 205struct lang_identifier GTY(())
471086d6 206{
1f3233d1 207 struct c_common_identifier c_common;
771cf831 208 cxx_binding *namespace_bindings;
209 cxx_binding *bindings;
471086d6 210 tree class_template_info;
0839f2a7 211 tree label_value;
471086d6 212};
213
518796ad 214/* In an IDENTIFIER_NODE, nonzero if this identifier is actually a
215 keyword. C_RID_CODE (node) is then the RID_* value of the keyword,
216 and C_RID_YYCODE is the token number wanted by Yacc. */
217
f58424d8 218#define C_IS_RESERVED_WORD(ID) TREE_LANG_FLAG_5 (ID)
518796ad 219
ad46fc6a 220#define LANG_IDENTIFIER_CAST(NODE) \
221 ((struct lang_identifier*)IDENTIFIER_NODE_CHECK (NODE))
222
018c1ab0 223struct template_parm_index_s GTY(())
f3110581 224{
851dfbff 225 struct tree_common common;
855ed7a1 226 int index;
227 int level;
228 int orig_level;
f3110581 229 tree decl;
018c1ab0 230};
231typedef struct template_parm_index_s template_parm_index;
232
1f3233d1 233struct ptrmem_cst GTY(())
0f2952a1 234{
851dfbff 235 struct tree_common common;
50cd3f45 236 /* This isn't used, but the middle-end expects all constants to have
23f83a9a 237 this field. */
f58424d8 238 rtx rtl;
0f2952a1 239 tree member;
1f3233d1 240};
241typedef struct ptrmem_cst * ptrmem_cst_t;
0f2952a1 242
18e99d00 243#define IDENTIFIER_GLOBAL_VALUE(NODE) \
f58424d8 244 namespace_binding ((NODE), global_namespace)
8417823c 245#define SET_IDENTIFIER_GLOBAL_VALUE(NODE, VAL) \
f58424d8 246 set_namespace_binding ((NODE), global_namespace, (VAL))
18e99d00 247#define IDENTIFIER_NAMESPACE_VALUE(NODE) \
f58424d8 248 namespace_binding ((NODE), current_namespace)
8417823c 249#define SET_IDENTIFIER_NAMESPACE_VALUE(NODE, VAL) \
f58424d8 250 set_namespace_binding ((NODE), current_namespace, (VAL))
18e99d00 251
653e5405 252#define CLEANUP_P(NODE) TREE_LANG_FLAG_0 (TRY_BLOCK_CHECK (NODE))
92915e1c 253
632f8185 254#define BIND_EXPR_TRY_BLOCK(NODE) \
255 TREE_LANG_FLAG_0 (BIND_EXPR_CHECK (NODE))
2363ef00 256
257/* Used to mark the block around the member initializers and cleanups. */
632f8185 258#define BIND_EXPR_BODY_BLOCK(NODE) \
259 TREE_LANG_FLAG_3 (BIND_EXPR_CHECK (NODE))
bc2b76e0 260#define FUNCTION_NEEDS_BODY_BLOCK(NODE) \
261 (DECL_CONSTRUCTOR_P (NODE) || DECL_DESTRUCTOR_P (NODE))
2363ef00 262
263#define STATEMENT_LIST_NO_SCOPE(NODE) \
264 TREE_LANG_FLAG_0 (STATEMENT_LIST_CHECK (NODE))
265#define STATEMENT_LIST_TRY_BLOCK(NODE) \
266 TREE_LANG_FLAG_2 (STATEMENT_LIST_CHECK (NODE))
267
d1725120 268/* Nonzero if this statement should be considered a full-expression,
269 i.e., if temporaries created during this statement should have
270 their destructors run at the end of this statement. */
271#define STMT_IS_FULL_EXPR_P(NODE) TREE_LANG_FLAG_1 ((NODE))
272
2363ef00 273/* Marks the result of a statement expression. */
274#define EXPR_STMT_STMT_EXPR_RESULT(NODE) \
275 TREE_LANG_FLAG_0 (EXPR_STMT_CHECK (NODE))
276
57f08f11 277/* Nonzero if this statement-expression does not have an associated scope. */
278#define STMT_EXPR_NO_SCOPE(NODE) \
279 TREE_LANG_FLAG_0 (STMT_EXPR_CHECK (NODE))
280
92915e1c 281/* Returns nonzero iff TYPE1 and TYPE2 are the same type, in the usual
282 sense of `same'. */
f58424d8 283#define same_type_p(TYPE1, TYPE2) \
284 comptypes ((TYPE1), (TYPE2), COMPARE_STRICT)
92915e1c 285
286/* Returns nonzero iff TYPE1 and TYPE2 are the same type, ignoring
287 top-level qualifiers. */
f58424d8 288#define same_type_ignoring_top_level_qualifiers_p(TYPE1, TYPE2) \
289 same_type_p (TYPE_MAIN_VARIANT (TYPE1), TYPE_MAIN_VARIANT (TYPE2))
92915e1c 290
3160db1d 291/* Nonzero if we are presently building a statement tree, rather
92915e1c 292 than expanding each statement as we encounter it. */
2363ef00 293#define building_stmt_tree() (cur_stmt_list != NULL_TREE)
92915e1c 294
3160db1d 295/* Returns nonzero iff NODE is a declaration for the global function
92915e1c 296 `main'. */
297#define DECL_MAIN_P(NODE) \
653e5405 298 (DECL_EXTERN_C_FUNCTION_P (NODE) \
92915e1c 299 && DECL_NAME (NODE) != NULL_TREE \
b24655ef 300 && MAIN_NAME_P (DECL_NAME (NODE))) \
301 && flag_hosted
92915e1c 302
c0af329c 303/* The overloaded FUNCTION_DECL. */
f58424d8 304#define OVL_FUNCTION(NODE) \
305 (((struct tree_overload*)OVERLOAD_CHECK (NODE))->function)
306#define OVL_CHAIN(NODE) TREE_CHAIN (NODE)
c0af329c 307/* Polymorphic access to FUNCTION and CHAIN. */
653e5405 308#define OVL_CURRENT(NODE) \
f58424d8 309 ((TREE_CODE (NODE) == OVERLOAD) ? OVL_FUNCTION (NODE) : (NODE))
653e5405 310#define OVL_NEXT(NODE) \
f58424d8 311 ((TREE_CODE (NODE) == OVERLOAD) ? TREE_CHAIN (NODE) : NULL_TREE)
8417823c 312/* If set, this was imported in a using declaration.
313 This is not to confuse with being used somewhere, which
c0af329c 314 is not important for this node. */
653e5405 315#define OVL_USED(NODE) TREE_USED (NODE)
8417823c 316
1f3233d1 317struct tree_overload GTY(())
8417823c 318{
851dfbff 319 struct tree_common common;
8417823c 320 tree function;
321};
322
4ac852cb 323/* Returns true iff NODE is a BASELINK. */
96776925 324#define BASELINK_P(NODE) \
4ac852cb 325 (TREE_CODE (NODE) == BASELINK)
326/* The BINFO indicating the base from which the BASELINK_FUNCTIONS came. */
f70cb9e6 327#define BASELINK_BINFO(NODE) \
8c1f65e6 328 (((struct tree_baselink*) BASELINK_CHECK (NODE))->binfo)
4ac852cb 329/* The functions referred to by the BASELINK; either a FUNCTION_DECL,
330 a TEMPLATE_DECL, an OVERLOAD, or a TEMPLATE_ID_EXPR. */
8042247d 331#define BASELINK_FUNCTIONS(NODE) \
8c1f65e6 332 (((struct tree_baselink*) BASELINK_CHECK (NODE))->functions)
ac13e8d9 333/* The BINFO in which the search for the functions indicated by this baselink
334 began. This base is used to determine the accessibility of functions
f70cb9e6 335 selected by overload resolution. */
336#define BASELINK_ACCESS_BINFO(NODE) \
8c1f65e6 337 (((struct tree_baselink*) BASELINK_CHECK (NODE))->access_binfo)
f70cb9e6 338/* For a type-conversion operator, the BASELINK_OPTYPE indicates the type
339 to which the conversion should occur. This value is important if
340 the BASELINK_FUNCTIONS include a template conversion operator --
341 the BASELINK_OPTYPE can be used to determine what type the user
342 requested. */
343#define BASELINK_OPTYPE(NODE) \
4ac852cb 344 (TREE_CHAIN (BASELINK_CHECK (NODE)))
a17c2a3a 345/* Nonzero if this baselink was from a qualified lookup. */
7276a1d0 346#define BASELINK_QUALIFIED_P(NODE) \
347 TREE_LANG_FLAG_0 (BASELINK_CHECK (NODE))
96776925 348
8c1f65e6 349struct tree_baselink GTY(())
350{
351 struct tree_common common;
352 tree binfo;
353 tree functions;
354 tree access_binfo;
355};
356
4a44ba29 357/* The different kinds of ids that we encounter. */
0886adbc 358
359typedef enum cp_id_kind
360{
361 /* Not an id at all. */
362 CP_ID_KIND_NONE,
363 /* An unqualified-id that is not a template-id. */
364 CP_ID_KIND_UNQUALIFIED,
63eff20d 365 /* An unqualified-id that is a dependent name. */
c08d51be 366 CP_ID_KIND_UNQUALIFIED_DEPENDENT,
0886adbc 367 /* An unqualified template-id. */
368 CP_ID_KIND_TEMPLATE_ID,
369 /* A qualified-id. */
370 CP_ID_KIND_QUALIFIED
371} cp_id_kind;
372
471086d6 373/* Macros for access to language-specific slots in an identifier. */
374
18e99d00 375#define IDENTIFIER_NAMESPACE_BINDINGS(NODE) \
ad46fc6a 376 (LANG_IDENTIFIER_CAST (NODE)->namespace_bindings)
471086d6 377#define IDENTIFIER_TEMPLATE(NODE) \
ad46fc6a 378 (LANG_IDENTIFIER_CAST (NODE)->class_template_info)
471086d6 379
771cf831 380/* The IDENTIFIER_BINDING is the innermost cxx_binding for the
381 identifier. It's PREVIOUS is the next outermost binding. Each
76608a37 382 VALUE field is a DECL for the associated declaration. Thus,
53137e6a 383 name lookup consists simply of pulling off the node at the front
384 of the list (modulo oddities for looking up the names of types,
76608a37 385 and such.) You can use SCOPE field to determine the scope
d36ac936 386 that bound the name. */
53137e6a 387#define IDENTIFIER_BINDING(NODE) \
ad46fc6a 388 (LANG_IDENTIFIER_CAST (NODE)->bindings)
53137e6a 389
8417823c 390/* TREE_TYPE only indicates on local and class scope the current
391 type. For namespace scope, the presence of a type in any namespace
392 is indicated with global_type_node, and the real type behind must
c0af329c 393 be found through lookup. */
f58424d8 394#define IDENTIFIER_TYPE_VALUE(NODE) identifier_type_value (NODE)
395#define REAL_IDENTIFIER_TYPE_VALUE(NODE) TREE_TYPE (NODE)
396#define SET_IDENTIFIER_TYPE_VALUE(NODE,TYPE) (TREE_TYPE (NODE) = (TYPE))
8417823c 397#define IDENTIFIER_HAS_TYPE_VALUE(NODE) (IDENTIFIER_TYPE_VALUE (NODE) ? 1 : 0)
471086d6 398
f58424d8 399#define IDENTIFIER_LABEL_VALUE(NODE) \
0839f2a7 400 (LANG_IDENTIFIER_CAST (NODE)->label_value)
f58424d8 401#define SET_IDENTIFIER_LABEL_VALUE(NODE, VALUE) \
0839f2a7 402 IDENTIFIER_LABEL_VALUE (NODE) = (VALUE)
471086d6 403
4c481f71 404/* Nonzero if this identifier is used as a virtual function name somewhere
405 (optimizes searches). */
f58424d8 406#define IDENTIFIER_VIRTUAL_P(NODE) TREE_LANG_FLAG_1 (NODE)
471086d6 407
ddea175e 408/* Nonzero if this identifier is the prefix for a mangled C++ operator
409 name. */
f58424d8 410#define IDENTIFIER_OPNAME_P(NODE) TREE_LANG_FLAG_2 (NODE)
471086d6 411
fb868a5d 412/* Nonzero if this identifier is the name of a type-conversion
413 operator. */
f0edcca6 414#define IDENTIFIER_TYPENAME_P(NODE) \
f58424d8 415 TREE_LANG_FLAG_4 (NODE)
471086d6 416
f04596da 417/* Nonzero if this identifier is the name of a constructor or
418 destructor. */
419#define IDENTIFIER_CTOR_OR_DTOR_P(NODE) \
420 TREE_LANG_FLAG_3 (NODE)
421
caa6fdce 422/* True iff NAME is the DECL_ASSEMBLER_NAME for an entity with vague
423 linkage which the prelinker has assigned to this translation
424 unit. */
425#define IDENTIFIER_REPO_CHOSEN(NAME) \
426 (TREE_LANG_FLAG_6 (NAME))
427
471086d6 428/* In a RECORD_TYPE or UNION_TYPE, nonzero if any component is read-only. */
7f77d1f0 429#define C_TYPE_FIELDS_READONLY(TYPE) \
430 (LANG_TYPE_CLASS_CHECK (TYPE)->fields_readonly)
bcf789d7 431
0a3b29ad 432/* The tokens stored in the default argument. */
433
434#define DEFARG_TOKENS(NODE) \
435 (((struct tree_default_arg *)DEFAULT_ARG_CHECK (NODE))->tokens)
f51f5e0b 436#define DEFARG_INSTANTIATIONS(NODE) \
437 (((struct tree_default_arg *)DEFAULT_ARG_CHECK (NODE))->instantiations)
0a3b29ad 438
439struct tree_default_arg GTY (())
440{
441 struct tree_common common;
442 struct cp_token_cache *tokens;
f51f5e0b 443 VEC(tree,gc) *instantiations;
0a3b29ad 444};
445
7a05c4b1 446/* The condition associated with the static assertion. This must be
447 an integral constant expression. */
448#define STATIC_ASSERT_CONDITION(NODE) \
449 (((struct tree_static_assert *)STATIC_ASSERT_CHECK (NODE))->condition)
450
451/* The message associated with the static assertion. This must be a
452 string constant, which will be emitted as an error message when the
453 static assert condition is false. */
454#define STATIC_ASSERT_MESSAGE(NODE) \
455 (((struct tree_static_assert *)STATIC_ASSERT_CHECK (NODE))->message)
456
457/* Source location information for a static assertion. */
458#define STATIC_ASSERT_SOURCE_LOCATION(NODE) \
459 (((struct tree_static_assert *)STATIC_ASSERT_CHECK (NODE))->location)
460
461struct tree_static_assert GTY (())
462{
463 struct tree_common common;
464 tree condition;
465 tree message;
466 location_t location;
467};
468
d95d815d 469struct tree_argument_pack_select GTY (())
470{
471 struct tree_common common;
472 tree argument_pack;
473 int index;
474};
475
481451eb 476/* The different kinds of traits that we encounter. */
477
478typedef enum cp_trait_kind
479{
480 CPTK_HAS_NOTHROW_ASSIGN,
481 CPTK_HAS_NOTHROW_CONSTRUCTOR,
482 CPTK_HAS_NOTHROW_COPY,
483 CPTK_HAS_TRIVIAL_ASSIGN,
484 CPTK_HAS_TRIVIAL_CONSTRUCTOR,
485 CPTK_HAS_TRIVIAL_COPY,
486 CPTK_HAS_TRIVIAL_DESTRUCTOR,
487 CPTK_HAS_VIRTUAL_DESTRUCTOR,
488 CPTK_IS_ABSTRACT,
489 CPTK_IS_BASE_OF,
490 CPTK_IS_CLASS,
491 CPTK_IS_CONVERTIBLE_TO,
492 CPTK_IS_EMPTY,
493 CPTK_IS_ENUM,
494 CPTK_IS_POD,
495 CPTK_IS_POLYMORPHIC,
496 CPTK_IS_UNION
497} cp_trait_kind;
498
499/* The types that we are processing. */
500#define TRAIT_EXPR_TYPE1(NODE) \
501 (((struct tree_trait_expr *)TRAIT_EXPR_CHECK (NODE))->type1)
502
503#define TRAIT_EXPR_TYPE2(NODE) \
504 (((struct tree_trait_expr *)TRAIT_EXPR_CHECK (NODE))->type2)
505
506/* The specific trait that we are processing. */
507#define TRAIT_EXPR_KIND(NODE) \
508 (((struct tree_trait_expr *)TRAIT_EXPR_CHECK (NODE))->kind)
509
510struct tree_trait_expr GTY (())
511{
512 struct tree_common common;
513 tree type1;
514 tree type2;
515 enum cp_trait_kind kind;
516};
517
1f3233d1 518enum cp_tree_node_structure_enum {
1f3233d1 519 TS_CP_GENERIC,
520 TS_CP_IDENTIFIER,
521 TS_CP_TPI,
522 TS_CP_PTRMEM,
523 TS_CP_BINDING,
524 TS_CP_OVERLOAD,
8c1f65e6 525 TS_CP_BASELINK,
1f3233d1 526 TS_CP_WRAPPER,
0a3b29ad 527 TS_CP_DEFAULT_ARG,
7a05c4b1 528 TS_CP_STATIC_ASSERT,
d95d815d 529 TS_CP_ARGUMENT_PACK_SELECT,
481451eb 530 TS_CP_TRAIT_EXPR,
1f3233d1 531 LAST_TS_CP_ENUM
532};
533
534/* The resulting tree type. */
c849df63 535union lang_tree_node GTY((desc ("cp_tree_node_structure (&%h)"),
98d4f925 536 chain_next ("(union lang_tree_node *)GENERIC_NEXT (&%h.generic)")))
1f3233d1 537{
1f3233d1 538 union tree_node GTY ((tag ("TS_CP_GENERIC"),
539 desc ("tree_node_structure (&%h)"))) generic;
540 struct template_parm_index_s GTY ((tag ("TS_CP_TPI"))) tpi;
541 struct ptrmem_cst GTY ((tag ("TS_CP_PTRMEM"))) ptrmem;
1f3233d1 542 struct tree_overload GTY ((tag ("TS_CP_OVERLOAD"))) overload;
8c1f65e6 543 struct tree_baselink GTY ((tag ("TS_CP_BASELINK"))) baselink;
0a3b29ad 544 struct tree_default_arg GTY ((tag ("TS_CP_DEFAULT_ARG"))) default_arg;
1f3233d1 545 struct lang_identifier GTY ((tag ("TS_CP_IDENTIFIER"))) identifier;
7a05c4b1 546 struct tree_static_assert GTY ((tag ("TS_CP_STATIC_ASSERT")))
547 static_assertion;
d95d815d 548 struct tree_argument_pack_select GTY ((tag ("TS_CP_ARGUMENT_PACK_SELECT")))
549 argument_pack_select;
481451eb 550 struct tree_trait_expr GTY ((tag ("TS_CP_TRAIT_EXPR")))
551 trait_expression;
1f3233d1 552};
553
554\f
72040e7e 555enum cp_tree_index
556{
ff84c0e4 557 CPTI_JAVA_BYTE_TYPE,
558 CPTI_JAVA_SHORT_TYPE,
559 CPTI_JAVA_INT_TYPE,
560 CPTI_JAVA_LONG_TYPE,
561 CPTI_JAVA_FLOAT_TYPE,
562 CPTI_JAVA_DOUBLE_TYPE,
563 CPTI_JAVA_CHAR_TYPE,
564 CPTI_JAVA_BOOLEAN_TYPE,
565
72040e7e 566 CPTI_WCHAR_DECL,
567 CPTI_VTABLE_ENTRY_TYPE,
568 CPTI_DELTA_TYPE,
63a6a423 569 CPTI_VTABLE_INDEX_TYPE,
054a0626 570 CPTI_CLEANUP_TYPE,
0ce25b06 571 CPTI_VTT_PARM_TYPE,
72040e7e 572
72040e7e 573 CPTI_CLASS_TYPE,
72040e7e 574 CPTI_UNKNOWN_TYPE,
72040e7e 575 CPTI_VTBL_TYPE,
576 CPTI_VTBL_PTR_TYPE,
577 CPTI_STD,
13d8774b 578 CPTI_ABI,
729f89ff 579 CPTI_CONST_TYPE_INFO_TYPE,
46f41950 580 CPTI_TYPE_INFO_PTR_TYPE,
72040e7e 581 CPTI_ABORT_FNDECL,
582 CPTI_GLOBAL_DELETE_FNDECL,
eccec853 583 CPTI_AGGR_TAG,
72040e7e 584
1e4853c2 585 CPTI_CTOR_IDENTIFIER,
cfb46e1f 586 CPTI_COMPLETE_CTOR_IDENTIFIER,
8eadd521 587 CPTI_BASE_CTOR_IDENTIFIER,
588 CPTI_DTOR_IDENTIFIER,
e55cba4c 589 CPTI_COMPLETE_DTOR_IDENTIFIER,
8eadd521 590 CPTI_BASE_DTOR_IDENTIFIER,
591 CPTI_DELETING_DTOR_IDENTIFIER,
1e4853c2 592 CPTI_DELTA_IDENTIFIER,
1e4853c2 593 CPTI_IN_CHARGE_IDENTIFIER,
0ce25b06 594 CPTI_VTT_PARM_IDENTIFIER,
1e4853c2 595 CPTI_NELTS_IDENTIFIER,
596 CPTI_THIS_IDENTIFIER,
597 CPTI_PFN_IDENTIFIER,
1e4853c2 598 CPTI_VPTR_IDENTIFIER,
98eaf693 599 CPTI_STD_IDENTIFIER,
1e4853c2 600
601 CPTI_LANG_NAME_C,
602 CPTI_LANG_NAME_CPLUSPLUS,
603 CPTI_LANG_NAME_JAVA,
604
605 CPTI_EMPTY_EXCEPT_SPEC,
1e4853c2 606 CPTI_JCLASS,
1e4853c2 607 CPTI_TERMINATE,
df4b504c 608 CPTI_CALL_UNEXPECTED,
34382091 609 CPTI_ATEXIT_FN_PTR_TYPE,
b9920b13 610 CPTI_ATEXIT,
1da45f21 611 CPTI_DSO_HANDLE,
71792355 612 CPTI_DCAST,
1e4853c2 613
9bacae7e 614 CPTI_KEYED_CLASSES,
6fc7a923 615
72040e7e 616 CPTI_MAX
617};
471086d6 618
1f3233d1 619extern GTY(()) tree cp_global_trees[CPTI_MAX];
72040e7e 620
84ea6a1d 621#define java_byte_type_node cp_global_trees[CPTI_JAVA_BYTE_TYPE]
622#define java_short_type_node cp_global_trees[CPTI_JAVA_SHORT_TYPE]
623#define java_int_type_node cp_global_trees[CPTI_JAVA_INT_TYPE]
624#define java_long_type_node cp_global_trees[CPTI_JAVA_LONG_TYPE]
625#define java_float_type_node cp_global_trees[CPTI_JAVA_FLOAT_TYPE]
626#define java_double_type_node cp_global_trees[CPTI_JAVA_DOUBLE_TYPE]
627#define java_char_type_node cp_global_trees[CPTI_JAVA_CHAR_TYPE]
628#define java_boolean_type_node cp_global_trees[CPTI_JAVA_BOOLEAN_TYPE]
629
72040e7e 630#define wchar_decl_node cp_global_trees[CPTI_WCHAR_DECL]
631#define vtable_entry_type cp_global_trees[CPTI_VTABLE_ENTRY_TYPE]
63a6a423 632/* The type used to represent an offset by which to adjust the `this'
dc9b5a48 633 pointer in pointer-to-member types. */
72040e7e 634#define delta_type_node cp_global_trees[CPTI_DELTA_TYPE]
63a6a423 635/* The type used to represent an index into the vtable. */
653e5405 636#define vtable_index_type cp_global_trees[CPTI_VTABLE_INDEX_TYPE]
73a07fbc 637
72040e7e 638#define class_type_node cp_global_trees[CPTI_CLASS_TYPE]
72040e7e 639#define unknown_type_node cp_global_trees[CPTI_UNKNOWN_TYPE]
72040e7e 640#define vtbl_type_node cp_global_trees[CPTI_VTBL_TYPE]
641#define vtbl_ptr_type_node cp_global_trees[CPTI_VTBL_PTR_TYPE]
642#define std_node cp_global_trees[CPTI_STD]
653e5405 643#define abi_node cp_global_trees[CPTI_ABI]
729f89ff 644#define const_type_info_type_node cp_global_trees[CPTI_CONST_TYPE_INFO_TYPE]
46f41950 645#define type_info_ptr_type cp_global_trees[CPTI_TYPE_INFO_PTR_TYPE]
72040e7e 646#define abort_fndecl cp_global_trees[CPTI_ABORT_FNDECL]
647#define global_delete_fndecl cp_global_trees[CPTI_GLOBAL_DELETE_FNDECL]
eccec853 648#define current_aggr cp_global_trees[CPTI_AGGR_TAG]
6ce4a0c3 649
1e4853c2 650/* We cache these tree nodes so as to call get_identifier less
651 frequently. */
652
cfb46e1f 653/* The name of a constructor that takes an in-charge parameter to
e55cba4c 654 decide whether or not to construct virtual base classes. */
653e5405 655#define ctor_identifier cp_global_trees[CPTI_CTOR_IDENTIFIER]
cfb46e1f 656/* The name of a constructor that constructs virtual base classes. */
653e5405 657#define complete_ctor_identifier cp_global_trees[CPTI_COMPLETE_CTOR_IDENTIFIER]
8eadd521 658/* The name of a constructor that does not construct virtual base classes. */
653e5405 659#define base_ctor_identifier cp_global_trees[CPTI_BASE_CTOR_IDENTIFIER]
e55cba4c 660/* The name of a destructor that takes an in-charge parameter to
661 decide whether or not to destroy virtual base classes and whether
662 or not to delete the object. */
653e5405 663#define dtor_identifier cp_global_trees[CPTI_DTOR_IDENTIFIER]
e55cba4c 664/* The name of a destructor that destroys virtual base classes. */
653e5405 665#define complete_dtor_identifier cp_global_trees[CPTI_COMPLETE_DTOR_IDENTIFIER]
8eadd521 666/* The name of a destructor that does not destroy virtual base
667 classes. */
653e5405 668#define base_dtor_identifier cp_global_trees[CPTI_BASE_DTOR_IDENTIFIER]
8eadd521 669/* The name of a destructor that destroys virtual base classes, and
670 then deletes the entire object. */
653e5405 671#define deleting_dtor_identifier cp_global_trees[CPTI_DELETING_DTOR_IDENTIFIER]
672#define delta_identifier cp_global_trees[CPTI_DELTA_IDENTIFIER]
673#define in_charge_identifier cp_global_trees[CPTI_IN_CHARGE_IDENTIFIER]
0ce25b06 674/* The name of the parameter that contains a pointer to the VTT to use
675 for this subobject constructor or destructor. */
653e5405 676#define vtt_parm_identifier cp_global_trees[CPTI_VTT_PARM_IDENTIFIER]
677#define nelts_identifier cp_global_trees[CPTI_NELTS_IDENTIFIER]
678#define this_identifier cp_global_trees[CPTI_THIS_IDENTIFIER]
679#define pfn_identifier cp_global_trees[CPTI_PFN_IDENTIFIER]
680#define vptr_identifier cp_global_trees[CPTI_VPTR_IDENTIFIER]
98eaf693 681/* The name of the std namespace. */
653e5405 682#define std_identifier cp_global_trees[CPTI_STD_IDENTIFIER]
683#define lang_name_c cp_global_trees[CPTI_LANG_NAME_C]
684#define lang_name_cplusplus cp_global_trees[CPTI_LANG_NAME_CPLUSPLUS]
685#define lang_name_java cp_global_trees[CPTI_LANG_NAME_JAVA]
1e4853c2 686
687/* Exception specifier used for throw(). */
653e5405 688#define empty_except_spec cp_global_trees[CPTI_EMPTY_EXCEPT_SPEC]
1e4853c2 689
c0af329c 690/* If non-NULL, a POINTER_TYPE equivalent to (java::lang::Class*). */
653e5405 691#define jclass_node cp_global_trees[CPTI_JCLASS]
1e4853c2 692
1e4853c2 693/* The declaration for `std::terminate'. */
653e5405 694#define terminate_node cp_global_trees[CPTI_TERMINATE]
1e4853c2 695
df4b504c 696/* The declaration for "__cxa_call_unexpected". */
653e5405 697#define call_unexpected_node cp_global_trees[CPTI_CALL_UNEXPECTED]
df4b504c 698
34382091 699/* The type of the function-pointer argument to "__cxa_atexit" (or
700 "std::atexit", if "__cxa_atexit" is not being used). */
701#define atexit_fn_ptr_type_node cp_global_trees[CPTI_ATEXIT_FN_PTR_TYPE]
702
1da45f21 703/* A pointer to `std::atexit'. */
653e5405 704#define atexit_node cp_global_trees[CPTI_ATEXIT]
b9920b13 705
1da45f21 706/* A pointer to `__dso_handle'. */
653e5405 707#define dso_handle_node cp_global_trees[CPTI_DSO_HANDLE]
1da45f21 708
71792355 709/* The declaration of the dynamic_cast runtime. */
653e5405 710#define dynamic_cast_node cp_global_trees[CPTI_DCAST]
71792355 711
054a0626 712/* The type of a destructor. */
653e5405 713#define cleanup_type cp_global_trees[CPTI_CLEANUP_TYPE]
054a0626 714
0ce25b06 715/* The type of the vtt parameter passed to subobject constructors and
716 destructors. */
653e5405 717#define vtt_parm_type cp_global_trees[CPTI_VTT_PARM_TYPE]
0ce25b06 718
9bacae7e 719/* A TREE_LIST of the dynamic classes whose vtables may have to be
720 emitted in this translation unit. */
6fc7a923 721
653e5405 722#define keyed_classes cp_global_trees[CPTI_KEYED_CLASSES]
6fc7a923 723
95f3173a 724/* Node to indicate default access. This must be distinct from the
725 access nodes in tree.h. */
726
727#define access_default_node null_node
728
1e4853c2 729/* Global state. */
730
1f3233d1 731struct saved_scope GTY(())
0d8a0bb5 732{
046bfc77 733 VEC(cxx_saved_binding,gc) *old_bindings;
1e4853c2 734 tree old_namespace;
0d8a0bb5 735 tree decl_ns_list;
a35129cf 736 tree class_name;
737 tree class_type;
1e4853c2 738 tree access_specifier;
d119628b 739 tree function_decl;
b943ebc0 740 VEC(tree,gc) *lang_base;
1e4853c2 741 tree lang_name;
1e4853c2 742 tree template_parms;
598057ec 743 struct cp_binding_level *x_previous_class_level;
76a24869 744 tree x_saved_tree;
a35129cf 745
855ed7a1 746 int x_processing_template_decl;
1e4853c2 747 int x_processing_specialization;
855ed7a1 748 BOOL_BITFIELD x_processing_explicit_instantiation : 1;
749 BOOL_BITFIELD need_pop_function_context : 1;
750 BOOL_BITFIELD skip_evaluation : 1;
a35129cf 751
a08e60ae 752 struct stmt_tree_s x_stmt_tree;
a35129cf 753
1f3233d1 754 struct cp_binding_level *class_bindings;
755 struct cp_binding_level *bindings;
a35129cf 756
757 struct saved_scope *prev;
1e4853c2 758};
759
760/* The current open namespace. */
761
762#define current_namespace scope_chain->old_namespace
763
c0af329c 764/* The stack for namespaces of current declarations. */
0d8a0bb5 765
766#define decl_namespace_list scope_chain->decl_ns_list
767
1e4853c2 768/* IDENTIFIER_NODE: name of current class */
769
770#define current_class_name scope_chain->class_name
771
772/* _TYPE: the type of the current class */
773
774#define current_class_type scope_chain->class_type
775
776/* When parsing a class definition, the access specifier most recently
777 given by the user, or, if no access specifier was given, the
778 default value appropriate for the kind of class (i.e., struct,
779 class, or union). */
780
781#define current_access_specifier scope_chain->access_specifier
782
783/* Pointer to the top of the language name stack. */
784
1e4853c2 785#define current_lang_base scope_chain->lang_base
786#define current_lang_name scope_chain->lang_name
787
8945cfb0 788/* When parsing a template declaration, a TREE_LIST represents the
1034b0d6 789 active template parameters. Each node in the list represents one
df476b3b 790 level of template parameters. The innermost level is first in the
791 list. The depth of each level is stored as an INTEGER_CST in the
792 TREE_PURPOSE of each node. The parameters for that level are
793 stored in the TREE_VALUE. */
1e4853c2 794
1e4853c2 795#define current_template_parms scope_chain->template_parms
796
797#define processing_template_decl scope_chain->x_processing_template_decl
798#define processing_specialization scope_chain->x_processing_specialization
799#define processing_explicit_instantiation scope_chain->x_processing_explicit_instantiation
800
598057ec 801/* The cached class binding level, from the most recently exited
802 class, or NULL if none. */
1e4853c2 803
598057ec 804#define previous_class_level scope_chain->x_previous_class_level
1e4853c2 805
fd8d6049 806/* A list of private types mentioned, for deferred access checking. */
807
1f3233d1 808extern GTY(()) struct saved_scope *scope_chain;
1e4853c2 809
7db5a284 810struct cxx_int_tree_map GTY(())
811{
812 unsigned int uid;
813 tree to;
814};
815
816extern unsigned int cxx_int_tree_map_hash (const void *);
817extern int cxx_int_tree_map_eq (const void *, const void *);
818
509cd7a7 819/* Global state pertinent to the current function. */
820
1f3233d1 821struct language_function GTY(())
509cd7a7 822{
1f3233d1 823 struct c_language_function base;
a08e60ae 824
853b7640 825 tree x_cdtor_label;
1e463950 826 tree x_current_class_ptr;
827 tree x_current_class_ref;
df4b504c 828 tree x_eh_spec_block;
2d041099 829 tree x_in_charge_parm;
dcbeb3ef 830 tree x_vtt_parm;
80ac742d 831 tree x_return_value;
1e463950 832
855ed7a1 833 BOOL_BITFIELD returns_value : 1;
834 BOOL_BITFIELD returns_null : 1;
835 BOOL_BITFIELD returns_abnormally : 1;
836 BOOL_BITFIELD in_function_try_handler : 1;
837 BOOL_BITFIELD in_base_initializer : 1;
509cd7a7 838
95cedffb 839 /* True if this function can throw an exception. */
2ccf1c3a 840 BOOL_BITFIELD can_throw : 1;
95cedffb 841
8487df40 842 htab_t GTY((param_is(struct named_label_entry))) x_named_labels;
1f3233d1 843 struct cp_binding_level *bindings;
f5b3a903 844 VEC(tree,gc) *x_local_names;
7db5a284 845 htab_t GTY((param_is (struct cxx_int_tree_map))) extern_decl_map;
509cd7a7 846};
847
54c2eeba 848/* The current C++-specific per-function global variables. */
509cd7a7 849
1f3233d1 850#define cp_function_chain (cfun->language)
509cd7a7 851
853b7640 852/* In a constructor destructor, the point at which all derived class
4a44ba29 853 destroying/construction has been has been done. Ie. just before a
854 constructor returns, or before any base class destroying will be done
853b7640 855 in a destructor. */
509cd7a7 856
853b7640 857#define cdtor_label cp_function_chain->x_cdtor_label
509cd7a7 858
509cd7a7 859/* When we're processing a member function, current_class_ptr is the
860 PARM_DECL for the `this' pointer. The current_class_ref is an
861 expression for `*this'. */
862
d119628b 863#define current_class_ptr \
08513b52 864 (cfun ? cp_function_chain->x_current_class_ptr : NULL_TREE)
d119628b 865#define current_class_ref \
08513b52 866 (cfun ? cp_function_chain->x_current_class_ref : NULL_TREE)
509cd7a7 867
df4b504c 868/* The EH_SPEC_BLOCK for the exception-specifiers for the current
2d041099 869 function, if any. */
870
df4b504c 871#define current_eh_spec_block cp_function_chain->x_eh_spec_block
2d041099 872
2d041099 873/* The `__in_chrg' parameter for the current function. Only used for
dcbeb3ef 874 constructors and destructors. */
2d041099 875
876#define current_in_charge_parm cp_function_chain->x_in_charge_parm
877
dcbeb3ef 878/* The `__vtt_parm' parameter for the current function. Only used for
879 constructors and destructors. */
880
881#define current_vtt_parm cp_function_chain->x_vtt_parm
882
509cd7a7 883/* Set to 0 at beginning of a function definition, set to 1 if
884 a return statement that specifies a return value is seen. */
885
886#define current_function_returns_value cp_function_chain->returns_value
887
888/* Set to 0 at beginning of a function definition, set to 1 if
889 a return statement with no argument is seen. */
890
891#define current_function_returns_null cp_function_chain->returns_null
892
69f4b398 893/* Set to 0 at beginning of a function definition, set to 1 if
894 a call to a noreturn function is seen. */
895
896#define current_function_returns_abnormally \
897 cp_function_chain->returns_abnormally
898
f1d555e3 899/* Nonzero if we are processing a base initializer. Zero elsewhere. */
5f1653d2 900#define in_base_initializer cp_function_chain->in_base_initializer
901
509cd7a7 902#define in_function_try_handler cp_function_chain->in_function_try_handler
903
80ac742d 904/* Expression always returned from function, or error_mark_node
905 otherwise, for use by the automatic named return value optimization. */
906
907#define current_function_return_value \
908 (cp_function_chain->x_return_value)
909
7ef14399 910/* True if NAME is the IDENTIFIER_NODE for an overloaded "operator
911 new" or "operator delete". */
912#define NEW_DELETE_OPNAME_P(NAME) \
653e5405 913 ((NAME) == ansi_opname (NEW_EXPR) \
914 || (NAME) == ansi_opname (VEC_NEW_EXPR) \
915 || (NAME) == ansi_opname (DELETE_EXPR) \
7ef14399 916 || (NAME) == ansi_opname (VEC_DELETE_EXPR))
917
97cc4539 918#define ansi_opname(CODE) \
919 (operator_name_info[(int) (CODE)].identifier)
920#define ansi_assopname(CODE) \
921 (assignment_operator_name_info[(int) (CODE)].identifier)
471086d6 922
0a3b29ad 923/* True if NODE is an erroneous expression. */
924
925#define error_operand_p(NODE) \
653e5405 926 ((NODE) == error_mark_node \
0a3b29ad 927 || ((NODE) && TREE_TYPE ((NODE)) == error_mark_node))
471086d6 928\f
929/* C++ language-specific tree codes. */
930#define DEFTREECODE(SYM, NAME, TYPE, LENGTH) SYM,
931enum cplus_tree_code {
51444f0d 932 CP_DUMMY_TREE_CODE = LAST_C_TREE_CODE,
96624a9e 933#include "cp-tree.def"
471086d6 934 LAST_CPLUS_TREE_CODE
935};
936#undef DEFTREECODE
937
820440d6 938/* TRUE if a tree code represents a statement. */
939extern bool statement_code_p[MAX_TREE_CODES];
940
941#define STATEMENT_CODE_P(CODE) statement_code_p[(int) (CODE)]
942
aa71ed0c 943enum languages { lang_c, lang_cplusplus, lang_java };
471086d6 944
945/* Macros to make error reporting functions' lives easier. */
946#define TYPE_IDENTIFIER(NODE) (DECL_NAME (TYPE_NAME (NODE)))
83c4eacf 947#define TYPE_LINKAGE_IDENTIFIER(NODE) \
948 (TYPE_IDENTIFIER (TYPE_MAIN_VARIANT (NODE)))
471086d6 949#define TYPE_NAME_STRING(NODE) (IDENTIFIER_POINTER (TYPE_IDENTIFIER (NODE)))
950#define TYPE_NAME_LENGTH(NODE) (IDENTIFIER_LENGTH (TYPE_IDENTIFIER (NODE)))
951
83c4eacf 952/* Nonzero if NODE has no name for linkage purposes. */
953#define TYPE_ANONYMOUS_P(NODE) \
954 (TAGGED_TYPE_P (NODE) && ANON_AGGRNAME_P (TYPE_LINKAGE_IDENTIFIER (NODE)))
955
d81e00a4 956/* The _DECL for this _TYPE. */
b0df6589 957#define TYPE_MAIN_DECL(NODE) (TYPE_STUB_DECL (TYPE_MAIN_VARIANT (NODE)))
d81e00a4 958
b99379bb 959/* Nonzero if T is a class (or struct or union) type. Also nonzero
fc327dbc 960 for template type parameters, typename types, and instantiated
961 template template parameters. Despite its name,
10d58b2e 962 this macro has nothing to do with the definition of aggregate given
9843a47d 963 in the standard. Think of this macro as MAYBE_CLASS_TYPE_P. Keep
964 these checks in ascending code order. */
f58424d8 965#define IS_AGGR_TYPE(T) \
966 (TREE_CODE (T) == TEMPLATE_TYPE_PARM \
967 || TREE_CODE (T) == TYPENAME_TYPE \
968 || TREE_CODE (T) == TYPEOF_TYPE \
969 || TREE_CODE (T) == BOUND_TEMPLATE_TEMPLATE_PARM \
34da8800 970 || TREE_CODE (T) == DECLTYPE_TYPE \
f58424d8 971 || TYPE_LANG_FLAG_5 (T))
e4e283ec 972
50cd3f45 973/* Set IS_AGGR_TYPE for T to VAL. T must be a class, struct, or
974 union type. */
e4e283ec 975#define SET_IS_AGGR_TYPE(T, VAL) \
976 (TYPE_LANG_FLAG_5 (T) = (VAL))
b99379bb 977
10d58b2e 978/* Nonzero if T is a class type. Zero for template type parameters,
979 typename types, and so forth. */
f58424d8 980#define CLASS_TYPE_P(T) \
9843a47d 981 (IS_AGGR_TYPE_CODE (TREE_CODE (T)) && TYPE_LANG_FLAG_5 (T))
b99379bb 982
481451eb 983/* Nonzero if T is a class type but not an union. */
984#define NON_UNION_CLASS_TYPE_P(T) \
985 (CLASS_TYPE_P (T) && TREE_CODE (T) != UNION_TYPE)
986
9843a47d 987/* Keep these checks in ascending code order. */
988#define IS_AGGR_TYPE_CODE(T) \
989 ((T) == RECORD_TYPE || (T) == UNION_TYPE)
f58424d8 990#define TAGGED_TYPE_P(T) \
991 (CLASS_TYPE_P (T) || TREE_CODE (T) == ENUMERAL_TYPE)
83c4eacf 992#define IS_OVERLOAD_TYPE(T) TAGGED_TYPE_P (T)
471086d6 993
c0af329c 994/* True if this a "Java" type, defined in 'extern "Java"'. */
f58424d8 995#define TYPE_FOR_JAVA(NODE) TYPE_LANG_FLAG_3 (NODE)
6ce4a0c3 996
7f77d1f0 997/* True if this type is dependent. This predicate is only valid if
998 TYPE_DEPENDENT_P_VALID is true. */
999#define TYPE_DEPENDENT_P(NODE) TYPE_LANG_FLAG_0 (NODE)
1000
1001/* True if dependent_type_p has been called for this type, with the
1002 result that TYPE_DEPENDENT_P is valid. */
1003#define TYPE_DEPENDENT_P_VALID(NODE) TYPE_LANG_FLAG_6(NODE)
1004
3e04bd45 1005/* Nonzero if this type is const-qualified. */
1006#define CP_TYPE_CONST_P(NODE) \
3119c950 1007 ((cp_type_quals (NODE) & TYPE_QUAL_CONST) != 0)
3e04bd45 1008
1009/* Nonzero if this type is volatile-qualified. */
1010#define CP_TYPE_VOLATILE_P(NODE) \
3119c950 1011 ((cp_type_quals (NODE) & TYPE_QUAL_VOLATILE) != 0)
3e04bd45 1012
d032c936 1013/* Nonzero if this type is restrict-qualified. */
3e04bd45 1014#define CP_TYPE_RESTRICT_P(NODE) \
3119c950 1015 ((cp_type_quals (NODE) & TYPE_QUAL_RESTRICT) != 0)
3e04bd45 1016
1017/* Nonzero if this type is const-qualified, but not
1018 volatile-qualified. Other qualifiers are ignored. This macro is
1019 used to test whether or not it is OK to bind an rvalue to a
1020 reference. */
1021#define CP_TYPE_CONST_NON_VOLATILE_P(NODE) \
3119c950 1022 ((cp_type_quals (NODE) & (TYPE_QUAL_CONST | TYPE_QUAL_VOLATILE)) \
3e04bd45 1023 == TYPE_QUAL_CONST)
1024
dcbeb3ef 1025#define FUNCTION_ARG_CHAIN(NODE) \
f58424d8 1026 TREE_CHAIN (TYPE_ARG_TYPES (TREE_TYPE (NODE)))
dcbeb3ef 1027
1028/* Given a FUNCTION_DECL, returns the first TREE_LIST out of TYPE_ARG_TYPES
1029 which refers to a user-written parameter. */
1030#define FUNCTION_FIRST_USER_PARMTYPE(NODE) \
f58424d8 1031 skip_artificial_parms_for ((NODE), TYPE_ARG_TYPES (TREE_TYPE (NODE)))
dcbeb3ef 1032
1033/* Similarly, but for DECL_ARGUMENTS. */
1034#define FUNCTION_FIRST_USER_PARM(NODE) \
f58424d8 1035 skip_artificial_parms_for ((NODE), DECL_ARGUMENTS (NODE))
dcbeb3ef 1036
f58424d8 1037#define PROMOTES_TO_AGGR_TYPE(NODE, CODE) \
471086d6 1038 (((CODE) == TREE_CODE (NODE) \
f58424d8 1039 && IS_AGGR_TYPE (TREE_TYPE (NODE))) \
471086d6 1040 || IS_AGGR_TYPE (NODE))
1041
7e6960e0 1042/* Nonzero iff TYPE is derived from PARENT. Ignores accessibility and
1043 ambiguity issues. */
f58424d8 1044#define DERIVED_FROM_P(PARENT, TYPE) \
3b91e7e7 1045 (lookup_base ((TYPE), (PARENT), ba_any, NULL) != NULL_TREE)
7e6960e0 1046/* Nonzero iff TYPE is uniquely derived from PARENT. Ignores
1047 accessibility. */
f58424d8 1048#define UNIQUELY_DERIVED_FROM_P(PARENT, TYPE) \
ada40935 1049 (lookup_base ((TYPE), (PARENT), ba_unique | ba_quiet, NULL) != NULL_TREE)
7e6960e0 1050/* Nonzero iff TYPE is publicly & uniquely derived from PARENT. */
f58424d8 1051#define PUBLICLY_UNIQUELY_DERIVED_P(PARENT, TYPE) \
ada40935 1052 (lookup_base ((TYPE), (PARENT), ba_ignore_scope | ba_check | ba_quiet, \
653e5405 1053 NULL) != NULL_TREE)
b212f378 1054
1055/* Gives the visibility specification for a class type. */
26cbb959 1056#define CLASSTYPE_VISIBILITY(TYPE) \
1057 DECL_VISIBILITY (TYPE_NAME (TYPE))
1058#define CLASSTYPE_VISIBILITY_SPECIFIED(TYPE) \
1059 DECL_VISIBILITY_SPECIFIED (TYPE_NAME (TYPE))
b212f378 1060
26cbb959 1061typedef struct tree_pair_s GTY (())
1062{
1063 tree purpose;
1064 tree value;
1065} tree_pair_s;
1066typedef tree_pair_s *tree_pair_p;
046bfc77 1067DEF_VEC_O (tree_pair_s);
1068DEF_VEC_ALLOC_O (tree_pair_s,gc);
b212f378 1069
1f3233d1 1070/* This is a few header flags for 'struct lang_type'. Actually,
1071 all but the first are used only for lang_type_class; they
1072 are put in this structure to save space. */
891e084d 1073struct lang_type_header GTY(())
1f3233d1 1074{
2ccf1c3a 1075 BOOL_BITFIELD is_lang_type_class : 1;
1076
1077 BOOL_BITFIELD has_type_conversion : 1;
1078 BOOL_BITFIELD has_init_ref : 1;
1079 BOOL_BITFIELD has_default_ctor : 1;
2ccf1c3a 1080 BOOL_BITFIELD const_needs_init : 1;
1081 BOOL_BITFIELD ref_needs_init : 1;
1082 BOOL_BITFIELD has_const_assign_ref : 1;
1f0b839e 1083
1084 BOOL_BITFIELD spare : 1;
1f3233d1 1085};
1086
e4e283ec 1087/* This structure provides additional information above and beyond
1088 what is provide in the ordinary tree_type. In the past, we used it
1089 for the types of class types, template parameters types, typename
1090 types, and so forth. However, there can be many (tens to hundreds
1091 of thousands) of template parameter types in a compilation, and
1092 there's no need for this additional information in that case.
1093 Therefore, we now use this data structure only for class types.
1094
1095 In the past, it was thought that there would be relatively few
1096 class types. However, in the presence of heavy use of templates,
1097 many (i.e., thousands) of classes can easily be generated.
1098 Therefore, we should endeavor to keep the size of this structure to
1099 a minimum. */
1f3233d1 1100struct lang_type_class GTY(())
471086d6 1101{
1f3233d1 1102 struct lang_type_header h;
ac13e8d9 1103
509cd7a7 1104 unsigned char align;
1105
7308eea2 1106 unsigned has_mutable : 1;
1107 unsigned com_interface : 1;
1108 unsigned non_pod_class : 1;
1109 unsigned nearly_empty_p : 1;
b53db2b0 1110 unsigned user_align : 1;
509cd7a7 1111 unsigned has_assign_ref : 1;
89e923d8 1112 unsigned has_new : 1;
1113 unsigned has_array_new : 1;
509cd7a7 1114
1115 unsigned gets_delete : 2;
509cd7a7 1116 unsigned interface_only : 1;
1117 unsigned interface_unknown : 1;
954ad420 1118 unsigned contains_empty_class_p : 1;
8172be22 1119 unsigned anon_aggr : 1;
1120 unsigned non_zero_init : 1;
1121 unsigned empty_p : 1;
509cd7a7 1122
5bc45500 1123 unsigned vec_new_uses_cookie : 1;
509cd7a7 1124 unsigned declared_class : 1;
ee086965 1125 unsigned diamond_shaped : 1;
1126 unsigned repeated_base : 1;
509cd7a7 1127 unsigned being_defined : 1;
3498e8b6 1128 unsigned java_interface : 1;
509cd7a7 1129 unsigned debug_requested : 1;
8172be22 1130 unsigned fields_readonly : 1;
9031d10b 1131
ee086965 1132 unsigned use_template : 2;
509cd7a7 1133 unsigned ptrmemfunc_flag : 1;
1134 unsigned was_anonymous : 1;
1827796b 1135 unsigned lazy_default_ctor : 1;
1136 unsigned lazy_copy_ctor : 1;
2967f654 1137 unsigned lazy_assignment_op : 1;
ed36f1cf 1138 unsigned lazy_destructor : 1;
1139
509cd7a7 1140 unsigned has_const_init_ref : 1;
1141 unsigned has_complex_init_ref : 1;
1142 unsigned has_complex_assign_ref : 1;
509cd7a7 1143 unsigned non_aggregate : 1;
481451eb 1144 unsigned has_complex_dflt : 1;
e63bd8ae 1145
509cd7a7 1146 /* When adding a flag here, consider whether or not it ought to
1147 apply to a template instance if it applies to the template. If
1148 so, make sure to copy it in instantiate_class_template! */
1149
7308eea2 1150 /* There are some bits left to fill out a 32-bit word. Keep track
1151 of this by updating the size of this bitfield whenever you add or
509cd7a7 1152 remove a flag. */
481451eb 1153 unsigned dummy : 11;
50cd3f45 1154
d0ceae4d 1155 tree primary_base;
046bfc77 1156 VEC(tree_pair_s,gc) *vcall_indices;
6fc7a923 1157 tree vtables;
d085a847 1158 tree typeinfo_var;
046bfc77 1159 VEC(tree,gc) *vbases;
af694375 1160 binding_table nested_udts;
23ed74d8 1161 tree as_base;
046bfc77 1162 VEC(tree,gc) *pure_virtuals;
59751e6c 1163 tree friend_classes;
046bfc77 1164 VEC(tree,gc) * GTY((reorder ("resort_type_method_vec"))) methods;
9bacae7e 1165 tree key_method;
7a40f9b7 1166 tree decl_list;
59751e6c 1167 tree template_info;
a731c87f 1168 tree befriending_classes;
2cf10c57 1169 /* In a RECORD_TYPE, information specific to Objective-C++, such
1170 as a list of adopted protocols or a pointer to a corresponding
1171 @interface. See objc/objc-act.h for details. */
1172 tree objc_info;
471086d6 1173};
1174
1f3233d1 1175struct lang_type_ptrmem GTY(())
1176{
1177 struct lang_type_header h;
1178 tree record;
1179};
1180
1181struct lang_type GTY(())
1182{
ac13e8d9 1183 union lang_type_u
1f3233d1 1184 {
873f1e89 1185 struct lang_type_header GTY((skip (""))) h;
1f3233d1 1186 struct lang_type_class GTY((tag ("1"))) c;
1187 struct lang_type_ptrmem GTY((tag ("0"))) ptrmem;
1188 } GTY((desc ("%h.h.is_lang_type_class"))) u;
1189};
1190
1191#if defined ENABLE_TREE_CHECKING && (GCC_VERSION >= 2007)
1192
4fa0b096 1193#define LANG_TYPE_CLASS_CHECK(NODE) __extension__ \
1f3233d1 1194({ struct lang_type *lt = TYPE_LANG_SPECIFIC (NODE); \
1195 if (! lt->u.h.is_lang_type_class) \
1196 lang_check_failed (__FILE__, __LINE__, __FUNCTION__); \
1197 &lt->u.c; })
1198
4fa0b096 1199#define LANG_TYPE_PTRMEM_CHECK(NODE) __extension__ \
1f3233d1 1200({ struct lang_type *lt = TYPE_LANG_SPECIFIC (NODE); \
1201 if (lt->u.h.is_lang_type_class) \
1202 lang_check_failed (__FILE__, __LINE__, __FUNCTION__); \
1203 &lt->u.ptrmem; })
1204
1205#else
1206
1207#define LANG_TYPE_CLASS_CHECK(NODE) (&TYPE_LANG_SPECIFIC (NODE)->u.c)
1208#define LANG_TYPE_PTRMEM_CHECK(NODE) (&TYPE_LANG_SPECIFIC (NODE)->u.ptrmem)
1209
1210#endif /* ENABLE_TREE_CHECKING */
1211
471086d6 1212/* Fields used for storing information before the class is defined.
1213 After the class is defined, these fields hold other information. */
1214
03106e7d 1215/* VEC(tree) of friends which were defined inline in this class
1216 definition. */
f58424d8 1217#define CLASSTYPE_INLINE_FRIENDS(NODE) CLASSTYPE_PURE_VIRTUALS (NODE)
471086d6 1218
89e923d8 1219/* Nonzero for _CLASSTYPE means that operator delete is defined. */
1f3233d1 1220#define TYPE_GETS_DELETE(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->gets_delete)
e581f478 1221#define TYPE_GETS_REG_DELETE(NODE) (TYPE_GETS_DELETE (NODE) & 1)
1222
89e923d8 1223/* Nonzero if `new NODE[x]' should cause the allocation of extra
5bc45500 1224 storage to indicate how many array elements are in use. */
1225#define TYPE_VEC_NEW_USES_COOKIE(NODE) \
1226 (CLASS_TYPE_P (NODE) \
1f3233d1 1227 && LANG_TYPE_CLASS_CHECK (NODE)->vec_new_uses_cookie)
471086d6 1228
471086d6 1229/* Nonzero means that this _CLASSTYPE node defines ways of converting
1230 itself to other types. */
f58424d8 1231#define TYPE_HAS_CONVERSION(NODE) \
1f3233d1 1232 (LANG_TYPE_CLASS_CHECK (NODE)->h.has_type_conversion)
471086d6 1233
1827796b 1234/* Nonzero means that NODE (a class type) has a default constructor --
1235 but that it has not yet been declared. */
1236#define CLASSTYPE_LAZY_DEFAULT_CTOR(NODE) \
1237 (LANG_TYPE_CLASS_CHECK (NODE)->lazy_default_ctor)
1238
1239/* Nonzero means that NODE (a class type) has a copy constructor --
1240 but that it has not yet been declared. */
1241#define CLASSTYPE_LAZY_COPY_CTOR(NODE) \
1242 (LANG_TYPE_CLASS_CHECK (NODE)->lazy_copy_ctor)
1243
2967f654 1244/* Nonzero means that NODE (a class type) has an assignment operator
1245 -- but that it has not yet been declared. */
1246#define CLASSTYPE_LAZY_ASSIGNMENT_OP(NODE) \
1247 (LANG_TYPE_CLASS_CHECK (NODE)->lazy_assignment_op)
1248
ed36f1cf 1249/* Nonzero means that NODE (a class type) has a destructor -- but that
1250 it has not yet been declared. */
1251#define CLASSTYPE_LAZY_DESTRUCTOR(NODE) \
1252 (LANG_TYPE_CLASS_CHECK (NODE)->lazy_destructor)
9031d10b 1253
471086d6 1254/* Nonzero means that this _CLASSTYPE node overloads operator=(X&). */
1f3233d1 1255#define TYPE_HAS_ASSIGN_REF(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->has_assign_ref)
de5ab3f1 1256
1257/* True iff the class type NODE has an "operator =" whose parameter
1258 has a parameter of type "const X&". */
f58424d8 1259#define TYPE_HAS_CONST_ASSIGN_REF(NODE) \
1f3233d1 1260 (LANG_TYPE_CLASS_CHECK (NODE)->h.has_const_assign_ref)
471086d6 1261
1262/* Nonzero means that this _CLASSTYPE node has an X(X&) constructor. */
1f3233d1 1263#define TYPE_HAS_INIT_REF(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->h.has_init_ref)
f58424d8 1264#define TYPE_HAS_CONST_INIT_REF(NODE) \
1f3233d1 1265 (LANG_TYPE_CLASS_CHECK (NODE)->has_const_init_ref)
471086d6 1266
89e923d8 1267/* Nonzero if this class defines an overloaded operator new. (An
1268 operator new [] doesn't count.) */
1269#define TYPE_HAS_NEW_OPERATOR(NODE) \
1f3233d1 1270 (LANG_TYPE_CLASS_CHECK (NODE)->has_new)
89e923d8 1271
1272/* Nonzero if this class defines an overloaded operator new[]. */
1273#define TYPE_HAS_ARRAY_NEW_OPERATOR(NODE) \
1f3233d1 1274 (LANG_TYPE_CLASS_CHECK (NODE)->has_array_new)
89e923d8 1275
471086d6 1276/* Nonzero means that this type is being defined. I.e., the left brace
1277 starting the definition of this type has been seen. */
1f3233d1 1278#define TYPE_BEING_DEFINED(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->being_defined)
471086d6 1279
ee086965 1280/* Mark bits for repeated base checks. */
1281#define TYPE_MARKED_P(NODE) TREE_LANG_FLAG_6 (TYPE_CHECK (NODE))
1282
14b50238 1283/* Nonzero if the class NODE has multiple paths to the same (virtual)
ee086965 1284 base object. */
1285#define CLASSTYPE_DIAMOND_SHAPED_P(NODE) \
1286 (LANG_TYPE_CLASS_CHECK(NODE)->diamond_shaped)
1287
14b50238 1288/* Nonzero if the class NODE has multiple instances of the same base
ee086965 1289 type. */
1290#define CLASSTYPE_REPEATED_BASE_P(NODE) \
1291 (LANG_TYPE_CLASS_CHECK(NODE)->repeated_base)
1292
9bacae7e 1293/* The member function with which the vtable will be emitted:
1294 the first noninline non-pure-virtual member function. NULL_TREE
1295 if there is no key function or if this is a class template */
1296#define CLASSTYPE_KEY_METHOD(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->key_method)
1297
0f2952a1 1298/* Vector member functions defined in this class. Each element is
88e449ea 1299 either a FUNCTION_DECL, a TEMPLATE_DECL, or an OVERLOAD. All
1300 functions with the same name end up in the same slot. The first
0f2952a1 1301 two elements are for constructors, and destructors, respectively.
c0af458b 1302 All template conversion operators to innermost template dependent
1303 types are overloaded on the next slot, if they exist. Note, the
1304 names for these functions will not all be the same. The
1305 non-template conversion operators & templated conversions to
1306 non-innermost template types are next, followed by ordinary member
1307 functions. There may be empty entries at the end of the vector.
1308 The conversion operators are unsorted. The ordinary member
1309 functions are sorted, once the class is complete. */
1f3233d1 1310#define CLASSTYPE_METHOD_VEC(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->methods)
471086d6 1311
7a40f9b7 1312/* For class templates, this is a TREE_LIST of all member data,
1313 functions, types, and friends in the order of declaration.
1314 The TREE_PURPOSE of each TREE_LIST is NULL_TREE for a friend,
1315 and the RECORD_TYPE for the class template otherwise. */
1316#define CLASSTYPE_DECL_LIST(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->decl_list)
1317
e55cba4c 1318/* The slot in the CLASSTYPE_METHOD_VEC where constructors go. */
1319#define CLASSTYPE_CONSTRUCTOR_SLOT 0
1320
1321/* The slot in the CLASSTYPE_METHOD_VEC where destructors go. */
1322#define CLASSTYPE_DESTRUCTOR_SLOT 1
1323
1324/* The first slot in the CLASSTYPE_METHOD_VEC where conversion
1325 operators can appear. */
1326#define CLASSTYPE_FIRST_CONVERSION_SLOT 2
1327
1328/* A FUNCTION_DECL or OVERLOAD for the constructors for NODE. These
1329 are the constructors that take an in-charge parameter. */
1330#define CLASSTYPE_CONSTRUCTORS(NODE) \
de5ab3f1 1331 (VEC_index (tree, CLASSTYPE_METHOD_VEC (NODE), CLASSTYPE_CONSTRUCTOR_SLOT))
e55cba4c 1332
b429d3ee 1333/* A FUNCTION_DECL for the destructor for NODE. These are the
ed36f1cf 1334 destructors that take an in-charge parameter. If
1335 CLASSTYPE_LAZY_DESTRUCTOR is true, then this entry will be NULL
1336 until the destructor is created with lazily_declare_fn. */
e55cba4c 1337#define CLASSTYPE_DESTRUCTORS(NODE) \
ed36f1cf 1338 (CLASSTYPE_METHOD_VEC (NODE) \
1339 ? VEC_index (tree, CLASSTYPE_METHOD_VEC (NODE), CLASSTYPE_DESTRUCTOR_SLOT) \
1340 : NULL_TREE)
bcf789d7 1341
af694375 1342/* A dictionary of the nested user-defined-types (class-types, or enums)
1343 found within this class. This table includes nested member class
1344 templates. */
1345#define CLASSTYPE_NESTED_UTDS(NODE) \
1346 (LANG_TYPE_CLASS_CHECK (NODE)->nested_udts)
471086d6 1347
4446df62 1348/* Nonzero if NODE has a primary base class, i.e., a base class with
9594b69d 1349 which it shares the virtual function table pointer. */
4446df62 1350#define CLASSTYPE_HAS_PRIMARY_BASE_P(NODE) \
d0ceae4d 1351 (CLASSTYPE_PRIMARY_BINFO (NODE) != NULL_TREE)
4446df62 1352
1353/* If non-NULL, this is the binfo for the primary base class, i.e.,
1354 the base class which contains the virtual function table pointer
1355 for this class. */
fc475736 1356#define CLASSTYPE_PRIMARY_BINFO(NODE) \
1f3233d1 1357 (LANG_TYPE_CLASS_CHECK (NODE)->primary_base)
4446df62 1358
97c118b9 1359/* A vector of BINFOs for the direct and indirect virtual base classes
59751e6c 1360 that this type uses in a post-order depth-first left-to-right
1361 order. (In other words, these bases appear in the order that they
95f3173a 1362 should be initialized.) */
1f3233d1 1363#define CLASSTYPE_VBASECLASSES(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->vbases)
e1efd682 1364
23ed74d8 1365/* The type corresponding to NODE when NODE is used as a base class,
1366 i.e., NODE without virtual base classes. */
1367
1368#define CLASSTYPE_AS_BASE(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->as_base)
1369
da7e5851 1370/* True iff NODE is the CLASSTYPE_AS_BASE version of some type. */
1371
1372#define IS_FAKE_BASE_TYPE(NODE) \
1373 (TREE_CODE (NODE) == RECORD_TYPE \
1374 && TYPE_CONTEXT (NODE) && CLASS_TYPE_P (TYPE_CONTEXT (NODE)) \
1375 && CLASSTYPE_AS_BASE (TYPE_CONTEXT (NODE)) == (NODE))
1376
d1e7f37a 1377/* These are the size and alignment of the type without its virtual
1378 base classes, for when we use this type as a base itself. */
23ed74d8 1379#define CLASSTYPE_SIZE(NODE) TYPE_SIZE (CLASSTYPE_AS_BASE (NODE))
1380#define CLASSTYPE_SIZE_UNIT(NODE) TYPE_SIZE_UNIT (CLASSTYPE_AS_BASE (NODE))
1381#define CLASSTYPE_ALIGN(NODE) TYPE_ALIGN (CLASSTYPE_AS_BASE (NODE))
1382#define CLASSTYPE_USER_ALIGN(NODE) TYPE_USER_ALIGN (CLASSTYPE_AS_BASE (NODE))
471086d6 1383
5e4e7e1f 1384/* The alignment of NODE, without its virtual bases, in bytes. */
1385#define CLASSTYPE_ALIGN_UNIT(NODE) \
1386 (CLASSTYPE_ALIGN (NODE) / BITS_PER_UNIT)
1387
ac13e8d9 1388/* True if this a Java interface type, declared with
c0af329c 1389 '__attribute__ ((java_interface))'. */
03106e7d 1390#define TYPE_JAVA_INTERFACE(NODE) \
1391 (LANG_TYPE_CLASS_CHECK (NODE)->java_interface)
15672c96 1392
03106e7d 1393/* A VEC(tree) of virtual functions which cannot be inherited by
471086d6 1394 derived classes. When deriving from this type, the derived
1395 class must provide its own definition for each of these functions. */
03106e7d 1396#define CLASSTYPE_PURE_VIRTUALS(NODE) \
1397 (LANG_TYPE_CLASS_CHECK (NODE)->pure_virtuals)
471086d6 1398
471086d6 1399/* Nonzero means that this type has an X() constructor. */
f58424d8 1400#define TYPE_HAS_DEFAULT_CONSTRUCTOR(NODE) \
1f3233d1 1401 (LANG_TYPE_CLASS_CHECK (NODE)->h.has_default_ctor)
471086d6 1402
331bc0ad 1403/* Nonzero means that this type contains a mutable member. */
1f3233d1 1404#define CLASSTYPE_HAS_MUTABLE(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->has_mutable)
6f9b1420 1405#define TYPE_HAS_MUTABLE_P(NODE) (cp_has_mutable_p (NODE))
1406
e63bd8ae 1407/* Nonzero means that this class type is a non-POD class. */
1f3233d1 1408#define CLASSTYPE_NON_POD_P(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->non_pod_class)
e36e96ee 1409
e63bd8ae 1410/* Nonzero means that this class contains pod types whose default
1411 initialization is not a zero initialization (namely, pointers to
1412 data members). */
1f3233d1 1413#define CLASSTYPE_NON_ZERO_INIT_P(NODE) \
1414 (LANG_TYPE_CLASS_CHECK (NODE)->non_zero_init)
e63bd8ae 1415
14786872 1416/* Nonzero if this class is "empty" in the sense of the C++ ABI. */
1417#define CLASSTYPE_EMPTY_P(NODE) \
1418 (LANG_TYPE_CLASS_CHECK (NODE)->empty_p)
1419
e6863ea0 1420/* Nonzero if this class is "nearly empty", i.e., contains only a
1421 virtual function table pointer. */
1422#define CLASSTYPE_NEARLY_EMPTY_P(NODE) \
1f3233d1 1423 (LANG_TYPE_CLASS_CHECK (NODE)->nearly_empty_p)
e6863ea0 1424
5671723d 1425/* Nonzero if this class contains an empty subobject. */
1426#define CLASSTYPE_CONTAINS_EMPTY_CLASS_P(NODE) \
1427 (LANG_TYPE_CLASS_CHECK (NODE)->contains_empty_class_p)
1428
a731c87f 1429/* A list of class types of which this type is a friend. The
52c6de7b 1430 TREE_VALUE is normally a TYPE, but will be a TEMPLATE_DECL in the
1431 case of a template friend. */
f58424d8 1432#define CLASSTYPE_FRIEND_CLASSES(NODE) \
1f3233d1 1433 (LANG_TYPE_CLASS_CHECK (NODE)->friend_classes)
471086d6 1434
a731c87f 1435/* A list of the classes which grant friendship to this class. */
1436#define CLASSTYPE_BEFRIENDING_CLASSES(NODE) \
1f3233d1 1437 (LANG_TYPE_CLASS_CHECK (NODE)->befriending_classes)
a731c87f 1438
471086d6 1439/* Say whether this node was declared as a "class" or a "struct". */
f58424d8 1440#define CLASSTYPE_DECLARED_CLASS(NODE) \
1f3233d1 1441 (LANG_TYPE_CLASS_CHECK (NODE)->declared_class)
471086d6 1442
b7151a8b 1443/* Nonzero if this class has const members
1444 which have no specified initialization. */
1445#define CLASSTYPE_READONLY_FIELDS_NEED_INIT(NODE) \
1446 (TYPE_LANG_SPECIFIC (NODE) \
1447 ? LANG_TYPE_CLASS_CHECK (NODE)->h.const_needs_init : 0)
1448#define SET_CLASSTYPE_READONLY_FIELDS_NEED_INIT(NODE, VALUE) \
1449 (LANG_TYPE_CLASS_CHECK (NODE)->h.const_needs_init = (VALUE))
1450
1451/* Nonzero if this class has ref members
1452 which have no specified initialization. */
1453#define CLASSTYPE_REF_FIELDS_NEED_INIT(NODE) \
1454 (TYPE_LANG_SPECIFIC (NODE) \
1455 ? LANG_TYPE_CLASS_CHECK (NODE)->h.ref_needs_init : 0)
1456#define SET_CLASSTYPE_REF_FIELDS_NEED_INIT(NODE, VALUE) \
1457 (LANG_TYPE_CLASS_CHECK (NODE)->h.ref_needs_init = (VALUE))
471086d6 1458
1459/* Nonzero if this class is included from a header file which employs
1460 `#pragma interface', and it is not included in its implementation file. */
f58424d8 1461#define CLASSTYPE_INTERFACE_ONLY(NODE) \
1f3233d1 1462 (LANG_TYPE_CLASS_CHECK (NODE)->interface_only)
471086d6 1463
20e29201 1464/* True if we have already determined whether or not vtables, VTTs,
1465 typeinfo, and other similar per-class data should be emitted in
1466 this translation unit. This flag does not indicate whether or not
1467 these items should be emitted; it only indicates that we know one
1468 way or the other. */
1469#define CLASSTYPE_INTERFACE_KNOWN(NODE) \
1f3233d1 1470 (LANG_TYPE_CLASS_CHECK (NODE)->interface_unknown == 0)
f5f73833 1471/* The opposite of CLASSTYPE_INTERFACE_KNOWN. */
20e29201 1472#define CLASSTYPE_INTERFACE_UNKNOWN(NODE) \
1f3233d1 1473 (LANG_TYPE_CLASS_CHECK (NODE)->interface_unknown)
20e29201 1474
1475#define SET_CLASSTYPE_INTERFACE_UNKNOWN_X(NODE,X) \
1f3233d1 1476 (LANG_TYPE_CLASS_CHECK (NODE)->interface_unknown = !!(X))
20e29201 1477#define SET_CLASSTYPE_INTERFACE_UNKNOWN(NODE) \
1f3233d1 1478 (LANG_TYPE_CLASS_CHECK (NODE)->interface_unknown = 1)
20e29201 1479#define SET_CLASSTYPE_INTERFACE_KNOWN(NODE) \
1f3233d1 1480 (LANG_TYPE_CLASS_CHECK (NODE)->interface_unknown = 0)
471086d6 1481
1482/* Nonzero if a _DECL node requires us to output debug info for this class. */
f58424d8 1483#define CLASSTYPE_DEBUG_REQUESTED(NODE) \
1f3233d1 1484 (LANG_TYPE_CLASS_CHECK (NODE)->debug_requested)
471086d6 1485\f
1486/* Additional macros for inheritance information. */
1487
471086d6 1488/* Nonzero means that this class is on a path leading to a new vtable. */
57c28194 1489#define BINFO_VTABLE_PATH_MARKED(NODE) BINFO_FLAG_1 (NODE)
95f3173a 1490
1491/* Nonzero means B (a BINFO) has its own vtable. Any copies will not
6beb3f76 1492 have this flag set. */
57c28194 1493#define BINFO_NEW_VTABLE_MARKED(B) (BINFO_FLAG_2 (B))
bd5edd91 1494
5e8d5ca1 1495/* Compare a BINFO_TYPE with another type for equality. For a binfo,
1496 this is functionally equivalent to using same_type_p, but
1497 measurably faster. At least one of the arguments must be a
1498 BINFO_TYPE. The other can be a BINFO_TYPE or a regular type. If
1499 BINFO_TYPE(T) ever stops being the main variant of the class the
1500 binfo is for, this macro must change. */
1501#define SAME_BINFO_TYPE_P(A, B) ((A) == (B))
1502
bd5edd91 1503/* Any subobject that needs a new vtable must have a vptr and must not
f235209b 1504 be a non-virtual primary base (since it would then use the vtable from a
1505 derived class and never become non-primary.) */
95f3173a 1506#define SET_BINFO_NEW_VTABLE_MARKED(B) \
1507 (BINFO_NEW_VTABLE_MARKED (B) = 1, \
1d8fc210 1508 gcc_assert (!BINFO_PRIMARY_P (B) || BINFO_VIRTUAL_P (B)), \
1509 gcc_assert (TYPE_VFIELD (BINFO_TYPE (B))))
471086d6 1510
95f3173a 1511/* Nonzero if this binfo is for a dependent base - one that should not
1512 be searched. */
57c28194 1513#define BINFO_DEPENDENT_BASE_P(NODE) BINFO_FLAG_3 (NODE)
95f3173a 1514
f235209b 1515/* Nonzero if this binfo has lost its primary base binfo (because that
1516 is a nearly-empty virtual base that has been taken by some other
4109ca29 1517 base in the complete hierarchy. */
57c28194 1518#define BINFO_LOST_PRIMARY_P(NODE) BINFO_FLAG_4 (NODE)
04a332ef 1519
eea75c62 1520/* Nonzero if this BINFO is a primary base class. */
1521#define BINFO_PRIMARY_P(NODE) BINFO_FLAG_5(NODE)
d0ceae4d 1522
d1aae31c 1523/* Used by various search routines. */
1524#define IDENTIFIER_MARKED(NODE) TREE_LANG_FLAG_0 (NODE)
471086d6 1525\f
26cbb959 1526/* A VEC(tree_pair_s) of the vcall indices associated with the class
1527 NODE. The PURPOSE of each element is a FUNCTION_DECL for a virtual
1528 function. The VALUE is the index into the virtual table where the
1529 vcall offset for that function is stored, when NODE is a virtual
1530 base. */
6fc7a923 1531#define CLASSTYPE_VCALL_INDICES(NODE) \
1532 (LANG_TYPE_CLASS_CHECK (NODE)->vcall_indices)
1533
1534/* The various vtables for the class NODE. The primary vtable will be
1535 first, followed by the construction vtables and VTT, if any. */
1536#define CLASSTYPE_VTABLES(NODE) \
1537 (LANG_TYPE_CLASS_CHECK (NODE)->vtables)
1538
d085a847 1539/* The std::type_info variable representing this class, or NULL if no
1540 such variable has been created. This field is only set for the
1541 TYPE_MAIN_VARIANT of the class. */
1542#define CLASSTYPE_TYPEINFO_VAR(NODE) \
1543 (LANG_TYPE_CLASS_CHECK (NODE)->typeinfo_var)
1544
c0af329c 1545/* Accessor macros for the BINFO_VIRTUALS list. */
7b4abb45 1546
1547/* The number of bytes by which to adjust the `this' pointer when
fcc15fc5 1548 calling this virtual function. Subtract this value from the this
c0af329c 1549 pointer. Always non-NULL, might be constant zero though. */
fc475736 1550#define BV_DELTA(NODE) (TREE_PURPOSE (NODE))
7b4abb45 1551
1552/* If non-NULL, the vtable index at which to find the vcall offset
fcc15fc5 1553 when calling this virtual function. Add the value at that vtable
1554 index to the this pointer. */
fc475736 1555#define BV_VCALL_INDEX(NODE) (TREE_TYPE (NODE))
7b4abb45 1556
1557/* The function to call. */
fc475736 1558#define BV_FN(NODE) (TREE_VALUE (NODE))
1559
471086d6 1560\f
471086d6 1561/* For FUNCTION_TYPE or METHOD_TYPE, a list of the exceptions that
aa595b3c 1562 this type can raise. Each TREE_VALUE is a _TYPE. The TREE_VALUE
46e5e818 1563 will be NULL_TREE to indicate a throw specification of `()', or
1564 no exceptions allowed. */
3cb98335 1565#define TYPE_RAISES_EXCEPTIONS(NODE) TYPE_LANG_SLOT_1 (NODE)
d0622bdf 1566
b7d68727 1567/* For FUNCTION_TYPE or METHOD_TYPE, return 1 iff it is declared `throw()'. */
1568#define TYPE_NOTHROW_P(NODE) \
1569 (TYPE_RAISES_EXCEPTIONS (NODE) \
1570 && TREE_VALUE (TYPE_RAISES_EXCEPTIONS (NODE)) == NULL_TREE)
1571
96624a9e 1572/* The binding level associated with the namespace. */
7af67ee8 1573#define NAMESPACE_LEVEL(NODE) \
f58424d8 1574 (DECL_LANG_SPECIFIC (NODE)->decl_flags.u.level)
471086d6 1575\f
a731c87f 1576
1577/* If a DECL has DECL_LANG_SPECIFIC, it is either a lang_decl_flags or
c6138f2d 1578 a lang_decl (which has lang_decl_flags as its initial prefix).
1579 This macro is nonzero for tree nodes whose DECL_LANG_SPECIFIC is
9843a47d 1580 the full lang_decl, and not just lang_decl_flags. Keep these
1581 checks in ascending code order. */
1582#define CAN_HAVE_FULL_LANG_DECL_P(NODE) \
1583 (!(TREE_CODE (NODE) == FIELD_DECL \
1584 || TREE_CODE (NODE) == VAR_DECL \
1585 || TREE_CODE (NODE) == CONST_DECL \
f58424d8 1586 || TREE_CODE (NODE) == USING_DECL))
a731c87f 1587
1f3233d1 1588struct lang_decl_flags GTY(())
471086d6 1589{
caa6fdce 1590 ENUM_BITFIELD(languages) language : 4;
1591 unsigned global_ctor_p : 1;
1592 unsigned global_dtor_p : 1;
1593 unsigned anticipated_p : 1;
1594 unsigned template_conv_p : 1;
471086d6 1595
1596 unsigned operator_attr : 1;
1597 unsigned constructor_attr : 1;
7ac05dd7 1598 unsigned destructor_attr : 1;
471086d6 1599 unsigned friend_attr : 1;
1600 unsigned static_function : 1;
a98fd0a1 1601 unsigned pure_virtual : 1;
a23287c6 1602 unsigned has_in_charge_parm_p : 1;
8f80e66d 1603 unsigned has_vtt_parm_p : 1;
a1b0969c 1604
bfb69cfe 1605 unsigned deferred : 1;
ddb9bca7 1606 unsigned use_template : 2;
c25194fd 1607 unsigned nonconverting : 1;
bb09dca5 1608 unsigned not_really_extern : 1;
c792eccc 1609 unsigned initialized_in_class : 1;
1f3233d1 1610 unsigned assignment_operator_p : 1;
1f3233d1 1611 unsigned u1sel : 1;
9031d10b 1612
1f3233d1 1613 unsigned u2sel : 1;
1614 unsigned can_be_full : 1;
d409f4c9 1615 unsigned thunk_p : 1;
805e22b2 1616 unsigned this_thunk_p : 1;
caa6fdce 1617 unsigned repo_available_p : 1;
c1d4295f 1618 unsigned hidden_friend_p : 1;
8487df40 1619 unsigned threadprivate_p : 1;
1620 /* One unused bit. */
471086d6 1621
1f3233d1 1622 union lang_decl_u {
2ca392fd 1623 /* In a FUNCTION_DECL for which DECL_THUNK_P holds, this is
1624 THUNK_ALIAS.
1625 In a FUNCTION_DECL for which DECL_THUNK_P does not hold,
6709b660 1626 VAR_DECL, TYPE_DECL, or TEMPLATE_DECL, this is
1627 DECL_TEMPLATE_INFO. */
1f3233d1 1628 tree GTY ((tag ("0"))) template_info;
7af67ee8 1629
1630 /* In a NAMESPACE_DECL, this is NAMESPACE_LEVEL. */
1f3233d1 1631 struct cp_binding_level * GTY ((tag ("1"))) level;
1632 } GTY ((desc ("%1.u1sel"))) u;
a56359e2 1633
1f3233d1 1634 union lang_decl_u2 {
2ca392fd 1635 /* In a FUNCTION_DECL for which DECL_THUNK_P holds, this is
1636 THUNK_VIRTUAL_OFFSET.
1637 Otherwise this is DECL_ACCESS. */
1f3233d1 1638 tree GTY ((tag ("0"))) access;
a56359e2 1639
e6393a02 1640 /* For VAR_DECL in function, this is DECL_DISCRIMINATOR. */
573aba85 1641 int GTY ((tag ("1"))) discriminator;
1f3233d1 1642 } GTY ((desc ("%1.u2sel"))) u2;
471086d6 1643};
1644
573aba85 1645/* sorted_fields is sorted based on a pointer, so we need to be able
1646 to resort it if pointers get rearranged. */
1647
1f3233d1 1648struct lang_decl GTY(())
471086d6 1649{
1650 struct lang_decl_flags decl_flags;
1651
1f3233d1 1652 union lang_decl_u4
1653 {
ac13e8d9 1654 struct full_lang_decl
1f3233d1 1655 {
d8a6108c 1656 /* In an overloaded operator, this is the value of
1657 DECL_OVERLOADED_OPERATOR_P. */
1658 ENUM_BITFIELD (tree_code) operator_code : 8;
1659
1660 unsigned u3sel : 1;
1661 unsigned pending_inline_p : 1;
d409f4c9 1662 unsigned spare : 22;
9031d10b 1663
71b1859a 1664 /* For a non-thunk function decl, this is a tree list of
653e5405 1665 friendly classes. For a thunk function decl, it is the
1666 thunked to function decl. */
1f3233d1 1667 tree befriending_classes;
ac13e8d9 1668
c83788c9 1669 /* For a non-virtual FUNCTION_DECL, this is
1670 DECL_FRIEND_CONTEXT. For a virtual FUNCTION_DECL for which
805e22b2 1671 DECL_THIS_THUNK_P does not hold, this is DECL_THUNKS. Both
1672 this pointer and result pointer adjusting thunks are
1673 chained here. This pointer thunks to return pointer thunks
6beb3f76 1674 will be chained on the return pointer thunk. */
1f3233d1 1675 tree context;
641985fa 1676
d409f4c9 1677 union lang_decl_u5
1678 {
1679 /* In a non-thunk FUNCTION_DECL or TEMPLATE_DECL, this is
1680 DECL_CLONED_FUNCTION. */
1681 tree GTY ((tag ("0"))) cloned_function;
9031d10b 1682
d409f4c9 1683 /* In a FUNCTION_DECL for which THUNK_P holds this is the
1684 THUNK_FIXED_OFFSET. */
1685 HOST_WIDE_INT GTY ((tag ("1"))) fixed_offset;
1686 } GTY ((desc ("%0.decl_flags.thunk_p"))) u5;
9031d10b 1687
1f3233d1 1688 union lang_decl_u3
1689 {
ac13e8d9 1690 struct sorted_fields_type * GTY ((tag ("0"), reorder ("resort_sorted_fields")))
573aba85 1691 sorted_fields;
653e5405 1692 struct cp_token_cache * GTY ((tag ("2"))) pending_inline_info;
ac13e8d9 1693 struct language_function * GTY ((tag ("1")))
1f3233d1 1694 saved_language_function;
1695 } GTY ((desc ("%1.u3sel + %1.pending_inline_p"))) u;
1696 } GTY ((tag ("1"))) f;
1697 } GTY ((desc ("%1.decl_flags.can_be_full"))) u;
1698};
70a658bd 1699
1f3233d1 1700#if defined ENABLE_TREE_CHECKING && (GCC_VERSION >= 2007)
70a658bd 1701
4fa0b096 1702#define LANG_DECL_U2_CHECK(NODE, TF) __extension__ \
1f3233d1 1703({ struct lang_decl *lt = DECL_LANG_SPECIFIC (NODE); \
1704 if (lt->decl_flags.u2sel != TF) \
1705 lang_check_failed (__FILE__, __LINE__, __FUNCTION__); \
1706 &lt->decl_flags.u2; })
e55cba4c 1707
1f3233d1 1708#else
1709
1710#define LANG_DECL_U2_CHECK(NODE, TF) \
1711 (&DECL_LANG_SPECIFIC (NODE)->decl_flags.u2)
1712
1713#endif /* ENABLE_TREE_CHECKING */
471086d6 1714
4b1984f5 1715/* For a FUNCTION_DECL or a VAR_DECL, the language linkage for the
1716 declaration. Some entities (like a member function in a local
1717 class, or a local variable) do not have linkage at all, and this
1718 macro should not be used in those cases.
ac13e8d9 1719
4b1984f5 1720 Implementation note: A FUNCTION_DECL without DECL_LANG_SPECIFIC was
1721 created by language-independent code, and has C linkage. Most
1722 VAR_DECLs have C++ linkage, and do not have DECL_LANG_SPECIFIC, but
1723 we do create DECL_LANG_SPECIFIC for variables with non-C++ linkage. */
653e5405 1724#define DECL_LANGUAGE(NODE) \
1725 (DECL_LANG_SPECIFIC (NODE) \
f58424d8 1726 ? DECL_LANG_SPECIFIC (NODE)->decl_flags.language \
4b1984f5 1727 : (TREE_CODE (NODE) == FUNCTION_DECL \
1728 ? lang_c : lang_cplusplus))
1729
1730/* Set the language linkage for NODE to LANGUAGE. */
1731#define SET_DECL_LANGUAGE(NODE, LANGUAGE) \
f58424d8 1732 (DECL_LANG_SPECIFIC (NODE)->decl_flags.language = (LANGUAGE))
471086d6 1733
1734/* For FUNCTION_DECLs: nonzero means that this function is a constructor. */
f58424d8 1735#define DECL_CONSTRUCTOR_P(NODE) \
1736 (DECL_LANG_SPECIFIC (NODE)->decl_flags.constructor_attr)
ff0e1638 1737
e55cba4c 1738/* Nonzero if NODE (a FUNCTION_DECL) is a constructor for a complete
1739 object. */
1740#define DECL_COMPLETE_CONSTRUCTOR_P(NODE) \
50cd3f45 1741 (DECL_CONSTRUCTOR_P (NODE) \
e55cba4c 1742 && DECL_NAME (NODE) == complete_ctor_identifier)
1743
1744/* Nonzero if NODE (a FUNCTION_DECL) is a constructor for a base
1745 object. */
1746#define DECL_BASE_CONSTRUCTOR_P(NODE) \
1747 (DECL_CONSTRUCTOR_P (NODE) \
1748 && DECL_NAME (NODE) == base_ctor_identifier)
1749
1750/* Nonzero if NODE (a FUNCTION_DECL) is a constructor, but not either the
1751 specialized in-charge constructor or the specialized not-in-charge
1752 constructor. */
1753#define DECL_MAYBE_IN_CHARGE_CONSTRUCTOR_P(NODE) \
1754 (DECL_CONSTRUCTOR_P (NODE) && !DECL_CLONED_FUNCTION_P (NODE))
1755
a23287c6 1756/* Nonzero if NODE (a FUNCTION_DECL) is a copy constructor. */
1757#define DECL_COPY_CONSTRUCTOR_P(NODE) \
01779b5f 1758 (DECL_CONSTRUCTOR_P (NODE) && copy_fn_p (NODE) > 0)
a23287c6 1759
63949b38 1760/* Nonzero if NODE (a FUNCTION_DECL) is a move constructor. */
1761#define DECL_MOVE_CONSTRUCTOR_P(NODE) \
1762 (DECL_CONSTRUCTOR_P (NODE) && move_fn_p (NODE))
1763
98eaf693 1764/* Nonzero if NODE is a destructor. */
ff0e1638 1765#define DECL_DESTRUCTOR_P(NODE) \
7ac05dd7 1766 (DECL_LANG_SPECIFIC (NODE)->decl_flags.destructor_attr)
ff0e1638 1767
e55cba4c 1768/* Nonzero if NODE (a FUNCTION_DECL) is a destructor, but not the
1769 specialized in-charge constructor, in-charge deleting constructor,
dfea972c 1770 or the base destructor. */
e55cba4c 1771#define DECL_MAYBE_IN_CHARGE_DESTRUCTOR_P(NODE) \
1772 (DECL_DESTRUCTOR_P (NODE) && !DECL_CLONED_FUNCTION_P (NODE))
1773
f04596da 1774/* Nonzero if NODE (a FUNCTION_DECL) is a destructor for a complete
1775 object. */
1776#define DECL_COMPLETE_DESTRUCTOR_P(NODE) \
50cd3f45 1777 (DECL_DESTRUCTOR_P (NODE) \
f04596da 1778 && DECL_NAME (NODE) == complete_dtor_identifier)
1779
1780/* Nonzero if NODE (a FUNCTION_DECL) is a destructor for a base
1781 object. */
1782#define DECL_BASE_DESTRUCTOR_P(NODE) \
1783 (DECL_DESTRUCTOR_P (NODE) \
1784 && DECL_NAME (NODE) == base_dtor_identifier)
1785
1786/* Nonzero if NODE (a FUNCTION_DECL) is a destructor for a complete
6d0f8076 1787 object that deletes the object after it has been destroyed. */
f04596da 1788#define DECL_DELETING_DESTRUCTOR_P(NODE) \
50cd3f45 1789 (DECL_DESTRUCTOR_P (NODE) \
f04596da 1790 && DECL_NAME (NODE) == deleting_dtor_identifier)
1791
e55cba4c 1792/* Nonzero if NODE (a FUNCTION_DECL) is a cloned constructor or
1793 destructor. */
d409f4c9 1794#define DECL_CLONED_FUNCTION_P(NODE) \
1795 ((TREE_CODE (NODE) == FUNCTION_DECL \
1796 || TREE_CODE (NODE) == TEMPLATE_DECL) \
1797 && DECL_LANG_SPECIFIC (NODE) \
1798 && !DECL_LANG_SPECIFIC (NODE)->decl_flags.thunk_p \
aa6b4383 1799 && DECL_CLONED_FUNCTION (NODE) != NULL_TREE)
e55cba4c 1800
1801/* If DECL_CLONED_FUNCTION_P holds, this is the function that was
1802 cloned. */
1803#define DECL_CLONED_FUNCTION(NODE) \
d409f4c9 1804 (DECL_LANG_SPECIFIC (NON_THUNK_FUNCTION_CHECK(NODE))->u.f.u5.cloned_function)
e55cba4c 1805
caa6fdce 1806/* Perform an action for each clone of FN, if FN is a function with
1807 clones. This macro should be used like:
ac13e8d9 1808
caa6fdce 1809 FOR_EACH_CLONE (clone, fn)
653e5405 1810 { ... }
caa6fdce 1811
1812 */
1813#define FOR_EACH_CLONE(CLONE, FN) \
1814 if (TREE_CODE (FN) == FUNCTION_DECL \
1815 && (DECL_MAYBE_IN_CHARGE_CONSTRUCTOR_P (FN) \
1816 || DECL_MAYBE_IN_CHARGE_DESTRUCTOR_P (FN))) \
1817 for (CLONE = TREE_CHAIN (FN); \
1818 CLONE && DECL_CLONED_FUNCTION_P (CLONE); \
1819 CLONE = TREE_CHAIN (CLONE))
1820
e6393a02 1821/* Nonzero if NODE has DECL_DISCRIMINATOR and not DECL_ACCESS. */
1822#define DECL_DISCRIMINATOR_P(NODE) \
1823 (TREE_CODE (NODE) == VAR_DECL \
1824 && DECL_FUNCTION_SCOPE_P (NODE))
1825
1826/* Discriminator for name mangling. */
1f3233d1 1827#define DECL_DISCRIMINATOR(NODE) (LANG_DECL_U2_CHECK (NODE, 1)->discriminator)
e6393a02 1828
3160db1d 1829/* Nonzero if the VTT parm has been added to NODE. */
dcbeb3ef 1830#define DECL_HAS_VTT_PARM_P(NODE) \
1831 (DECL_LANG_SPECIFIC (NODE)->decl_flags.has_vtt_parm_p)
0ce25b06 1832
3160db1d 1833/* Nonzero if NODE is a FUNCTION_DECL for which a VTT parameter is
0ce25b06 1834 required. */
1835#define DECL_NEEDS_VTT_PARM_P(NODE) \
1f0b839e 1836 (CLASSTYPE_VBASECLASSES (DECL_CONTEXT (NODE)) \
0ce25b06 1837 && (DECL_BASE_CONSTRUCTOR_P (NODE) \
1838 || DECL_BASE_DESTRUCTOR_P (NODE)))
1839
3160db1d 1840/* Nonzero if NODE is a user-defined conversion operator. */
f0edcca6 1841#define DECL_CONV_FN_P(NODE) \
4ec630ad 1842 (DECL_NAME (NODE) && IDENTIFIER_TYPENAME_P (DECL_NAME (NODE)))
e46cb663 1843
8060e03f 1844/* If FN is a conversion operator, the type to which it converts.
1845 Otherwise, NULL_TREE. */
1846#define DECL_CONV_FN_TYPE(FN) \
1847 (DECL_CONV_FN_P (FN) ? TREE_TYPE (DECL_NAME (FN)) : NULL_TREE)
1848
3160db1d 1849/* Nonzero if NODE, which is a TEMPLATE_DECL, is a template
c0af458b 1850 conversion operator to a type dependent on the innermost template
1851 args. */
1852#define DECL_TEMPLATE_CONV_FN_P(NODE) \
1853 (DECL_LANG_SPECIFIC (NODE)->decl_flags.template_conv_p)
1854
97cc4539 1855/* Set the overloaded operator code for NODE to CODE. */
1856#define SET_OVERLOADED_OPERATOR_CODE(NODE, CODE) \
1f3233d1 1857 (DECL_LANG_SPECIFIC (NODE)->u.f.operator_code = (CODE))
97cc4539 1858
1859/* If NODE is an overloaded operator, then this returns the TREE_CODE
755edffd 1860 associated with the overloaded operator.
97cc4539 1861 DECL_ASSIGNMENT_OPERATOR_P must also be checked to determine
1862 whether or not NODE is an assignment operator. If NODE is not an
1863 overloaded operator, ERROR_MARK is returned. Since the numerical
1864 value of ERROR_MARK is zero, this macro can be used as a predicate
1865 to test whether or not NODE is an overloaded operator. */
50cd3f45 1866#define DECL_OVERLOADED_OPERATOR_P(NODE) \
f58424d8 1867 (IDENTIFIER_OPNAME_P (DECL_NAME (NODE)) \
1f3233d1 1868 ? DECL_LANG_SPECIFIC (NODE)->u.f.operator_code : ERROR_MARK)
97cc4539 1869
3160db1d 1870/* Nonzero if NODE is an assignment operator. */
97cc4539 1871#define DECL_ASSIGNMENT_OPERATOR_P(NODE) \
1872 (DECL_LANG_SPECIFIC (NODE)->decl_flags.assignment_operator_p)
ddea175e 1873
a23287c6 1874/* For FUNCTION_DECLs: nonzero means that this function is a
1875 constructor or a destructor with an extra in-charge parameter to
1876 control whether or not virtual bases are constructed. */
1877#define DECL_HAS_IN_CHARGE_PARM_P(NODE) \
1878 (DECL_LANG_SPECIFIC (NODE)->decl_flags.has_in_charge_parm_p)
471086d6 1879
0dbadc68 1880/* Nonzero if DECL is a declaration of __builtin_constant_p. */
1881#define DECL_IS_BUILTIN_CONSTANT_P(NODE) \
1882 (TREE_CODE (NODE) == FUNCTION_DECL \
1883 && DECL_BUILT_IN_CLASS (NODE) == BUILT_IN_NORMAL \
1884 && DECL_FUNCTION_CODE (NODE) == BUILT_IN_CONSTANT_P)
1885
471086d6 1886/* Nonzero for _DECL means that this decl appears in (or will appear
1887 in) as a member in a RECORD_TYPE or UNION_TYPE node. It is also for
1888 detecting circularity in case members are multiply defined. In the
1889 case of a VAR_DECL, it is also used to determine how program storage
1890 should be allocated. */
f58424d8 1891#define DECL_IN_AGGR_P(NODE) (DECL_LANG_FLAG_3 (NODE))
471086d6 1892
a6b4af6d 1893/* Nonzero for a VAR_DECL means that the variable's initialization (if
1894 any) has been processed. (In general, DECL_INITIALIZED_P is
1895 !DECL_EXTERN, but static data members may be initialized even if
1896 not defined.) */
23ed74d8 1897#define DECL_INITIALIZED_P(NODE) \
1898 (TREE_LANG_FLAG_1 (VAR_DECL_CHECK (NODE)))
1899
a6b4af6d 1900/* Nonzero for a VAR_DECL iff an explicit initializer was provided. */
1901#define DECL_NONTRIVIALLY_INITIALIZED_P(NODE) \
1902 (TREE_LANG_FLAG_3 (VAR_DECL_CHECK (NODE)))
1903
878870b4 1904/* Nonzero for a VAR_DECL that was initialized with a
1905 constant-expression. */
1906#define DECL_INITIALIZED_BY_CONSTANT_EXPRESSION_P(NODE) \
1907 (TREE_LANG_FLAG_2 (VAR_DECL_CHECK (NODE)))
1908
5575ae2d 1909/* Nonzero for a VAR_DECL that can be used in an integral constant
ac13e8d9 1910 expression.
5575ae2d 1911
1912 [expr.const]
1913
1914 An integral constant-expression can only involve ... const
1915 variables of static or enumeration types initialized with
1916 constant expressions ...
ac13e8d9 1917
5575ae2d 1918 The standard does not require that the expression be non-volatile.
1919 G++ implements the proposed correction in DR 457. */
1920#define DECL_INTEGRAL_CONSTANT_VAR_P(NODE) \
1921 (TREE_CODE (NODE) == VAR_DECL \
1922 && CP_TYPE_CONST_NON_VOLATILE_P (TREE_TYPE (NODE)) \
1923 && INTEGRAL_OR_ENUMERATION_TYPE_P (TREE_TYPE (NODE)) \
1924 && DECL_INITIALIZED_BY_CONSTANT_EXPRESSION_P (NODE))
1925
c792eccc 1926/* Nonzero if the DECL was initialized in the class definition itself,
7b827e01 1927 rather than outside the class. This is used for both static member
6beb3f76 1928 VAR_DECLS, and FUNTION_DECLS that are defined in the class. */
c792eccc 1929#define DECL_INITIALIZED_IN_CLASS_P(DECL) \
1930 (DECL_LANG_SPECIFIC (DECL)->decl_flags.initialized_in_class)
df5066e2 1931
c1d4295f 1932/* Nonzero for DECL means that this decl is just a friend declaration,
1933 and should not be added to the list of members for this class. */
f58424d8 1934#define DECL_FRIEND_P(NODE) (DECL_LANG_SPECIFIC (NODE)->decl_flags.friend_attr)
471086d6 1935
a731c87f 1936/* A TREE_LIST of the types which have befriended this FUNCTION_DECL. */
1937#define DECL_BEFRIENDING_CLASSES(NODE) \
1f3233d1 1938 (DECL_LANG_SPECIFIC (NODE)->u.f.befriending_classes)
a731c87f 1939
471086d6 1940/* Nonzero for FUNCTION_DECL means that this decl is a static
1941 member function. */
f58424d8 1942#define DECL_STATIC_FUNCTION_P(NODE) \
1943 (DECL_LANG_SPECIFIC (NODE)->decl_flags.static_function)
471086d6 1944
2d45f35b 1945/* Nonzero for FUNCTION_DECL means that this decl is a non-static
1946 member function. */
1947#define DECL_NONSTATIC_MEMBER_FUNCTION_P(NODE) \
1948 (TREE_CODE (TREE_TYPE (NODE)) == METHOD_TYPE)
1949
0543e7a9 1950/* Nonzero for FUNCTION_DECL means that this decl is a member function
1951 (static or non-static). */
1952#define DECL_FUNCTION_MEMBER_P(NODE) \
2d45f35b 1953 (DECL_NONSTATIC_MEMBER_FUNCTION_P (NODE) || DECL_STATIC_FUNCTION_P (NODE))
0543e7a9 1954
471086d6 1955/* Nonzero for FUNCTION_DECL means that this member function
1956 has `this' as const X *const. */
7ac05dd7 1957#define DECL_CONST_MEMFUNC_P(NODE) \
1958 (DECL_NONSTATIC_MEMBER_FUNCTION_P (NODE) \
50cd3f45 1959 && CP_TYPE_CONST_P (TREE_TYPE (TREE_VALUE \
7ac05dd7 1960 (TYPE_ARG_TYPES (TREE_TYPE (NODE))))))
471086d6 1961
98eaf693 1962/* Nonzero for FUNCTION_DECL means that this member function
1963 has `this' as volatile X *const. */
1964#define DECL_VOLATILE_MEMFUNC_P(NODE) \
1965 (DECL_NONSTATIC_MEMBER_FUNCTION_P (NODE) \
1966 && CP_TYPE_VOLATILE_P (TREE_TYPE (TREE_VALUE \
1967 (TYPE_ARG_TYPES (TREE_TYPE (NODE))))))
1968
b90e9c68 1969/* Nonzero for a DECL means that this member is a non-static member. */
50cd3f45 1970#define DECL_NONSTATIC_MEMBER_P(NODE) \
1971 ((TREE_CODE (NODE) == FUNCTION_DECL \
b90e9c68 1972 && DECL_NONSTATIC_MEMBER_FUNCTION_P (NODE)) \
1973 || TREE_CODE (NODE) == FIELD_DECL)
1974
471086d6 1975/* Nonzero for _DECL means that this member object type
1976 is mutable. */
a484e8db 1977#define DECL_MUTABLE_P(NODE) (DECL_LANG_FLAG_0 (NODE))
471086d6 1978
c25194fd 1979/* Nonzero for _DECL means that this constructor is a non-converting
1980 constructor. */
f58424d8 1981#define DECL_NONCONVERTING_P(NODE) \
1982 (DECL_LANG_SPECIFIC (NODE)->decl_flags.nonconverting)
c25194fd 1983
a98fd0a1 1984/* Nonzero for FUNCTION_DECL means that this member function is a pure
1985 virtual function. */
f58424d8 1986#define DECL_PURE_VIRTUAL_P(NODE) \
1987 (DECL_LANG_SPECIFIC (NODE)->decl_flags.pure_virtual)
471086d6 1988
28bbd27a 1989/* True (in a FUNCTION_DECL) if NODE is a virtual function that is an
1990 invalid overrider for a function from a base class. Once we have
1991 complained about an invalid overrider we avoid complaining about it
1992 again. */
1993#define DECL_INVALID_OVERRIDER_P(NODE) \
1994 (DECL_LANG_FLAG_4 (NODE))
1995
805e22b2 1996/* The thunks associated with NODE, a FUNCTION_DECL. */
641985fa 1997#define DECL_THUNKS(NODE) \
c83788c9 1998 (DECL_LANG_SPECIFIC (NODE)->u.f.context)
641985fa 1999
a2697ab6 2000/* Nonzero if NODE is a thunk, rather than an ordinary function. */
2001#define DECL_THUNK_P(NODE) \
2002 (TREE_CODE (NODE) == FUNCTION_DECL \
d409f4c9 2003 && DECL_LANG_SPECIFIC (NODE) \
2004 && DECL_LANG_SPECIFIC (NODE)->decl_flags.thunk_p)
9031d10b 2005
d409f4c9 2006/* Set DECL_THUNK_P for node. */
2007#define SET_DECL_THUNK_P(NODE, THIS_ADJUSTING) \
2008 (DECL_LANG_SPECIFIC (NODE)->decl_flags.thunk_p = 1, \
2009 DECL_LANG_SPECIFIC (NODE)->u.f.u3sel = 1, \
2010 DECL_LANG_SPECIFIC (NODE)->decl_flags.this_thunk_p = (THIS_ADJUSTING))
a2697ab6 2011
805e22b2 2012/* Nonzero if NODE is a this pointer adjusting thunk. */
2013#define DECL_THIS_THUNK_P(NODE) \
2014 (DECL_THUNK_P (NODE) && DECL_LANG_SPECIFIC (NODE)->decl_flags.this_thunk_p)
2015
2016/* Nonzero if NODE is a result pointer adjusting thunk. */
2017#define DECL_RESULT_THUNK_P(NODE) \
2018 (DECL_THUNK_P (NODE) && !DECL_LANG_SPECIFIC (NODE)->decl_flags.this_thunk_p)
2019
a2697ab6 2020/* Nonzero if NODE is a FUNCTION_DECL, but not a thunk. */
2021#define DECL_NON_THUNK_FUNCTION_P(NODE) \
2022 (TREE_CODE (NODE) == FUNCTION_DECL && !DECL_THUNK_P (NODE))
2023
2024/* Nonzero if NODE is `extern "C"'. */
2025#define DECL_EXTERN_C_P(NODE) \
2026 (DECL_LANGUAGE (NODE) == lang_c)
2027
2028/* Nonzero if NODE is an `extern "C"' function. */
2029#define DECL_EXTERN_C_FUNCTION_P(NODE) \
2030 (DECL_NON_THUNK_FUNCTION_P (NODE) && DECL_EXTERN_C_P (NODE))
2031
caa6fdce 2032/* True iff DECL is an entity with vague linkage whose definition is
2033 available in this translation unit. */
2034#define DECL_REPO_AVAILABLE_P(NODE) \
2035 (DECL_LANG_SPECIFIC (NODE)->decl_flags.repo_available_p)
2036
b0944a40 2037/* Nonzero if this DECL is the __PRETTY_FUNCTION__ variable in a
2038 template function. */
2039#define DECL_PRETTY_FUNCTION_P(NODE) \
878870b4 2040 (TREE_LANG_FLAG_0 (VAR_DECL_CHECK (NODE)))
b0944a40 2041
0543e7a9 2042/* The _TYPE context in which this _DECL appears. This field holds the
c0af329c 2043 class where a virtual function instance is actually defined. */
9ba4048d 2044#define DECL_CLASS_CONTEXT(NODE) \
2045 (DECL_CLASS_SCOPE_P (NODE) ? DECL_CONTEXT (NODE) : NULL_TREE)
2046
2047/* For a non-member friend function, the class (if any) in which this
2048 friend was defined. For example, given:
50cd3f45 2049
9ba4048d 2050 struct S { friend void f (); };
2051
2052 the DECL_FRIEND_CONTEXT for `f' will be `S'. */
2053#define DECL_FRIEND_CONTEXT(NODE) \
2054 ((DECL_FRIEND_P (NODE) && !DECL_FUNCTION_MEMBER_P (NODE)) \
1f3233d1 2055 ? DECL_LANG_SPECIFIC (NODE)->u.f.context \
9ba4048d 2056 : NULL_TREE)
2057
2058/* Set the DECL_FRIEND_CONTEXT for NODE to CONTEXT. */
2059#define SET_DECL_FRIEND_CONTEXT(NODE, CONTEXT) \
1f3233d1 2060 (DECL_LANG_SPECIFIC (NODE)->u.f.context = (CONTEXT))
d8396542 2061
c0af329c 2062/* NULL_TREE in DECL_CONTEXT represents the global namespace. */
d8396542 2063#define CP_DECL_CONTEXT(NODE) \
2064 (DECL_CONTEXT (NODE) ? DECL_CONTEXT (NODE) : global_namespace)
799435d8 2065#define CP_TYPE_CONTEXT(NODE) \
2066 (TYPE_CONTEXT (NODE) ? TYPE_CONTEXT (NODE) : global_namespace)
d8396542 2067#define FROB_CONTEXT(NODE) ((NODE) == global_namespace ? NULL_TREE : (NODE))
471086d6 2068
d0fbc643 2069/* 1 iff NODE has namespace scope, including the global namespace. */
88e10762 2070#define DECL_NAMESPACE_SCOPE_P(NODE) \
2071 (!DECL_TEMPLATE_PARM_P (NODE) \
2072 && TREE_CODE (CP_DECL_CONTEXT (NODE)) == NAMESPACE_DECL)
d0fbc643 2073
2074/* 1 iff NODE is a class member. */
ddb39453 2075#define DECL_CLASS_SCOPE_P(NODE) \
9ba4048d 2076 (DECL_CONTEXT (NODE) && TYPE_P (DECL_CONTEXT (NODE)))
d0fbc643 2077
799435d8 2078#define TYPE_CLASS_SCOPE_P(NODE) \
2079 (TYPE_CONTEXT (NODE) && TYPE_P (TYPE_CONTEXT (NODE)))
2080
caa99b15 2081/* 1 iff NODE is function-local. */
2082#define DECL_FUNCTION_SCOPE_P(NODE) \
2083 (DECL_CONTEXT (NODE) \
2084 && TREE_CODE (DECL_CONTEXT (NODE)) == FUNCTION_DECL)
98eaf693 2085
caa6fdce 2086/* 1 iff VAR_DECL node NODE is a type-info decl. This flag is set for
2087 both the primary typeinfo object and the associated NTBS name. */
2088#define DECL_TINFO_P(NODE) TREE_LANG_FLAG_4 (VAR_DECL_CHECK (NODE))
2089
8efca15a 2090/* 1 iff VAR_DECL node NODE is virtual table or VTT. */
2091#define DECL_VTABLE_OR_VTT_P(NODE) TREE_LANG_FLAG_5 (VAR_DECL_CHECK (NODE))
2092
4fc9a8ec 2093/* Returns 1 iff VAR_DECL is a construction virtual table.
2094 DECL_VTABLE_OR_VTT_P will be true in this case and must be checked
2095 before using this macro. */
2096#define DECL_CONSTRUCTION_VTABLE_P(NODE) \
2097 TREE_LANG_FLAG_6 (VAR_DECL_CHECK (NODE))
2098
19f716e5 2099/* 1 iff NODE is function-local, but for types. */
2100#define LOCAL_CLASS_P(NODE) \
07e8c188 2101 (decl_function_context (TYPE_MAIN_DECL (NODE)) != NULL_TREE)
19f716e5 2102
8417823c 2103/* For a NAMESPACE_DECL: the list of using namespace directives
18e99d00 2104 The PURPOSE is the used namespace, the value is the namespace
c0af329c 2105 that is the common ancestor. */
ad46fc6a 2106#define DECL_NAMESPACE_USING(NODE) DECL_VINDEX (NAMESPACE_DECL_CHECK (NODE))
18e99d00 2107
2108/* In a NAMESPACE_DECL, the DECL_INITIAL is used to record all users
c0af329c 2109 of a namespace, to record the transitive closure of using namespace. */
ad46fc6a 2110#define DECL_NAMESPACE_USERS(NODE) DECL_INITIAL (NAMESPACE_DECL_CHECK (NODE))
18e99d00 2111
a5ed46c9 2112/* In a NAMESPACE_DECL, the list of namespaces which have associated
2113 themselves with this one. */
2114#define DECL_NAMESPACE_ASSOCIATIONS(NODE) \
5ded8c6f 2115 (NAMESPACE_DECL_CHECK (NODE)->decl_non_common.saved_tree)
a5ed46c9 2116
626864c5 2117/* In a NAMESPACE_DECL, points to the original namespace if this is
2118 a namespace alias. */
ad46fc6a 2119#define DECL_NAMESPACE_ALIAS(NODE) \
2120 DECL_ABSTRACT_ORIGIN (NAMESPACE_DECL_CHECK (NODE))
626864c5 2121#define ORIGINAL_NAMESPACE(NODE) \
2122 (DECL_NAMESPACE_ALIAS (NODE) ? DECL_NAMESPACE_ALIAS (NODE) : (NODE))
2123
3160db1d 2124/* Nonzero if NODE is the std namespace. */
98eaf693 2125#define DECL_NAMESPACE_STD_P(NODE) \
2126 (TREE_CODE (NODE) == NAMESPACE_DECL \
2127 && CP_DECL_CONTEXT (NODE) == global_namespace \
2128 && DECL_NAME (NODE) == std_identifier)
2129
ab7943b9 2130/* In a TREE_LIST concatenating using directives, indicate indirect
18e99d00 2131 directives */
35cc02b5 2132#define TREE_INDIRECT_USING(NODE) (TREE_LIST_CHECK (NODE)->base.lang_flag_0)
471086d6 2133
2fdd6488 2134/* In a TREE_LIST in an attribute list, indicates that the attribute
2135 must be applied at instantiation time. */
2136#define ATTR_IS_DEPENDENT(NODE) (TREE_LIST_CHECK (NODE)->base.lang_flag_0)
2137
5ded8c6f 2138extern tree decl_shadowed_for_var_lookup (tree);
2139extern void decl_shadowed_for_var_insert (tree, tree);
2140
094fb0d8 2141/* Non zero if this is a using decl for a dependent scope. */
2142#define DECL_DEPENDENT_P(NODE) DECL_LANG_FLAG_0 (USING_DECL_CHECK (NODE))
2143
2144/* The scope named in a using decl. */
2145#define USING_DECL_SCOPE(NODE) TREE_TYPE (USING_DECL_CHECK (NODE))
2146
2147/* The decls named by a using decl. */
2148#define USING_DECL_DECLS(NODE) DECL_INITIAL (USING_DECL_CHECK (NODE))
2149
5ded8c6f 2150/* In a VAR_DECL, true if we have a shadowed local variable
2151 in the shadowed var table for this VAR_DECL. */
2152#define DECL_HAS_SHADOWED_FOR_VAR_P(NODE) \
2153 (VAR_DECL_CHECK (NODE)->decl_with_vis.shadowed_for_var_p)
2154
dd931f64 2155/* In a VAR_DECL for a variable declared in a for statement,
96624a9e 2156 this is the shadowed (local) variable. */
5ded8c6f 2157#define DECL_SHADOWED_FOR_VAR(NODE) \
2158 (DECL_HAS_SHADOWED_FOR_VAR_P(NODE) ? decl_shadowed_for_var_lookup (NODE) : NULL)
2159
2160#define SET_DECL_SHADOWED_FOR_VAR(NODE, VAL) \
2161 (decl_shadowed_for_var_insert (NODE, VAL))
dd931f64 2162
7f075a5e 2163/* In a FUNCTION_DECL, this is nonzero if this function was defined in
2164 the class definition. We have saved away the text of the function,
2165 but have not yet processed it. */
2166#define DECL_PENDING_INLINE_P(NODE) \
1f3233d1 2167 (DECL_LANG_SPECIFIC (NODE)->u.f.pending_inline_p)
50cd3f45 2168
7f075a5e 2169/* If DECL_PENDING_INLINE_P holds, this is the saved text of the
2170 function. */
2171#define DECL_PENDING_INLINE_INFO(NODE) \
1f3233d1 2172 (DECL_LANG_SPECIFIC (NODE)->u.f.u.pending_inline_info)
15eb8b2d 2173
5f81c5db 2174/* For a TYPE_DECL: if this structure has many fields, we'll sort them
c0af329c 2175 and put them into a TREE_VEC. */
ad46fc6a 2176#define DECL_SORTED_FIELDS(NODE) \
1f3233d1 2177 (DECL_LANG_SPECIFIC (TYPE_DECL_CHECK (NODE))->u.f.u.sorted_fields)
471086d6 2178
bfb69cfe 2179/* True if on the deferred_fns (see decl2.c) list. */
2180#define DECL_DEFERRED_FN(DECL) \
f58424d8 2181 (DECL_LANG_SPECIFIC (DECL)->decl_flags.deferred)
0543e7a9 2182
61385e34 2183/* If non-NULL for a VAR_DECL, FUNCTION_DECL, TYPE_DECL or
a0ae7f4b 2184 TEMPLATE_DECL, the entity is either a template specialization (if
a17c2a3a 2185 DECL_USE_TEMPLATE is nonzero) or the abstract instance of the
a0ae7f4b 2186 template itself.
2187
2188 In either case, DECL_TEMPLATE_INFO is a TREE_LIST, whose
2189 TREE_PURPOSE is the TEMPLATE_DECL of which this entity is a
2190 specialization or abstract instance. The TREE_VALUE is the
2191 template arguments used to specialize the template.
2192
61385e34 2193 Consider:
2194
2195 template <typename T> struct S { friend void f(T) {} };
2196
2197 In this case, S<int>::f is, from the point of view of the compiler,
2198 an instantiation of a template -- but, from the point of view of
2199 the language, each instantiation of S results in a wholly unrelated
a0ae7f4b 2200 global function f. In this case, DECL_TEMPLATE_INFO for S<int>::f
2201 will be non-NULL, but DECL_USE_TEMPLATE will be zero. */
7af67ee8 2202#define DECL_TEMPLATE_INFO(NODE) \
f58424d8 2203 (DECL_LANG_SPECIFIC (VAR_TEMPL_TYPE_OR_FUNCTION_DECL_CHECK (NODE)) \
2204 ->decl_flags.u.template_info)
11fa0698 2205
8b2afb7a 2206/* For a VAR_DECL, indicates that the variable is actually a
2207 non-static data member of anonymous union that has been promoted to
2208 variable status. */
2209#define DECL_ANON_UNION_VAR_P(NODE) \
0cbb2e67 2210 (DECL_LANG_FLAG_4 (VAR_DECL_CHECK (NODE)))
2211
11fa0698 2212/* Template information for a RECORD_TYPE or UNION_TYPE. */
ad46fc6a 2213#define CLASSTYPE_TEMPLATE_INFO(NODE) \
3cb98335 2214 (LANG_TYPE_CLASS_CHECK (RECORD_OR_UNION_CHECK (NODE))->template_info)
11fa0698 2215
2216/* Template information for an ENUMERAL_TYPE. Although an enumeration may
2217 not be a primary template, it may be declared within the scope of a
2218 primary template and the enumeration constants may depend on
2219 non-type template parameters. */
3cb98335 2220#define ENUM_TEMPLATE_INFO(NODE) \
2221 (TYPE_LANG_SLOT_1 (ENUMERAL_TYPE_CHECK (NODE)))
11fa0698 2222
1d36b416 2223/* Template information for a template template parameter. */
2224#define TEMPLATE_TEMPLATE_PARM_TEMPLATE_INFO(NODE) \
1f3233d1 2225 (LANG_TYPE_CLASS_CHECK (BOUND_TEMPLATE_TEMPLATE_PARM_TYPE_CHECK (NODE)) \
1d36b416 2226 ->template_info)
e4e283ec 2227
11fa0698 2228/* Template information for an ENUMERAL_, RECORD_, or UNION_TYPE. */
e4e283ec 2229#define TYPE_TEMPLATE_INFO(NODE) \
2230 (TREE_CODE (NODE) == ENUMERAL_TYPE \
1459abb8 2231 ? ENUM_TEMPLATE_INFO (NODE) : \
1e93ca27 2232 (TREE_CODE (NODE) == BOUND_TEMPLATE_TEMPLATE_PARM \
1459abb8 2233 ? TEMPLATE_TEMPLATE_PARM_TEMPLATE_INFO (NODE) : \
2234 (TYPE_LANG_SPECIFIC (NODE) \
2235 ? CLASSTYPE_TEMPLATE_INFO (NODE) \
2236 : NULL_TREE)))
11fa0698 2237
2238/* Set the template information for an ENUMERAL_, RECORD_, or
2239 UNION_TYPE to VAL. */
50cd3f45 2240#define SET_TYPE_TEMPLATE_INFO(NODE, VAL) \
2241 (TREE_CODE (NODE) == ENUMERAL_TYPE \
f58424d8 2242 ? (ENUM_TEMPLATE_INFO (NODE) = (VAL)) \
2243 : (CLASSTYPE_TEMPLATE_INFO (NODE) = (VAL)))
11fa0698 2244
e857e9c7 2245#define TI_TEMPLATE(NODE) (TREE_PURPOSE (NODE))
2246#define TI_ARGS(NODE) (TREE_VALUE (NODE))
02d7f858 2247#define TI_PENDING_TEMPLATE_FLAG(NODE) TREE_LANG_FLAG_1 (NODE)
11fa0698 2248
a6604172 2249/* We use TREE_VECs to hold template arguments. If there is only one
2250 level of template arguments, then the TREE_VEC contains the
2251 arguments directly. If there is more than one level of template
2252 arguments, then each entry in the TREE_VEC is itself a TREE_VEC,
2253 containing the template arguments for a single level. The first
2254 entry in the outer TREE_VEC is the outermost level of template
50cd3f45 2255 parameters; the last is the innermost.
a6604172 2256
2257 It is incorrect to ever form a template argument vector containing
2258 only one level of arguments, but which is a TREE_VEC containing as
2259 its only entry the TREE_VEC for that level. */
2260
3160db1d 2261/* Nonzero if the template arguments is actually a vector of vectors,
a6604172 2262 rather than just a vector. */
653e5405 2263#define TMPL_ARGS_HAVE_MULTIPLE_LEVELS(NODE) \
d95d815d 2264 (NODE && TREE_VEC_ELT (NODE, 0) \
a6604172 2265 && TREE_CODE (TREE_VEC_ELT (NODE, 0)) == TREE_VEC)
2266
2267/* The depth of a template argument vector. When called directly by
2268 the parser, we use a TREE_LIST rather than a TREE_VEC to represent
2269 template arguments. In fact, we may even see NULL_TREE if there
2270 are no template arguments. In both of those cases, there is only
2271 one level of template arguments. */
2272#define TMPL_ARGS_DEPTH(NODE) \
2273 (TMPL_ARGS_HAVE_MULTIPLE_LEVELS (NODE) ? TREE_VEC_LENGTH (NODE) : 1)
2274
92d27c95 2275/* The LEVELth level of the template ARGS. The outermost level of
a32fe883 2276 args is level 1, not level 0. */
a6604172 2277#define TMPL_ARGS_LEVEL(ARGS, LEVEL) \
50cd3f45 2278 (TMPL_ARGS_HAVE_MULTIPLE_LEVELS (ARGS) \
f58424d8 2279 ? TREE_VEC_ELT (ARGS, (LEVEL) - 1) : (ARGS))
a6604172 2280
2281/* Set the LEVELth level of the template ARGS to VAL. This macro does
2282 not work with single-level argument vectors. */
2283#define SET_TMPL_ARGS_LEVEL(ARGS, LEVEL, VAL) \
f58424d8 2284 (TREE_VEC_ELT (ARGS, (LEVEL) - 1) = (VAL))
a6604172 2285
2286/* Accesses the IDXth parameter in the LEVELth level of the ARGS. */
2287#define TMPL_ARG(ARGS, LEVEL, IDX) \
2288 (TREE_VEC_ELT (TMPL_ARGS_LEVEL (ARGS, LEVEL), IDX))
2289
a6604172 2290/* Given a single level of template arguments in NODE, return the
2291 number of arguments. */
50cd3f45 2292#define NUM_TMPL_ARGS(NODE) \
b5959ba9 2293 (TREE_VEC_LENGTH (NODE))
a6604172 2294
a32fe883 2295/* Returns the innermost level of template arguments in ARGS. */
2296#define INNERMOST_TEMPLATE_ARGS(NODE) \
2297 (get_innermost_template_args ((NODE), 1))
2298
a6604172 2299/* The number of levels of template parameters given by NODE. */
2300#define TMPL_PARMS_DEPTH(NODE) \
7f5c5d3e 2301 ((HOST_WIDE_INT) TREE_INT_CST_LOW (TREE_PURPOSE (NODE)))
a6604172 2302
34197853 2303/* The TEMPLATE_DECL instantiated or specialized by NODE. This
2304 TEMPLATE_DECL will be the immediate parent, not the most general
2305 template. For example, in:
2306
2307 template <class T> struct S { template <class U> void f(U); }
2308
2309 the FUNCTION_DECL for S<int>::f<double> will have, as its
50cd3f45 2310 DECL_TI_TEMPLATE, `template <class U> S<int>::f<U>'.
34197853 2311
2312 As a special case, for a member friend template of a template
c08d51be 2313 class, this value will not be a TEMPLATE_DECL, but rather an
2314 IDENTIFIER_NODE or OVERLOAD indicating the name of the template and
2315 any explicit template arguments provided. For example, in:
34197853 2316
2317 template <class T> struct S { friend void f<int>(int, double); }
2318
c08d51be 2319 the DECL_TI_TEMPLATE will be an IDENTIFIER_NODE for `f' and the
50cd3f45 2320 DECL_TI_ARGS will be {int}. */
e857e9c7 2321#define DECL_TI_TEMPLATE(NODE) TI_TEMPLATE (DECL_TEMPLATE_INFO (NODE))
11fa0698 2322
34197853 2323/* The template arguments used to obtain this decl from the most
2324 general form of DECL_TI_TEMPLATE. For the example given for
2325 DECL_TI_TEMPLATE, the DECL_TI_ARGS will be {int, double}. These
2326 are always the full set of arguments required to instantiate this
2327 declaration from the most general template specialized here. */
653e5405 2328#define DECL_TI_ARGS(NODE) TI_ARGS (DECL_TEMPLATE_INFO (NODE))
a0ae7f4b 2329
2330/* The TEMPLATE_DECL associated with NODE, a class type. Even if NODE
2331 will be generated from a partial specialization, the TEMPLATE_DECL
2332 referred to here will be the original template. For example,
2333 given:
2334
2335 template <typename T> struct S {};
2336 template <typename T> struct S<T*> {};
2337
2338 the CLASSTPYE_TI_TEMPLATE for S<int*> will be S, not the S<T*>. */
e857e9c7 2339#define CLASSTYPE_TI_TEMPLATE(NODE) TI_TEMPLATE (CLASSTYPE_TEMPLATE_INFO (NODE))
2340#define CLASSTYPE_TI_ARGS(NODE) TI_ARGS (CLASSTYPE_TEMPLATE_INFO (NODE))
11fa0698 2341
5c6faf71 2342/* For a template instantiation TYPE, returns the TYPE corresponding
f0a4ea5b 2343 to the primary template. Otherwise returns TYPE itself. */
c0f42aca 2344#define CLASSTYPE_PRIMARY_TEMPLATE_TYPE(TYPE) \
2345 ((CLASSTYPE_USE_TEMPLATE ((TYPE)) \
2346 && !CLASSTYPE_TEMPLATE_SPECIALIZATION ((TYPE))) \
2347 ? TREE_TYPE (DECL_TEMPLATE_RESULT (DECL_PRIMARY_TEMPLATE \
2348 (CLASSTYPE_TI_TEMPLATE ((TYPE))))) \
f0a4ea5b 2349 : (TYPE))
5c6faf71 2350
a0ae7f4b 2351/* Like CLASS_TI_TEMPLATE, but also works for ENUMERAL_TYPEs. */
11fa0698 2352#define TYPE_TI_TEMPLATE(NODE) \
2353 (TI_TEMPLATE (TYPE_TEMPLATE_INFO (NODE)))
2354
7f075a5e 2355/* Like DECL_TI_ARGS, but for an ENUMERAL_, RECORD_, or UNION_TYPE. */
11fa0698 2356#define TYPE_TI_ARGS(NODE) \
2357 (TI_ARGS (TYPE_TEMPLATE_INFO (NODE)))
2358
f58424d8 2359#define INNERMOST_TEMPLATE_PARMS(NODE) TREE_VALUE (NODE)
e857e9c7 2360
38d89ee9 2361/* Nonzero if NODE (a TEMPLATE_DECL) is a member template, in the
2362 sense of [temp.mem]. */
2363#define DECL_MEMBER_TEMPLATE_P(NODE) \
2364 (DECL_LANG_FLAG_1 (TEMPLATE_DECL_CHECK (NODE)))
2365
df5066e2 2366/* Nonzero if the NODE corresponds to the template parameters for a
2367 member template, whose inline definition is being processed after
2368 the class definition is complete. */
4a330908 2369#define TEMPLATE_PARMS_FOR_INLINE(NODE) TREE_LANG_FLAG_1 (NODE)
2370
d95d815d 2371/* Determine if a parameter (i.e., a PARM_DECL) is a function
2372 parameter pack. */
2373#define FUNCTION_PARAMETER_PACK_P(NODE) \
2374 (DECL_LANG_FLAG_1 (PARM_DECL_CHECK (NODE)))
2375
2376/* Determines if NODE is an expansion of one or more parameter packs,
2377 e.g., a TYPE_PACK_EXPANSION or EXPR_PACK_EXPANSION. */
2378#define PACK_EXPANSION_P(NODE) \
2379 (TREE_CODE (NODE) == TYPE_PACK_EXPANSION \
2380 || TREE_CODE (NODE) == EXPR_PACK_EXPANSION)
2381
2382/* Extracts the type or expression pattern from a TYPE_PACK_EXPANSION or
2383 EXPR_PACK_EXPANSION. */
2384#define PACK_EXPANSION_PATTERN(NODE) \
2385 (TREE_CODE (NODE) == TYPE_PACK_EXPANSION? TREE_TYPE (NODE) \
2386 : TREE_OPERAND (NODE, 0))
2387
2388/* Sets the type or expression pattern for a TYPE_PACK_EXPANSION or
2389 EXPR_PACK_EXPANSION. */
2390#define SET_PACK_EXPANSION_PATTERN(NODE,VALUE) \
2391 if (TREE_CODE (NODE) == TYPE_PACK_EXPANSION) \
2392 TREE_TYPE (NODE) = VALUE; \
2393 else \
2394 TREE_OPERAND (NODE, 0) = VALUE
2395
2396/* The list of parameter packs used in the PACK_EXPANSION_* node. The
2397 TREE_VALUE of each TREE_LIST contains the parameter packs. */
2398#define PACK_EXPANSION_PARAMETER_PACKS(NODE) TREE_CHAIN (NODE)
2399
2400/* Determine if this is an argument pack. */
2401#define ARGUMENT_PACK_P(NODE) \
2402 (TREE_CODE (NODE) == TYPE_ARGUMENT_PACK \
2403 || TREE_CODE (NODE) == NONTYPE_ARGUMENT_PACK)
2404
2405/* The arguments stored in an argument pack. Arguments are stored in a
2406 TREE_VEC, which may have length zero. */
2407#define ARGUMENT_PACK_ARGS(NODE) \
2408 (TREE_CODE (NODE) == TYPE_ARGUMENT_PACK? TREE_TYPE (NODE) \
2409 : TREE_OPERAND (NODE, 0))
2410
2411/* Set the arguments stored in an argument pack. VALUE must be a
2412 TREE_VEC. */
2413#define SET_ARGUMENT_PACK_ARGS(NODE,VALUE) \
2414 if (TREE_CODE (NODE) == TYPE_ARGUMENT_PACK) \
2415 TREE_TYPE (NODE) = VALUE; \
2416 else \
2417 TREE_OPERAND (NODE, 0) = VALUE
2418
2419/* Whether the argument pack is "incomplete", meaning that more
2420 arguments can still be deduced. Incomplete argument packs are only
2421 used when the user has provided an explicit template argument list
2422 for a variadic function template. Some of the explicit template
2423 arguments will be placed into the beginning of the argument pack,
2424 but additional arguments might still be deduced. */
2425#define ARGUMENT_PACK_INCOMPLETE_P(NODE) \
2426 TREE_LANG_FLAG_0 (ARGUMENT_PACK_ARGS (NODE))
2427
2428/* When ARGUMENT_PACK_INCOMPLETE_P, stores the explicit template
2429 arguments used to fill this pack. */
2430#define ARGUMENT_PACK_EXPLICIT_ARGS(NODE) \
2431 TREE_TYPE (ARGUMENT_PACK_ARGS (NODE))
2432
2433/* In an ARGUMENT_PACK_SELECT, the argument pack from which an
2434 argument will be selected. */
2435#define ARGUMENT_PACK_SELECT_FROM_PACK(NODE) \
2436 (((struct tree_argument_pack_select *)ARGUMENT_PACK_SELECT_CHECK (NODE))->argument_pack)
2437
2438/* In an ARGUMENT_PACK_SELECT, the index of the argument we want to
2439 select. */
2440#define ARGUMENT_PACK_SELECT_INDEX(NODE) \
2441 (((struct tree_argument_pack_select *)ARGUMENT_PACK_SELECT_CHECK (NODE))->index)
2442
2443/* In an ARGUMENT_PACK_SELECT, the actual underlying argument that the
2444 ARGUMENT_PACK_SELECT represents. */
2445#define ARGUMENT_PACK_SELECT_ARG(NODE) \
2446 TREE_VEC_ELT (ARGUMENT_PACK_ARGS (ARGUMENT_PACK_SELECT_FROM_PACK (NODE)), \
2447 ARGUMENT_PACK_SELECT_INDEX (NODE));
2448
7f075a5e 2449/* In a FUNCTION_DECL, the saved language-specific per-function data. */
1f3233d1 2450#define DECL_SAVED_FUNCTION_DATA(NODE) \
2451 (DECL_LANG_SPECIFIC (FUNCTION_DECL_CHECK (NODE)) \
2452 ->u.f.u.saved_language_function)
7f075a5e 2453
729f89ff 2454/* Indicates an indirect_expr is for converting a reference. */
2455#define REFERENCE_REF_P(NODE) \
2456 TREE_LANG_FLAG_0 (INDIRECT_REF_CHECK (NODE))
2457
75e26b19 2458#define NEW_EXPR_USE_GLOBAL(NODE) \
2459 TREE_LANG_FLAG_0 (NEW_EXPR_CHECK (NODE))
2460#define DELETE_EXPR_USE_GLOBAL(NODE) \
2461 TREE_LANG_FLAG_0 (DELETE_EXPR_CHECK (NODE))
2462#define DELETE_EXPR_USE_VEC(NODE) \
2463 TREE_LANG_FLAG_1 (DELETE_EXPR_CHECK (NODE))
471086d6 2464
b6691ff5 2465/* Indicates that this is a non-dependent COMPOUND_EXPR which will
2466 resolve to a function call. */
75e26b19 2467#define COMPOUND_EXPR_OVERLOADED(NODE) \
2468 TREE_LANG_FLAG_0 (COMPOUND_EXPR_CHECK (NODE))
b6691ff5 2469
cbce34a5 2470/* In a CALL_EXPR appearing in a template, true if Koenig lookup
2471 should be performed at instantiation time. */
75e26b19 2472#define KOENIG_LOOKUP_P(NODE) TREE_LANG_FLAG_0 (CALL_EXPR_CHECK (NODE))
cbce34a5 2473
a9aacc0c 2474/* Indicates whether a string literal has been parenthesized. Such
2475 usages are disallowed in certain circumstances. */
2476
2477#define PAREN_STRING_LITERAL_P(NODE) \
2478 TREE_LANG_FLAG_0 (STRING_CST_CHECK (NODE))
2479
fd1d7ba7 2480/* Nonzero if this AGGR_INIT_EXPR provides for initialization via a
2481 constructor call, rather than an ordinary function call. */
ad46fc6a 2482#define AGGR_INIT_VIA_CTOR_P(NODE) \
2483 TREE_LANG_FLAG_0 (AGGR_INIT_EXPR_CHECK (NODE))
fd1d7ba7 2484
c2f47e15 2485/* AGGR_INIT_EXPR accessors. These are equivalent to the CALL_EXPR
2486 accessors, except for AGGR_INIT_EXPR_SLOT (which takes the place of
2487 CALL_EXPR_STATIC_CHAIN). */
2488
2489#define AGGR_INIT_EXPR_FN(NODE) TREE_OPERAND (AGGR_INIT_EXPR_CHECK (NODE), 1)
2490#define AGGR_INIT_EXPR_SLOT(NODE) \
2491 TREE_OPERAND (AGGR_INIT_EXPR_CHECK (NODE), 2)
2492#define AGGR_INIT_EXPR_ARG(NODE, I) \
2493 TREE_OPERAND (AGGR_INIT_EXPR_CHECK (NODE), (I) + 3)
2494#define aggr_init_expr_nargs(NODE) (VL_EXP_OPERAND_LENGTH(NODE) - 3)
2495
2496/* AGGR_INIT_EXPR_ARGP returns a pointer to the argument vector for NODE.
2497 We can't use &AGGR_INIT_EXPR_ARG (NODE, 0) because that will complain if
2498 the argument count is zero when checking is enabled. Instead, do
2499 the pointer arithmetic to advance past the 3 fixed operands in a
2500 AGGR_INIT_EXPR. That produces a valid pointer to just past the end of
2501 the operand array, even if it's not valid to dereference it. */
2502#define AGGR_INIT_EXPR_ARGP(NODE) \
2503 (&(TREE_OPERAND (AGGR_INIT_EXPR_CHECK (NODE), 0)) + 3)
2504
2505/* Abstract iterators for AGGR_INIT_EXPRs. */
2506
2507/* Structure containing iterator state. */
2508typedef struct aggr_init_expr_arg_iterator_d GTY (())
2509{
2510 tree t; /* the aggr_init_expr */
2511 int n; /* argument count */
2512 int i; /* next argument index */
2513} aggr_init_expr_arg_iterator;
2514
2515/* Initialize the abstract argument list iterator object ITER with the
2516 arguments from AGGR_INIT_EXPR node EXP. */
2517static inline void
2518init_aggr_init_expr_arg_iterator (tree exp,
2519 aggr_init_expr_arg_iterator *iter)
2520{
2521 iter->t = exp;
2522 iter->n = aggr_init_expr_nargs (exp);
2523 iter->i = 0;
2524}
2525
2526/* Return the next argument from abstract argument list iterator object ITER,
2527 and advance its state. Return NULL_TREE if there are no more arguments. */
2528static inline tree
2529next_aggr_init_expr_arg (aggr_init_expr_arg_iterator *iter)
2530{
2531 tree result;
2532 if (iter->i >= iter->n)
2533 return NULL_TREE;
2534 result = AGGR_INIT_EXPR_ARG (iter->t, iter->i);
2535 iter->i++;
2536 return result;
2537}
2538
2539/* Initialize the abstract argument list iterator object ITER, then advance
2540 past and return the first argument. Useful in for expressions, e.g.
2541 for (arg = first_aggr_init_expr_arg (exp, &iter); arg;
2542 arg = next_aggr_init_expr_arg (&iter)) */
2543static inline tree
2544first_aggr_init_expr_arg (tree exp, aggr_init_expr_arg_iterator *iter)
2545{
2546 init_aggr_init_expr_arg_iterator (exp, iter);
2547 return next_aggr_init_expr_arg (iter);
2548}
2549
2550/* Test whether there are more arguments in abstract argument list iterator
2551 ITER, without changing its state. */
2552static inline bool
2553more_aggr_init_expr_args_p (const aggr_init_expr_arg_iterator *iter)
2554{
2555 return (iter->i < iter->n);
2556}
2557
2558/* Iterate through each argument ARG of AGGR_INIT_EXPR CALL, using variable
2559 ITER (of type aggr_init_expr_arg_iterator) to hold the iteration state. */
2560#define FOR_EACH_AGGR_INIT_EXPR_ARG(arg, iter, call) \
2561 for ((arg) = first_aggr_init_expr_arg ((call), &(iter)); (arg); \
2562 (arg) = next_aggr_init_expr_arg (&(iter)))
2563
0f0d5a69 2564/* The TYPE_MAIN_DECL for a class template type is a TYPE_DECL, not a
2565 TEMPLATE_DECL. This macro determines whether or not a given class
2566 type is really a template type, as opposed to an instantiation or
2567 specialization of one. */
2568#define CLASSTYPE_IS_TEMPLATE(NODE) \
2569 (CLASSTYPE_TEMPLATE_INFO (NODE) \
2570 && !CLASSTYPE_USE_TEMPLATE (NODE) \
2571 && PRIMARY_TEMPLATE_P (CLASSTYPE_TI_TEMPLATE (NODE)))
2572
871d88e7 2573/* The name used by the user to name the typename type. Typically,
2574 this is an IDENTIFIER_NODE, and the same as the DECL_NAME on the
2575 corresponding TYPE_DECL. However, this may also be a
2576 TEMPLATE_ID_EXPR if we had something like `typename X::Y<T>'. */
75e26b19 2577#define TYPENAME_TYPE_FULLNAME(NODE) (TYPENAME_TYPE_CHECK (NODE))->type.values
89c5805a 2578
e2ae55f2 2579/* True if a TYPENAME_TYPE was declared as an "enum". */
2580#define TYPENAME_IS_ENUM_P(NODE) \
2581 (TREE_LANG_FLAG_0 (TYPENAME_TYPE_CHECK (NODE)))
2582
2583/* True if a TYPENAME_TYPE was declared as a "class", "struct", or
2584 "union". */
2585#define TYPENAME_IS_CLASS_P(NODE) \
2586 (TREE_LANG_FLAG_1 (TYPENAME_TYPE_CHECK (NODE)))
2587
8826a863 2588/* True if a TYPENAME_TYPE is in the process of being resolved. */
2589#define TYPENAME_IS_RESOLVING_P(NODE) \
2590 (TREE_LANG_FLAG_2 (TYPENAME_TYPE_CHECK (NODE)))
2591
c5c6781c 2592/* Nonzero in INTEGER_CST means that this int is negative by dint of
471086d6 2593 using a twos-complement negated operand. */
ad46fc6a 2594#define TREE_NEGATED_INT(NODE) TREE_LANG_FLAG_0 (INTEGER_CST_CHECK (NODE))
471086d6 2595
1d6228f0 2596/* [class.virtual]
471086d6 2597
1d6228f0 2598 A class that declares or inherits a virtual function is called a
2599 polymorphic class. */
2600#define TYPE_POLYMORPHIC_P(NODE) (TREE_LANG_FLAG_2 (NODE))
471086d6 2601
b53fb33d 2602/* Nonzero if this class has a virtual function table pointer. */
50cd3f45 2603#define TYPE_CONTAINS_VPTR_P(NODE) \
1f0b839e 2604 (TYPE_POLYMORPHIC_P (NODE) || CLASSTYPE_VBASECLASSES (NODE))
b53fb33d 2605
dd931f64 2606/* This flag is true of a local VAR_DECL if it was declared in a for
96624a9e 2607 statement, but we are no longer in the scope of the for. */
ad46fc6a 2608#define DECL_DEAD_FOR_LOCAL(NODE) DECL_LANG_FLAG_7 (VAR_DECL_CHECK (NODE))
dd931f64 2609
2610/* This flag is set on a VAR_DECL that is a DECL_DEAD_FOR_LOCAL
2611 if we already emitted a warning about using it. */
ad46fc6a 2612#define DECL_ERROR_REPORTED(NODE) DECL_LANG_FLAG_0 (VAR_DECL_CHECK (NODE))
dd931f64 2613
ce23987e 2614/* Nonzero if NODE is a FUNCTION_DECL (for a function with global
2615 scope) declared in a local scope. */
2616#define DECL_LOCAL_FUNCTION_P(NODE) \
2617 DECL_LANG_FLAG_0 (FUNCTION_DECL_CHECK (NODE))
c324ed63 2618
c1d4295f 2619/* Nonzero if NODE is a DECL which we know about but which has not
2620 been explicitly declared, such as a built-in function or a friend
2621 declared inside a class. In the latter case DECL_HIDDEN_FRIEND_P
2622 will be set. */
021a57f4 2623#define DECL_ANTICIPATED(NODE) \
5ded8c6f 2624 (DECL_LANG_SPECIFIC (DECL_COMMON_CHECK (NODE))->decl_flags.anticipated_p)
ce23987e 2625
c1d4295f 2626/* Nonzero if NODE is a FUNCTION_DECL which was declared as a friend
2627 within a class but has not been declared in the surrounding scope.
2628 The function is invisible except via argument dependent lookup. */
2629#define DECL_HIDDEN_FRIEND_P(NODE) \
2630 (DECL_LANG_SPECIFIC (DECL_COMMON_CHECK (NODE))->decl_flags.hidden_friend_p)
2631
8487df40 2632/* Nonzero if DECL has been declared threadprivate by
2633 #pragma omp threadprivate. */
2634#define CP_DECL_THREADPRIVATE_P(DECL) \
2635 (DECL_LANG_SPECIFIC (VAR_DECL_CHECK (DECL))->decl_flags.threadprivate_p)
2636
471086d6 2637/* Record whether a typedef for type `int' was actually `signed int'. */
f58424d8 2638#define C_TYPEDEF_EXPLICITLY_SIGNED(EXP) DECL_LANG_FLAG_1 (EXP)
471086d6 2639
3160db1d 2640/* Returns nonzero if DECL has external linkage, as specified by the
a1abbd01 2641 language standard. (This predicate may hold even when the
2642 corresponding entity is not actually given external linkage in the
2643 object file; see decl_linkage for details.) */
2644#define DECL_EXTERNAL_LINKAGE_P(DECL) \
2645 (decl_linkage (DECL) == lk_external)
2646
f92d4c86 2647/* Keep these codes in ascending code order. */
9843a47d 2648
f92d4c86 2649#define INTEGRAL_CODE_P(CODE) \
2650 ((CODE) == ENUMERAL_TYPE \
2651 || (CODE) == BOOLEAN_TYPE \
2652 || (CODE) == INTEGER_TYPE)
8c18e707 2653
2654/* [basic.fundamental]
2655
2656 Types bool, char, wchar_t, and the signed and unsigned integer types
50cd3f45 2657 are collectively called integral types.
8c18e707 2658
2659 Note that INTEGRAL_TYPE_P, as defined in tree.h, allows enumeration
9843a47d 2660 types as well, which is incorrect in C++. Keep these checks in
f92d4c86 2661 ascending code order. */
50cd3f45 2662#define CP_INTEGRAL_TYPE_P(TYPE) \
f58424d8 2663 (TREE_CODE (TYPE) == BOOLEAN_TYPE \
2664 || TREE_CODE (TYPE) == INTEGER_TYPE)
8c18e707 2665
9843a47d 2666/* Returns true if TYPE is an integral or enumeration name. Keep
2667 these checks in ascending code order. */
5f6526e1 2668#define INTEGRAL_OR_ENUMERATION_TYPE_P(TYPE) \
9843a47d 2669 (TREE_CODE (TYPE) == ENUMERAL_TYPE || CP_INTEGRAL_TYPE_P (TYPE))
5f6526e1 2670
8c18e707 2671/* [basic.fundamental]
2672
2673 Integral and floating types are collectively called arithmetic
04791a75 2674 types.
2675
2676 As a GNU extension, we also accept complex types.
2677
2678 Keep these checks in ascending code order. */
8c18e707 2679#define ARITHMETIC_TYPE_P(TYPE) \
04791a75 2680 (CP_INTEGRAL_TYPE_P (TYPE) \
2681 || TREE_CODE (TYPE) == REAL_TYPE \
2682 || TREE_CODE (TYPE) == COMPLEX_TYPE)
bb0726a1 2683
334ec926 2684/* [basic.types]
2685
2686 Arithmetic types, enumeration types, pointer types, and
9843a47d 2687 pointer-to-member types, are collectively called scalar types.
04791a75 2688
9843a47d 2689 Keep these checks in ascending code order. */
334ec926 2690#define SCALAR_TYPE_P(TYPE) \
9843a47d 2691 (TYPE_PTRMEM_P (TYPE) \
334ec926 2692 || TREE_CODE (TYPE) == ENUMERAL_TYPE \
9843a47d 2693 || ARITHMETIC_TYPE_P (TYPE) \
334ec926 2694 || TYPE_PTR_P (TYPE) \
9843a47d 2695 || TYPE_PTRMEMFUNC_P (TYPE))
334ec926 2696
2437a99c 2697/* [dcl.init.aggr]
2698
2699 An aggregate is an array or a class with no user-declared
2700 constructors, no private or protected non-static data members, no
5264d007 2701 base classes, and no virtual functions.
2702
9843a47d 2703 As an extension, we also treat vectors as aggregates. Keep these
2704 checks in ascending code order. */
2705#define CP_AGGREGATE_TYPE_P(TYPE) \
2706 (TREE_CODE (TYPE) == VECTOR_TYPE \
2707 ||TREE_CODE (TYPE) == ARRAY_TYPE \
2708 || (CLASS_TYPE_P (TYPE) && !CLASSTYPE_NON_AGGREGATE (TYPE)))
2437a99c 2709
2710/* Nonzero for a class type means that the class type has a
2711 user-declared constructor. */
f58424d8 2712#define TYPE_HAS_CONSTRUCTOR(NODE) (TYPE_LANG_FLAG_1 (NODE))
471086d6 2713
2714/* When appearing in an INDIRECT_REF, it means that the tree structure
2715 underneath is actually a call to a constructor. This is needed
2716 when the constructor must initialize local storage (which can
2717 be automatically destroyed), rather than allowing it to allocate
2718 space from the heap.
2719
2720 When appearing in a SAVE_EXPR, it means that underneath
2721 is a call to a constructor.
2722
e6517de8 2723 When appearing in a CONSTRUCTOR, the expression is a
2724 compound literal.
471086d6 2725
2726 When appearing in a FIELD_DECL, it means that this field
2727 has been duly initialized in its constructor. */
f58424d8 2728#define TREE_HAS_CONSTRUCTOR(NODE) (TREE_LANG_FLAG_4 (NODE))
471086d6 2729
e6517de8 2730/* True if NODE is a brace-enclosed initializer. */
2731#define BRACE_ENCLOSED_INITIALIZER_P(NODE) \
2732 (TREE_CODE (NODE) == CONSTRUCTOR && !TREE_TYPE (NODE))
2733
79b01846 2734/* True if NODE is a compound-literal, i.e., a brace-enclosed
2735 initializer cast to a particular type. */
2736#define COMPOUND_LITERAL_P(NODE) \
2737 (TREE_CODE (NODE) == CONSTRUCTOR && TREE_HAS_CONSTRUCTOR (NODE))
2738
c75b4594 2739#define EMPTY_CONSTRUCTOR_P(NODE) (TREE_CODE (NODE) == CONSTRUCTOR \
2740 && VEC_empty (constructor_elt, \
2741 CONSTRUCTOR_ELTS (NODE)) \
2742 && !TREE_HAS_CONSTRUCTOR (NODE))
ad91f3ed 2743
ce28ee2e 2744/* Nonzero means that an object of this type can not be initialized using
2745 an initializer list. */
2746#define CLASSTYPE_NON_AGGREGATE(NODE) \
1f3233d1 2747 (LANG_TYPE_CLASS_CHECK (NODE)->non_aggregate)
ce28ee2e 2748#define TYPE_NON_AGGREGATE_CLASS(NODE) \
2749 (IS_AGGR_TYPE (NODE) && CLASSTYPE_NON_AGGREGATE (NODE))
2750
471086d6 2751/* Nonzero if there is a user-defined X::op=(x&) for this class. */
1f3233d1 2752#define TYPE_HAS_COMPLEX_ASSIGN_REF(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->has_complex_assign_ref)
481451eb 2753
2754/* Nonzero if there is a user-defined X::X(x&) for this class. */
1f3233d1 2755#define TYPE_HAS_COMPLEX_INIT_REF(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->has_complex_init_ref)
471086d6 2756
481451eb 2757/* Nonzero if there is a user-defined default constructor for this class. */
2758#define TYPE_HAS_COMPLEX_DFLT(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->has_complex_dflt)
2759
89e923d8 2760/* Nonzero if TYPE has a trivial destructor. From [class.dtor]:
50cd3f45 2761
89e923d8 2762 A destructor is trivial if it is an implicitly declared
2763 destructor and if:
2764
2765 - all of the direct base classes of its class have trivial
653e5405 2766 destructors,
89e923d8 2767
2768 - for all of the non-static data members of its class that are
653e5405 2769 of class type (or array thereof), each such class has a
89e923d8 2770 trivial destructor. */
2771#define TYPE_HAS_TRIVIAL_DESTRUCTOR(NODE) \
2772 (!TYPE_HAS_NONTRIVIAL_DESTRUCTOR (NODE))
2773
2774/* Nonzero for _TYPE node means that this type does not have a trivial
2775 destructor. Therefore, destroying an object of this type will
2776 involve a call to a destructor. This can apply to objects of
2777 ARRAY_TYPE is the type of the elements needs a destructor. */
2778#define TYPE_HAS_NONTRIVIAL_DESTRUCTOR(NODE) \
f58424d8 2779 (TYPE_LANG_FLAG_4 (NODE))
471086d6 2780
481451eb 2781/* Nonzero for class type means that the default constructor is trivial. */
2782#define TYPE_HAS_TRIVIAL_DFLT(NODE) \
2783 (TYPE_HAS_DEFAULT_CONSTRUCTOR (NODE) && ! TYPE_HAS_COMPLEX_DFLT (NODE))
2784
e4e264a5 2785/* Nonzero for class type means that copy initialization of this type can use
3f7d79e4 2786 a bitwise copy. */
2787#define TYPE_HAS_TRIVIAL_INIT_REF(NODE) \
2788 (TYPE_HAS_INIT_REF (NODE) && ! TYPE_HAS_COMPLEX_INIT_REF (NODE))
2789
2790/* Nonzero for class type means that assignment of this type can use
2791 a bitwise copy. */
2792#define TYPE_HAS_TRIVIAL_ASSIGN_REF(NODE) \
2793 (TYPE_HAS_ASSIGN_REF (NODE) && ! TYPE_HAS_COMPLEX_ASSIGN_REF (NODE))
2794
1bc16cab 2795/* Returns true if NODE is a pointer-to-data-member. */
2796#define TYPE_PTRMEM_P(NODE) \
2797 (TREE_CODE (NODE) == OFFSET_TYPE)
b312a686 2798/* Returns true if NODE is a pointer. */
1bc16cab 2799#define TYPE_PTR_P(NODE) \
2800 (TREE_CODE (NODE) == POINTER_TYPE)
ac4d57eb 2801
2802/* Returns true if NODE is an object type:
2803
2804 [basic.types]
2805
2806 An object type is a (possibly cv-qualified) type that is not a
074ab442 2807 function type, not a reference type, and not a void type.
ac4d57eb 2808
2809 Keep these checks in ascending order, for speed. */
2810#define TYPE_OBJ_P(NODE) \
2811 (TREE_CODE (NODE) != REFERENCE_TYPE \
2812 && TREE_CODE (NODE) != VOID_TYPE \
2813 && TREE_CODE (NODE) != FUNCTION_TYPE \
2814 && TREE_CODE (NODE) != METHOD_TYPE)
2815
9843a47d 2816/* Returns true if NODE is a pointer to an object. Keep these checks
2817 in ascending tree code order. */
2818#define TYPE_PTROB_P(NODE) \
ac4d57eb 2819 (TYPE_PTR_P (NODE) && TYPE_OBJ_P (TREE_TYPE (NODE)))
2820
9843a47d 2821/* Returns true if NODE is a reference to an object. Keep these checks
2822 in ascending tree code order. */
2823#define TYPE_REF_OBJ_P(NODE) \
ac4d57eb 2824 (TREE_CODE (NODE) == REFERENCE_TYPE && TYPE_OBJ_P (TREE_TYPE (NODE)))
2825
63949b38 2826/* True if reference type NODE is an rvalue reference */
2827#define TYPE_REF_IS_RVALUE(NODE) \
2828 TREE_LANG_FLAG_0 (REFERENCE_TYPE_CHECK (NODE))
2829
9843a47d 2830/* Returns true if NODE is a pointer to an object, or a pointer to
2831 void. Keep these checks in ascending tree code order. */
2832#define TYPE_PTROBV_P(NODE) \
653e5405 2833 (TYPE_PTR_P (NODE) \
9843a47d 2834 && !(TREE_CODE (TREE_TYPE (NODE)) == FUNCTION_TYPE \
653e5405 2835 || TREE_CODE (TREE_TYPE (NODE)) == METHOD_TYPE))
ac4d57eb 2836
b312a686 2837/* Returns true if NODE is a pointer to function. */
f9670f72 2838#define TYPE_PTRFN_P(NODE) \
2839 (TREE_CODE (NODE) == POINTER_TYPE \
2840 && TREE_CODE (TREE_TYPE (NODE)) == FUNCTION_TYPE)
ac4d57eb 2841
b312a686 2842/* Returns true if NODE is a reference to function. */
054e01a7 2843#define TYPE_REFFN_P(NODE) \
2844 (TREE_CODE (NODE) == REFERENCE_TYPE \
2845 && TREE_CODE (TREE_TYPE (NODE)) == FUNCTION_TYPE)
f9670f72 2846
471086d6 2847/* Nonzero for _TYPE node means that this type is a pointer to member
96624a9e 2848 function type. */
595d03ea 2849#define TYPE_PTRMEMFUNC_P(NODE) \
f58424d8 2850 (TREE_CODE (NODE) == RECORD_TYPE \
2851 && TYPE_LANG_SPECIFIC (NODE) \
595d03ea 2852 && TYPE_PTRMEMFUNC_FLAG (NODE))
2853
1c16607c 2854#define TYPE_PTRMEMFUNC_FLAG(NODE) \
1f3233d1 2855 (LANG_TYPE_CLASS_CHECK (NODE)->ptrmemfunc_flag)
1c16607c 2856
1bc16cab 2857/* Returns true if NODE is a pointer-to-member. */
2858#define TYPE_PTR_TO_MEMBER_P(NODE) \
2859 (TYPE_PTRMEM_P (NODE) || TYPE_PTRMEMFUNC_P (NODE))
2860
30efa7ed 2861/* Indicates when overload resolution may resolve to a pointer to
2862 member function. [expr.unary.op]/3 */
75e26b19 2863#define PTRMEM_OK_P(NODE) \
2864 TREE_LANG_FLAG_0 (TREE_CHECK2 ((NODE), ADDR_EXPR, OFFSET_REF))
30efa7ed 2865
471086d6 2866/* Get the POINTER_TYPE to the METHOD_TYPE associated with this
2867 pointer to member function. TYPE_PTRMEMFUNC_P _must_ be true,
96624a9e 2868 before using this macro. */
63a6a423 2869#define TYPE_PTRMEMFUNC_FN_TYPE(NODE) \
606b494c 2870 (TREE_TYPE (TYPE_FIELDS (NODE)))
772e70a1 2871
2872/* Returns `A' for a type like `int (A::*)(double)' */
2873#define TYPE_PTRMEMFUNC_OBJECT_TYPE(NODE) \
2874 TYPE_METHOD_BASETYPE (TREE_TYPE (TYPE_PTRMEMFUNC_FN_TYPE (NODE)))
2875
3398e91d 2876/* These are use to manipulate the canonical RECORD_TYPE from the
96624a9e 2877 hashed POINTER_TYPE, and can only be used on the POINTER_TYPE. */
f58424d8 2878#define TYPE_GET_PTRMEMFUNC_TYPE(NODE) \
1f3233d1 2879 (TYPE_LANG_SPECIFIC (NODE) ? LANG_TYPE_PTRMEM_CHECK (NODE)->record : NULL)
2880#define TYPE_SET_PTRMEMFUNC_TYPE(NODE, VALUE) \
2881 do { \
2882 if (TYPE_LANG_SPECIFIC (NODE) == NULL) \
2883 { \
653e5405 2884 TYPE_LANG_SPECIFIC (NODE) = GGC_CNEWVAR \
2885 (struct lang_type, sizeof (struct lang_type_ptrmem)); \
1f3233d1 2886 TYPE_LANG_SPECIFIC (NODE)->u.ptrmem.h.is_lang_type_class = 0; \
2887 } \
2888 TYPE_LANG_SPECIFIC (NODE)->u.ptrmem.record = (VALUE); \
2889 } while (0)
471086d6 2890
22d98382 2891/* For a pointer-to-member type of the form `T X::*', this is `X'.
2892 For a type like `void (X::*)() const', this type is `X', not `const
2893 X'. To get at the `const X' you have to look at the
2894 TYPE_PTRMEM_POINTED_TO_TYPE; there, the first parameter will have
2895 type `const X*'. */
ddea175e 2896#define TYPE_PTRMEM_CLASS_TYPE(NODE) \
f58424d8 2897 (TYPE_PTRMEM_P (NODE) \
1bc16cab 2898 ? TYPE_OFFSET_BASETYPE (NODE) \
f58424d8 2899 : TYPE_PTRMEMFUNC_OBJECT_TYPE (NODE))
ddea175e 2900
2901/* For a pointer-to-member type of the form `T X::*', this is `T'. */
2902#define TYPE_PTRMEM_POINTED_TO_TYPE(NODE) \
f58424d8 2903 (TYPE_PTRMEM_P (NODE) \
1bc16cab 2904 ? TREE_TYPE (NODE) \
f58424d8 2905 : TREE_TYPE (TYPE_PTRMEMFUNC_FN_TYPE (NODE)))
ddea175e 2906
0f2952a1 2907/* For a pointer-to-member constant `X::Y' this is the RECORD_TYPE for
2908 `X'. */
ddea175e 2909#define PTRMEM_CST_CLASS(NODE) \
ad46fc6a 2910 TYPE_PTRMEM_CLASS_TYPE (TREE_TYPE (PTRMEM_CST_CHECK (NODE)))
0f2952a1 2911
50cd3f45 2912/* For a pointer-to-member constant `X::Y' this is the _DECL for
0f2952a1 2913 `Y'. */
ad46fc6a 2914#define PTRMEM_CST_MEMBER(NODE) (((ptrmem_cst_t)PTRMEM_CST_CHECK (NODE))->member)
0f2952a1 2915
75e26b19 2916/* The expression in question for a TYPEOF_TYPE. */
2917#define TYPEOF_TYPE_EXPR(NODE) (TYPEOF_TYPE_CHECK (NODE))->type.values
2918
34da8800 2919/* The expression in question for a DECLTYPE_TYPE. */
2920#define DECLTYPE_TYPE_EXPR(NODE) (DECLTYPE_TYPE_CHECK (NODE))->type.values
2921
2922/* Whether the DECLTYPE_TYPE_EXPR of NODE was originally parsed as an
2923 id-expression or a member-access expression. When false, it was
2924 parsed as a full expression. */
2925#define DECLTYPE_TYPE_ID_EXPR_OR_MEMBER_ACCESS_P(NODE) \
2926 (DECLTYPE_TYPE_CHECK (NODE))->type.string_flag
2927
bb09dca5 2928/* Nonzero for VAR_DECL and FUNCTION_DECL node means that `extern' was
3d411d73 2929 specified in its declaration. This can also be set for an
2930 erroneously declared PARM_DECL. */
ad46fc6a 2931#define DECL_THIS_EXTERN(NODE) \
3d411d73 2932 DECL_LANG_FLAG_2 (VAR_FUNCTION_OR_PARM_DECL_CHECK (NODE))
471086d6 2933
bb09dca5 2934/* Nonzero for VAR_DECL and FUNCTION_DECL node means that `static' was
3d411d73 2935 specified in its declaration. This can also be set for an
2936 erroneously declared PARM_DECL. */
ad46fc6a 2937#define DECL_THIS_STATIC(NODE) \
3d411d73 2938 DECL_LANG_FLAG_6 (VAR_FUNCTION_OR_PARM_DECL_CHECK (NODE))
bb09dca5 2939
6078f68f 2940/* Nonzero for FIELD_DECL node means that this field is a base class
2941 of the parent object, as opposed to a member field. */
2942#define DECL_FIELD_IS_BASE(NODE) \
2943 DECL_LANG_FLAG_6 (FIELD_DECL_CHECK (NODE))
2944
128e1d72 2945/* Nonzero if TYPE is an anonymous union or struct type. We have to use a
2946 flag for this because "A union for which objects or pointers are
2947 declared is not an anonymous union" [class.union]. */
2948#define ANON_AGGR_TYPE_P(NODE) \
1f3233d1 2949 (CLASS_TYPE_P (NODE) && LANG_TYPE_CLASS_CHECK (NODE)->anon_aggr)
128e1d72 2950#define SET_ANON_AGGR_TYPE_P(NODE) \
1f3233d1 2951 (LANG_TYPE_CLASS_CHECK (NODE)->anon_aggr = 1)
29926476 2952
5c035e5d 2953/* Nonzero if TYPE is an anonymous union type. */
2954#define ANON_UNION_TYPE_P(NODE) \
2955 (TREE_CODE (NODE) == UNION_TYPE && ANON_AGGR_TYPE_P (NODE))
2956
471086d6 2957#define UNKNOWN_TYPE LANG_TYPE
2958
2959/* Define fields and accessors for nodes representing declared names. */
2960
1f3233d1 2961#define TYPE_WAS_ANONYMOUS(NODE) (LANG_TYPE_CLASS_CHECK (NODE)->was_anonymous)
471086d6 2962
2963/* C++: all of these are overloaded! These apply only to TYPE_DECLs. */
f3110581 2964
2965/* The format of each node in the DECL_FRIENDLIST is as follows:
2966
2967 The TREE_PURPOSE will be the name of a function, i.e., an
f4da5882 2968 IDENTIFIER_NODE. The TREE_VALUE will be itself a TREE_LIST, whose
2969 TREE_VALUEs are friends with the given name. */
471086d6 2970#define DECL_FRIENDLIST(NODE) (DECL_INITIAL (NODE))
a731c87f 2971#define FRIEND_NAME(LIST) (TREE_PURPOSE (LIST))
2972#define FRIEND_DECLS(LIST) (TREE_VALUE (LIST))
471086d6 2973
1fc84929 2974/* The DECL_ACCESS, if non-NULL, is a TREE_LIST. The TREE_PURPOSE of
2975 each node is a type; the TREE_VALUE is the access granted for this
2976 DECL in that type. The DECL_ACCESS is set by access declarations.
2977 For example, if a member that would normally be public in a
2978 derived class is made protected, then the derived class and the
2979 protected_access_node will appear in the DECL_ACCESS for the node. */
1f3233d1 2980#define DECL_ACCESS(NODE) (LANG_DECL_U2_CHECK (NODE, 0)->access)
a56359e2 2981
2982/* Nonzero if the FUNCTION_DECL is a global constructor. */
2983#define DECL_GLOBAL_CTOR_P(NODE) \
f58424d8 2984 (DECL_LANG_SPECIFIC (NODE)->decl_flags.global_ctor_p)
a56359e2 2985
2986/* Nonzero if the FUNCTION_DECL is a global destructor. */
2987#define DECL_GLOBAL_DTOR_P(NODE) \
f58424d8 2988 (DECL_LANG_SPECIFIC (NODE)->decl_flags.global_dtor_p)
a56359e2 2989
471086d6 2990/* Accessor macros for C++ template decl nodes. */
f3110581 2991
2992/* The DECL_TEMPLATE_PARMS are a list. The TREE_PURPOSE of each node
180f098b 2993 is a INT_CST whose TREE_INT_CST_LOW indicates the level of the
34197853 2994 template parameters, with 1 being the outermost set of template
2995 parameters. The TREE_VALUE is a vector, whose elements are the
2996 template parameters at each level. Each element in the vector is a
2997 TREE_LIST, whose TREE_VALUE is a PARM_DECL (if the parameter is a
2998 non-type parameter), or a TYPE_DECL (if the parameter is a type
2999 parameter). The TREE_PURPOSE is the default value, if any. The
755edffd 3000 TEMPLATE_PARM_INDEX for the parameter is available as the
34197853 3001 DECL_INITIAL (for a PARM_DECL) or as the TREE_TYPE (for a
3002 TYPE_DECL). */
5ded8c6f 3003#define DECL_TEMPLATE_PARMS(NODE) DECL_NON_COMMON_CHECK (NODE)->decl_non_common.arguments
64b4f183 3004#define DECL_INNERMOST_TEMPLATE_PARMS(NODE) \
3005 INNERMOST_TEMPLATE_PARMS (DECL_TEMPLATE_PARMS (NODE))
3006#define DECL_NTPARMS(NODE) \
3007 TREE_VEC_LENGTH (DECL_INNERMOST_TEMPLATE_PARMS (NODE))
471086d6 3008/* For function, method, class-data templates. */
f58424d8 3009#define DECL_TEMPLATE_RESULT(NODE) DECL_RESULT_FLD (NODE)
34197853 3010/* For a static member variable template, the
3011 DECL_TEMPLATE_INSTANTIATIONS list contains the explicitly and
3012 implicitly generated instantiations of the variable. There are no
3013 partial instantiations of static member variables, so all of these
3014 will be full instantiations.
3015
3016 For a class template the DECL_TEMPLATE_INSTANTIATIONS lists holds
3017 all instantiations and specializations of the class type, including
3018 partial instantiations and partial specializations.
3019
3020 In both cases, the TREE_PURPOSE of each node contains the arguments
3021 used; the TREE_VALUE contains the generated variable. The template
3022 arguments are always complete. For example, given:
3023
3024 template <class T> struct S1 {
653e5405 3025 template <class U> struct S2 {};
34197853 3026 template <class U> struct S2<U*> {};
3027 };
3028
3029 the record for the partial specialization will contain, as its
3030 argument list, { {T}, {U*} }, and will be on the
3031 DECL_TEMPLATE_INSTANTIATIONS list for `template <class T> template
3032 <class U> struct S1<T>::S2'.
3033
3034 This list is not used for function templates. */
f58424d8 3035#define DECL_TEMPLATE_INSTANTIATIONS(NODE) DECL_VINDEX (NODE)
34197853 3036/* For a function template, the DECL_TEMPLATE_SPECIALIZATIONS lists
3037 contains all instantiations and specializations of the function,
3038 including partial instantiations. For a partial instantiation
3039 which is a specialization, this list holds only full
3040 specializations of the template that are instantiations of the
3041 partial instantiation. For example, given:
3042
3043 template <class T> struct S {
653e5405 3044 template <class U> void f(U);
50cd3f45 3045 template <> void f(T);
34197853 3046 };
3047
3048 the `S<int>::f<int>(int)' function will appear on the
3049 DECL_TEMPLATE_SPECIALIZATIONS list for both `template <class T>
3050 template <class U> void S<T>::f(U)' and `template <class T> void
3051 S<int>::f(T)'. In the latter case, however, it will have only the
3052 innermost set of arguments (T, in this case). The DECL_TI_TEMPLATE
3053 for the function declaration will point at the specialization, not
3054 the fully general template.
3055
3056 For a class template, this list contains the partial
3057 specializations of this template. (Full specializations are not
aa32d258 3058 recorded on this list.) The TREE_PURPOSE holds the arguments used
3059 in the partial specialization (e.g., for `template <class T> struct
3060 S<T*, int>' this will be `T*'.) The arguments will also include
3061 any outer template arguments. The TREE_VALUE holds the innermost
3062 template parameters for the specialization (e.g., `T' in the
3063 example above.) The TREE_TYPE is the _TYPE node for the partial
3064 specialization.
34197853 3065
3066 This list is not used for static variable templates. */
f58424d8 3067#define DECL_TEMPLATE_SPECIALIZATIONS(NODE) DECL_SIZE (NODE)
e857e9c7 3068
9843a47d 3069/* Nonzero for a DECL which is actually a template parameter. Keep
3070 these checks in ascending tree code order. */
50cd3f45 3071#define DECL_TEMPLATE_PARM_P(NODE) \
ce23987e 3072 (DECL_LANG_FLAG_0 (NODE) \
3073 && (TREE_CODE (NODE) == CONST_DECL \
1f062702 3074 || TREE_CODE (NODE) == PARM_DECL \
ce23987e 3075 || TREE_CODE (NODE) == TYPE_DECL \
3076 || TREE_CODE (NODE) == TEMPLATE_DECL))
3077
3078/* Mark NODE as a template parameter. */
3079#define SET_DECL_TEMPLATE_PARM_P(NODE) \
3080 (DECL_LANG_FLAG_0 (NODE) = 1)
6219a7c1 3081
ce23987e 3082/* Nonzero if NODE is a template template parameter. */
cd5dd2d8 3083#define DECL_TEMPLATE_TEMPLATE_PARM_P(NODE) \
6219a7c1 3084 (TREE_CODE (NODE) == TEMPLATE_DECL && DECL_TEMPLATE_PARM_P (NODE))
cd5dd2d8 3085
c3b9e457 3086/* Nonzero if NODE is a TEMPLATE_DECL representing an
3087 UNBOUND_CLASS_TEMPLATE tree node. */
3088#define DECL_UNBOUND_CLASS_TEMPLATE_P(NODE) \
3089 (TREE_CODE (NODE) == TEMPLATE_DECL && !DECL_TEMPLATE_RESULT (NODE))
3090
e857e9c7 3091#define DECL_FUNCTION_TEMPLATE_P(NODE) \
3092 (TREE_CODE (NODE) == TEMPLATE_DECL \
c3b9e457 3093 && !DECL_UNBOUND_CLASS_TEMPLATE_P (NODE) \
e857e9c7 3094 && TREE_CODE (DECL_TEMPLATE_RESULT (NODE)) == FUNCTION_DECL)
3095
0f0d5a69 3096/* Nonzero for a DECL that represents a template class. */
3097#define DECL_CLASS_TEMPLATE_P(NODE) \
3098 (TREE_CODE (NODE) == TEMPLATE_DECL \
c3b9e457 3099 && !DECL_UNBOUND_CLASS_TEMPLATE_P (NODE) \
0f0d5a69 3100 && TREE_CODE (DECL_TEMPLATE_RESULT (NODE)) == TYPE_DECL \
3101 && !DECL_TEMPLATE_TEMPLATE_PARM_P (NODE))
3102
c221de6c 3103/* Nonzero if NODE which declares a type. */
3104#define DECL_DECLARES_TYPE_P(NODE) \
3105 (TREE_CODE (NODE) == TYPE_DECL || DECL_CLASS_TEMPLATE_P (NODE))
3106
70a658bd 3107/* Nonzero if NODE is the typedef implicitly generated for a type when
56e75739 3108 the type is declared. In C++, `struct S {};' is roughly
3109 equivalent to `struct S {}; typedef struct S S;' in C.
3110 DECL_IMPLICIT_TYPEDEF_P will hold for the typedef indicated in this
3111 example. In C++, there is a second implicit typedef for each
3112 class, in the scope of `S' itself, so that you can say `S::S'.
3113 DECL_SELF_REFERENCE_P will hold for that second typedef. */
70a658bd 3114#define DECL_IMPLICIT_TYPEDEF_P(NODE) \
f58424d8 3115 (TREE_CODE (NODE) == TYPE_DECL && DECL_LANG_FLAG_2 (NODE))
70a658bd 3116#define SET_DECL_IMPLICIT_TYPEDEF_P(NODE) \
f58424d8 3117 (DECL_LANG_FLAG_2 (NODE) = 1)
56e75739 3118#define DECL_SELF_REFERENCE_P(NODE) \
3119 (TREE_CODE (NODE) == TYPE_DECL && DECL_LANG_FLAG_4 (NODE))
3120#define SET_DECL_SELF_REFERENCE_P(NODE) \
3121 (DECL_LANG_FLAG_4 (NODE) = 1)
70a658bd 3122
1ac9b32b 3123/* A `primary' template is one that has its own template header. A
3124 member function of a class template is a template, but not primary.
0f0d5a69 3125 A member template is primary. Friend templates are primary, too. */
3126
3127/* Returns the primary template corresponding to these parameters. */
3128#define DECL_PRIMARY_TEMPLATE(NODE) \
3129 (TREE_TYPE (DECL_INNERMOST_TEMPLATE_PARMS (NODE)))
3130
3160db1d 3131/* Returns nonzero if NODE is a primary template. */
f58424d8 3132#define PRIMARY_TEMPLATE_P(NODE) (DECL_PRIMARY_TEMPLATE (NODE) == (NODE))
e857e9c7 3133
a17c2a3a 3134/* Nonzero iff NODE is a specialization of a template. The value
a0ae7f4b 3135 indicates the type of specializations:
3136
3137 1=implicit instantiation
04ef83b7 3138
3139 2=partial or explicit specialization, e.g.:
3140
3141 template <> int min<int> (int, int),
3142
3143 3=explicit instantiation, e.g.:
3144
3145 template int min<int> (int, int);
55e5ccb9 3146
a0ae7f4b 3147 Note that NODE will be marked as a specialization even if the
3148 template it is instantiating is not a primary template. For
3149 example, given:
3150
3151 template <typename T> struct O {
3152 void f();
3153 struct I {};
3154 };
3155
3156 both O<int>::f and O<int>::I will be marked as instantiations.
3157
a17c2a3a 3158 If DECL_USE_TEMPLATE is nonzero, then DECL_TEMPLATE_INFO will also
55e5ccb9 3159 be non-NULL. */
f58424d8 3160#define DECL_USE_TEMPLATE(NODE) (DECL_LANG_SPECIFIC (NODE)->decl_flags.use_template)
ddb9bca7 3161
a0ae7f4b 3162/* Like DECL_USE_TEMPLATE, but for class types. */
3163#define CLASSTYPE_USE_TEMPLATE(NODE) \
3164 (LANG_TYPE_CLASS_CHECK (NODE)->use_template)
3165
3166/* True if NODE is a specialization of a primary template. */
3167#define CLASSTYPE_SPECIALIZATION_OF_PRIMARY_TEMPLATE_P(NODE) \
3168 (CLASS_TYPE_P (NODE) \
3169 && CLASSTYPE_USE_TEMPLATE (NODE) \
3170 && PRIMARY_TEMPLATE_P (CLASSTYPE_TI_TEMPLATE (arg)))
3171
ddb9bca7 3172#define DECL_TEMPLATE_INSTANTIATION(NODE) (DECL_USE_TEMPLATE (NODE) & 1)
3173#define CLASSTYPE_TEMPLATE_INSTANTIATION(NODE) \
3174 (CLASSTYPE_USE_TEMPLATE (NODE) & 1)
3175
3176#define DECL_TEMPLATE_SPECIALIZATION(NODE) (DECL_USE_TEMPLATE (NODE) == 2)
3177#define SET_DECL_TEMPLATE_SPECIALIZATION(NODE) (DECL_USE_TEMPLATE (NODE) = 2)
b5fe3425 3178
3179/* Returns true for an explicit or partial specialization of a class
3180 template. */
3a8f9e39 3181#define CLASSTYPE_TEMPLATE_SPECIALIZATION(NODE) \
ddb9bca7 3182 (CLASSTYPE_USE_TEMPLATE (NODE) == 2)
3a8f9e39 3183#define SET_CLASSTYPE_TEMPLATE_SPECIALIZATION(NODE) \
ddb9bca7 3184 (CLASSTYPE_USE_TEMPLATE (NODE) = 2)
3185
3186#define DECL_IMPLICIT_INSTANTIATION(NODE) (DECL_USE_TEMPLATE (NODE) == 1)
3187#define SET_DECL_IMPLICIT_INSTANTIATION(NODE) (DECL_USE_TEMPLATE (NODE) = 1)
3188#define CLASSTYPE_IMPLICIT_INSTANTIATION(NODE) \
f58424d8 3189 (CLASSTYPE_USE_TEMPLATE (NODE) == 1)
ddb9bca7 3190#define SET_CLASSTYPE_IMPLICIT_INSTANTIATION(NODE) \
f58424d8 3191 (CLASSTYPE_USE_TEMPLATE (NODE) = 1)
ddb9bca7 3192
3193#define DECL_EXPLICIT_INSTANTIATION(NODE) (DECL_USE_TEMPLATE (NODE) == 3)
3194#define SET_DECL_EXPLICIT_INSTANTIATION(NODE) (DECL_USE_TEMPLATE (NODE) = 3)
3195#define CLASSTYPE_EXPLICIT_INSTANTIATION(NODE) \
f58424d8 3196 (CLASSTYPE_USE_TEMPLATE (NODE) == 3)
ddb9bca7 3197#define SET_CLASSTYPE_EXPLICIT_INSTANTIATION(NODE) \
f58424d8 3198 (CLASSTYPE_USE_TEMPLATE (NODE) = 3)
b0722fac 3199
3160db1d 3200/* Nonzero if DECL is a friend function which is an instantiation
ff4b738d 3201 from the point of view of the compiler, but not from the point of
3202 view of the language. For example given:
3203 template <class T> struct S { friend void f(T) {}; };
3204 the declaration of `void f(int)' generated when S<int> is
3205 instantiated will not be a DECL_TEMPLATE_INSTANTIATION, but will be
3206 a DECL_FRIEND_PSUEDO_TEMPLATE_INSTANTIATION. */
3207#define DECL_FRIEND_PSEUDO_TEMPLATE_INSTANTIATION(DECL) \
3208 (DECL_TEMPLATE_INFO (DECL) && !DECL_USE_TEMPLATE (DECL))
3209
3160db1d 3210/* Nonzero iff we are currently processing a declaration for an
63e8563c 3211 entity with its own template parameter list, and which is not a
3212 full specialization. */
3213#define PROCESSING_REAL_TEMPLATE_DECL_P() \
4c1469a9 3214 (processing_template_decl > template_class_depth (current_scope ()))
63e8563c 3215
4012c20a 3216/* Nonzero if this VAR_DECL or FUNCTION_DECL has already been
3217 instantiated, i.e. its definition has been generated from the
dfea972c 3218 pattern given in the template. */
ad46fc6a 3219#define DECL_TEMPLATE_INSTANTIATED(NODE) \
3220 DECL_LANG_FLAG_1 (VAR_OR_FUNCTION_DECL_CHECK (NODE))
4012c20a 3221
c25194fd 3222/* We know what we're doing with this decl now. */
7030c696 3223#define DECL_INTERFACE_KNOWN(NODE) DECL_LANG_FLAG_5 (NODE)
c25194fd 3224
bb09dca5 3225/* DECL_EXTERNAL must be set on a decl until the decl is actually emitted,
3226 so that assemble_external will work properly. So we have this flag to
3227 tell us whether the decl is really not external. */
3228#define DECL_NOT_REALLY_EXTERN(NODE) \
3229 (DECL_LANG_SPECIFIC (NODE)->decl_flags.not_really_extern)
c25194fd 3230
3a8c5440 3231#define DECL_REALLY_EXTERN(NODE) \
3232 (DECL_EXTERNAL (NODE) && ! DECL_NOT_REALLY_EXTERN (NODE))
3233
a2697ab6 3234/* A thunk is a stub function.
3235
3236 A thunk is an alternate entry point for an ordinary FUNCTION_DECL.
3237 The address of the ordinary FUNCTION_DECL is given by the
3238 DECL_INITIAL, which is always an ADDR_EXPR whose operand is a
805e22b2 3239 FUNCTION_DECL. The job of the thunk is to either adjust the this
3240 pointer before transferring control to the FUNCTION_DECL, or call
3241 FUNCTION_DECL and then adjust the result value. Note, the result
3242 pointer adjusting thunk must perform a call to the thunked
3243 function, (or be implemented via passing some invisible parameter
3244 to the thunked function, which is modified to perform the
3245 adjustment just before returning).
ac13e8d9 3246
a2697ab6 3247 A thunk may perform either, or both, of the following operations:
3248
805e22b2 3249 o Adjust the this or result pointer by a constant offset.
3250 o Adjust the this or result pointer by looking up a vcall or vbase offset
a2697ab6 3251 in the vtable.
3252
805e22b2 3253 A this pointer adjusting thunk converts from a base to a derived
3254 class, and hence adds the offsets. A result pointer adjusting thunk
3255 converts from a derived class to a base, and hence subtracts the
3256 offsets. If both operations are performed, then the constant
755edffd 3257 adjustment is performed first for this pointer adjustment and last
805e22b2 3258 for the result pointer adjustment.
a2697ab6 3259
805e22b2 3260 The constant adjustment is given by THUNK_FIXED_OFFSET. If the
6709b660 3261 vcall or vbase offset is required, THUNK_VIRTUAL_OFFSET is
3262 used. For this pointer adjusting thunks, it is the vcall offset
3263 into the vtable. For result pointer adjusting thunks it is the
3264 binfo of the virtual base to convert to. Use that binfo's vbase
3265 offset.
3266
3267 It is possible to have equivalent covariant thunks. These are
3268 distinct virtual covariant thunks whose vbase offsets happen to
3269 have the same value. THUNK_ALIAS is used to pick one as the
3270 canonical thunk, which will get all the this pointer adjusting
3271 thunks attached to it. */
a2697ab6 3272
7b4abb45 3273/* An integer indicating how many bytes should be subtracted from the
805e22b2 3274 this or result pointer when this function is called. */
3275#define THUNK_FIXED_OFFSET(DECL) \
d409f4c9 3276 (DECL_LANG_SPECIFIC (THUNK_FUNCTION_CHECK (DECL))->u.f.u5.fixed_offset)
71b1859a 3277
3278/* A tree indicating how to perform the virtual adjustment. For a this
3279 adjusting thunk it is the number of bytes to be added to the vtable
3280 to find the vcall offset. For a result adjusting thunk, it is the
1bf5bd08 3281 binfo of the relevant virtual base. If NULL, then there is no
3282 virtual adjust. (The vptr is always located at offset zero from
3283 the this or result pointer.) (If the covariant type is within the
4880ab99 3284 class hierarchy being laid out, the vbase index is not yet known
1bf5bd08 3285 at the point we need to create the thunks, hence the need to use
3286 binfos.) */
3287
805e22b2 3288#define THUNK_VIRTUAL_OFFSET(DECL) \
2ca392fd 3289 (LANG_DECL_U2_CHECK (FUNCTION_DECL_CHECK (DECL), 0)->access)
71b1859a 3290
331bc0ad 3291/* A thunk which is equivalent to another thunk. */
6709b660 3292#define THUNK_ALIAS(DECL) \
2ca392fd 3293 (DECL_LANG_SPECIFIC (FUNCTION_DECL_CHECK (DECL))->decl_flags.u.template_info)
4880ab99 3294
f05abcd9 3295/* For thunk NODE, this is the FUNCTION_DECL thunked to. It is
3296 possible for the target to be a thunk too. */
71b1859a 3297#define THUNK_TARGET(NODE) \
3298 (DECL_LANG_SPECIFIC (NODE)->u.f.befriending_classes)
7b4abb45 3299
fbb01da7 3300/* True for a SCOPE_REF iff the "template" keyword was used to
3301 indicate that the qualified name denotes a template. */
3302#define QUALIFIED_NAME_IS_TEMPLATE(NODE) \
3303 (TREE_LANG_FLAG_0 (SCOPE_REF_CHECK (NODE)))
3304
8487df40 3305/* True for an OMP_ATOMIC that has dependent parameters. These are stored
75ba2ce8 3306 as an expr in operand 1, and integer_zero_node in operand 0. */
8487df40 3307#define OMP_ATOMIC_DEPENDENT_P(NODE) \
75ba2ce8 3308 (TREE_CODE (TREE_OPERAND (OMP_ATOMIC_CHECK (NODE), 0)) == INTEGER_CST)
8487df40 3309
3310/* Used while gimplifying continue statements bound to OMP_FOR nodes. */
3311#define OMP_FOR_GIMPLIFYING_P(NODE) \
3312 (TREE_LANG_FLAG_0 (OMP_FOR_CHECK (NODE)))
3313
074ab442 3314/* A language-specific token attached to the OpenMP data clauses to
8487df40 3315 hold code (or code fragments) related to ctors, dtors, and op=.
3316 See semantics.c for details. */
3317#define CP_OMP_CLAUSE_INFO(NODE) \
3318 TREE_TYPE (OMP_CLAUSE_RANGE_CHECK (NODE, OMP_CLAUSE_PRIVATE, \
074ab442 3319 OMP_CLAUSE_COPYPRIVATE))
8487df40 3320
0090dad2 3321/* These macros provide convenient access to the various _STMT nodes
3322 created when parsing template declarations. */
653e5405 3323#define TRY_STMTS(NODE) TREE_OPERAND (TRY_BLOCK_CHECK (NODE), 0)
3324#define TRY_HANDLERS(NODE) TREE_OPERAND (TRY_BLOCK_CHECK (NODE), 1)
92915e1c 3325
653e5405 3326#define EH_SPEC_STMTS(NODE) TREE_OPERAND (EH_SPEC_BLOCK_CHECK (NODE), 0)
3327#define EH_SPEC_RAISES(NODE) TREE_OPERAND (EH_SPEC_BLOCK_CHECK (NODE), 1)
df4b504c 3328
632cab6c 3329#define USING_STMT_NAMESPACE(NODE) TREE_OPERAND (USING_STMT_CHECK (NODE), 0)
3330
0a8302dc 3331/* Nonzero if this try block is a function try block. */
653e5405 3332#define FN_TRY_BLOCK_P(NODE) TREE_LANG_FLAG_3 (TRY_BLOCK_CHECK (NODE))
3333#define HANDLER_PARMS(NODE) TREE_OPERAND (HANDLER_CHECK (NODE), 0)
3334#define HANDLER_BODY(NODE) TREE_OPERAND (HANDLER_CHECK (NODE), 1)
6993fb0a 3335#define HANDLER_TYPE(NODE) TREE_TYPE (HANDLER_CHECK (NODE))
31236dcd 3336
dddab69e 3337/* CLEANUP_STMT accessors. The statement(s) covered, the cleanup to run
3338 and the VAR_DECL for which this cleanup exists. */
3339#define CLEANUP_BODY(NODE) TREE_OPERAND (CLEANUP_STMT_CHECK (NODE), 0)
3340#define CLEANUP_EXPR(NODE) TREE_OPERAND (CLEANUP_STMT_CHECK (NODE), 1)
3341#define CLEANUP_DECL(NODE) TREE_OPERAND (CLEANUP_STMT_CHECK (NODE), 2)
3342
3343/* IF_STMT accessors. These give access to the condition of the if
3344 statement, the then block of the if statement, and the else block
3345 of the if statement if it exists. */
653e5405 3346#define IF_COND(NODE) TREE_OPERAND (IF_STMT_CHECK (NODE), 0)
3347#define THEN_CLAUSE(NODE) TREE_OPERAND (IF_STMT_CHECK (NODE), 1)
3348#define ELSE_CLAUSE(NODE) TREE_OPERAND (IF_STMT_CHECK (NODE), 2)
dddab69e 3349
e7911019 3350/* WHILE_STMT accessors. These give access to the condition of the
3351 while statement and the body of the while statement, respectively. */
653e5405 3352#define WHILE_COND(NODE) TREE_OPERAND (WHILE_STMT_CHECK (NODE), 0)
3353#define WHILE_BODY(NODE) TREE_OPERAND (WHILE_STMT_CHECK (NODE), 1)
e7911019 3354
3355/* DO_STMT accessors. These give access to the condition of the do
3356 statement and the body of the do statement, respectively. */
653e5405 3357#define DO_COND(NODE) TREE_OPERAND (DO_STMT_CHECK (NODE), 0)
3358#define DO_BODY(NODE) TREE_OPERAND (DO_STMT_CHECK (NODE), 1)
e7911019 3359
3360/* FOR_STMT accessors. These give access to the init statement,
3361 condition, update expression, and body of the for statement,
3362 respectively. */
653e5405 3363#define FOR_INIT_STMT(NODE) TREE_OPERAND (FOR_STMT_CHECK (NODE), 0)
3364#define FOR_COND(NODE) TREE_OPERAND (FOR_STMT_CHECK (NODE), 1)
3365#define FOR_EXPR(NODE) TREE_OPERAND (FOR_STMT_CHECK (NODE), 2)
3366#define FOR_BODY(NODE) TREE_OPERAND (FOR_STMT_CHECK (NODE), 3)
e7911019 3367
3368#define SWITCH_STMT_COND(NODE) TREE_OPERAND (SWITCH_STMT_CHECK (NODE), 0)
3369#define SWITCH_STMT_BODY(NODE) TREE_OPERAND (SWITCH_STMT_CHECK (NODE), 1)
3370#define SWITCH_STMT_TYPE(NODE) TREE_OPERAND (SWITCH_STMT_CHECK (NODE), 2)
3371
57f08f11 3372/* STMT_EXPR accessor. */
653e5405 3373#define STMT_EXPR_STMT(NODE) TREE_OPERAND (STMT_EXPR_CHECK (NODE), 0)
57f08f11 3374
7219fab5 3375/* EXPR_STMT accessor. This gives the expression associated with an
3376 expression statement. */
653e5405 3377#define EXPR_STMT_EXPR(NODE) TREE_OPERAND (EXPR_STMT_CHECK (NODE), 0)
7219fab5 3378
25b3017b 3379/* True if this TARGET_EXPR was created by build_cplus_new, and so we can
3380 discard it if it isn't useful. */
3381#define TARGET_EXPR_IMPLICIT_P(NODE) \
3382 TREE_LANG_FLAG_0 (TARGET_EXPR_CHECK (NODE))
3383
471086d6 3384/* An enumeration of the kind of tags that C++ accepts. */
ac13e8d9 3385enum tag_types {
0a3b29ad 3386 none_type = 0, /* Not a tag type. */
3387 record_type, /* "struct" types. */
3388 class_type, /* "class" types. */
3389 union_type, /* "union" types. */
3390 enum_type, /* "enum" types. */
3391 typename_type /* "typename" types. */
3392};
471086d6 3393
a3786328 3394/* The various kinds of lvalues we distinguish. */
3395typedef enum cp_lvalue_kind {
3396 clk_none = 0, /* Things that are not an lvalue. */
3397 clk_ordinary = 1, /* An ordinary lvalue. */
3398 clk_class = 2, /* An rvalue of class-type. */
8e68bf5f 3399 clk_bitfield = 4, /* An lvalue for a bit-field. */
331bc0ad 3400 clk_packed = 8 /* An lvalue for a packed field. */
a3786328 3401} cp_lvalue_kind;
3402
3467e461 3403/* Various kinds of template specialization, instantiation, etc. */
3404typedef enum tmpl_spec_kind {
653e5405 3405 tsk_none, /* Not a template at all. */
3467e461 3406 tsk_invalid_member_spec, /* An explicit member template
3407 specialization, but the enclosing
3408 classes have not all been explicitly
3409 specialized. */
3410 tsk_invalid_expl_inst, /* An explicit instantiation containing
3411 template parameter lists. */
653e5405 3412 tsk_excessive_parms, /* A template declaration with too many
3467e461 3413 template parameter lists. */
3414 tsk_insufficient_parms, /* A template declaration with too few
3415 parameter lists. */
653e5405 3416 tsk_template, /* A template declaration. */
3417 tsk_expl_spec, /* An explicit specialization. */
3418 tsk_expl_inst /* An explicit instantiation. */
3467e461 3419} tmpl_spec_kind;
3420
59751e6c 3421/* The various kinds of access. BINFO_ACCESS depends on these being
3422 two bit quantities. The numerical values are important; they are
9abe66a7 3423 used to initialize RTTI data structures, so changing them changes
6beb3f76 3424 the ABI. */
59751e6c 3425typedef enum access_kind {
653e5405 3426 ak_none = 0, /* Inaccessible. */
3427 ak_public = 1, /* Accessible, as a `public' thing. */
3428 ak_protected = 2, /* Accessible, as a `protected' thing. */
3429 ak_private = 3 /* Accessible, as a `private' thing. */
59751e6c 3430} access_kind;
3431
6d0f8076 3432/* The various kinds of special functions. If you add to this list,
3433 you should update special_function_p as well. */
bb855ff9 3434typedef enum special_function_kind {
653e5405 3435 sfk_none = 0, /* Not a special function. This enumeral
6d0f8076 3436 must have value zero; see
3437 special_function_p. */
653e5405 3438 sfk_constructor, /* A constructor. */
cfb46e1f 3439 sfk_copy_constructor, /* A copy constructor. */
3440 sfk_assignment_operator, /* An assignment operator. */
653e5405 3441 sfk_destructor, /* A destructor. */
6d0f8076 3442 sfk_complete_destructor, /* A destructor for complete objects. */
3443 sfk_base_destructor, /* A destructor for base subobjects. */
3444 sfk_deleting_destructor, /* A destructor for complete objects that
3445 deletes the object after it has been
3446 destroyed. */
653e5405 3447 sfk_conversion /* A conversion operator. */
bb855ff9 3448} special_function_kind;
3449
ac13e8d9 3450/* The various kinds of linkage. From [basic.link],
3451
a1abbd01 3452 A name is said to have linkage when it might denote the same
3453 object, reference, function, type, template, namespace or value
3454 as a name introduced in another scope:
3455
3456 -- When a name has external linkage, the entity it denotes can
653e5405 3457 be referred to from scopes of other translation units or from
a1abbd01 3458 other scopes of the same translation unit.
3459
3460 -- When a name has internal linkage, the entity it denotes can
653e5405 3461 be referred to by names from other scopes in the same
a1abbd01 3462 translation unit.
3463
3464 -- When a name has no linkage, the entity it denotes cannot be
653e5405 3465 referred to by names from other scopes. */
a1abbd01 3466
3467typedef enum linkage_kind {
653e5405 3468 lk_none, /* No linkage. */
3469 lk_internal, /* Internal linkage. */
3470 lk_external /* External linkage. */
a1abbd01 3471} linkage_kind;
3472
4b471722 3473/* Bitmask flags to control type substitution. */
3474typedef enum tsubst_flags_t {
653e5405 3475 tf_none = 0, /* nothing special */
3476 tf_error = 1 << 0, /* give error messages */
3477 tf_warning = 1 << 1, /* give warnings too */
3478 tf_ignore_bad_quals = 1 << 2, /* ignore bad cvr qualifiers */
56f8f075 3479 tf_keep_type_decl = 1 << 3, /* retain typedef type decls
9edbac04 3480 (make_typename_type use) */
653e5405 3481 tf_ptrmem_ok = 1 << 4, /* pointers to member ok (internal
b992fe70 3482 instantiate_type use) */
942ab15b 3483 tf_user = 1 << 5, /* found template must be a user template
b992fe70 3484 (lookup_template_class use) */
a26072fd 3485 tf_conv = 1 << 6, /* We are determining what kind of
4d1539d1 3486 conversion might be permissible,
3487 not actually performing the
3488 conversion. */
a26072fd 3489 /* Convenient substitution flags combinations. */
0fbca5e8 3490 tf_warning_or_error = tf_warning | tf_error
4b471722 3491} tsubst_flags_t;
ffe5bd74 3492
c0af329c 3493/* The kind of checking we can do looking in a class hierarchy. */
4a2680fc 3494typedef enum base_access {
ada40935 3495 ba_any = 0, /* Do not check access, allow an ambiguous base,
4a2680fc 3496 prefer a non-virtual base */
ada40935 3497 ba_unique = 1 << 0, /* Must be a unique base. */
3498 ba_check_bit = 1 << 1, /* Check access. */
3499 ba_check = ba_unique | ba_check_bit,
3500 ba_ignore_scope = 1 << 2, /* Ignore access allowed by local scope. */
3501 ba_quiet = 1 << 3 /* Do not issue error messages. */
4a2680fc 3502} base_access;
3503
4f62c42e 3504/* The various kinds of access check during parsing. */
3505typedef enum deferring_kind {
3506 dk_no_deferred = 0, /* Check access immediately */
3507 dk_deferred = 1, /* Deferred check */
3508 dk_no_check = 2 /* No access check */
3509} deferring_kind;
3510
4109ca29 3511/* The kind of base we can find, looking in a class hierarchy.
c0af329c 3512 Values <0 indicate we failed. */
4a2680fc 3513typedef enum base_kind {
3514 bk_inaccessible = -3, /* The base is inaccessible */
653e5405 3515 bk_ambig = -2, /* The base is ambiguous */
3516 bk_not_base = -1, /* It is not a base */
3517 bk_same_type = 0, /* It is the same type */
3518 bk_proper_base = 1, /* It is a proper base */
3519 bk_via_virtual = 2 /* It is a proper base, but via a virtual
4a2680fc 3520 path. This might not be the canonical
c0af329c 3521 binfo. */
4a2680fc 3522} base_kind;
3523
94f3b32d 3524/* Node for "pointer to (virtual) function".
96624a9e 3525 This may be distinct from ptr_type_node so gdb can distinguish them. */
dc9b5a48 3526#define vfunc_ptr_type_node vtable_entry_type
94f3b32d 3527
471086d6 3528
471086d6 3529/* For building calls to `delete'. */
1f3233d1 3530extern GTY(()) tree integer_two_node;
3531extern GTY(()) tree integer_three_node;
471086d6 3532
3563027c 3533/* The number of function bodies which we are currently processing.
3534 (Zero if we are at namespace scope, one inside the body of a
3535 function, two inside the body of a function in a local class, etc.) */
3536extern int function_depth;
3537
ac9386a0 3538/* in pt.c */
e857e9c7 3539
efa31275 3540/* These values are used for the `STRICT' parameter to type_unification and
32b5f03e 3541 fn_type_unification. Their meanings are described with the
3542 documentation for fn_type_unification. */
3543
3544typedef enum unification_kind_t {
3545 DEDUCE_CALL,
3546 DEDUCE_CONV,
517ee39a 3547 DEDUCE_EXACT
32b5f03e 3548} unification_kind_t;
3549
ac9386a0 3550/* in class.c */
0f2952a1 3551
01b3f071 3552extern int current_class_depth;
471086d6 3553
98eaf693 3554/* An array of all local classes present in this translation unit, in
3555 declaration order. */
836c0125 3556extern GTY(()) VEC(tree,gc) *local_classes;
471086d6 3557\f
3558/* Here's where we control how name mangling takes place. */
3559
471086d6 3560/* Cannot use '$' up front, because this confuses gdb
3561 (names beginning with '$' are gdb-local identifiers).
3562
3563 Note that all forms in which the '$' is significant are long enough
3564 for direct indexing (meaning that if we know there is a '$'
3565 at a particular location, we can index into the string at
3566 any other location that provides distinguishing characters). */
3567
3568/* Define NO_DOLLAR_IN_LABEL in your favorite tm file if your assembler
3569 doesn't allow '$' in symbol names. */
3570#ifndef NO_DOLLAR_IN_LABEL
3571
3572#define JOINER '$'
3573
471086d6 3574#define AUTO_TEMP_NAME "_$tmp_"
471086d6 3575#define VFIELD_BASE "$vf"
3576#define VFIELD_NAME "_vptr$"
3577#define VFIELD_NAME_FORMAT "_vptr$%s"
471086d6 3578#define ANON_AGGRNAME_FORMAT "$_%d"
3579
3580#else /* NO_DOLLAR_IN_LABEL */
3581
3582#ifndef NO_DOT_IN_LABEL
3583
3584#define JOINER '.'
3585
471086d6 3586#define AUTO_TEMP_NAME "_.tmp_"
471086d6 3587#define VFIELD_BASE ".vf"
3588#define VFIELD_NAME "_vptr."
3589#define VFIELD_NAME_FORMAT "_vptr.%s"
471086d6 3590
3591#define ANON_AGGRNAME_FORMAT "._%d"
3592
3593#else /* NO_DOT_IN_LABEL */
3594
471086d6 3595#define IN_CHARGE_NAME "__in_chrg"
471086d6 3596#define AUTO_TEMP_NAME "__tmp_"
3597#define TEMP_NAME_P(ID_NODE) \
3598 (!strncmp (IDENTIFIER_POINTER (ID_NODE), AUTO_TEMP_NAME, \
3599 sizeof (AUTO_TEMP_NAME) - 1))
471086d6 3600#define VTABLE_NAME "__vt_"
471086d6 3601#define VTABLE_NAME_P(ID_NODE) \
3602 (!strncmp (IDENTIFIER_POINTER (ID_NODE), VTABLE_NAME, \
3603 sizeof (VTABLE_NAME) - 1))
3604#define VFIELD_BASE "__vfb"
3605#define VFIELD_NAME "__vptr_"
3606#define VFIELD_NAME_P(ID_NODE) \
3607 (!strncmp (IDENTIFIER_POINTER (ID_NODE), VFIELD_NAME, \
3608 sizeof (VFIELD_NAME) - 1))
b5672762 3609#define VFIELD_NAME_FORMAT "__vptr_%s"
471086d6 3610
3611#define ANON_AGGRNAME_PREFIX "__anon_"
3612#define ANON_AGGRNAME_P(ID_NODE) \
3613 (!strncmp (IDENTIFIER_POINTER (ID_NODE), ANON_AGGRNAME_PREFIX, \
3614 sizeof (ANON_AGGRNAME_PREFIX) - 1))
3615#define ANON_AGGRNAME_FORMAT "__anon_%d"
471086d6 3616
3617#endif /* NO_DOT_IN_LABEL */
3618#endif /* NO_DOLLAR_IN_LABEL */
3619
3620#define THIS_NAME "this"
471086d6 3621
3622#define IN_CHARGE_NAME "__in_chrg"
3623
3624#define VTBL_PTR_TYPE "__vtbl_ptr_type"
3625#define VTABLE_DELTA_NAME "__delta"
471086d6 3626#define VTABLE_PFN_NAME "__pfn"
471086d6 3627
471086d6 3628#if !defined(NO_DOLLAR_IN_LABEL) || !defined(NO_DOT_IN_LABEL)
3629
471086d6 3630#define VTABLE_NAME_P(ID_NODE) (IDENTIFIER_POINTER (ID_NODE)[1] == 'v' \
3631 && IDENTIFIER_POINTER (ID_NODE)[2] == 't' \
3632 && IDENTIFIER_POINTER (ID_NODE)[3] == JOINER)
3633
f58424d8 3634#define TEMP_NAME_P(ID_NODE) \
3635 (!strncmp (IDENTIFIER_POINTER (ID_NODE), AUTO_TEMP_NAME, sizeof (AUTO_TEMP_NAME)-1))
3636#define VFIELD_NAME_P(ID_NODE) \
3637 (!strncmp (IDENTIFIER_POINTER (ID_NODE), VFIELD_NAME, sizeof(VFIELD_NAME)-1))
471086d6 3638
3639/* For anonymous aggregate types, we need some sort of name to
3640 hold on to. In practice, this should not appear, but it should
3641 not be harmful if it does. */
3642#define ANON_AGGRNAME_P(ID_NODE) (IDENTIFIER_POINTER (ID_NODE)[0] == JOINER \
3643 && IDENTIFIER_POINTER (ID_NODE)[1] == '_')
471086d6 3644#endif /* !defined(NO_DOLLAR_IN_LABEL) || !defined(NO_DOT_IN_LABEL) */
9426b767 3645
471086d6 3646\f
e857e9c7 3647/* Nonzero if we're done parsing and into end-of-file activities. */
3648
3649extern int at_eof;
3650
ce0c3b07 3651/* A list of namespace-scope objects which have constructors or
3652 destructors which reside in the global scope. The decl is stored
3653 in the TREE_VALUE slot and the initializer is stored in the
3654 TREE_PURPOSE slot. */
3655extern GTY(()) tree static_aggregates;
3656
471086d6 3657enum overload_flags { NO_SPECIAL = 0, DTOR_FLAG, OP_FLAG, TYPENAME_FLAG };
3658
1fb8fb56 3659/* These are uses as bits in flags passed to various functions to
3660 control their behavior. Despite the LOOKUP_ prefix, many of these
3661 do not control name lookup. ??? Functions using these flags should
3662 probably be modified to accept explicit boolean flags for the
3663 behaviors relevant to them. */
3664/* Check for access violations. */
bb560c37 3665#define LOOKUP_PROTECT (1 << 0)
1fb8fb56 3666/* Complain if no suitable member function matching the arguments is
3667 found. */
bb560c37 3668#define LOOKUP_COMPLAIN (1 << 1)
3669#define LOOKUP_NORMAL (LOOKUP_PROTECT | LOOKUP_COMPLAIN)
1fb8fb56 3670/* Even if the function found by lookup is a virtual function, it
3671 should be called directly. */
bb560c37 3672#define LOOKUP_NONVIRTUAL (1 << 2)
1fb8fb56 3673/* Non-converting (i.e., "explicit") constructors are not tried. */
a529afc9 3674#define LOOKUP_ONLYCONVERTING (1 << 3)
1fb8fb56 3675/* If a temporary is created, it should be created so that it lives
3676 as long as the current variable bindings; otherwise it only lives
3677 until the end of the complete-expression. It also forces
3678 direct-initialization in cases where other parts of the compiler
3679 have already generated a temporary, such as reference
3680 initialization and the catch parameter. */
a529afc9 3681#define DIRECT_BIND (1 << 4)
1fb8fb56 3682/* User-defined conversions are not permitted. (Built-in conversions
3683 are permitted.) */
a529afc9 3684#define LOOKUP_NO_CONVERSION (1 << 5)
1fb8fb56 3685/* The user has explicitly called a destructor. (Therefore, we do
3686 not need to check that the object is non-NULL before calling the
3687 destructor.) */
a529afc9 3688#define LOOKUP_DESTRUCTOR (1 << 6)
1fb8fb56 3689/* Do not permit references to bind to temporaries. */
a529afc9 3690#define LOOKUP_NO_TEMP_BIND (1 << 7)
1fb8fb56 3691/* Do not accept objects, and possibly namespaces. */
a529afc9 3692#define LOOKUP_PREFER_TYPES (1 << 8)
1fb8fb56 3693/* Do not accept objects, and possibly types. */
a529afc9 3694#define LOOKUP_PREFER_NAMESPACES (1 << 9)
1fb8fb56 3695/* Accept types or namespaces. */
bb560c37 3696#define LOOKUP_PREFER_BOTH (LOOKUP_PREFER_TYPES | LOOKUP_PREFER_NAMESPACES)
1fb8fb56 3697/* We are checking that a constructor can be called -- but we do not
3698 actually plan to call it. */
a529afc9 3699#define LOOKUP_CONSTRUCTOR_CALLABLE (1 << 10)
c5f4a9c4 3700/* Return friend declarations and un-declared builtin functions.
1fb8fb56 3701 (Normally, these entities are registered in the symbol table, but
3702 not found by lookup.) */
3703#define LOOKUP_HIDDEN (LOOKUP_CONSTRUCTOR_CALLABLE << 1)
63949b38 3704/* Prefer that the lvalue be treated as an rvalue. */
3705#define LOOKUP_PREFER_RVALUE (LOOKUP_HIDDEN << 1)
0309a517 3706
f58424d8 3707#define LOOKUP_NAMESPACES_ONLY(F) \
3708 (((F) & LOOKUP_PREFER_NAMESPACES) && !((F) & LOOKUP_PREFER_TYPES))
3709#define LOOKUP_TYPES_ONLY(F) \
3710 (!((F) & LOOKUP_PREFER_NAMESPACES) && ((F) & LOOKUP_PREFER_TYPES))
3711#define LOOKUP_QUALIFIERS_ONLY(F) ((F) & LOOKUP_PREFER_BOTH)
50cd3f45 3712
471086d6 3713
d81e00a4 3714/* These flags are used by the conversion code.
3715 CONV_IMPLICIT : Perform implicit conversions (standard and user-defined).
3716 CONV_STATIC : Perform the explicit conversions for static_cast.
3717 CONV_CONST : Perform the explicit conversions for const_cast.
3718 CONV_REINTERPRET: Perform the explicit conversions for reinterpret_cast.
a74e8896 3719 CONV_PRIVATE : Perform upcasts to private bases.
1a3f833b 3720 CONV_FORCE_TEMP : Require a new temporary when converting to the same
50cd3f45 3721 aggregate type. */
d81e00a4 3722
3723#define CONV_IMPLICIT 1
3724#define CONV_STATIC 2
3725#define CONV_CONST 4
3726#define CONV_REINTERPRET 8
3727#define CONV_PRIVATE 16
860740a7 3728/* #define CONV_NONCONVERTING 32 */
1a3f833b 3729#define CONV_FORCE_TEMP 64
d81e00a4 3730#define CONV_OLD_CONVERT (CONV_IMPLICIT | CONV_STATIC | CONV_CONST \
3731 | CONV_REINTERPRET)
3732#define CONV_C_CAST (CONV_IMPLICIT | CONV_STATIC | CONV_CONST \
1a3f833b 3733 | CONV_REINTERPRET | CONV_PRIVATE | CONV_FORCE_TEMP)
d81e00a4 3734
1e66592c 3735/* Used by build_expr_type_conversion to indicate which types are
3736 acceptable as arguments to the expression under consideration. */
3737
3738#define WANT_INT 1 /* integer types, including bool */
3739#define WANT_FLOAT 2 /* floating point types */
3740#define WANT_ENUM 4 /* enumerated types */
3741#define WANT_POINTER 8 /* pointer types */
3742#define WANT_NULL 16 /* null pointer constant */
96ec9e30 3743#define WANT_VECTOR 32 /* vector types */
3744#define WANT_ARITH (WANT_INT | WANT_FLOAT | WANT_VECTOR)
1e66592c 3745
daf9ff67 3746/* Used with comptypes, and related functions, to guide type
3747 comparison. */
3748
653e5405 3749#define COMPARE_STRICT 0 /* Just check if the types are the
daf9ff67 3750 same. */
653e5405 3751#define COMPARE_BASE 1 /* Check to see if the second type is
00952d10 3752 derived from the first. */
653e5405 3753#define COMPARE_DERIVED 2 /* Like COMPARE_BASE, but in
00952d10 3754 reverse. */
755edffd 3755#define COMPARE_REDECLARATION 4 /* The comparison is being done when
daf9ff67 3756 another declaration of an existing
3757 entity is seen. */
6753bca0 3758#define COMPARE_STRUCTURAL 8 /* The comparison is intended to be
3759 structural. The actual comparison
3760 will be identical to
3761 COMPARE_STRICT. */
daf9ff67 3762
91bbfe2a 3763/* Used with push_overloaded_decl. */
653e5405 3764#define PUSH_GLOBAL 0 /* Push the DECL into namespace scope,
91bbfe2a 3765 regardless of the current scope. */
653e5405 3766#define PUSH_LOCAL 1 /* Push the DECL into the current
91bbfe2a 3767 scope. */
653e5405 3768#define PUSH_USING 2 /* We are pushing this DECL as the
91bbfe2a 3769 result of a using declaration. */
3770
d119628b 3771/* Used with start function. */
653e5405 3772#define SF_DEFAULT 0 /* No flags. */
3773#define SF_PRE_PARSED 1 /* The function declaration has
d119628b 3774 already been parsed. */
3775#define SF_INCLASS_INLINE 2 /* The function is an inline, defined
3776 in the class body. */
1361fb16 3777
daf9ff67 3778/* Returns nonzero iff TYPE1 and TYPE2 are the same type, or if TYPE2
3779 is derived from TYPE1, or if TYPE2 is a pointer (reference) to a
3780 class derived from the type pointed to (referred to) by TYPE1. */
f58424d8 3781#define same_or_base_type_p(TYPE1, TYPE2) \
3782 comptypes ((TYPE1), (TYPE2), COMPARE_BASE)
daf9ff67 3783
f3110581 3784/* These macros are used to access a TEMPLATE_PARM_INDEX. */
ad46fc6a 3785#define TEMPLATE_PARM_INDEX_CAST(NODE) \
3786 ((template_parm_index*)TEMPLATE_PARM_INDEX_CHECK (NODE))
3787#define TEMPLATE_PARM_IDX(NODE) (TEMPLATE_PARM_INDEX_CAST (NODE)->index)
3788#define TEMPLATE_PARM_LEVEL(NODE) (TEMPLATE_PARM_INDEX_CAST (NODE)->level)
f3110581 3789#define TEMPLATE_PARM_DESCENDANTS(NODE) (TREE_CHAIN (NODE))
ad46fc6a 3790#define TEMPLATE_PARM_ORIG_LEVEL(NODE) (TEMPLATE_PARM_INDEX_CAST (NODE)->orig_level)
3791#define TEMPLATE_PARM_DECL(NODE) (TEMPLATE_PARM_INDEX_CAST (NODE)->decl)
855ed7a1 3792#define TEMPLATE_PARM_PARAMETER_PACK(NODE) \
3793 (TREE_LANG_FLAG_0 (TEMPLATE_PARM_INDEX_CHECK (NODE)))
f3110581 3794
50cd3f45 3795/* These macros are for accessing the fields of TEMPLATE_TYPE_PARM,
1e93ca27 3796 TEMPLATE_TEMPLATE_PARM and BOUND_TEMPLATE_TEMPLATE_PARM nodes. */
75e26b19 3797#define TEMPLATE_TYPE_PARM_INDEX(NODE) \
3798 (TREE_CHECK3 ((NODE), TEMPLATE_TYPE_PARM, TEMPLATE_TEMPLATE_PARM, \
3799 BOUND_TEMPLATE_TEMPLATE_PARM))->type.values
f3110581 3800#define TEMPLATE_TYPE_IDX(NODE) \
3801 (TEMPLATE_PARM_IDX (TEMPLATE_TYPE_PARM_INDEX (NODE)))
3802#define TEMPLATE_TYPE_LEVEL(NODE) \
3803 (TEMPLATE_PARM_LEVEL (TEMPLATE_TYPE_PARM_INDEX (NODE)))
3804#define TEMPLATE_TYPE_ORIG_LEVEL(NODE) \
3805 (TEMPLATE_PARM_ORIG_LEVEL (TEMPLATE_TYPE_PARM_INDEX (NODE)))
3806#define TEMPLATE_TYPE_DECL(NODE) \
3807 (TEMPLATE_PARM_DECL (TEMPLATE_TYPE_PARM_INDEX (NODE)))
d95d815d 3808#define TEMPLATE_TYPE_PARAMETER_PACK(NODE) \
3809 (TEMPLATE_PARM_PARAMETER_PACK (TEMPLATE_TYPE_PARM_INDEX (NODE)))
471086d6 3810
682959c4 3811/* These constants can used as bit flags in the process of tree formatting.
3812
3813 TFF_PLAIN_IDENTIFIER: unqualified part of a name.
5124a2c8 3814 TFF_SCOPE: include the class and namespace scope of the name.
682959c4 3815 TFF_CHASE_TYPEDEF: print the original type-id instead of the typedef-name.
3816 TFF_DECL_SPECIFIERS: print decl-specifiers.
3817 TFF_CLASS_KEY_OR_ENUM: precede a class-type name (resp. enum name) with
3818 a class-key (resp. `enum').
3819 TFF_RETURN_TYPE: include function return type.
3820 TFF_FUNCTION_DEFAULT_ARGUMENTS: include function default parameter values.
3821 TFF_EXCEPTION_SPECIFICATION: show function exception specification.
09cf0821 3822 TFF_TEMPLATE_HEADER: show the template<...> header in a
682959c4 3823 template-declaration.
682959c4 3824 TFF_TEMPLATE_NAME: show only template-name.
3d2a7578 3825 TFF_EXPR_IN_PARENS: parenthesize expressions.
facb12b2 3826 TFF_NO_FUNCTION_ARGUMENTS: don't show function arguments.
3827 TFF_UNQUALIFIED_NAME: do not print the qualifying scope of the
3828 top-level entity. */
682959c4 3829
653e5405 3830#define TFF_PLAIN_IDENTIFIER (0)
3831#define TFF_SCOPE (1)
3832#define TFF_CHASE_TYPEDEF (1 << 1)
3833#define TFF_DECL_SPECIFIERS (1 << 2)
3834#define TFF_CLASS_KEY_OR_ENUM (1 << 3)
3835#define TFF_RETURN_TYPE (1 << 4)
3836#define TFF_FUNCTION_DEFAULT_ARGUMENTS (1 << 5)
3837#define TFF_EXCEPTION_SPECIFICATION (1 << 6)
3838#define TFF_TEMPLATE_HEADER (1 << 7)
3839#define TFF_TEMPLATE_NAME (1 << 8)
3840#define TFF_EXPR_IN_PARENS (1 << 9)
3841#define TFF_NO_FUNCTION_ARGUMENTS (1 << 10)
facb12b2 3842#define TFF_UNQUALIFIED_NAME (1 << 11)
d04f0501 3843
6d2b611f 3844/* Returns the TEMPLATE_DECL associated to a TEMPLATE_TEMPLATE_PARM
3845 node. */
50cd3f45 3846#define TEMPLATE_TEMPLATE_PARM_TEMPLATE_DECL(NODE) \
1e93ca27 3847 ((TREE_CODE (NODE) == BOUND_TEMPLATE_TEMPLATE_PARM) \
50cd3f45 3848 ? TYPE_TI_TEMPLATE (NODE) \
6d2b611f 3849 : TYPE_NAME (NODE))
3850
ac9386a0 3851/* in lex.c */
9ceb1c29 3852
42283c76 3853extern void init_reswords (void);
9ceb1c29 3854
92915e1c 3855/* Indexed by TREE_CODE, these tables give C-looking names to
3856 operators represented by TREE_CODES. For example,
3857 opname_tab[(int) MINUS_EXPR] == "-". */
3858extern const char **opname_tab, **assignop_tab;
97cc4539 3859
573aba85 3860typedef struct operator_name_info_t GTY(())
97cc4539 3861{
3862 /* The IDENTIFIER_NODE for the operator. */
3863 tree identifier;
3864 /* The name of the operator. */
3865 const char *name;
3866 /* The mangled name of the operator. */
3867 const char *mangled_name;
94302392 3868 /* The arity of the operator. */
3869 int arity;
97cc4539 3870} operator_name_info_t;
3871
3872/* A mapping from tree codes to operator name information. */
573aba85 3873extern GTY(()) operator_name_info_t operator_name_info
3874 [(int) LAST_CPLUS_TREE_CODE];
97cc4539 3875/* Similar, but for assignment operators. */
573aba85 3876extern GTY(()) operator_name_info_t assignment_operator_name_info
3877 [(int) LAST_CPLUS_TREE_CODE];
97cc4539 3878
2cfb6cde 3879/* A type-qualifier, or bitmask therefore, using the TYPE_QUAL
3880 constants. */
3881
3882typedef int cp_cv_quals;
3883
4b9b2871 3884/* A storage class. */
3885
3886typedef enum cp_storage_class {
3887 /* sc_none must be zero so that zeroing a cp_decl_specifier_seq
3888 sets the storage_class field to sc_none. */
3889 sc_none = 0,
3890 sc_auto,
3891 sc_register,
3892 sc_static,
3893 sc_extern,
3fb4d428 3894 sc_mutable
4b9b2871 3895} cp_storage_class;
3896
3897/* An individual decl-specifier. */
3898
3899typedef enum cp_decl_spec {
3900 ds_first,
3901 ds_signed = ds_first,
3902 ds_unsigned,
3903 ds_short,
3904 ds_long,
3905 ds_const,
3906 ds_volatile,
3907 ds_restrict,
3908 ds_inline,
3909 ds_virtual,
3910 ds_explicit,
3911 ds_friend,
3912 ds_typedef,
3913 ds_complex,
3914 ds_thread,
3915 ds_last
3916} cp_decl_spec;
3917
3918/* A decl-specifier-seq. */
3919
3920typedef struct cp_decl_specifier_seq {
3921 /* The number of times each of the keywords has been seen. */
3922 unsigned specs[(int) ds_last];
3923 /* The primary type, if any, given by the decl-specifier-seq.
3924 Modifiers, like "short", "const", and "unsigned" are not
3925 reflected here. This field will be a TYPE, unless a typedef-name
3926 was used, in which case it will be a TYPE_DECL. */
3927 tree type;
3928 /* The attributes, if any, provided with the specifier sequence. */
3929 tree attributes;
3930 /* If non-NULL, a built-in type that the user attempted to redefine
3931 to some other type. */
3932 tree redefined_builtin_type;
3933 /* The storage class specified -- or sc_none if no storage class was
3934 explicitly specified. */
3935 cp_storage_class storage_class;
3936 /* True iff TYPE_SPEC indicates a user-defined type. */
3937 BOOL_BITFIELD user_defined_type_p : 1;
3938 /* True iff multiple types were (erroneously) specified for this
3939 decl-specifier-seq. */
3940 BOOL_BITFIELD multiple_types_p : 1;
3941 /* True iff multiple storage classes were (erroneously) specified
ceec99b9 3942 for this decl-specifier-seq or a combination of a storage class
3943 with a typedef specifier. */
3944 BOOL_BITFIELD conflicting_specifiers_p : 1;
4b9b2871 3945 /* True iff at least one decl-specifier was found. */
3946 BOOL_BITFIELD any_specifiers_p : 1;
3947 /* True iff "int" was explicitly provided. */
3948 BOOL_BITFIELD explicit_int_p : 1;
3949 /* True iff "char" was explicitly provided. */
3950 BOOL_BITFIELD explicit_char_p : 1;
3951} cp_decl_specifier_seq;
3952
3046c0a3 3953/* The various kinds of declarators. */
3954
3955typedef enum cp_declarator_kind {
3956 cdk_id,
3957 cdk_function,
3958 cdk_array,
3959 cdk_pointer,
3960 cdk_reference,
3961 cdk_ptrmem,
3962 cdk_error
3963} cp_declarator_kind;
3964
3965/* A declarator. */
3966
3967typedef struct cp_declarator cp_declarator;
3968
3969typedef struct cp_parameter_declarator cp_parameter_declarator;
3970
3971/* A parameter, before it has been semantically analyzed. */
3972struct cp_parameter_declarator {
3973 /* The next parameter, or NULL_TREE if none. */
3974 cp_parameter_declarator *next;
3975 /* The decl-specifiers-seq for the parameter. */
4b9b2871 3976 cp_decl_specifier_seq decl_specifiers;
3046c0a3 3977 /* The declarator for the parameter. */
3978 cp_declarator *declarator;
3979 /* The default-argument expression, or NULL_TREE, if none. */
3980 tree default_argument;
3981 /* True iff this is the first parameter in the list and the
3982 parameter sequence ends with an ellipsis. */
3983 bool ellipsis_p;
3984};
3985
3986/* A declarator. */
3987struct cp_declarator {
3988 /* The kind of declarator. */
855ed7a1 3989 ENUM_BITFIELD (cp_declarator_kind) kind : 4;
3990 /* Whether we parsed an ellipsis (`...') just before the declarator,
3991 to indicate this is a parameter pack. */
3992 BOOL_BITFIELD parameter_pack_p : 1;
3046c0a3 3993 /* Attributes that apply to this declarator. */
3994 tree attributes;
3995 /* For all but cdk_id and cdk_error, the contained declarator. For
3996 cdk_id and cdk_error, guaranteed to be NULL. */
3997 cp_declarator *declarator;
9d819530 3998 location_t id_loc; /* Currently only set for cdk_id. */
3046c0a3 3999 union {
4000 /* For identifiers. */
4001 struct {
4c7c159a 4002 /* If non-NULL, the qualifying scope (a NAMESPACE_DECL or
653e5405 4003 *_TYPE) for this identifier. */
2ded3667 4004 tree qualifying_scope;
4005 /* The unqualified name of the entity -- an IDENTIFIER_NODE,
4006 BIT_NOT_EXPR, or TEMPLATE_ID_EXPR. */
4007 tree unqualified_name;
3046c0a3 4008 /* If this is the name of a function, what kind of special
4009 function (if any). */
4010 special_function_kind sfk;
4011 } id;
4012 /* For functions. */
4013 struct {
4014 /* The parameters to the function. */
4015 cp_parameter_declarator *parameters;
4016 /* The cv-qualifiers for the function. */
2cfb6cde 4017 cp_cv_quals qualifiers;
3046c0a3 4018 /* The exception-specification for the function. */
4019 tree exception_specification;
4020 } function;
4021 /* For arrays. */
4022 struct {
4023 /* The bounds to the array. */
4024 tree bounds;
4025 } array;
63949b38 4026 /* For cdk_pointer and cdk_ptrmem. */
3046c0a3 4027 struct {
4028 /* The cv-qualifiers for the pointer. */
2cfb6cde 4029 cp_cv_quals qualifiers;
3046c0a3 4030 /* For cdk_ptrmem, the class type containing the member. */
4031 tree class_type;
4032 } pointer;
63949b38 4033 /* For cdk_reference */
4034 struct {
4035 /* The cv-qualifiers for the reference. These qualifiers are
4036 only used to diagnose ill-formed code. */
4037 cp_cv_quals qualifiers;
4038 /* Whether this is an rvalue reference */
4039 bool rvalue_ref;
4040 } reference;
3046c0a3 4041 } u;
4042};
4043
c5dd8e06 4044/* A level of template instantiation. */
4045struct tinst_level GTY(())
4046{
4047 /* The immediately deeper level in the chain. */
4048 struct tinst_level *next;
4049
4050 /* The original node. Can be either a DECL (for a function or static
4051 data member) or a TYPE (for a class), depending on what we were
4052 asked to instantiate. */
4053 tree decl;
4054
4055 /* The location where the template is instantiated. */
4056 location_t locus;
4057
4058 /* True if the location is in a system header. */
4059 bool in_system_header_p;
4060};
4061
3046c0a3 4062/* A parameter list indicating for a function with no parameters,
4063 e.g "int f(void)". */
4064extern cp_parameter_declarator *no_parameters;
4065
ac9386a0 4066/* in call.c */
653e5405 4067extern bool check_dtor_name (tree, tree);
24054144 4068
42283c76 4069extern tree build_vfield_ref (tree, tree);
42283c76 4070extern tree build_conditional_expr (tree, tree, tree);
653e5405 4071extern tree build_addr_func (tree);
d01f58f9 4072extern tree build_call_a (tree, int, tree*);
4073extern tree build_call_n (tree, int, ...);
653e5405 4074extern bool null_ptr_cst_p (tree);
9f627b1a 4075extern bool sufficient_parms_p (const_tree);
653e5405 4076extern tree type_decays_to (tree);
4077extern tree build_user_type_conversion (tree, tree, int);
c1d4295f 4078extern tree build_new_function_call (tree, tree, bool);
393f878f 4079extern tree build_operator_new_call (tree, tree, tree *, tree *,
4080 tree *);
4081extern tree build_new_method_call (tree, tree, tree, tree, int,
4082 tree *);
653e5405 4083extern tree build_special_member_call (tree, tree, tree, tree, int);
4084extern tree build_new_op (enum tree_code, int, tree, tree, tree, bool *);
393f878f 4085extern tree build_op_delete_call (enum tree_code, tree, tree, bool, tree, tree);
653e5405 4086extern bool can_convert (tree, tree);
db3bf8f6 4087extern bool can_convert_arg (tree, tree, tree, int);
653e5405 4088extern bool can_convert_arg_bad (tree, tree, tree);
579bb663 4089extern bool enforce_access (tree, tree, tree);
653e5405 4090extern tree convert_default_arg (tree, tree, tree, int);
4091extern tree convert_arg_to_ellipsis (tree);
4092extern tree build_x_va_arg (tree, tree);
4093extern tree cxx_type_promotes_to (tree);
4094extern tree type_passed_as (tree);
4095extern tree convert_for_arg_passing (tree, tree);
4096extern bool is_properly_derived_from (tree, tree);
4097extern tree initialize_reference (tree, tree, tree, tree *);
4098extern tree make_temporary_var_for_ref_to_temp (tree, tree);
4099extern tree strip_top_quals (tree);
4100extern tree perform_implicit_conversion (tree, tree);
6ab399e8 4101extern tree perform_direct_initialization_if_possible (tree, tree, bool);
653e5405 4102extern tree in_charge_arg_for_name (tree);
d01f58f9 4103extern tree build_cxx_call (tree, int, tree *);
1611df57 4104#ifdef ENABLE_CHECKING
653e5405 4105extern void validate_conversion_obstack (void);
1611df57 4106#endif /* ENABLE_CHECKING */
471086d6 4107
ac9386a0 4108/* in class.c */
653e5405 4109extern tree build_base_path (enum tree_code, tree,
4110 tree, int);
4111extern tree convert_to_base (tree, tree, bool, bool);
4112extern tree convert_to_base_statically (tree, tree);
42283c76 4113extern tree build_vtbl_ref (tree, tree);
4114extern tree build_vfn_ref (tree, tree);
653e5405 4115extern tree get_vtable_decl (tree, int);
4116extern void resort_type_method_vec (void *, void *,
4117 gt_pointer_operator, void *);
e36e7923 4118extern bool add_method (tree, tree, tree);
197c9df7 4119extern bool currently_open_class (tree);
42283c76 4120extern tree currently_open_derived_class (tree);
42283c76 4121extern tree finish_struct (tree, tree);
4122extern void finish_struct_1 (tree);
4123extern int resolves_to_fixed_type_p (tree, int *);
4124extern void init_class_processing (void);
4125extern int is_empty_class (tree);
f815eb0f 4126extern void pushclass (tree);
42283c76 4127extern void popclass (void);
5f6526e1 4128extern void push_nested_class (tree);
42283c76 4129extern void pop_nested_class (void);
4130extern int current_lang_depth (void);
4131extern void push_lang_context (tree);
4132extern void pop_lang_context (void);
4133extern tree instantiate_type (tree, tree, tsubst_flags_t);
653e5405 4134extern void print_class_statistics (void);
42283c76 4135extern void cxx_print_statistics (void);
653e5405 4136extern void cxx_print_xnode (FILE *, tree, int);
4137extern void cxx_print_decl (FILE *, tree, int);
4138extern void cxx_print_type (FILE *, tree, int);
4139extern void cxx_print_identifier (FILE *, tree, int);
42283c76 4140extern void cxx_print_error_function (struct diagnostic_context *,
4141 const char *);
4142extern void build_self_reference (void);
9f627b1a 4143extern int same_signature_p (const_tree, const_tree);
42283c76 4144extern void maybe_add_class_template_decl_list (tree, tree, int);
653e5405 4145extern void unreverse_member_declarations (tree);
4146extern void invalidate_class_lookup_cache (void);
4147extern void maybe_note_name_used_in_class (tree, tree);
4148extern void note_name_declared_in_class (tree, tree);
4149extern tree get_vtbl_decl_for_binfo (tree);
4880ab99 4150extern void debug_class (tree);
653e5405 4151extern void debug_thunks (tree);
215e2f1d 4152extern tree cp_fold_obj_type_ref (tree, tree);
653e5405 4153extern void set_linkage_according_to_type (tree, tree);
4154extern void determine_key_method (tree);
4155extern void check_for_override (tree, tree);
074ab442 4156extern void push_class_stack (void);
4157extern void pop_class_stack (void);
471086d6 4158
ac9386a0 4159/* in cvt.c */
653e5405 4160extern tree convert_to_reference (tree, tree, int, int, tree);
4161extern tree convert_from_reference (tree);
4162extern tree force_rvalue (tree);
4163extern tree ocp_convert (tree, tree, int, int);
4164extern tree cp_convert (tree, tree);
59dd8856 4165extern tree cp_convert_and_check (tree, tree);
653e5405 4166extern tree convert_to_void (tree, const char */*implicit context*/);
4167extern tree convert_force (tree, tree, int);
653e5405 4168extern tree build_expr_type_conversion (int, tree, bool);
4169extern tree type_promotes_to (tree);
4170extern tree perform_qualification_conversions (tree, tree);
4171extern void clone_function_decl (tree, int);
42283c76 4172extern void adjust_clone_args (tree);
471086d6 4173
ac9386a0 4174/* decl.c */
d458bdd7 4175extern tree poplevel (int, int, int);
42283c76 4176extern void insert_block (tree);
42283c76 4177extern tree pushdecl (tree);
c1d4295f 4178extern tree pushdecl_maybe_friend (tree, bool);
42283c76 4179extern void cxx_init_decl_processing (void);
ac13e8d9 4180enum cp_tree_node_structure_enum cp_tree_node_structure
653e5405 4181 (union lang_tree_node *);
42283c76 4182extern bool cxx_mark_addressable (tree);
4183extern void cxx_push_function_context (struct function *);
4184extern void cxx_pop_function_context (struct function *);
653e5405 4185extern void maybe_push_cleanup_level (tree);
4186extern void finish_scope (void);
42283c76 4187extern void push_switch (tree);
4188extern void pop_switch (void);
3f3fa556 4189extern tree pushtag (tree, tree, tag_scope);
42283c76 4190extern tree make_anon_name (void);
42283c76 4191extern int decls_match (tree, tree);
c1d4295f 4192extern tree duplicate_decls (tree, tree, bool);
c1d4295f 4193extern tree pushdecl_top_level_maybe_friend (tree, bool);
653e5405 4194extern tree pushdecl_top_level_and_finish (tree, tree);
653e5405 4195extern tree declare_local_label (tree);
92ddaf90 4196extern tree define_label (location_t, tree);
42283c76 4197extern void check_goto (tree);
8487df40 4198extern bool check_omp_return (void);
e2ae55f2 4199extern tree make_typename_type (tree, tree, enum tag_types, tsubst_flags_t);
f95fba26 4200extern tree make_unbound_class_template (tree, tree, tree, tsubst_flags_t);
653e5405 4201extern tree check_for_out_of_scope_variable (tree);
42283c76 4202extern tree build_library_fn (tree, tree);
4203extern tree build_library_fn_ptr (const char *, tree);
4204extern tree build_cp_library_fn_ptr (const char *, tree);
4205extern tree push_library_fn (tree, tree);
4206extern tree push_void_library_fn (tree, tree);
4207extern tree push_throw_library_fn (tree, tree);
4b9b2871 4208extern tree check_tag_decl (cp_decl_specifier_seq *);
4209extern tree shadow_tag (cp_decl_specifier_seq *);
4210extern tree groktypename (cp_decl_specifier_seq *, const cp_declarator *);
7f602bca 4211extern tree start_decl (const cp_declarator *, cp_decl_specifier_seq *, int, tree, tree, tree *);
788f3e3e 4212extern void start_decl_1 (tree, bool);
d91303a6 4213extern void cp_finish_decl (tree, tree, bool, tree, int);
42283c76 4214extern void finish_decl (tree, tree, tree);
c271bdb2 4215extern int cp_complete_array_type (tree *, tree, bool);
42283c76 4216extern tree build_ptrmemfunc_type (tree);
653e5405 4217extern tree build_ptrmem_type (tree, tree);
ce28ee2e 4218/* the grokdeclarator prototype is in decl.h */
074ab442 4219extern tree build_this_parm (tree, cp_cv_quals);
9f627b1a 4220extern int copy_fn_p (const_tree);
4221extern bool move_fn_p (const_tree);
653e5405 4222extern tree get_scope_of_declarator (const cp_declarator *);
42283c76 4223extern void grok_special_member_properties (tree);
9f627b1a 4224extern int grok_ctor_properties (const_tree, const_tree);
fcdd34ab 4225extern bool grok_op_properties (tree, bool);
1fadf2c8 4226extern tree xref_tag (enum tag_types, tree, tag_scope, bool);
4227extern tree xref_tag_from_type (tree, tree, tag_scope);
47afaf8b 4228extern bool xref_basetypes (tree, tree);
42283c76 4229extern tree start_enum (tree);
4230extern void finish_enum (tree);
4231extern void build_enumerator (tree, tree, tree);
653e5405 4232extern void start_preparsed_function (tree, tree, int);
4b9b2871 4233extern int start_function (cp_decl_specifier_seq *, const cp_declarator *, tree);
42283c76 4234extern tree begin_function_body (void);
4235extern void finish_function_body (tree);
4236extern tree finish_function (int);
4b9b2871 4237extern tree start_method (cp_decl_specifier_seq *, const cp_declarator *, tree);
42283c76 4238extern tree finish_method (tree);
653e5405 4239extern void maybe_register_incomplete_var (tree);
42283c76 4240extern void complete_vars (tree);
4241extern void finish_stmt (void);
4242extern void print_other_binding_stack (struct cp_binding_level *);
653e5405 4243extern void revert_static_member_fn (tree);
4244extern void fixup_anonymous_aggr (tree);
4245extern int check_static_variable_definition (tree, tree);
42283c76 4246extern tree compute_array_index_type (tree, tree);
653e5405 4247extern tree check_default_argument (tree, tree);
4248typedef int (*walk_namespaces_fn) (tree, void *);
4249extern int walk_namespaces (walk_namespaces_fn,
4250 void *);
4251extern int wrapup_globals_for_namespace (tree, void *);
4252extern tree create_implicit_typedef (tree, tree);
4253extern tree maybe_push_decl (tree);
cf91a12d 4254extern tree force_target_expr (tree, tree);
653e5405 4255extern tree build_target_expr_with_type (tree, tree);
f8fd23c0 4256extern int local_variable_p (const_tree);
653e5405 4257extern tree register_dtor_fn (tree);
4258extern tmpl_spec_kind current_tmpl_spec_kind (int);
4880ab99 4259extern tree cp_fname_init (const char *, tree *);
54be5d7e 4260extern tree cxx_builtin_function (tree decl);
653e5405 4261extern tree check_elaborated_type_specifier (enum tag_types, tree, bool);
4262extern void warn_extern_redeclared_static (tree, tree);
4263extern const char *cxx_comdat_group (tree);
4ee9c684 4264extern bool cp_missing_noreturn_ok_p (tree);
653e5405 4265extern void initialize_artificial_var (tree, tree);
4266extern tree check_var_type (tree, tree);
79b01846 4267extern tree reshape_init (tree, tree);
54bd1509 4268
ac9386a0 4269/* in decl2.c */
653e5405 4270extern bool check_java_method (tree);
074ab442 4271extern tree build_memfn_type (tree, tree, cp_cv_quals);
653e5405 4272extern void maybe_retrofit_in_chrg (tree);
4273extern void maybe_make_one_only (tree);
4274extern void grokclassfn (tree, tree,
7873fcd6 4275 enum overload_flags);
653e5405 4276extern tree grok_array_decl (tree, tree);
4277extern tree delete_sanity (tree, tree, bool, int);
4278extern tree check_classfn (tree, tree, tree);
4279extern void check_member_template (tree);
4280extern tree grokfield (const cp_declarator *, cp_decl_specifier_seq *,
d91303a6 4281 tree, bool, tree, tree);
653e5405 4282extern tree grokbitfield (const cp_declarator *, cp_decl_specifier_seq *,
4283 tree);
4284extern void cplus_decl_attributes (tree *, tree, int);
4285extern void finish_anon_union (tree);
15daca6e 4286extern void cp_write_global_declarations (void);
653e5405 4287extern tree coerce_new_type (tree);
4288extern tree coerce_delete_type (tree);
4289extern void comdat_linkage (tree);
4290extern void determine_visibility (tree);
4a2849cb 4291extern void constrain_class_visibility (tree);
4292extern void update_member_visibility (tree);
653e5405 4293extern void import_export_decl (tree);
ab84aad4 4294extern tree build_cleanup (tree);
653e5405 4295extern tree build_offset_ref_call_from_tree (tree, tree);
4296extern void check_default_args (tree);
4297extern void mark_used (tree);
d91303a6 4298extern void finish_static_data_member_decl (tree, tree, bool, tree, int);
653e5405 4299extern tree cp_build_parm_decl (tree, tree);
4300extern tree get_guard (tree);
4301extern tree get_guard_cond (tree);
4302extern tree set_guard (tree);
4303extern tree cxx_callgraph_analyze_expr (tree *, int *, tree);
4304extern void mark_needed (tree);
4305extern bool decl_needed_p (tree);
4306extern void note_vague_linkage_fn (tree);
074ab442 4307extern tree build_artificial_parm (tree, tree);
471086d6 4308
02d7f858 4309/* in error.c */
42283c76 4310extern void init_error (void);
4311extern const char *type_as_string (tree, int);
4312extern const char *decl_as_string (tree, int);
4313extern const char *expr_as_string (tree, int);
42283c76 4314extern const char *lang_decl_name (tree, int);
653e5405 4315extern const char *language_to_string (enum languages);
4316extern const char *class_key_or_enum_as_string (tree);
4317extern void print_instantiation_context (void);
d95d815d 4318extern void maybe_warn_variadic_templates (void);
02d7f858 4319
ac9386a0 4320/* in except.c */
42283c76 4321extern void init_exception_processing (void);
4322extern tree expand_start_catch_block (tree);
4323extern void expand_end_catch_block (void);
42283c76 4324extern tree build_exc_ptr (void);
4325extern tree build_throw (tree);
9f627b1a 4326extern int nothrow_libfn_p (const_tree);
42283c76 4327extern void check_handlers (tree);
4328extern void choose_personality_routine (enum languages);
a6a203ec 4329extern tree eh_type_info (tree);
471086d6 4330
ac9386a0 4331/* in expr.c */
42283c76 4332extern rtx cxx_expand_expr (tree, rtx,
60ffaf4d 4333 enum machine_mode,
4334 int, rtx *);
653e5405 4335extern tree cplus_expand_constant (tree);
471086d6 4336
b465397d 4337/* friend.c */
42283c76 4338extern int is_friend (tree, tree);
b123b79d 4339extern void make_friend_class (tree, tree, bool);
653e5405 4340extern void add_friend (tree, tree, bool);
7873fcd6 4341extern tree do_friend (tree, tree, tree, tree, enum overload_flags, bool);
b465397d 4342
ac9386a0 4343/* in init.c */
5f1653d2 4344extern tree expand_member_init (tree);
6507cda8 4345extern void emit_mem_initializers (tree);
42283c76 4346extern tree build_aggr_init (tree, tree, int);
42283c76 4347extern int is_aggr_type (tree, int);
42283c76 4348extern tree get_type_value (tree);
653e5405 4349extern tree build_zero_init (tree, tree, bool);
1bc16cab 4350extern tree build_offset_ref (tree, tree, bool);
3046c0a3 4351extern tree build_new (tree, tree, tree, tree, int);
687a1c50 4352extern tree build_vec_init (tree, tree, tree, bool, int);
2d7f50b9 4353extern tree build_default_init (tree, tree);
653e5405 4354extern tree build_delete (tree, tree,
4355 special_function_kind,
4356 int, int);
42283c76 4357extern void push_base_cleanups (void);
653e5405 4358extern tree build_vec_delete (tree, tree,
4359 special_function_kind, int);
4360extern tree create_temporary_var (tree);
4361extern void initialize_vtbl_ptrs (tree);
4362extern tree build_java_class_ref (tree);
4363extern tree integral_constant_value (tree);
471086d6 4364
ac9386a0 4365/* in lex.c */
42283c76 4366extern void cxx_dup_lang_specific_decl (tree);
42283c76 4367extern void yyungetc (int, int);
42283c76 4368
653e5405 4369extern tree unqualified_name_lookup_error (tree);
4370extern tree unqualified_fn_lookup_error (tree);
42283c76 4371extern tree build_lang_decl (enum tree_code, tree, tree);
4372extern void retrofit_lang_decl (tree);
653e5405 4373extern tree copy_decl (tree);
4374extern tree copy_type (tree);
42283c76 4375extern tree cxx_make_type (enum tree_code);
4376extern tree make_aggr_type (enum tree_code);
4377extern void yyerror (const char *);
4378extern void yyhook (int);
03bde601 4379extern bool cxx_init (void);
653e5405 4380extern void cxx_finish (void);
96cc8e6a 4381extern bool in_main_input_context (void);
471086d6 4382
ac9386a0 4383/* in method.c */
653e5405 4384extern void init_method (void);
4385extern tree make_thunk (tree, bool, tree, tree);
4386extern void finish_thunk (tree);
4387extern void use_thunk (tree, bool);
4388extern void synthesize_method (tree);
653e5405 4389extern tree lazily_declare_fn (special_function_kind,
4390 tree);
9f627b1a 4391extern tree skip_artificial_parms_for (const_tree, tree);
4392extern int num_artificial_parms_for (const_tree);
653e5405 4393extern tree make_alias_for (tree, tree);
481451eb 4394extern tree locate_copy (tree, void *);
4395extern tree locate_ctor (tree, void *);
4396extern tree locate_dtor (tree, void *);
471086d6 4397
31236dcd 4398/* In optimize.c */
653e5405 4399extern bool maybe_clone_body (tree);
31236dcd 4400
ac9386a0 4401/* in pt.c */
42283c76 4402extern void check_template_shadow (tree);
653e5405 4403extern tree get_innermost_template_args (tree, int);
42283c76 4404extern void maybe_begin_member_template_processing (tree);
4405extern void maybe_end_member_template_processing (void);
653e5405 4406extern tree finish_member_template_decl (tree);
42283c76 4407extern void begin_template_parm_list (void);
6d9bff9f 4408extern bool begin_specialization (void);
653e5405 4409extern void reset_specialization (void);
4410extern void end_specialization (void);
4411extern void begin_explicit_instantiation (void);
4412extern void end_explicit_instantiation (void);
4413extern tree check_explicit_specialization (tree, tree, int, int);
d95d815d 4414extern tree process_template_parm (tree, tree, bool, bool);
42283c76 4415extern tree end_template_parm_list (tree);
4416extern void end_template_decl (void);
82d31768 4417extern bool check_default_tmpl_args (tree, tree, int, int, int);
42283c76 4418extern tree push_template_decl (tree);
c1d4295f 4419extern tree push_template_decl_real (tree, bool);
2ed0bcc0 4420extern bool redeclare_class_template (tree, tree);
653e5405 4421extern tree lookup_template_class (tree, tree, tree, tree,
4422 int, tsubst_flags_t);
4423extern tree lookup_template_function (tree, tree);
42283c76 4424extern int uses_template_parms (tree);
7bdfc61c 4425extern int uses_template_parms_level (tree, int);
42283c76 4426extern tree instantiate_class_template (tree);
2bc53434 4427extern tree instantiate_template (tree, tree, tsubst_flags_t);
653e5405 4428extern int fn_type_unification (tree, tree, tree, tree,
db3bf8f6 4429 tree, unification_kind_t, int);
42283c76 4430extern void mark_decl_instantiated (tree, int);
517ee39a 4431extern int more_specialized_fn (tree, tree, int);
ab93b497 4432extern void do_decl_instantiation (tree, tree);
42283c76 4433extern void do_type_instantiation (tree, tree, tsubst_flags_t);
2806ee49 4434extern tree instantiate_decl (tree, int, bool);
9f627b1a 4435extern int comp_template_parms (const_tree, const_tree);
d95d815d 4436extern bool uses_parameter_packs (tree);
9f627b1a 4437extern bool template_parameter_pack_p (const_tree);
d95d815d 4438extern tree make_pack_expansion (tree);
a4f66688 4439extern bool check_for_bare_parameter_packs (tree);
653e5405 4440extern int template_class_depth (tree);
4441extern int is_specialization_of (tree, tree);
4442extern bool is_specialization_of_friend (tree, tree);
4443extern int comp_template_args (tree, tree);
2ce07779 4444extern tree maybe_process_partial_specialization (tree);
653e5405 4445extern tree most_specialized_instantiation (tree);
4446extern void print_candidates (tree);
4447extern void instantiate_pending_templates (int);
4448extern tree tsubst_default_argument (tree, tree, tree);
4449extern tree tsubst_copy_and_build (tree, tree, tsubst_flags_t,
bde9ebf7 4450 tree, bool, bool);
42283c76 4451extern tree most_general_template (tree);
4452extern tree get_mostly_instantiated_function_type (tree);
653e5405 4453extern int problematic_instantiation_changed (void);
42283c76 4454extern void record_last_problematic_instantiation (void);
c5dd8e06 4455extern struct tinst_level *current_instantiation(void);
0a3b29ad 4456extern tree maybe_get_template_decl_from_type_decl (tree);
29926476 4457extern int processing_template_parmlist;
653e5405 4458extern bool dependent_type_p (tree);
9f627b1a 4459extern bool any_dependent_template_arguments_p (const_tree);
653e5405 4460extern bool dependent_template_p (tree);
4461extern bool dependent_template_id_p (tree, tree);
4462extern bool type_dependent_expression_p (tree);
9f627b1a 4463extern bool any_type_dependent_arguments_p (const_tree);
653e5405 4464extern bool value_dependent_expression_p (tree);
9f627b1a 4465extern bool any_value_dependent_elements_p (const_tree);
653e5405 4466extern tree resolve_typename_type (tree, bool);
4467extern tree template_for_substitution (tree);
4468extern tree build_non_dependent_expr (tree);
4469extern tree build_non_dependent_args (tree);
4470extern bool reregister_specialization (tree, tree, tree);
4471extern tree fold_non_dependent_expr (tree);
04ef83b7 4472extern bool explicit_class_specialization_p (tree);
c5dd8e06 4473extern struct tinst_level *outermost_tinst_level(void);
02d7f858 4474
4475/* in repo.c */
653e5405 4476extern void init_repo (void);
4477extern int repo_emit_p (tree);
9f627b1a 4478extern bool repo_export_class_p (const_tree);
653e5405 4479extern void finish_repo (void);
02d7f858 4480
4481/* in rtti.c */
2beb8f09 4482/* A vector of all tinfo decls that haven't been emitted yet. */
046bfc77 4483extern GTY(()) VEC(tree,gc) *unemitted_tinfo_decls;
981bab5c 4484
653e5405 4485extern void init_rtti_processing (void);
4486extern tree build_typeid (tree);
4487extern tree get_tinfo_decl (tree);
4488extern tree get_typeid (tree);
56a58a8c 4489extern tree build_headof (tree);
653e5405 4490extern tree build_dynamic_cast (tree, tree);
4491extern void emit_support_tinfos (void);
4492extern bool emit_tinfo_decl (tree);
471086d6 4493
ac9386a0 4494/* in search.c */
653e5405 4495extern bool accessible_base_p (tree, tree, bool);
4496extern tree lookup_base (tree, tree, base_access,
4497 base_kind *);
4498extern tree dcast_base_hint (tree, tree);
4499extern int accessible_p (tree, tree, bool);
4500extern tree lookup_field_1 (tree, tree, bool);
b330805e 4501extern tree lookup_field (tree, tree, int, bool);
653e5405 4502extern int lookup_fnfields_1 (tree, tree);
4503extern int class_method_index_for_fn (tree, tree);
42283c76 4504extern tree lookup_fnfields (tree, tree, int);
b330805e 4505extern tree lookup_member (tree, tree, int, bool);
42283c76 4506extern int look_for_overrides (tree, tree);
653e5405 4507extern void get_pure_virtuals (tree);
42283c76 4508extern void maybe_suppress_debug_info (tree);
4509extern void note_debug_info_needed (tree);
42283c76 4510extern void print_search_statistics (void);
42283c76 4511extern void reinit_search_statistics (void);
4512extern tree current_scope (void);
653e5405 4513extern int at_function_scope_p (void);
4514extern bool at_class_scope_p (void);
4515extern bool at_namespace_scope_p (void);
42283c76 4516extern tree context_for_name_lookup (tree);
4517extern tree lookup_conversions (tree);
42283c76 4518extern tree binfo_from_vbase (tree);
97c118b9 4519extern tree binfo_for_vbase (tree, tree);
42283c76 4520extern tree look_for_overrides_here (tree, tree);
398b91ef 4521#define dfs_skip_bases ((tree)1)
4522extern tree dfs_walk_all (tree, tree (*) (tree, void *),
4523 tree (*) (tree, void *), void *);
4524extern tree dfs_walk_once (tree, tree (*) (tree, void *),
4525 tree (*) (tree, void *), void *);
653e5405 4526extern tree binfo_via_virtual (tree, tree);
4527extern tree build_baselink (tree, tree, tree, tree);
3645386f 4528extern tree adjust_result_of_qualified_name_lookup
653e5405 4529 (tree, tree, tree);
95f3173a 4530extern tree copied_binfo (tree, tree);
4531extern tree original_binfo (tree, tree);
653e5405 4532extern int shared_member_p (tree);
95f3173a 4533
3369eb76 4534
4535/* The representation of a deferred access check. */
4536
4537typedef struct deferred_access_check GTY(())
4538{
4539 /* The base class in which the declaration is referenced. */
4540 tree binfo;
4541 /* The declaration whose access must be checked. */
4542 tree decl;
4543 /* The declaration that should be used in the error message. */
4544 tree diag_decl;
4545} deferred_access_check;
4546DEF_VEC_O(deferred_access_check);
4547DEF_VEC_ALLOC_O(deferred_access_check,gc);
4548
0090dad2 4549/* in semantics.c */
4f62c42e 4550extern void push_deferring_access_checks (deferring_kind);
9b57b06b 4551extern void resume_deferring_access_checks (void);
4552extern void stop_deferring_access_checks (void);
4553extern void pop_deferring_access_checks (void);
3369eb76 4554extern VEC (deferred_access_check,gc)* get_deferred_access_checks (void);
653e5405 4555extern void pop_to_parent_deferring_access_checks (void);
3369eb76 4556extern void perform_access_checks (VEC (deferred_access_check,gc)*);
9b57b06b 4557extern void perform_deferred_access_checks (void);
579bb663 4558extern void perform_or_defer_access_check (tree, tree, tree);
d1725120 4559extern int stmts_are_full_exprs_p (void);
653e5405 4560extern void init_cp_semantics (void);
d7e71db9 4561extern tree do_poplevel (tree);
7dd37241 4562extern void add_decl_expr (tree);
653e5405 4563extern tree finish_expr_stmt (tree);
4564extern tree begin_if_stmt (void);
4565extern void finish_if_stmt_cond (tree, tree);
4566extern tree finish_then_clause (tree);
2363ef00 4567extern void begin_else_clause (tree);
653e5405 4568extern void finish_else_clause (tree);
4569extern void finish_if_stmt (tree);
4570extern tree begin_while_stmt (void);
4571extern void finish_while_stmt_cond (tree, tree);
4572extern void finish_while_stmt (tree);
4573extern tree begin_do_stmt (void);
4574extern void finish_do_body (tree);
4575extern void finish_do_stmt (tree, tree);
4576extern tree finish_return_stmt (tree);
4577extern tree begin_for_stmt (void);
4578extern void finish_for_init_stmt (tree);
4579extern void finish_for_cond (tree, tree);
4580extern void finish_for_expr (tree, tree);
4581extern void finish_for_stmt (tree);
4582extern tree finish_break_stmt (void);
4583extern tree finish_continue_stmt (void);
4584extern tree begin_switch_stmt (void);
4585extern void finish_switch_cond (tree, tree);
4586extern void finish_switch_stmt (tree);
4587extern tree finish_case_label (tree, tree);
4588extern tree finish_goto_stmt (tree);
4589extern tree begin_try_block (void);
4590extern void finish_try_block (tree);
42283c76 4591extern tree begin_eh_spec_block (void);
4592extern void finish_eh_spec_block (tree, tree);
653e5405 4593extern void finish_handler_sequence (tree);
78f7169a 4594extern tree begin_function_try_block (tree *);
653e5405 4595extern void finish_function_try_block (tree);
78f7169a 4596extern void finish_function_handler_sequence (tree, tree);
653e5405 4597extern void finish_cleanup_try_block (tree);
4598extern tree begin_handler (void);
4599extern void finish_handler_parms (tree, tree);
4600extern void finish_handler (tree);
4601extern void finish_cleanup (tree, tree);
2363ef00 4602
4603enum {
4604 BCS_NO_SCOPE = 1,
4605 BCS_TRY_BLOCK = 2,
4606 BCS_FN_BODY = 4
4607};
653e5405 4608extern tree begin_compound_stmt (unsigned int);
2363ef00 4609
653e5405 4610extern void finish_compound_stmt (tree);
4611extern tree finish_asm_stmt (int, tree, tree, tree, tree);
4612extern tree finish_label_stmt (tree);
4613extern void finish_label_decl (tree);
4614extern tree finish_parenthesized_expr (tree);
26d880e6 4615extern tree finish_non_static_data_member (tree, tree, tree);
653e5405 4616extern tree begin_stmt_expr (void);
4617extern tree finish_stmt_expr_expr (tree, tree);
4618extern tree finish_stmt_expr (tree, bool);
ffc6c453 4619extern tree stmt_expr_value_expr (tree);
653e5405 4620extern tree perform_koenig_lookup (tree, tree);
4621extern tree finish_call_expr (tree, tree, bool, bool);
4622extern tree finish_increment_expr (tree, enum tree_code);
4623extern tree finish_this_expr (void);
0a3b29ad 4624extern tree finish_pseudo_destructor_expr (tree, tree, tree);
653e5405 4625extern tree finish_unary_op_expr (enum tree_code, tree);
c75b4594 4626extern tree finish_compound_literal (tree, VEC(constructor_elt,gc) *);
653e5405 4627extern tree finish_fname (tree);
4628extern void finish_translation_unit (void);
4629extern tree finish_template_type_parm (tree, tree);
42283c76 4630extern tree finish_template_template_parm (tree, tree);
4a2849cb 4631extern tree begin_class_definition (tree, tree);
653e5405 4632extern void finish_template_decl (tree);
4633extern tree finish_template_type (tree, tree, int);
4634extern tree finish_base_specifier (tree, tree, bool);
4635extern void finish_member_declaration (tree);
2cdbcd51 4636extern void qualified_name_lookup_error (tree, tree, tree);
074ab442 4637extern void check_template_keyword (tree);
653e5405 4638extern tree finish_id_expression (tree, tree, tree,
fbb01da7 4639 cp_id_kind *,
ac13e8d9 4640 bool, bool, bool *,
fbb01da7 4641 bool, bool, bool, bool,
0886adbc 4642 const char **);
42283c76 4643extern tree finish_typeof (tree);
bf75f33a 4644extern tree finish_offsetof (tree);
653e5405 4645extern void finish_decl_cleanup (tree, tree);
4646extern void finish_eh_cleanup (tree);
84e10000 4647extern void emit_associated_thunks (tree);
653e5405 4648extern void finish_mem_initializers (tree);
4c487414 4649extern tree check_template_template_default_arg (tree);
6cb758f0 4650extern void expand_or_defer_fn (tree);
ef4534a3 4651extern void check_accessibility_of_qualified_id (tree, tree, tree);
fbb01da7 4652extern tree finish_qualified_id_expr (tree, tree, bool, bool,
4653 bool, bool);
b9e35020 4654extern void simplify_aggr_init_expr (tree *);
4ee9c684 4655extern void finalize_nrv (tree *, tree, tree);
653e5405 4656extern void note_decl_for_pch (tree);
8487df40 4657extern tree finish_omp_clauses (tree);
4658extern void finish_omp_threadprivate (tree);
4659extern tree begin_omp_structured_block (void);
4660extern tree finish_omp_structured_block (tree);
4661extern tree begin_omp_parallel (void);
4662extern tree finish_omp_parallel (tree, tree);
4663extern tree finish_omp_for (location_t, tree, tree,
4664 tree, tree, tree, tree);
4665extern void finish_omp_atomic (enum tree_code, tree, tree);
4666extern void finish_omp_barrier (void);
4667extern void finish_omp_flush (void);
4668extern enum omp_clause_default_kind cxx_omp_predetermined_sharing (tree);
4669extern tree cxx_omp_clause_default_ctor (tree, tree);
4670extern tree cxx_omp_clause_copy_ctor (tree, tree, tree);
4671extern tree cxx_omp_clause_assign_op (tree, tree, tree);
4672extern tree cxx_omp_clause_dtor (tree, tree);
9f627b1a 4673extern bool cxx_omp_privatize_by_reference (const_tree);
0e5cde0c 4674extern tree baselink_for_fns (tree);
7a05c4b1 4675extern void finish_static_assert (tree, tree, location_t,
4676 bool);
34da8800 4677extern tree finish_decltype_type (tree, bool);
481451eb 4678extern tree finish_trait_expr (enum cp_trait_kind, tree, tree);
8036397f 4679
ac9386a0 4680/* in tree.c */
42283c76 4681extern void lang_check_failed (const char *, int,
a0b604fc 4682 const char *) ATTRIBUTE_NORETURN;
42283c76 4683extern tree stabilize_expr (tree, tree *);
4ee9c684 4684extern void stabilize_call (tree, tree *);
c2f47e15 4685extern void stabilize_aggr_init (tree, tree *);
4ee9c684 4686extern bool stabilize_init (tree, tree *);
4813f5af 4687extern tree add_stmt_to_compound (tree, tree);
42283c76 4688extern tree cxx_maybe_build_cleanup (tree);
653e5405 4689extern void init_tree (void);
9f627b1a 4690extern int pod_type_p (const_tree);
f8fd23c0 4691extern bool class_tmpl_impl_spec_p (const_tree);
9f627b1a 4692extern int zero_init_p (const_tree);
653e5405 4693extern tree canonical_type_variant (tree);
168db9a4 4694extern tree copy_binfo (tree, tree, tree,
4695 tree *, int);
9f627b1a 4696extern int member_p (const_tree);
4697extern cp_lvalue_kind real_lvalue_p (const_tree);
4698extern bool builtin_valid_in_constant_expr_p (const_tree);
b6691ff5 4699extern tree build_min (enum tree_code, tree, ...);
42283c76 4700extern tree build_min_nt (enum tree_code, ...);
b6691ff5 4701extern tree build_min_non_dep (enum tree_code, tree, ...);
c2f47e15 4702extern tree build_min_non_dep_call_list (tree, tree, tree);
42283c76 4703extern tree build_cplus_new (tree, tree);
4704extern tree get_target_expr (tree);
42283c76 4705extern tree build_cplus_array_type (tree, tree);
4706extern tree hash_tree_cons (tree, tree, tree);
4707extern tree hash_tree_chain (tree, tree);
074ab442 4708extern tree build_qualified_name (tree, tree, tree, bool);
42283c76 4709extern int is_overloaded_fn (tree);
4710extern tree get_first_fn (tree);
653e5405 4711extern tree ovl_cons (tree, tree);
4712extern tree build_overload (tree, tree);
42283c76 4713extern const char *cxx_printable_name (tree, int);
4714extern tree build_exception_variant (tree, tree);
4715extern tree bind_template_template_parm (tree, tree);
4716extern tree array_type_nelts_total (tree);
4717extern tree array_type_nelts_top (tree);
4718extern tree break_out_target_exprs (tree);
4719extern tree get_type_decl (tree);
42283c76 4720extern tree decl_namespace_context (tree);
9f627b1a 4721extern bool decl_anon_ns_mem_p (const_tree);
42283c76 4722extern tree lvalue_type (tree);
4723extern tree error_type (tree);
9f627b1a 4724extern int varargs_function_p (const_tree);
0e5cde0c 4725extern bool really_overloaded_fn (tree);
00952d10 4726extern bool cp_tree_equal (tree, tree);
caa6fdce 4727extern tree no_linkage_check (tree, bool);
42283c76 4728extern void debug_binfo (tree);
4729extern tree build_dummy_object (tree);
4730extern tree maybe_dummy_object (tree, tree *);
9f627b1a 4731extern int is_dummy_object (const_tree);
f8e93a2e 4732extern const struct attribute_spec cxx_attribute_table[];
653e5405 4733extern tree make_ptrmem_cst (tree, tree);
b3beaf30 4734extern tree cp_build_type_attribute_variant (tree, tree);
63949b38 4735extern tree cp_build_reference_type (tree, bool);
653e5405 4736extern tree cp_build_qualified_type_real (tree, int, tsubst_flags_t);
e9c0ac6a 4737#define cp_build_qualified_type(TYPE, QUALS) \
0fbca5e8 4738 cp_build_qualified_type_real ((TYPE), (QUALS), tf_warning_or_error)
9f627b1a 4739extern special_function_kind special_function_p (const_tree);
653e5405 4740extern int count_trees (tree);
4741extern int char_type_p (tree);
4742extern void verify_stmt_tree (tree);
653e5405 4743extern linkage_kind decl_linkage (tree);
42283c76 4744extern tree cp_walk_subtrees (tree*, int*, walk_tree_fn,
653e5405 4745 void*, struct pointer_set_t*);
20a8f962 4746#define cp_walk_tree(a,b,c,d) \
4747 walk_tree_1 (a, b, c, d, cp_walk_subtrees)
4748#define cp_walk_tree_without_duplicates(a,b,c) \
4749 walk_tree_without_duplicates_1 (a, b, c, cp_walk_subtrees)
653e5405 4750extern tree fold_if_not_in_template (tree);
074ab442 4751extern tree rvalue (tree);
b34f0fc7 4752extern tree convert_bitfield_to_declared_type (tree);
074ab442 4753extern tree cp_save_expr (tree);
bde9ebf7 4754extern bool cast_valid_in_integral_constant_expression_p (tree);
743f8dd1 4755extern bool cxx_type_hash_eq (const_tree, const_tree);
074ab442 4756
ac9386a0 4757/* in typeck.c */
9f627b1a 4758extern int string_conv_p (const_tree, const_tree, int);
42283c76 4759extern tree cp_truthvalue_conversion (tree);
4760extern tree condition_conversion (tree);
42283c76 4761extern tree require_complete_type (tree);
4762extern tree complete_type (tree);
a20e2be9 4763extern tree complete_type_or_else (tree, tree);
9f627b1a 4764extern int type_unknown_p (const_tree);
4765extern bool comp_except_specs (const_tree, const_tree, bool);
00952d10 4766extern bool comptypes (tree, tree, int);
9f627b1a 4767extern bool compparms (const_tree, const_tree);
4768extern int comp_cv_qualification (const_tree, const_tree);
653e5405 4769extern int comp_cv_qual_signature (tree, tree);
4770extern tree cxx_sizeof_or_alignof_expr (tree, enum tree_code);
4771extern tree cxx_sizeof_or_alignof_type (tree, enum tree_code, bool);
d3a4d008 4772#define cxx_sizeof_nowarn(T) cxx_sizeof_or_alignof_type (T, SIZEOF_EXPR, false)
42283c76 4773extern tree inline_conversion (tree);
9f627b1a 4774extern tree is_bitfield_expr_with_lowered_type (const_tree);
4775extern tree unlowered_expr_type (const_tree);
42283c76 4776extern tree decay_conversion (tree);
4ac852cb 4777extern tree build_class_member_access_expr (tree, tree, tree, bool);
fbb01da7 4778extern tree finish_class_member_access_expr (tree, tree, bool);
42283c76 4779extern tree build_x_indirect_ref (tree, const char *);
4780extern tree build_indirect_ref (tree, const char *);
4781extern tree build_array_ref (tree, tree);
4782extern tree get_member_function_from_ptrfunc (tree *, tree);
e534436e 4783extern tree build_x_binary_op (enum tree_code, tree,
4784 enum tree_code, tree,
4785 enum tree_code, bool *);
42283c76 4786extern tree build_x_unary_op (enum tree_code, tree);
4787extern tree unary_complex_lvalue (enum tree_code, tree);
4788extern tree build_x_conditional_expr (tree, tree, tree);
653e5405 4789extern tree build_x_compound_expr_from_list (tree, const char *);
13795292 4790extern tree build_x_compound_expr (tree, tree);
8a4008da 4791extern tree build_compound_expr (tree, tree);
42283c76 4792extern tree build_static_cast (tree, tree);
4793extern tree build_reinterpret_cast (tree, tree);
4794extern tree build_const_cast (tree, tree);
4795extern tree build_c_cast (tree, tree);
4796extern tree build_x_modify_expr (tree, enum tree_code, tree);
4797extern tree build_modify_expr (tree, enum tree_code, tree);
653e5405 4798extern tree convert_for_initialization (tree, tree, tree, int,
4799 const char *, tree, int);
42283c76 4800extern int comp_ptr_ttypes (tree, tree);
074ab442 4801extern bool comp_ptr_ttypes_const (tree, tree);
9f627b1a 4802extern int ptr_reasonably_similar (const_tree, const_tree);
cb02169c 4803extern tree build_ptrmemfunc (tree, tree, int, bool);
f8fd23c0 4804extern int cp_type_quals (const_tree);
9f627b1a 4805extern bool cp_type_readonly (const_tree);
4806extern bool cp_has_mutable_p (const_tree);
4807extern bool at_least_as_qualified_p (const_tree, const_tree);
653e5405 4808extern void cp_apply_type_quals_to_decl (int, tree);
4809extern tree build_ptrmemfunc1 (tree, tree, tree);
4810extern void expand_ptrmemfunc_cst (tree, tree *, tree *);
42283c76 4811extern tree type_after_usual_arithmetic_conversions (tree, tree);
653e5405 4812extern tree composite_pointer_type (tree, tree, tree, tree,
4813 const char*);
42283c76 4814extern tree merge_types (tree, tree);
81a3c55b 4815extern tree check_return_expr (tree, bool *);
29d00ba7 4816#define cp_build_binary_op(code, arg1, arg2) \
4817 build_binary_op(code, arg1, arg2, 1)
d3a4d008 4818#define cxx_sizeof(T) cxx_sizeof_or_alignof_type (T, SIZEOF_EXPR, true)
653e5405 4819extern tree build_ptrmemfunc_access_expr (tree, tree);
4820extern tree build_address (tree);
4821extern tree build_nop (tree, tree);
4822extern tree non_reference (tree);
4823extern tree lookup_anon_field (tree, tree);
9f627b1a 4824extern bool invalid_nonstatic_memfn_p (const_tree);
653e5405 4825extern tree convert_member_func_to_ptr (tree, tree);
4826extern tree convert_ptrmem (tree, tree, bool, bool);
9f627b1a 4827extern int lvalue_or_else (const_tree, enum lvalue_use);
4828extern int lvalue_p (const_tree);
471086d6 4829
ac9386a0 4830/* in typeck2.c */
42283c76 4831extern void require_complete_eh_spec_types (tree, tree);
f8fd23c0 4832extern void cxx_incomplete_type_diagnostic (const_tree, const_tree, int);
e097fb33 4833#undef cxx_incomplete_type_error
f8fd23c0 4834extern void cxx_incomplete_type_error (const_tree, const_tree);
e097fb33 4835#define cxx_incomplete_type_error(V,T) \
4836 (cxx_incomplete_type_diagnostic ((V), (T), 0))
42283c76 4837extern tree error_not_base_type (tree, tree);
4838extern tree binfo_or_else (tree, tree);
2c592404 4839extern void readonly_error (tree, const char *);
d97a7640 4840extern void complete_type_check_abstract (tree);
42283c76 4841extern int abstract_virtuals_error (tree, tree);
4842
4843extern tree store_init_value (tree, tree);
c75b4594 4844extern tree digest_init (tree, tree);
42283c76 4845extern tree build_scoped_ref (tree, tree, tree *);
4846extern tree build_x_arrow (tree);
4847extern tree build_m_component_ref (tree, tree);
4848extern tree build_functional_cast (tree, tree);
653e5405 4849extern tree add_exception_specifier (tree, tree, int);
4850extern tree merge_exception_specifiers (tree, tree);
471086d6 4851
98eaf693 4852/* in mangle.c */
653e5405 4853extern void init_mangle (void);
4854extern void mangle_decl (tree);
4855extern const char *mangle_type_string (tree);
4856extern tree mangle_typeinfo_for_type (tree);
4857extern tree mangle_typeinfo_string_for_type (tree);
4858extern tree mangle_vtbl_for_type (tree);
4859extern tree mangle_vtt_for_type (tree);
4860extern tree mangle_ctor_vtbl_for_type (tree, tree);
4861extern tree mangle_thunk (tree, int, tree, tree);
4862extern tree mangle_conv_op_name_for_type (tree);
4863extern tree mangle_guard_variable (tree);
4864extern tree mangle_ref_init_variable (tree);
98eaf693 4865
c25509f2 4866/* in dump.c */
653e5405 4867extern bool cp_dump_tree (void *, tree);
c25509f2 4868
7a4e126b 4869/* In cp/cp-objcp-common.c. */
4870
32c2fdea 4871extern alias_set_type cxx_get_alias_set (tree);
f8fd23c0 4872extern bool cxx_warn_unused_global_decl (const_tree);
4873extern tree cp_expr_size (const_tree);
653e5405 4874extern size_t cp_tree_size (enum tree_code);
4875extern bool cp_var_mod_type_p (tree, tree);
4876extern void cxx_initialize_diagnostics (struct diagnostic_context *);
4877extern int cxx_types_compatible_p (tree, tree);
4dd41a12 4878extern void init_shadowed_var_for_decl (void);
cf484390 4879extern tree cxx_staticp (tree);
7a4e126b 4880
dfea972c 4881/* in cp-gimplify.c */
653e5405 4882extern int cp_gimplify_expr (tree *, tree *, tree *);
dddab69e 4883extern void cp_genericize (tree);
4ee9c684 4884
471086d6 4885/* -- end of C++ */
4886
a17c2a3a 4887/* In order for the format checking to accept the C++ front end
69579044 4888 diagnostic framework extensions, you must include this file before
7781aa77 4889 toplev.h, not after. We override the definition of GCC_DIAG_STYLE
4890 in c-common.h. */
4891#undef GCC_DIAG_STYLE
69579044 4892#define GCC_DIAG_STYLE __gcc_cxxdiag__
7781aa77 4893#if GCC_VERSION >= 4001
69579044 4894#define ATTRIBUTE_GCC_CXXDIAG(m, n) __attribute__ ((__format__ (GCC_DIAG_STYLE, m, n))) ATTRIBUTE_NONNULL(m)
4895#else
4896#define ATTRIBUTE_GCC_CXXDIAG(m, n) ATTRIBUTE_NONNULL(m)
4897#endif
eb0d20b7 4898extern void cp_cpp_error (cpp_reader *, int,
d65b3a40 4899 const char *, va_list *)
eb0d20b7 4900 ATTRIBUTE_GCC_CXXDIAG(3,0);
69579044 4901
2a281353 4902#endif /* ! GCC_CP_TREE_H */