1 /* Definitions for c-common.c. 2 Copyright (C) 1987-2013 Free Software Foundation, Inc. 3 4 This file is part of GCC. 5 6 GCC is free software; you can redistribute it and/or modify it under 7 the terms of the GNU General Public License as published by the Free 8 Software Foundation; either version 3, or (at your option) any later 9 version. 10 11 GCC is distributed in the hope that it will be useful, but WITHOUT ANY 12 WARRANTY; without even the implied warranty of MERCHANTABILITY or 13 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 14 for more details. 15 16 You should have received a copy of the GNU General Public License 17 along with GCC; see the file COPYING3. If not see 18 <http://www.gnu.org/licenses/>. */ 19 20 #ifndef GCC_C_COMMON_H 21 #define GCC_C_COMMON_H 22 23 #include "splay-tree.h" 24 #include "cpplib.h" 25 #include "ggc.h" 26 #include "tree.h" 27 28 /* In order for the format checking to accept the C frontend 29 diagnostic framework extensions, you must include this file before 30 diagnostic-core.h, not after. The C front end formats are a subset of those 31 for C++, so they are the appropriate set to use in common code; 32 cp-tree.h overrides this for C++. */ 33 #if defined(GCC_DIAGNOSTIC_CORE_H) 34 #error \ 35 In order for the format checking to accept the C front end diagnostic \ 36 framework extensions, you must include this file before diagnostic-core.h \ 37 never after. 38 #endif 39 #ifndef GCC_DIAG_STYLE 40 #define GCC_DIAG_STYLE __gcc_cdiag__ 41 #endif 42 #include "diagnostic-core.h" 43 44 /* Usage of TREE_LANG_FLAG_?: 45 0: IDENTIFIER_MARKED (used by search routines). 46 C_MAYBE_CONST_EXPR_INT_OPERANDS (in C_MAYBE_CONST_EXPR, for C) 47 1: C_DECLARED_LABEL_FLAG (in LABEL_DECL) 48 STATEMENT_LIST_STMT_EXPR (in STATEMENT_LIST) 49 C_MAYBE_CONST_EXPR_NON_CONST (in C_MAYBE_CONST_EXPR, for C) 50 2: unused 51 3: STATEMENT_LIST_HAS_LABEL (in STATEMENT_LIST) 52 4: unused 53 */ 54 55 /* Reserved identifiers. This is the union of all the keywords for C, 56 C++, and Objective-C. All the type modifiers have to be in one 57 block at the beginning, because they are used as mask bits. There 58 are 28 type modifiers; if we add many more we will have to redesign 59 the mask mechanism. */ 60 61 enum rid 62 { 63 /* Modifiers: */ 64 /* C, in empirical order of frequency. */ 65 RID_STATIC = 0, 66 RID_UNSIGNED, RID_LONG, RID_CONST, RID_EXTERN, 67 RID_REGISTER, RID_TYPEDEF, RID_SHORT, RID_INLINE, 68 RID_VOLATILE, RID_SIGNED, RID_AUTO, RID_RESTRICT, 69 RID_NORETURN, 70 71 /* C extensions */ 72 RID_COMPLEX, RID_THREAD, RID_SAT, 73 74 /* C++ */ 75 RID_FRIEND, RID_VIRTUAL, RID_EXPLICIT, RID_EXPORT, RID_MUTABLE, 76 77 /* ObjC ("PQ" reserved words - they do not appear after a '@' and 78 are keywords only in specific contexts) */ 79 RID_IN, RID_OUT, RID_INOUT, RID_BYCOPY, RID_BYREF, RID_ONEWAY, 80 81 /* ObjC ("PATTR" reserved words - they do not appear after a '@' 82 and are keywords only as property attributes) */ 83 RID_GETTER, RID_SETTER, 84 RID_READONLY, RID_READWRITE, 85 RID_ASSIGN, RID_RETAIN, RID_COPY, 86 RID_NONATOMIC, 87 88 /* C (reserved and imaginary types not implemented, so any use is a 89 syntax error) */ 90 RID_IMAGINARY, 91 92 /* C */ 93 RID_INT, RID_CHAR, RID_FLOAT, RID_DOUBLE, RID_VOID, 94 RID_INT128, 95 RID_ENUM, RID_STRUCT, RID_UNION, RID_IF, RID_ELSE, 96 RID_WHILE, RID_DO, RID_FOR, RID_SWITCH, RID_CASE, 97 RID_DEFAULT, RID_BREAK, RID_CONTINUE, RID_RETURN, RID_GOTO, 98 RID_SIZEOF, 99 100 /* C extensions */ 101 RID_ASM, RID_TYPEOF, RID_ALIGNOF, RID_ATTRIBUTE, RID_VA_ARG, 102 RID_EXTENSION, RID_IMAGPART, RID_REALPART, RID_LABEL, RID_CHOOSE_EXPR, 103 RID_TYPES_COMPATIBLE_P, RID_BUILTIN_COMPLEX, RID_BUILTIN_SHUFFLE, 104 RID_DFLOAT32, RID_DFLOAT64, RID_DFLOAT128, 105 RID_FRACT, RID_ACCUM, 106 107 /* C11 */ 108 RID_ALIGNAS, 109 110 /* This means to warn that this is a C++ keyword, and then treat it 111 as a normal identifier. */ 112 RID_CXX_COMPAT_WARN, 113 114 /* GNU transactional memory extension */ 115 RID_TRANSACTION_ATOMIC, RID_TRANSACTION_RELAXED, RID_TRANSACTION_CANCEL, 116 117 /* Too many ways of getting the name of a function as a string */ 118 RID_FUNCTION_NAME, RID_PRETTY_FUNCTION_NAME, RID_C99_FUNCTION_NAME, 119 120 /* C++ (some of these are keywords in Objective-C as well, but only 121 if they appear after a '@') */ 122 RID_BOOL, RID_WCHAR, RID_CLASS, 123 RID_PUBLIC, RID_PRIVATE, RID_PROTECTED, 124 RID_TEMPLATE, RID_NULL, RID_CATCH, 125 RID_DELETE, RID_FALSE, RID_NAMESPACE, 126 RID_NEW, RID_OFFSETOF, RID_OPERATOR, 127 RID_THIS, RID_THROW, RID_TRUE, 128 RID_TRY, RID_TYPENAME, RID_TYPEID, 129 RID_USING, RID_CHAR16, RID_CHAR32, 130 131 /* casts */ 132 RID_CONSTCAST, RID_DYNCAST, RID_REINTCAST, RID_STATCAST, 133 134 /* C++ extensions */ 135 RID_BASES, RID_DIRECT_BASES, 136 RID_HAS_NOTHROW_ASSIGN, RID_HAS_NOTHROW_CONSTRUCTOR, 137 RID_HAS_NOTHROW_COPY, RID_HAS_TRIVIAL_ASSIGN, 138 RID_HAS_TRIVIAL_CONSTRUCTOR, RID_HAS_TRIVIAL_COPY, 139 RID_HAS_TRIVIAL_DESTRUCTOR, RID_HAS_VIRTUAL_DESTRUCTOR, 140 RID_IS_ABSTRACT, RID_IS_BASE_OF, 141 RID_IS_CLASS, RID_IS_CONVERTIBLE_TO, 142 RID_IS_EMPTY, RID_IS_ENUM, 143 RID_IS_FINAL, RID_IS_LITERAL_TYPE, 144 RID_IS_POD, RID_IS_POLYMORPHIC, 145 RID_IS_STD_LAYOUT, RID_IS_TRIVIAL, 146 RID_IS_UNION, RID_UNDERLYING_TYPE, 147 148 /* C++11 */ 149 RID_CONSTEXPR, RID_DECLTYPE, RID_NOEXCEPT, RID_NULLPTR, RID_STATIC_ASSERT, 150 151 /* Objective-C ("AT" reserved words - they are only keywords when 152 they follow '@') */ 153 RID_AT_ENCODE, RID_AT_END, 154 RID_AT_CLASS, RID_AT_ALIAS, RID_AT_DEFS, 155 RID_AT_PRIVATE, RID_AT_PROTECTED, RID_AT_PUBLIC, RID_AT_PACKAGE, 156 RID_AT_PROTOCOL, RID_AT_SELECTOR, 157 RID_AT_THROW, RID_AT_TRY, RID_AT_CATCH, 158 RID_AT_FINALLY, RID_AT_SYNCHRONIZED, 159 RID_AT_OPTIONAL, RID_AT_REQUIRED, RID_AT_PROPERTY, 160 RID_AT_SYNTHESIZE, RID_AT_DYNAMIC, 161 RID_AT_INTERFACE, 162 RID_AT_IMPLEMENTATION, 163 164 /* Named address support, mapping the keyword to a particular named address 165 number. Named address space 0 is reserved for the generic address. If 166 there are more than 254 named addresses, the addr_space_t type will need 167 to be grown from an unsigned char to unsigned short. */ 168 RID_ADDR_SPACE_0, /* generic address */ 169 RID_ADDR_SPACE_1, 170 RID_ADDR_SPACE_2, 171 RID_ADDR_SPACE_3, 172 RID_ADDR_SPACE_4, 173 RID_ADDR_SPACE_5, 174 RID_ADDR_SPACE_6, 175 RID_ADDR_SPACE_7, 176 RID_ADDR_SPACE_8, 177 RID_ADDR_SPACE_9, 178 RID_ADDR_SPACE_10, 179 RID_ADDR_SPACE_11, 180 RID_ADDR_SPACE_12, 181 RID_ADDR_SPACE_13, 182 RID_ADDR_SPACE_14, 183 RID_ADDR_SPACE_15, 184 185 RID_FIRST_ADDR_SPACE = RID_ADDR_SPACE_0, 186 RID_LAST_ADDR_SPACE = RID_ADDR_SPACE_15, 187 188 RID_MAX, 189 190 RID_FIRST_MODIFIER = RID_STATIC, 191 RID_LAST_MODIFIER = RID_ONEWAY, 192 193 RID_FIRST_CXX0X = RID_CONSTEXPR, 194 RID_LAST_CXX0X = RID_STATIC_ASSERT, 195 RID_FIRST_AT = RID_AT_ENCODE, 196 RID_LAST_AT = RID_AT_IMPLEMENTATION, 197 RID_FIRST_PQ = RID_IN, 198 RID_LAST_PQ = RID_ONEWAY, 199 RID_FIRST_PATTR = RID_GETTER, 200 RID_LAST_PATTR = RID_NONATOMIC 201 }; 202 203 #define OBJC_IS_AT_KEYWORD(rid) \ 204 ((unsigned int) (rid) >= (unsigned int) RID_FIRST_AT && \ 205 (unsigned int) (rid) <= (unsigned int) RID_LAST_AT) 206 207 #define OBJC_IS_PQ_KEYWORD(rid) \ 208 ((unsigned int) (rid) >= (unsigned int) RID_FIRST_PQ && \ 209 (unsigned int) (rid) <= (unsigned int) RID_LAST_PQ) 210 211 #define OBJC_IS_PATTR_KEYWORD(rid) \ 212 ((unsigned int) (rid) >= (unsigned int) RID_FIRST_PATTR && \ 213 (unsigned int) (rid) <= (unsigned int) RID_LAST_PATTR) 214 215 /* OBJC_IS_CXX_KEYWORD recognizes the 'CXX_OBJC' keywords (such as 216 'class') which are shared in a subtle way between Objective-C and 217 C++. When the lexer is lexing in Objective-C/Objective-C++, if it 218 finds '@' followed by one of these identifiers (eg, '@class'), it 219 recognizes the whole as an Objective-C keyword. If the identifier 220 is found elsewhere, it follows the rules of the C/C++ language. 221 */ 222 #define OBJC_IS_CXX_KEYWORD(rid) \ 223 (rid == RID_CLASS \ 224 || rid == RID_PUBLIC || rid == RID_PROTECTED || rid == RID_PRIVATE \ 225 || rid == RID_TRY || rid == RID_THROW || rid == RID_CATCH) 226 227 /* The elements of `ridpointers' are identifier nodes for the reserved 228 type names and storage classes. It is indexed by a RID_... value. */ 229 extern GTY ((length ("(int) RID_MAX"))) tree *ridpointers; 230 231 /* Standard named or nameless data types of the C compiler. */ 232 233 enum c_tree_index 234 { 235 CTI_CHAR16_TYPE, 236 CTI_CHAR32_TYPE, 237 CTI_WCHAR_TYPE, 238 CTI_UNDERLYING_WCHAR_TYPE, 239 CTI_WINT_TYPE, 240 CTI_SIGNED_SIZE_TYPE, /* For format checking only. */ 241 CTI_UNSIGNED_PTRDIFF_TYPE, /* For format checking only. */ 242 CTI_INTMAX_TYPE, 243 CTI_UINTMAX_TYPE, 244 CTI_WIDEST_INT_LIT_TYPE, 245 CTI_WIDEST_UINT_LIT_TYPE, 246 247 /* Types for <stdint.h>, that may not be defined on all 248 targets. */ 249 CTI_SIG_ATOMIC_TYPE, 250 CTI_INT8_TYPE, 251 CTI_INT16_TYPE, 252 CTI_INT32_TYPE, 253 CTI_INT64_TYPE, 254 CTI_UINT8_TYPE, 255 CTI_UINT16_TYPE, 256 CTI_UINT32_TYPE, 257 CTI_UINT64_TYPE, 258 CTI_INT_LEAST8_TYPE, 259 CTI_INT_LEAST16_TYPE, 260 CTI_INT_LEAST32_TYPE, 261 CTI_INT_LEAST64_TYPE, 262 CTI_UINT_LEAST8_TYPE, 263 CTI_UINT_LEAST16_TYPE, 264 CTI_UINT_LEAST32_TYPE, 265 CTI_UINT_LEAST64_TYPE, 266 CTI_INT_FAST8_TYPE, 267 CTI_INT_FAST16_TYPE, 268 CTI_INT_FAST32_TYPE, 269 CTI_INT_FAST64_TYPE, 270 CTI_UINT_FAST8_TYPE, 271 CTI_UINT_FAST16_TYPE, 272 CTI_UINT_FAST32_TYPE, 273 CTI_UINT_FAST64_TYPE, 274 CTI_INTPTR_TYPE, 275 CTI_UINTPTR_TYPE, 276 277 CTI_CHAR_ARRAY_TYPE, 278 CTI_CHAR16_ARRAY_TYPE, 279 CTI_CHAR32_ARRAY_TYPE, 280 CTI_WCHAR_ARRAY_TYPE, 281 CTI_INT_ARRAY_TYPE, 282 CTI_STRING_TYPE, 283 CTI_CONST_STRING_TYPE, 284 285 /* Type for boolean expressions (bool in C++, int in C). */ 286 CTI_TRUTHVALUE_TYPE, 287 CTI_TRUTHVALUE_TRUE, 288 CTI_TRUTHVALUE_FALSE, 289 290 CTI_DEFAULT_FUNCTION_TYPE, 291 292 /* These are not types, but we have to look them up all the time. */ 293 CTI_FUNCTION_NAME_DECL, 294 CTI_PRETTY_FUNCTION_NAME_DECL, 295 CTI_C99_FUNCTION_NAME_DECL, 296 CTI_SAVED_FUNCTION_NAME_DECLS, 297 298 CTI_VOID_ZERO, 299 300 CTI_NULL, 301 302 CTI_MAX 303 }; 304 305 #define C_CPP_HASHNODE(id) \ 306 (&(((struct c_common_identifier *) (id))->node)) 307 #define C_RID_CODE(id) \ 308 ((enum rid) (((struct c_common_identifier *) (id))->node.rid_code)) 309 #define C_SET_RID_CODE(id, code) \ 310 (((struct c_common_identifier *) (id))->node.rid_code = (unsigned char) code) 311 312 /* Identifier part common to the C front ends. Inherits from 313 tree_identifier, despite appearances. */ 314 struct GTY(()) c_common_identifier { 315 struct tree_common common; 316 struct cpp_hashnode node; 317 }; 318 319 /* An entry in the reserved keyword table. */ 320 321 struct c_common_resword 322 { 323 const char *const word; 324 ENUM_BITFIELD(rid) const rid : 16; 325 const unsigned int disable : 16; 326 }; 327 328 /* Extra cpp_ttype values for C++. */ 329 330 /* A token type for keywords, as opposed to ordinary identifiers. */ 331 #define CPP_KEYWORD ((enum cpp_ttype) (N_TTYPES + 1)) 332 333 /* A token type for template-ids. If a template-id is processed while 334 parsing tentatively, it is replaced with a CPP_TEMPLATE_ID token; 335 the value of the CPP_TEMPLATE_ID is whatever was returned by 336 cp_parser_template_id. */ 337 #define CPP_TEMPLATE_ID ((enum cpp_ttype) (CPP_KEYWORD + 1)) 338 339 /* A token type for nested-name-specifiers. If a 340 nested-name-specifier is processed while parsing tentatively, it is 341 replaced with a CPP_NESTED_NAME_SPECIFIER token; the value of the 342 CPP_NESTED_NAME_SPECIFIER is whatever was returned by 343 cp_parser_nested_name_specifier_opt. */ 344 #define CPP_NESTED_NAME_SPECIFIER ((enum cpp_ttype) (CPP_TEMPLATE_ID + 1)) 345 346 /* A token type for pre-parsed C++0x decltype. */ 347 #define CPP_DECLTYPE ((enum cpp_ttype) (CPP_NESTED_NAME_SPECIFIER + 1)) 348 349 /* The number of token types, including C++-specific ones. */ 350 #define N_CP_TTYPES ((int) (CPP_DECLTYPE + 1)) 351 352 /* Disable mask. Keywords are disabled if (reswords[i].disable & 353 mask) is _true_. Thus for keywords which are present in all 354 languages the disable field is zero. */ 355 356 #define D_CONLY 0x001 /* C only (not in C++). */ 357 #define D_CXXONLY 0x002 /* C++ only (not in C). */ 358 #define D_C99 0x004 /* In C, C99 only. */ 359 #define D_CXX0X 0x008 /* In C++, C++0X only. */ 360 #define D_EXT 0x010 /* GCC extension. */ 361 #define D_EXT89 0x020 /* GCC extension incorporated in C99. */ 362 #define D_ASM 0x040 /* Disabled by -fno-asm. */ 363 #define D_OBJC 0x080 /* In Objective C and neither C nor C++. */ 364 #define D_CXX_OBJC 0x100 /* In Objective C, and C++, but not C. */ 365 #define D_CXXWARN 0x200 /* In C warn with -Wcxx-compat. */ 366 367 /* The reserved keyword table. */ 368 extern const struct c_common_resword c_common_reswords[]; 369 370 /* The number of items in the reserved keyword table. */ 371 extern const unsigned int num_c_common_reswords; 372 373 #define char16_type_node c_global_trees[CTI_CHAR16_TYPE] 374 #define char32_type_node c_global_trees[CTI_CHAR32_TYPE] 375 #define wchar_type_node c_global_trees[CTI_WCHAR_TYPE] 376 #define underlying_wchar_type_node c_global_trees[CTI_UNDERLYING_WCHAR_TYPE] 377 #define wint_type_node c_global_trees[CTI_WINT_TYPE] 378 #define signed_size_type_node c_global_trees[CTI_SIGNED_SIZE_TYPE] 379 #define unsigned_ptrdiff_type_node c_global_trees[CTI_UNSIGNED_PTRDIFF_TYPE] 380 #define intmax_type_node c_global_trees[CTI_INTMAX_TYPE] 381 #define uintmax_type_node c_global_trees[CTI_UINTMAX_TYPE] 382 #define widest_integer_literal_type_node c_global_trees[CTI_WIDEST_INT_LIT_TYPE] 383 #define widest_unsigned_literal_type_node c_global_trees[CTI_WIDEST_UINT_LIT_TYPE] 384 385 #define sig_atomic_type_node c_global_trees[CTI_SIG_ATOMIC_TYPE] 386 #define int8_type_node c_global_trees[CTI_INT8_TYPE] 387 #define int16_type_node c_global_trees[CTI_INT16_TYPE] 388 #define int32_type_node c_global_trees[CTI_INT32_TYPE] 389 #define int64_type_node c_global_trees[CTI_INT64_TYPE] 390 #define uint8_type_node c_global_trees[CTI_UINT8_TYPE] 391 #define c_uint16_type_node c_global_trees[CTI_UINT16_TYPE] 392 #define c_uint32_type_node c_global_trees[CTI_UINT32_TYPE] 393 #define c_uint64_type_node c_global_trees[CTI_UINT64_TYPE] 394 #define int_least8_type_node c_global_trees[CTI_INT_LEAST8_TYPE] 395 #define int_least16_type_node c_global_trees[CTI_INT_LEAST16_TYPE] 396 #define int_least32_type_node c_global_trees[CTI_INT_LEAST32_TYPE] 397 #define int_least64_type_node c_global_trees[CTI_INT_LEAST64_TYPE] 398 #define uint_least8_type_node c_global_trees[CTI_UINT_LEAST8_TYPE] 399 #define uint_least16_type_node c_global_trees[CTI_UINT_LEAST16_TYPE] 400 #define uint_least32_type_node c_global_trees[CTI_UINT_LEAST32_TYPE] 401 #define uint_least64_type_node c_global_trees[CTI_UINT_LEAST64_TYPE] 402 #define int_fast8_type_node c_global_trees[CTI_INT_FAST8_TYPE] 403 #define int_fast16_type_node c_global_trees[CTI_INT_FAST16_TYPE] 404 #define int_fast32_type_node c_global_trees[CTI_INT_FAST32_TYPE] 405 #define int_fast64_type_node c_global_trees[CTI_INT_FAST64_TYPE] 406 #define uint_fast8_type_node c_global_trees[CTI_UINT_FAST8_TYPE] 407 #define uint_fast16_type_node c_global_trees[CTI_UINT_FAST16_TYPE] 408 #define uint_fast32_type_node c_global_trees[CTI_UINT_FAST32_TYPE] 409 #define uint_fast64_type_node c_global_trees[CTI_UINT_FAST64_TYPE] 410 #define intptr_type_node c_global_trees[CTI_INTPTR_TYPE] 411 #define uintptr_type_node c_global_trees[CTI_UINTPTR_TYPE] 412 413 #define truthvalue_type_node c_global_trees[CTI_TRUTHVALUE_TYPE] 414 #define truthvalue_true_node c_global_trees[CTI_TRUTHVALUE_TRUE] 415 #define truthvalue_false_node c_global_trees[CTI_TRUTHVALUE_FALSE] 416 417 #define char_array_type_node c_global_trees[CTI_CHAR_ARRAY_TYPE] 418 #define char16_array_type_node c_global_trees[CTI_CHAR16_ARRAY_TYPE] 419 #define char32_array_type_node c_global_trees[CTI_CHAR32_ARRAY_TYPE] 420 #define wchar_array_type_node c_global_trees[CTI_WCHAR_ARRAY_TYPE] 421 #define int_array_type_node c_global_trees[CTI_INT_ARRAY_TYPE] 422 #define string_type_node c_global_trees[CTI_STRING_TYPE] 423 #define const_string_type_node c_global_trees[CTI_CONST_STRING_TYPE] 424 425 #define default_function_type c_global_trees[CTI_DEFAULT_FUNCTION_TYPE] 426 427 #define function_name_decl_node c_global_trees[CTI_FUNCTION_NAME_DECL] 428 #define pretty_function_name_decl_node c_global_trees[CTI_PRETTY_FUNCTION_NAME_DECL] 429 #define c99_function_name_decl_node c_global_trees[CTI_C99_FUNCTION_NAME_DECL] 430 #define saved_function_name_decls c_global_trees[CTI_SAVED_FUNCTION_NAME_DECLS] 431 432 /* A node for `((void) 0)'. */ 433 #define void_zero_node c_global_trees[CTI_VOID_ZERO] 434 435 /* The node for C++ `__null'. */ 436 #define null_node c_global_trees[CTI_NULL] 437 438 extern GTY(()) tree c_global_trees[CTI_MAX]; 439 440 /* In a RECORD_TYPE, a sorted array of the fields of the type, not a 441 tree for size reasons. */ 442 struct GTY((variable_size)) sorted_fields_type { 443 int len; 444 tree GTY((length ("%h.len"))) elts[1]; 445 }; 446 447 /* Mark which labels are explicitly declared. 448 These may be shadowed, and may be referenced from nested functions. */ 449 #define C_DECLARED_LABEL_FLAG(label) TREE_LANG_FLAG_1 (label) 450 451 typedef enum c_language_kind 452 { 453 clk_c = 0, /* C90, C94 or C99 */ 454 clk_objc = 1, /* clk_c with ObjC features. */ 455 clk_cxx = 2, /* ANSI/ISO C++ */ 456 clk_objcxx = 3 /* clk_cxx with ObjC features. */ 457 } 458 c_language_kind; 459 460 /* To test for a specific language use c_language, defined by each 461 front end. For "ObjC features" or "not C++" use the macros. */ 462 extern c_language_kind c_language; 463 464 #define c_dialect_cxx() ((c_language & clk_cxx) != 0) 465 #define c_dialect_objc() ((c_language & clk_objc) != 0) 466 467 /* The various name of operator that appears in error messages. */ 468 typedef enum ref_operator { 469 /* NULL */ 470 RO_NULL, 471 /* array indexing */ 472 RO_ARRAY_INDEXING, 473 /* unary * */ 474 RO_UNARY_STAR, 475 /* -> */ 476 RO_ARROW, 477 /* implicit conversion */ 478 RO_IMPLICIT_CONVERSION, 479 /* ->* */ 480 RO_ARROW_STAR 481 } ref_operator; 482 483 /* Information about a statement tree. */ 484 485 struct GTY(()) stmt_tree_s { 486 /* A stack of statement lists being collected. */ 487 vec<tree, va_gc> *x_cur_stmt_list; 488 489 /* In C++, Nonzero if we should treat statements as full 490 expressions. In particular, this variable is non-zero if at the 491 end of a statement we should destroy any temporaries created 492 during that statement. Similarly, if, at the end of a block, we 493 should destroy any local variables in this block. Normally, this 494 variable is nonzero, since those are the normal semantics of 495 C++. 496 497 This flag has no effect in C. */ 498 int stmts_are_full_exprs_p; 499 }; 500 501 typedef struct stmt_tree_s *stmt_tree; 502 503 /* Global state pertinent to the current function. Some C dialects 504 extend this structure with additional fields. */ 505 506 struct GTY(()) c_language_function { 507 /* While we are parsing the function, this contains information 508 about the statement-tree that we are building. */ 509 struct stmt_tree_s x_stmt_tree; 510 511 /* Vector of locally defined typedefs, for 512 -Wunused-local-typedefs. */ 513 vec<tree, va_gc> *local_typedefs; 514 }; 515 516 #define stmt_list_stack (current_stmt_tree ()->x_cur_stmt_list) 517 518 /* When building a statement-tree, this is the current statement list 519 being collected. */ 520 #define cur_stmt_list (stmt_list_stack->last ()) 521 522 #define building_stmt_list_p() (stmt_list_stack && !stmt_list_stack->is_empty()) 523 524 /* Language-specific hooks. */ 525 526 /* If non-NULL, this function is called after a precompile header file 527 is loaded. */ 528 extern void (*lang_post_pch_load) (void); 529 530 extern void push_file_scope (void); 531 extern void pop_file_scope (void); 532 extern stmt_tree current_stmt_tree (void); 533 extern tree push_stmt_list (void); 534 extern tree pop_stmt_list (tree); 535 extern tree add_stmt (tree); 536 extern void push_cleanup (tree, tree, bool); 537 extern tree pushdecl_top_level (tree); 538 extern tree pushdecl (tree); 539 extern tree build_modify_expr (location_t, tree, tree, enum tree_code, 540 location_t, tree, tree); 541 extern tree build_indirect_ref (location_t, tree, ref_operator); 542 543 extern int field_decl_cmp (const void *, const void *); 544 extern void resort_sorted_fields (void *, void *, gt_pointer_operator, 545 void *); 546 extern bool has_c_linkage (const_tree decl); 547 548 /* Switches common to the C front ends. */ 550 551 /* Nonzero means don't output line number information. */ 552 553 extern char flag_no_line_commands; 554 555 /* Nonzero causes -E output not to be done, but directives such as 556 #define that have side effects are still obeyed. */ 557 558 extern char flag_no_output; 559 560 /* Nonzero means dump macros in some fashion; contains the 'D', 'M', 561 'N' or 'U' of the command line switch. */ 562 563 extern char flag_dump_macros; 564 565 /* Nonzero means pass #include lines through to the output. */ 566 567 extern char flag_dump_includes; 568 569 /* Nonzero means process PCH files while preprocessing. */ 570 571 extern bool flag_pch_preprocess; 572 573 /* The file name to which we should write a precompiled header, or 574 NULL if no header will be written in this compile. */ 575 576 extern const char *pch_file; 577 578 /* Nonzero if an ISO standard was selected. It rejects macros in the 579 user's namespace. */ 580 581 extern int flag_iso; 582 583 /* C/ObjC language option variables. */ 584 585 586 /* Nonzero means allow type mismatches in conditional expressions; 587 just make their values `void'. */ 588 589 extern int flag_cond_mismatch; 590 591 /* Nonzero means enable C89 Amendment 1 features. */ 592 593 extern int flag_isoc94; 594 595 /* Nonzero means use the ISO C99 (or C11) dialect of C. */ 596 597 extern int flag_isoc99; 598 599 /* Nonzero means use the ISO C11 dialect of C. */ 600 601 extern int flag_isoc11; 602 603 /* Nonzero means that we have builtin functions, and main is an int. */ 604 605 extern int flag_hosted; 606 607 /* ObjC language option variables. */ 608 609 610 /* Tells the compiler that this is a special run. Do not perform any 611 compiling, instead we are to test some platform dependent features 612 and output a C header file with appropriate definitions. */ 613 614 extern int print_struct_values; 615 616 /* Tells the compiler what is the constant string class for ObjC. */ 617 618 extern const char *constant_string_class_name; 619 620 621 /* C++ language option variables. */ 622 623 624 /* Nonzero means generate separate instantiation control files and 625 juggle them at link time. */ 626 627 extern int flag_use_repository; 628 629 /* The supported C++ dialects. */ 630 631 enum cxx_dialect { 632 /* C++98 with TC1 */ 633 cxx98, 634 cxx03 = cxx98, 635 /* C++11 */ 636 cxx0x, 637 cxx11 = cxx0x, 638 /* C++1y (C++17?) */ 639 cxx1y 640 }; 641 642 /* The C++ dialect being used. C++98 is the default. */ 643 extern enum cxx_dialect cxx_dialect; 644 645 /* Maximum template instantiation depth. This limit is rather 646 arbitrary, but it exists to limit the time it takes to notice 647 excessively recursive template instantiations. */ 648 649 extern int max_tinst_depth; 650 651 /* Nonzero means that we should not issue warnings about problems that 652 occur when the code is executed, because the code being processed 653 is not expected to be executed. This is set during parsing. This 654 is used for cases like sizeof() and "0 ? a : b". This is a count, 655 not a bool, because unexecuted expressions can nest. */ 656 657 extern int c_inhibit_evaluation_warnings; 658 659 /* Whether lexing has been completed, so subsequent preprocessor 660 errors should use the compiler's input_location. */ 661 662 extern bool done_lexing; 663 664 /* C types are partitioned into three subsets: object, function, and 665 incomplete types. */ 666 #define C_TYPE_OBJECT_P(type) \ 667 (TREE_CODE (type) != FUNCTION_TYPE && TYPE_SIZE (type)) 668 669 #define C_TYPE_INCOMPLETE_P(type) \ 670 (TREE_CODE (type) != FUNCTION_TYPE && TYPE_SIZE (type) == 0) 671 672 #define C_TYPE_FUNCTION_P(type) \ 673 (TREE_CODE (type) == FUNCTION_TYPE) 674 675 /* For convenience we define a single macro to identify the class of 676 object or incomplete types. */ 677 #define C_TYPE_OBJECT_OR_INCOMPLETE_P(type) \ 678 (!C_TYPE_FUNCTION_P (type)) 679 680 struct visibility_flags 681 { 682 unsigned inpragma : 1; /* True when in #pragma GCC visibility. */ 683 unsigned inlines_hidden : 1; /* True when -finlineshidden in effect. */ 684 }; 685 686 /* Global visibility options. */ 687 extern struct visibility_flags visibility_options; 688 689 /* Attribute table common to the C front ends. */ 690 extern const struct attribute_spec c_common_attribute_table[]; 691 extern const struct attribute_spec c_common_format_attribute_table[]; 692 693 /* Pointer to function to lazily generate the VAR_DECL for __FUNCTION__ etc. 694 ID is the identifier to use, NAME is the string. 695 TYPE_DEP indicates whether it depends on type of the function or not 696 (i.e. __PRETTY_FUNCTION__). */ 697 698 extern tree (*make_fname_decl) (location_t, tree, int); 699 700 /* In c-decl.c and cp/tree.c. FIXME. */ 701 extern void c_register_addr_space (const char *str, addr_space_t as); 702 703 /* In c-common.c. */ 704 extern bool in_late_binary_op; 705 extern const char *c_addr_space_name (addr_space_t as); 706 extern tree identifier_global_value (tree); 707 extern tree c_linkage_bindings (tree); 708 extern void record_builtin_type (enum rid, const char *, tree); 709 extern tree build_void_list_node (void); 710 extern void start_fname_decls (void); 711 extern void finish_fname_decls (void); 712 extern const char *fname_as_string (int); 713 extern tree fname_decl (location_t, unsigned, tree); 714 715 extern int check_user_alignment (const_tree, bool); 716 extern void check_function_arguments (const_tree, int, tree *); 717 extern void check_function_arguments_recurse (void (*) 718 (void *, tree, 719 unsigned HOST_WIDE_INT), 720 void *, tree, 721 unsigned HOST_WIDE_INT); 722 extern bool check_builtin_function_arguments (tree, int, tree *); 723 extern void check_function_format (tree, int, tree *); 724 extern tree handle_format_attribute (tree *, tree, tree, int, bool *); 725 extern tree handle_format_arg_attribute (tree *, tree, tree, int, bool *); 726 extern bool attribute_takes_identifier_p (const_tree); 727 extern bool c_common_handle_option (size_t, const char *, int, int, location_t, 728 const struct cl_option_handlers *); 729 extern bool default_handle_c_option (size_t, const char *, int); 730 extern tree c_common_type_for_mode (enum machine_mode, int); 731 extern tree c_common_type_for_size (unsigned int, int); 732 extern tree c_common_fixed_point_type_for_size (unsigned int, unsigned int, 733 int, int); 734 extern tree c_common_unsigned_type (tree); 735 extern tree c_common_signed_type (tree); 736 extern tree c_common_signed_or_unsigned_type (int, tree); 737 extern void c_common_init_ts (void); 738 extern tree c_build_bitfield_integer_type (unsigned HOST_WIDE_INT, int); 739 extern bool unsafe_conversion_p (tree, tree, bool); 740 extern bool decl_with_nonnull_addr_p (const_tree); 741 extern tree c_fully_fold (tree, bool, bool *); 742 extern tree decl_constant_value_for_optimization (tree); 743 extern tree c_wrap_maybe_const (tree, bool); 744 extern tree c_save_expr (tree); 745 extern tree c_common_truthvalue_conversion (location_t, tree); 746 extern void c_apply_type_quals_to_decl (int, tree); 747 extern tree c_sizeof_or_alignof_type (location_t, tree, bool, int); 748 extern tree c_alignof_expr (location_t, tree); 749 /* Print an error message for invalid operands to arith operation CODE. 750 NOP_EXPR is used as a special case (see truthvalue_conversion). */ 751 extern void binary_op_error (location_t, enum tree_code, tree, tree); 752 extern tree fix_string_type (tree); 753 extern void constant_expression_warning (tree); 754 extern void constant_expression_error (tree); 755 extern bool strict_aliasing_warning (tree, tree, tree); 756 extern void sizeof_pointer_memaccess_warning (location_t *, tree, 757 vec<tree, va_gc> *, tree *, 758 bool (*) (tree, tree)); 759 extern void warnings_for_convert_and_check (tree, tree, tree); 760 extern tree convert_and_check (tree, tree); 761 extern void overflow_warning (location_t, tree); 762 extern bool warn_if_unused_value (const_tree, location_t); 763 extern void warn_logical_operator (location_t, enum tree_code, tree, 764 enum tree_code, tree, enum tree_code, tree); 765 extern void check_main_parameter_types (tree decl); 766 extern bool c_determine_visibility (tree); 767 extern bool same_scalar_type_ignoring_signedness (tree, tree); 768 extern void mark_valid_location_for_stdc_pragma (bool); 769 extern bool valid_location_for_stdc_pragma_p (void); 770 extern void set_float_const_decimal64 (void); 771 extern void clear_float_const_decimal64 (void); 772 extern bool float_const_decimal64_p (void); 773 774 extern bool keyword_begins_type_specifier (enum rid); 775 extern bool keyword_is_storage_class_specifier (enum rid); 776 extern bool keyword_is_type_qualifier (enum rid); 777 extern bool keyword_is_decl_specifier (enum rid); 778 extern bool cxx_fundamental_alignment_p (unsigned); 779 780 #define c_sizeof(LOC, T) c_sizeof_or_alignof_type (LOC, T, true, 1) 781 #define c_alignof(LOC, T) c_sizeof_or_alignof_type (LOC, T, false, 1) 782 783 /* Subroutine of build_binary_op, used for certain operations. */ 784 extern tree shorten_binary_op (tree result_type, tree op0, tree op1, bool bitwise); 785 786 /* Subroutine of build_binary_op, used for comparison operations. 787 See if the operands have both been converted from subword integer types 788 and, if so, perhaps change them both back to their original type. */ 789 extern tree shorten_compare (tree *, tree *, tree *, enum tree_code *); 790 791 extern tree pointer_int_sum (location_t, enum tree_code, tree, tree); 792 793 /* Add qualifiers to a type, in the fashion for C. */ 794 extern tree c_build_qualified_type (tree, int); 795 796 /* Build tree nodes and builtin functions common to both C and C++ language 797 frontends. */ 798 extern void c_common_nodes_and_builtins (void); 799 800 extern void disable_builtin_function (const char *); 801 802 extern void set_compound_literal_name (tree decl); 803 804 extern tree build_va_arg (location_t, tree, tree); 805 806 extern const unsigned int c_family_lang_mask; 807 extern unsigned int c_common_option_lang_mask (void); 808 extern void c_common_initialize_diagnostics (diagnostic_context *); 809 extern bool c_common_complain_wrong_lang_p (const struct cl_option *); 810 extern void c_common_init_options_struct (struct gcc_options *); 811 extern void c_common_init_options (unsigned int, struct cl_decoded_option *); 812 extern bool c_common_post_options (const char **); 813 extern bool c_common_init (void); 814 extern void c_common_finish (void); 815 extern void c_common_parse_file (void); 816 extern alias_set_type c_common_get_alias_set (tree); 817 extern void c_register_builtin_type (tree, const char*); 818 extern bool c_promoting_integer_type_p (const_tree); 819 extern int self_promoting_args_p (const_tree); 820 extern tree strip_pointer_operator (tree); 821 extern tree strip_pointer_or_array_types (tree); 822 extern HOST_WIDE_INT c_common_to_target_charset (HOST_WIDE_INT); 823 824 /* This is the basic parsing function. */ 825 extern void c_parse_file (void); 826 827 extern void warn_for_omitted_condop (location_t, tree); 828 829 /* These macros provide convenient access to the various _STMT nodes. */ 830 831 /* Nonzero if a given STATEMENT_LIST represents the outermost binding 832 if a statement expression. */ 833 #define STATEMENT_LIST_STMT_EXPR(NODE) \ 834 TREE_LANG_FLAG_1 (STATEMENT_LIST_CHECK (NODE)) 835 836 /* Nonzero if a label has been added to the statement list. */ 837 #define STATEMENT_LIST_HAS_LABEL(NODE) \ 838 TREE_LANG_FLAG_3 (STATEMENT_LIST_CHECK (NODE)) 839 840 /* C_MAYBE_CONST_EXPR accessors. */ 841 #define C_MAYBE_CONST_EXPR_PRE(NODE) \ 842 TREE_OPERAND (C_MAYBE_CONST_EXPR_CHECK (NODE), 0) 843 #define C_MAYBE_CONST_EXPR_EXPR(NODE) \ 844 TREE_OPERAND (C_MAYBE_CONST_EXPR_CHECK (NODE), 1) 845 #define C_MAYBE_CONST_EXPR_INT_OPERANDS(NODE) \ 846 TREE_LANG_FLAG_0 (C_MAYBE_CONST_EXPR_CHECK (NODE)) 847 #define C_MAYBE_CONST_EXPR_NON_CONST(NODE) \ 848 TREE_LANG_FLAG_1 (C_MAYBE_CONST_EXPR_CHECK (NODE)) 849 #define EXPR_INT_CONST_OPERANDS(EXPR) \ 850 (INTEGRAL_TYPE_P (TREE_TYPE (EXPR)) \ 851 && (TREE_CODE (EXPR) == INTEGER_CST \ 852 || (TREE_CODE (EXPR) == C_MAYBE_CONST_EXPR \ 853 && C_MAYBE_CONST_EXPR_INT_OPERANDS (EXPR)))) 854 855 /* In a FIELD_DECL, nonzero if the decl was originally a bitfield. */ 856 #define DECL_C_BIT_FIELD(NODE) \ 857 (DECL_LANG_FLAG_4 (FIELD_DECL_CHECK (NODE)) == 1) 858 #define SET_DECL_C_BIT_FIELD(NODE) \ 859 (DECL_LANG_FLAG_4 (FIELD_DECL_CHECK (NODE)) = 1) 860 #define CLEAR_DECL_C_BIT_FIELD(NODE) \ 861 (DECL_LANG_FLAG_4 (FIELD_DECL_CHECK (NODE)) = 0) 862 863 extern tree do_case (location_t, tree, tree); 864 extern tree build_stmt (location_t, enum tree_code, ...); 865 extern tree build_real_imag_expr (location_t, enum tree_code, tree); 866 867 /* These functions must be defined by each front-end which implements 868 a variant of the C language. They are used in c-common.c. */ 869 870 extern tree build_unary_op (location_t, enum tree_code, tree, int); 871 extern tree build_binary_op (location_t, enum tree_code, tree, tree, int); 872 extern tree perform_integral_promotions (tree); 873 874 /* These functions must be defined by each front-end which implements 875 a variant of the C language. They are used by port files. */ 876 877 extern tree default_conversion (tree); 878 879 /* Given two integer or real types, return the type for their sum. 880 Given two compatible ANSI C types, returns the merged type. */ 881 882 extern tree common_type (tree, tree); 883 884 extern tree decl_constant_value (tree); 885 886 /* Handle increment and decrement of boolean types. */ 887 extern tree boolean_increment (enum tree_code, tree); 888 889 extern int case_compare (splay_tree_key, splay_tree_key); 890 891 extern tree c_add_case_label (location_t, splay_tree, tree, tree, tree, tree); 892 893 extern void c_do_switch_warnings (splay_tree, location_t, tree, tree); 894 895 extern tree build_function_call (location_t, tree, tree); 896 897 extern tree build_function_call_vec (location_t, tree, vec<tree, va_gc> *, 898 vec<tree, va_gc> *); 899 900 extern tree resolve_overloaded_builtin (location_t, tree, vec<tree, va_gc> *); 901 902 extern tree finish_label_address_expr (tree, location_t); 903 904 /* Same function prototype, but the C and C++ front ends have 905 different implementations. Used in c-common.c. */ 906 extern tree lookup_label (tree); 907 extern tree lookup_name (tree); 908 extern bool lvalue_p (const_tree); 909 910 extern bool vector_targets_convertible_p (const_tree t1, const_tree t2); 911 extern bool vector_types_convertible_p (const_tree t1, const_tree t2, bool emit_lax_note); 912 extern tree c_build_vec_perm_expr (location_t, tree, tree, tree); 913 914 extern rtx c_expand_expr (tree, rtx, enum machine_mode, int, rtx *); 915 916 extern void init_c_lex (void); 917 918 extern void c_cpp_builtins (cpp_reader *); 919 extern void c_cpp_builtins_optimize_pragma (cpp_reader *, tree, tree); 920 extern bool c_cpp_error (cpp_reader *, int, int, location_t, unsigned int, 921 const char *, va_list *) 922 ATTRIBUTE_GCC_DIAG(6,0); 923 924 extern bool parse_optimize_options (tree, bool); 925 926 /* Positive if an implicit `extern "C"' scope has just been entered; 927 negative if such a scope has just been exited. */ 928 extern GTY(()) int pending_lang_change; 929 930 /* Information recorded about each file examined during compilation. */ 931 932 struct c_fileinfo 933 { 934 int time; /* Time spent in the file. */ 935 936 /* Flags used only by C++. 937 INTERFACE_ONLY nonzero means that we are in an "interface" section 938 of the compiler. INTERFACE_UNKNOWN nonzero means we cannot trust 939 the value of INTERFACE_ONLY. If INTERFACE_UNKNOWN is zero and 940 INTERFACE_ONLY is zero, it means that we are responsible for 941 exporting definitions that others might need. */ 942 short interface_only; 943 short interface_unknown; 944 }; 945 946 struct c_fileinfo *get_fileinfo (const char *); 947 extern void dump_time_statistics (void); 948 949 extern bool c_dump_tree (void *, tree); 950 951 extern void verify_sequence_points (tree); 952 953 extern tree fold_offsetof_1 (tree); 954 extern tree fold_offsetof (tree); 955 956 /* Places where an lvalue, or modifiable lvalue, may be required. 957 Used to select diagnostic messages in lvalue_error and 958 readonly_error. */ 959 enum lvalue_use { 960 lv_assign, 961 lv_increment, 962 lv_decrement, 963 lv_addressof, 964 lv_asm 965 }; 966 967 extern void readonly_error (tree, enum lvalue_use); 968 extern void lvalue_error (location_t, enum lvalue_use); 969 extern void invalid_indirection_error (location_t, tree, ref_operator); 970 971 extern int complete_array_type (tree *, tree, bool); 972 973 extern tree builtin_type_for_size (int, bool); 974 975 extern void c_common_mark_addressable_vec (tree); 976 977 extern void warn_array_subscript_with_type_char (tree); 978 extern void warn_about_parentheses (location_t, 979 enum tree_code, 980 enum tree_code, tree, 981 enum tree_code, tree); 982 extern void warn_for_unused_label (tree label); 983 extern void warn_for_div_by_zero (location_t, tree divisor); 984 extern void warn_for_sign_compare (location_t, 985 tree orig_op0, tree orig_op1, 986 tree op0, tree op1, 987 tree result_type, 988 enum tree_code resultcode); 989 extern void do_warn_double_promotion (tree, tree, tree, const char *, 990 location_t); 991 extern void set_underlying_type (tree); 992 extern void record_locally_defined_typedef (tree); 993 extern void maybe_record_typedef_use (tree); 994 extern void maybe_warn_unused_local_typedefs (void); 995 extern vec<tree, va_gc> *make_tree_vector (void); 996 extern void release_tree_vector (vec<tree, va_gc> *); 997 extern vec<tree, va_gc> *make_tree_vector_single (tree); 998 extern vec<tree, va_gc> *make_tree_vector_from_list (tree); 999 extern vec<tree, va_gc> *make_tree_vector_copy (const vec<tree, va_gc> *); 1000 1001 /* In c-gimplify.c */ 1002 extern void c_genericize (tree); 1003 extern int c_gimplify_expr (tree *, gimple_seq *, gimple_seq *); 1004 extern tree c_build_bind_expr (location_t, tree, tree); 1005 1006 /* In c-pch.c */ 1007 extern void pch_init (void); 1008 extern void pch_cpp_save_state (void); 1009 extern int c_common_valid_pch (cpp_reader *pfile, const char *name, int fd); 1010 extern void c_common_read_pch (cpp_reader *pfile, const char *name, int fd, 1011 const char *orig); 1012 extern void c_common_write_pch (void); 1013 extern void c_common_no_more_pch (void); 1014 extern void c_common_pch_pragma (cpp_reader *pfile, const char *); 1015 1016 /* In *-checksum.c */ 1017 extern const unsigned char executable_checksum[16]; 1018 1019 /* In c-cppbuiltin.c */ 1020 extern void builtin_define_std (const char *macro); 1021 extern void builtin_define_with_value (const char *, const char *, int); 1022 extern void c_stddef_cpp_builtins (void); 1023 extern void fe_file_change (const struct line_map *); 1024 extern void c_parse_error (const char *, enum cpp_ttype, tree, unsigned char); 1025 1026 /* In c-ppoutput.c */ 1027 extern void init_pp_output (FILE *); 1028 extern void preprocess_file (cpp_reader *); 1029 extern void pp_file_change (const struct line_map *); 1030 extern void pp_dir_change (cpp_reader *, const char *); 1031 extern bool check_missing_format_attribute (tree, tree); 1032 1033 /* In c-omp.c */ 1034 extern tree c_finish_omp_master (location_t, tree); 1035 extern tree c_finish_omp_critical (location_t, tree, tree); 1036 extern tree c_finish_omp_ordered (location_t, tree); 1037 extern void c_finish_omp_barrier (location_t); 1038 extern tree c_finish_omp_atomic (location_t, enum tree_code, enum tree_code, 1039 tree, tree, tree, tree, tree); 1040 extern void c_finish_omp_flush (location_t); 1041 extern void c_finish_omp_taskwait (location_t); 1042 extern void c_finish_omp_taskyield (location_t); 1043 extern tree c_finish_omp_for (location_t, tree, tree, tree, tree, tree, tree); 1044 extern void c_split_parallel_clauses (location_t, tree, tree *, tree *); 1045 extern enum omp_clause_default_kind c_omp_predetermined_sharing (tree); 1046 1047 /* Not in c-omp.c; provided by the front end. */ 1048 extern bool c_omp_sharing_predetermined (tree); 1049 extern tree c_omp_remap_decl (tree, bool); 1050 extern void record_types_used_by_current_var_decl (tree); 1051 1052 /* Return next tree in the chain for chain_next walking of tree nodes. */ 1053 static inline tree 1054 c_tree_chain_next (tree t) 1055 { 1056 /* TREE_CHAIN of a type is TYPE_STUB_DECL, which is different 1057 kind of object, never a long chain of nodes. Prefer 1058 TYPE_NEXT_VARIANT for types. */ 1059 if (CODE_CONTAINS_STRUCT (TREE_CODE (t), TS_TYPE_COMMON)) 1060 return TYPE_NEXT_VARIANT (t); 1061 /* Otherwise, if there is TREE_CHAIN, return it. */ 1062 if (CODE_CONTAINS_STRUCT (TREE_CODE (t), TS_COMMON)) 1063 return TREE_CHAIN (t); 1064 return NULL; 1065 } 1066 1067 /* Mask used by tm_stmt_attr. */ 1068 #define TM_STMT_ATTR_OUTER 2 1069 #define TM_STMT_ATTR_ATOMIC 4 1070 #define TM_STMT_ATTR_RELAXED 8 1071 1072 extern int parse_tm_stmt_attr (tree, int); 1073 1074 /* Mask used by tm_attr_to_mask and tm_mask_to_attr. Note that these 1075 are ordered specifically such that more restrictive attributes are 1076 at lower bit positions. This fact is known by the C++ tm attribute 1077 inheritance code such that least bit extraction (mask & -mask) results 1078 in the most restrictive attribute. */ 1079 #define TM_ATTR_SAFE 1 1080 #define TM_ATTR_CALLABLE 2 1081 #define TM_ATTR_PURE 4 1082 #define TM_ATTR_IRREVOCABLE 8 1083 #define TM_ATTR_MAY_CANCEL_OUTER 16 1084 1085 extern int tm_attr_to_mask (tree); 1086 extern tree tm_mask_to_attr (int); 1087 extern tree find_tm_attribute (tree); 1088 1089 /* A suffix-identifier value doublet that represents user-defined literals 1090 for C++-0x. */ 1091 enum overflow_type { 1092 OT_UNDERFLOW = -1, 1093 OT_NONE, 1094 OT_OVERFLOW 1095 }; 1096 1097 struct GTY(()) tree_userdef_literal { 1098 struct tree_base base; 1099 tree suffix_id; 1100 tree value; 1101 tree num_string; 1102 enum overflow_type overflow; 1103 }; 1104 1105 #define USERDEF_LITERAL_SUFFIX_ID(NODE) \ 1106 (((struct tree_userdef_literal *)USERDEF_LITERAL_CHECK (NODE))->suffix_id) 1107 1108 #define USERDEF_LITERAL_VALUE(NODE) \ 1109 (((struct tree_userdef_literal *)USERDEF_LITERAL_CHECK (NODE))->value) 1110 1111 #define USERDEF_LITERAL_OVERFLOW(NODE) \ 1112 (((struct tree_userdef_literal *)USERDEF_LITERAL_CHECK (NODE))->overflow) 1113 1114 #define USERDEF_LITERAL_NUM_STRING(NODE) \ 1115 (((struct tree_userdef_literal *)USERDEF_LITERAL_CHECK (NODE))->num_string) 1116 1117 #define USERDEF_LITERAL_TYPE(NODE) \ 1118 (TREE_TYPE (USERDEF_LITERAL_VALUE (NODE))) 1119 1120 extern tree build_userdef_literal (tree suffix_id, tree value, 1121 enum overflow_type overflow, 1122 tree num_string); 1123 1124 extern void convert_vector_to_pointer_for_subscript (location_t, tree*, tree); 1125 1126 /* Possibe cases of scalar_to_vector conversion. */ 1127 enum stv_conv { 1128 stv_error, /* Error occured. */ 1129 stv_nothing, /* Nothing happened. */ 1130 stv_firstarg, /* First argument must be expanded. */ 1131 stv_secondarg /* Second argument must be expanded. */ 1132 }; 1133 1134 extern enum stv_conv scalar_to_vector (location_t loc, enum tree_code code, 1135 tree op0, tree op1, bool); 1136 1137 #endif /* ! GCC_C_COMMON_H */ 1138