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