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