diff options
-rw-r--r-- | gcc/cp/ChangeLog | 43 | ||||
-rw-r--r-- | gcc/cp/cp-tree.h | 22 | ||||
-rw-r--r-- | gcc/cp/decl.c | 4 | ||||
-rw-r--r-- | gcc/cp/dump.c | 2 | ||||
-rw-r--r-- | gcc/cp/error.c | 7 | ||||
-rw-r--r-- | gcc/cp/init.c | 126 | ||||
-rw-r--r-- | gcc/cp/lex.c | 7 | ||||
-rw-r--r-- | gcc/cp/method.c | 26 | ||||
-rw-r--r-- | gcc/cp/parse.c | 1707 | ||||
-rw-r--r-- | gcc/cp/parse.y | 92 | ||||
-rw-r--r-- | gcc/cp/pt.c | 57 | ||||
-rw-r--r-- | gcc/cp/semantics.c | 9 | ||||
-rw-r--r-- | gcc/testsuite/g++.old-deja/g++.pt/ref3.C | 21 |
13 files changed, 1146 insertions, 977 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 9dc43ee..a6452ac 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -12,6 +12,49 @@ 2000-06-15 Mark Mitchell <mark@codesourcery.com> + * cp-tree.h (struct language_function): Remove x_base_init_list + and x_member_init_list. + (current_base_init_list): Remove. + (current_member_init_list): Likewise. + (setup_vtbl_ptr): Change prototype. + (emit_base_init): Likewise. + (expand_member_init): Likewise. + (reinit_parse_for_function): Remove. + * decl.c (save_function_data): Don't clear x_base_init_list and + x_member_init_list. + (mark_language_function): Don't mark them. + * init.c (perform_member_init): Tweak comment. + (sort_member_init): Take the list of initializers as an argument. + (sort_base_init): Likewise. + (emit_base_init): Likewise. + (expand_member_init): Return the initializer. Don't use global + variables. + * lex.c (reinit_parse_for_function): Remove. + * method.c (build_template_parm_names): Correct substitution. + (do_build_copy_constructor): Don't use current_member_init_list + and current_base_init_list. + (synthesize_method): Likewise. + * parse.y (base_init): Split mem-initializers into + base-initializers and field-initializers. + (member_init_list): Build up the list here. + (member_init): Return the initializer. + (fn.depfn): Don't use reinit_parse_for_function. + * parse.c: Regenerated. + * pt.c (convert_nontype_argument): Don't make an ADDR_EXPR of the + ERROR_MARK. + (tsubst_expr): Don't use current_member_init_list + and current_base_init_list. + (tsubst_expr_values): Rename to ... + (tsubst_initializer_list): ... this. Use convert_from_reference. + * semantics.c (setup_vtbl_ptr): Don't use current_member_init_list + and current_base_init_list. + (begin_function_definition): Don't call reinit_parse_for_function. + + * dump.c (dequeue_and_dump): Use TREE_VEC_LENGTH with vectors. + + * error.c (dump_expr): Handle ADDR_EXPRs with REFERENCE_TYPE + correctly. + * cp-tree.h (DECL_PENDING_INLINE_P): Relax checking. 2000-06-14 Benjamin Chelf <chelf@cabriolet.stanford.edu> diff --git a/gcc/cp/cp-tree.h b/gcc/cp/cp-tree.h index c11dc33..79441dc 100644 --- a/gcc/cp/cp-tree.h +++ b/gcc/cp/cp-tree.h @@ -883,8 +883,6 @@ struct language_function { tree x_ctor_label; tree x_dtor_label; - tree x_base_init_list; - tree x_member_init_list; tree x_current_class_ptr; tree x_current_class_ref; tree x_eh_spec_try_block; @@ -927,19 +925,6 @@ struct language_function #define ctor_label cp_function_chain->x_ctor_label -/* In C++, structures with well-defined constructors are initialized by - those constructors, unasked. CURRENT_BASE_INIT_LIST - holds a list of stmts for a BASE_INIT term in the grammar. - This list has one element for each base class which must be - initialized. The list elements are [basename, init], with - type basetype. This allows the possibly anachronistic form - (assuming d : a, b, c) "d (int a) : c(a+5), b (a-4), a (a+3)" - where each successive term can be handed down the constructor - line. Perhaps this was not intended. */ - -#define current_base_init_list cp_function_chain->x_base_init_list -#define current_member_init_list cp_function_chain->x_member_init_list - /* When we're processing a member function, current_class_ptr is the PARM_DECL for the `this' pointer. The current_class_ref is an expression for `*this'. */ @@ -4082,7 +4067,7 @@ extern int copy_assignment_arg_p PARAMS ((tree, int)); extern void cplus_decl_attributes PARAMS ((tree, tree, tree)); extern tree constructor_name_full PARAMS ((tree)); extern tree constructor_name PARAMS ((tree)); -extern void setup_vtbl_ptr PARAMS ((void)); +extern void setup_vtbl_ptr PARAMS ((tree, tree)); extern void defer_fn PARAMS ((tree)); extern tree get_temp_name PARAMS ((tree, int)); extern void finish_anon_union PARAMS ((tree)); @@ -4174,8 +4159,8 @@ extern tree do_friend PARAMS ((tree, tree, tree, tree, tree, enum overload_fl /* in init.c */ extern void init_init_processing PARAMS ((void)); -extern void emit_base_init PARAMS ((void)); -extern void expand_member_init PARAMS ((tree, tree, tree)); +extern void emit_base_init PARAMS ((tree, tree)); +extern tree expand_member_init PARAMS ((tree, tree, tree)); extern tree build_aggr_init PARAMS ((tree, tree, int)); extern int is_aggr_type PARAMS ((tree, int)); extern tree get_aggr_from_typedef PARAMS ((tree, int)); @@ -4209,7 +4194,6 @@ extern void lang_finish PARAMS ((void)); #if 0 extern void reinit_lang_specific PARAMS ((void)); #endif -extern void reinit_parse_for_function PARAMS ((void)); extern void print_parse_statistics PARAMS ((void)); extern void extract_interface_info PARAMS ((void)); extern void do_pending_inlines PARAMS ((void)); diff --git a/gcc/cp/decl.c b/gcc/cp/decl.c index 93e6c3f..72fb758 100644 --- a/gcc/cp/decl.c +++ b/gcc/cp/decl.c @@ -14090,8 +14090,6 @@ save_function_data (decl) DECL_SAVED_FUNCTION_DATA (decl) = f; /* Clear out the bits we don't need. */ - f->x_base_init_list = NULL_TREE; - f->x_member_init_list = NULL_TREE; f->x_stmt_tree.x_last_stmt = NULL_TREE; f->x_stmt_tree.x_last_expr_type = NULL_TREE; f->x_result_rtx = NULL_RTX; @@ -14972,8 +14970,6 @@ mark_lang_function (p) ggc_mark_tree (p->x_ctor_label); ggc_mark_tree (p->x_dtor_label); - ggc_mark_tree (p->x_base_init_list); - ggc_mark_tree (p->x_member_init_list); ggc_mark_tree (p->x_current_class_ptr); ggc_mark_tree (p->x_current_class_ref); ggc_mark_tree (p->x_eh_spec_try_block); diff --git a/gcc/cp/dump.c b/gcc/cp/dump.c index 09fbf4b..ca3baa0 100644 --- a/gcc/cp/dump.c +++ b/gcc/cp/dump.c @@ -454,7 +454,7 @@ dequeue_and_dump (di) break; case TREE_VEC: - dump_int (di, "lngt", IDENTIFIER_LENGTH (t)); + dump_int (di, "lngt", TREE_VEC_LENGTH (t)); for (i = 0; i < TREE_VEC_LENGTH (t); ++i) { char buffer[32]; diff --git a/gcc/cp/error.c b/gcc/cp/error.c index 82ba33d..1d338d9 100644 --- a/gcc/cp/error.c +++ b/gcc/cp/error.c @@ -1741,7 +1741,12 @@ dump_expr (t, flags) case ADDR_EXPR: if (TREE_CODE (TREE_OPERAND (t, 0)) == FUNCTION_DECL - || TREE_CODE (TREE_OPERAND (t, 0)) == STRING_CST) + || TREE_CODE (TREE_OPERAND (t, 0)) == STRING_CST + /* An ADDR_EXPR can have reference type. In that case, we + shouldn't print the `&' doing so indicates to the user + that the expression has pointer type. */ + || (TREE_TYPE (t) + && TREE_CODE (TREE_TYPE (t)) == REFERENCE_TYPE)) dump_expr (TREE_OPERAND (t, 0), flags | TS_EXPR_PARENS); else dump_unary_op ("&", t, flags); diff --git a/gcc/cp/init.c b/gcc/cp/init.c index 0dfa403..a7c8ebb 100644 --- a/gcc/cp/init.c +++ b/gcc/cp/init.c @@ -40,11 +40,11 @@ static void expand_aggr_init_1 PARAMS ((tree, tree, tree, tree, int)); static void expand_default_init PARAMS ((tree, tree, tree, tree, int)); static tree build_vec_delete_1 PARAMS ((tree, tree, tree, special_function_kind, int)); static void perform_member_init PARAMS ((tree, tree, int)); -static void sort_base_init PARAMS ((tree, tree *, tree *)); +static void sort_base_init PARAMS ((tree, tree, tree *, tree *)); static tree build_builtin_delete_call PARAMS ((tree)); static int member_init_ok_or_else PARAMS ((tree, tree, const char *)); static void expand_virtual_init PARAMS ((tree, tree)); -static tree sort_member_init PARAMS ((tree)); +static tree sort_member_init PARAMS ((tree, tree)); static tree initializing_context PARAMS ((tree)); static void expand_cleanup_for_base PARAMS ((tree, tree)); static tree get_temp_regvar PARAMS ((tree, tree)); @@ -213,7 +213,7 @@ perform_member_init (member, init, explicit) else if (TYPE_NEEDS_CONSTRUCTING (type) || (init && TYPE_HAS_CONSTRUCTOR (type))) { - /* Since `init' is already a TREE_LIST on the current_member_init_list, + /* Since `init' is already a TREE_LIST on the member_init_list, only build it into one if we aren't already a list. */ if (init != NULL_TREE && TREE_CODE (init) != TREE_LIST) init = build_tree_list (NULL_TREE, init); @@ -338,11 +338,17 @@ build_field_list (t, list, uses_unions_p) return list; } -/* Subroutine of emit_member_init. */ +/* The MEMBER_INIT_LIST is a TREE_LIST. The TREE_PURPOSE of each list + gives a FIELD_DECL in T that needs initialization. The TREE_VALUE + gives the initializer, or list of initializer arguments. Sort the + MEMBER_INIT_LIST, returning a version that contains the same + information but in the order that the fields should actually be + initialized. Perform error-checking in the process. */ static tree -sort_member_init (t) +sort_member_init (t, member_init_list) tree t; + tree member_init_list; { tree init_list; tree last_field; @@ -355,7 +361,7 @@ sort_member_init (t) /* Go through the explicit initializers, adding them to the INIT_LIST. */ last_field = init_list; - for (init = current_member_init_list; init; init = TREE_CHAIN (init)) + for (init = member_init_list; init; init = TREE_CHAIN (init)) { tree f; tree initialized_field; @@ -492,9 +498,15 @@ sort_member_init (t) return init_list; } +/* Like sort_member_init, but used for initializers of base classes. + *RBASE_PTR is filled in with the initializers for non-virtual bases; + vbase_ptr gets the virtual bases. */ + static void -sort_base_init (t, rbase_ptr, vbase_ptr) - tree t, *rbase_ptr, *vbase_ptr; +sort_base_init (t, base_init_list, rbase_ptr, vbase_ptr) + tree t; + tree base_init_list; + tree *rbase_ptr, *vbase_ptr; { tree binfos = BINFO_BASETYPES (TYPE_BINFO (t)); int n_baseclasses = binfos ? TREE_VEC_LENGTH (binfos) : 0; @@ -513,7 +525,7 @@ sort_base_init (t, rbase_ptr, vbase_ptr) /* First walk through and splice out vbase and invalid initializers. Also replace names with binfos. */ - last = tree_cons (NULL_TREE, NULL_TREE, current_base_init_list); + last = tree_cons (NULL_TREE, NULL_TREE, base_init_list); for (x = TREE_CHAIN (last); x; x = TREE_CHAIN (x)) { tree basetype = TREE_PURPOSE (x); @@ -580,20 +592,24 @@ sort_base_init (t, rbase_ptr, vbase_ptr) for (i = 0; i < n_baseclasses; ++i) { + /* The base for which we're currently initializing. */ tree base_binfo = TREE_VEC_ELT (binfos, i); + /* The initializer for BASE_BINFO. */ + tree init; int pos; if (TREE_VIA_VIRTUAL (base_binfo)) continue; - for (x = current_base_init_list, pos = 0; x; x = TREE_CHAIN (x), ++pos) + /* We haven't found the BASE_BINFO yet. */ + init = NULL_TREE; + /* Loop through all the explicitly initialized bases, looking + for an appropriate initializer. */ + for (x = base_init_list, pos = 0; x; x = TREE_CHAIN (x), ++pos) { tree binfo = TREE_PURPOSE (x); - if (binfo == NULL_TREE) - continue; - - if (binfo == base_binfo) + if (binfo == base_binfo && !init) { if (warn_reorder) { @@ -609,17 +625,22 @@ sort_base_init (t, rbase_ptr, vbase_ptr) /* Make sure we won't try to work on this init again. */ TREE_PURPOSE (x) = NULL_TREE; - x = build_tree_list (binfo, TREE_VALUE (x)); - goto got_it; + init = build_tree_list (binfo, TREE_VALUE (x)); + } + else if (binfo == base_binfo) + { + cp_error ("base class `%T' already initialized", + BINFO_TYPE (binfo)); + break; } } /* If we didn't find BASE_BINFO in the list, create a dummy entry so the two lists (RBASES and the list of bases) will be symmetrical. */ - x = build_tree_list (NULL_TREE, NULL_TREE); - got_it: - rbases = chainon (rbases, x); + if (!init) + init = build_tree_list (NULL_TREE, NULL_TREE); + rbases = chainon (rbases, init); } *rbase_ptr = rbases; @@ -627,10 +648,9 @@ sort_base_init (t, rbase_ptr, vbase_ptr) } /* Perform whatever initializations have yet to be done on the base - class of the class variable. These actions are in the global - variable CURRENT_BASE_INIT_LIST. Such an action could be - NULL_TREE, meaning that the user has explicitly called the base - class constructor with no arguments. + class, and non-static data members, of the CURRENT_CLASS_TYPE. + These actions are given by the BASE_INIT_LIST and MEM_INIT_LIST, + respectively. If there is a need for a call to a constructor, we must surround that call with a pushlevel/poplevel pair, since we are technically @@ -640,10 +660,11 @@ sort_base_init (t, rbase_ptr, vbase_ptr) classes. That is done specially, elsewhere. */ void -emit_base_init () +emit_base_init (mem_init_list, base_init_list) + tree mem_init_list; + tree base_init_list; { tree member; - tree mem_init_list; tree rbase_init_list, vbase_init_list; tree t = current_class_type; tree t_binfo = TYPE_BINFO (t); @@ -651,11 +672,8 @@ emit_base_init () int i; int n_baseclasses = BINFO_N_BASETYPES (t_binfo); - mem_init_list = sort_member_init (t); - current_member_init_list = NULL_TREE; - - sort_base_init (t, &rbase_init_list, &vbase_init_list); - current_base_init_list = NULL_TREE; + mem_init_list = sort_member_init (t, mem_init_list); + sort_base_init (t, base_init_list, &rbase_init_list, &vbase_init_list); /* First, initialize the virtual base classes, if we are constructing the most-derived object. */ @@ -1004,13 +1022,9 @@ member_init_ok_or_else (field, type, member_name) We do not yet have a fixed-point finder to instantiate types being fed to overloaded constructors. If there is a unique - constructor, then argument types can be got from that one. + constructor, then argument types can be got from that one. */ - If INIT is non-NULL, then it the initialization should - be placed in `current_base_init_list', where it will be processed - by `emit_base_init'. */ - -void +tree expand_member_init (exp, name, init) tree exp, name, init; { @@ -1018,7 +1032,7 @@ expand_member_init (exp, name, init) tree type; if (exp == NULL_TREE) - return; /* complain about this later */ + return NULL_TREE; type = TYPE_MAIN_VARIANT (TREE_TYPE (exp)); @@ -1033,14 +1047,14 @@ expand_member_init (exp, name, init) { case 0: error ("base class initializer specified, but no base class to initialize"); - return; + return NULL_TREE; case 1: basetype = TYPE_BINFO_BASETYPE (type, 0); break; default: error ("initializer for unnamed base class ambiguous"); cp_error ("(type `%T' uses multiple inheritance)", type); - return; + return NULL_TREE; } my_friendly_assert (init != NULL_TREE, 0); @@ -1056,8 +1070,6 @@ expand_member_init (exp, name, init) if (name == NULL_TREE || basetype) { - tree base_init; - if (name == NULL_TREE) { #if 0 @@ -1084,43 +1096,23 @@ expand_member_init (exp, name, init) else cp_error ("type `%T' is not an immediate basetype for `%T'", basetype, type); - return; + return NULL_TREE; } - if (purpose_member (basetype, current_base_init_list)) - { - cp_error ("base class `%T' already initialized", basetype); - return; - } - - if (warn_reorder && current_member_init_list) - { - cp_warning ("base initializer for `%T'", basetype); - warning (" will be re-ordered to precede member initializations"); - } - - base_init = build_tree_list (basetype, init); - current_base_init_list = chainon (current_base_init_list, base_init); + init = build_tree_list (basetype, init); } else { - tree member_init; - try_member: field = lookup_field (type, name, 1, 0); if (! member_init_ok_or_else (field, type, IDENTIFIER_POINTER (name))) - return; - - if (purpose_member (name, current_member_init_list)) - { - cp_error ("field `%D' already initialized", field); - return; - } + return NULL_TREE; - member_init = build_tree_list (field, init); - current_member_init_list = chainon (current_member_init_list, member_init); + init = build_tree_list (field, init); } + + return init; } /* This is like `expand_member_init', only it stores one aggregate diff --git a/gcc/cp/lex.c b/gcc/cp/lex.c index 234207f..c17a6cc 100644 --- a/gcc/cp/lex.c +++ b/gcc/cp/lex.c @@ -730,13 +730,6 @@ finish_parse () fclose (finput); #endif } - -void -reinit_parse_for_function () -{ - current_base_init_list = NULL_TREE; - current_member_init_list = NULL_TREE; -} inline void yyprint (file, yychar, yylval) diff --git a/gcc/cp/method.c b/gcc/cp/method.c index f145650..cdf2771 100644 --- a/gcc/cp/method.c +++ b/gcc/cp/method.c @@ -987,7 +987,7 @@ build_template_parm_names (parmlist, arglist) } else { - parm = tsubst (parm, arglist, /*complain=*/1, NULL_TREE); + parm = tsubst (parm, inner_args, /*complain=*/1, NULL_TREE); /* It's a PARM_DECL. */ build_mangled_name_for_type (TREE_TYPE (parm)); build_overload_value (TREE_TYPE (parm), arg, @@ -2315,22 +2315,24 @@ do_build_copy_constructor (fndecl) tree fields = TYPE_FIELDS (current_class_type); int n_bases = CLASSTYPE_N_BASECLASSES (current_class_type); tree binfos = TYPE_BINFO_BASETYPES (current_class_type); + tree member_init_list = NULL_TREE; + tree base_init_list = NULL_TREE; int i; /* Initialize all the base-classes. */ for (t = CLASSTYPE_VBASECLASSES (current_class_type); t; t = TREE_CHAIN (t)) - current_base_init_list + base_init_list = tree_cons (BINFO_TYPE (TREE_VALUE (t)), parm, - current_base_init_list); + base_init_list); for (i = 0; i < n_bases; ++i) { t = TREE_VEC_ELT (binfos, i); if (TREE_VIA_VIRTUAL (t)) continue; - current_base_init_list - = tree_cons (BINFO_TYPE (t), parm, current_base_init_list); + base_init_list + = tree_cons (BINFO_TYPE (t), parm, base_init_list); } for (; fields; fields = TREE_CHAIN (fields)) @@ -2364,12 +2366,12 @@ do_build_copy_constructor (fndecl) init = build (COMPONENT_REF, TREE_TYPE (field), init, field); init = build_tree_list (NULL_TREE, init); - current_member_init_list - = tree_cons (field, init, current_member_init_list); + member_init_list + = tree_cons (field, init, member_init_list); } - current_member_init_list = nreverse (current_member_init_list); - current_base_init_list = nreverse (current_base_init_list); - setup_vtbl_ptr (); + member_init_list = nreverse (member_init_list); + base_init_list = nreverse (base_init_list); + setup_vtbl_ptr (member_init_list, base_init_list); } } @@ -2512,7 +2514,7 @@ synthesize_method (fndecl) need_body = 0; } else if (DECL_DESTRUCTOR_P (fndecl)) - setup_vtbl_ptr (); + setup_vtbl_ptr (NULL_TREE, NULL_TREE); else { tree arg_chain = FUNCTION_ARG_CHAIN (fndecl); @@ -2521,7 +2523,7 @@ synthesize_method (fndecl) if (arg_chain != void_list_node) do_build_copy_constructor (fndecl); else if (TYPE_NEEDS_CONSTRUCTING (current_class_type)) - setup_vtbl_ptr (); + setup_vtbl_ptr (NULL_TREE, NULL_TREE); } /* If we haven't yet generated the body of the function, just diff --git a/gcc/cp/parse.c b/gcc/cp/parse.c index 9cb24dd..3a063f1 100644 --- a/gcc/cp/parse.c +++ b/gcc/cp/parse.c @@ -288,7 +288,7 @@ typedef union { flagged_type_tree ftype; struct pending_inline *pi; } YYSTYPE; -#line 424 "parse.y" +#line 425 "parse.y" /* Tell yyparse how to print a token's value, if yydebug is set. */ #define YYPRINT(FILE,YYCHAR,YYLVAL) yyprint(FILE,YYCHAR,YYLVAL) @@ -732,94 +732,94 @@ static const short yyrhs[] = { -1, #if YYDEBUG != 0 static const short yyrline[] = { 0, - 431, 433, 441, 444, 445, 449, 451, 454, 459, 463, - 469, 473, 477, 481, 484, 486, 488, 491, 493, 496, - 499, 501, 503, 505, 507, 508, 510, 511, 515, 518, - 527, 530, 532, 536, 539, 541, 545, 548, 560, 567, - 575, 577, 578, 580, 584, 587, 593, 596, 598, 603, - 606, 610, 613, 616, 619, 623, 628, 638, 640, 642, - 644, 646, 659, 662, 666, 669, 671, 673, 676, 679, - 683, 685, 687, 689, 694, 696, 698, 700, 702, 703, - 710, 711, 712, 715, 718, 722, 724, 725, 728, 730, - 733, 736, 738, 742, 745, 747, 751, 753, 755, 759, - 761, 763, 767, 769, 771, 777, 782, 785, 788, 791, - 796, 799, 801, 803, 809, 818, 821, 823, 825, 828, - 830, 835, 844, 847, 849, 853, 862, 878, 881, 883, - 884, 887, 894, 900, 902, 904, 906, 908, 911, 914, - 917, 919, 920, 921, 922, 925, 927, 928, 931, 933, - 934, 937, 942, 942, 946, 946, 949, 949, 952, 952, - 956, 956, 961, 961, 964, 964, 967, 969, 972, 979, - 983, 986, 989, 991, 995, 1001, 1010, 1012, 1020, 1023, - 1026, 1029, 1033, 1036, 1038, 1041, 1044, 1046, 1048, 1050, - 1054, 1057, 1060, 1065, 1069, 1074, 1078, 1081, 1082, 1086, - 1103, 1109, 1112, 1114, 1115, 1116, 1119, 1123, 1124, 1128, - 1132, 1135, 1137, 1141, 1144, 1147, 1151, 1154, 1156, 1158, - 1160, 1163, 1167, 1169, 1172, 1174, 1180, 1183, 1186, 1189, - 1192, 1197, 1200, 1203, 1207, 1209, 1213, 1217, 1219, 1221, - 1226, 1229, 1234, 1237, 1239, 1247, 1260, 1265, 1271, 1273, - 1275, 1288, 1291, 1293, 1295, 1297, 1299, 1301, 1303, 1305, - 1307, 1309, 1311, 1313, 1315, 1317, 1319, 1321, 1323, 1325, - 1327, 1329, 1331, 1335, 1337, 1339, 1356, 1359, 1361, 1362, - 1363, 1364, 1365, 1368, 1380, 1383, 1387, 1390, 1392, 1397, - 1399, 1400, 1403, 1405, 1413, 1415, 1417, 1419, 1423, 1426, - 1430, 1434, 1435, 1436, 1440, 1448, 1449, 1450, 1460, 1462, - 1465, 1467, 1478, 1483, 1485, 1487, 1489, 1491, 1493, 1495, - 1498, 1500, 1511, 1512, 1516, 1520, 1524, 1528, 1530, 1534, - 1536, 1538, 1546, 1548, 1550, 1552, 1556, 1558, 1560, 1562, - 1567, 1569, 1571, 1573, 1576, 1578, 1580, 1624, 1627, 1631, - 1634, 1638, 1641, 1646, 1648, 1652, 1661, 1664, 1671, 1677, - 1681, 1683, 1688, 1690, 1697, 1699, 1703, 1707, 1713, 1717, - 1720, 1724, 1727, 1737, 1740, 1744, 1748, 1751, 1754, 1757, - 1760, 1766, 1772, 1774, 1779, 1781, 1799, 1802, 1807, 1812, - 1820, 1822, 1835, 1839, 1842, 1845, 1850, 1853, 1861, 1864, - 1866, 1868, 1871, 1874, 1889, 1908, 1911, 1913, 1916, 1918, - 1922, 1924, 1928, 1930, 1934, 1937, 1941, 1946, 1947, 1960, - 1967, 1968, 1974, 1979, 1984, 1990, 1991, 1998, 2001, 2005, - 2008, 2012, 2017, 2020, 2024, 2027, 2029, 2031, 2033, 2040, - 2042, 2043, 2044, 2048, 2051, 2055, 2058, 2064, 2066, 2069, - 2072, 2075, 2081, 2084, 2087, 2089, 2091, 2095, 2102, 2108, - 2113, 2119, 2121, 2126, 2129, 2132, 2134, 2136, 2140, 2144, - 2149, 2152, 2157, 2160, 2163, 2169, 2171, 2183, 2187, 2192, - 2218, 2220, 2223, 2225, 2230, 2232, 2234, 2236, 2238, 2240, - 2244, 2252, 2255, 2257, 2261, 2268, 2274, 2280, 2286, 2296, - 2302, 2306, 2313, 2341, 2351, 2357, 2360, 2363, 2365, 2369, - 2371, 2375, 2378, 2382, 2390, 2393, 2395, 2399, 2410, 2424, - 2425, 2426, 2427, 2430, 2439, 2444, 2450, 2452, 2457, 2459, - 2461, 2463, 2465, 2467, 2470, 2480, 2487, 2512, 2518, 2521, - 2524, 2526, 2537, 2542, 2545, 2550, 2553, 2560, 2570, 2573, - 2580, 2590, 2592, 2595, 2597, 2600, 2604, 2609, 2613, 2616, - 2619, 2624, 2627, 2631, 2634, 2636, 2640, 2642, 2649, 2651, - 2654, 2657, 2662, 2666, 2671, 2681, 2684, 2688, 2692, 2701, - 2704, 2706, 2708, 2714, 2716, 2725, 2728, 2730, 2732, 2734, - 2738, 2741, 2744, 2746, 2748, 2750, 2754, 2757, 2768, 2778, - 2780, 2781, 2785, 2793, 2795, 2803, 2806, 2808, 2810, 2812, - 2816, 2819, 2822, 2824, 2826, 2828, 2832, 2835, 2838, 2840, - 2842, 2844, 2846, 2853, 2857, 2862, 2866, 2871, 2873, 2877, - 2880, 2882, 2886, 2888, 2889, 2892, 2894, 2896, 2903, 2914, - 2920, 2926, 2940, 2942, 2946, 2960, 2962, 2964, 2968, 2974, - 2987, 2990, 2995, 3008, 3014, 3016, 3017, 3018, 3026, 3031, - 3040, 3041, 3045, 3048, 3054, 3060, 3063, 3065, 3067, 3069, - 3073, 3077, 3081, 3084, 3088, 3090, 3099, 3102, 3104, 3106, - 3108, 3110, 3112, 3114, 3116, 3120, 3124, 3128, 3132, 3134, - 3136, 3138, 3140, 3142, 3144, 3146, 3148, 3156, 3158, 3159, - 3160, 3163, 3169, 3171, 3176, 3178, 3181, 3194, 3197, 3200, - 3204, 3207, 3214, 3216, 3219, 3221, 3223, 3226, 3229, 3232, - 3235, 3237, 3240, 3244, 3246, 3252, 3254, 3255, 3257, 3262, - 3264, 3266, 3268, 3270, 3273, 3274, 3276, 3279, 3280, 3283, - 3283, 3286, 3286, 3289, 3289, 3291, 3293, 3295, 3297, 3303, - 3309, 3311, 3314, 3317, 3320, 3323, 3329, 3331, 3332, 3335, - 3337, 3338, 3339, 3341, 3344, 3347, 3350, 3356, 3360, 3362, - 3365, 3367, 3370, 3374, 3376, 3379, 3381, 3384, 3401, 3409, - 3412, 3414, 3416, 3420, 3423, 3424, 3432, 3435, 3438, 3441, - 3442, 3448, 3451, 3454, 3456, 3460, 3465, 3468, 3478, 3483, - 3484, 3491, 3494, 3497, 3499, 3502, 3504, 3514, 3528, 3532, - 3535, 3537, 3541, 3545, 3548, 3551, 3553, 3557, 3559, 3566, - 3573, 3576, 3580, 3584, 3588, 3594, 3598, 3603, 3605, 3608, - 3613, 3619, 3630, 3633, 3635, 3639, 3647, 3650, 3654, 3657, - 3659, 3661, 3667, 3672, 3675, 3677, 3679, 3681, 3683, 3685, - 3687, 3689, 3691, 3693, 3695, 3697, 3699, 3701, 3703, 3705, - 3707, 3709, 3711, 3713, 3715, 3717, 3719, 3721, 3723, 3725, - 3727, 3729, 3731, 3733, 3735, 3737, 3740, 3742 + 432, 434, 442, 445, 446, 450, 452, 455, 460, 464, + 470, 474, 478, 482, 485, 487, 489, 492, 494, 497, + 500, 502, 504, 506, 508, 509, 511, 512, 516, 519, + 528, 531, 533, 537, 540, 542, 546, 549, 561, 568, + 576, 578, 579, 581, 585, 588, 594, 597, 599, 604, + 607, 611, 614, 617, 620, 624, 629, 639, 641, 643, + 645, 647, 660, 663, 667, 670, 672, 674, 677, 680, + 684, 686, 688, 690, 695, 697, 699, 701, 703, 704, + 711, 712, 713, 716, 719, 723, 725, 726, 729, 731, + 734, 737, 739, 743, 746, 748, 752, 754, 756, 760, + 762, 764, 768, 770, 772, 778, 783, 786, 789, 792, + 797, 800, 802, 804, 810, 819, 822, 824, 826, 829, + 831, 836, 845, 848, 850, 854, 894, 910, 916, 921, + 932, 935, 942, 950, 952, 955, 957, 960, 964, 968, + 972, 974, 975, 976, 977, 980, 982, 983, 986, 988, + 989, 992, 997, 997, 1001, 1001, 1004, 1004, 1007, 1007, + 1011, 1011, 1016, 1016, 1019, 1019, 1022, 1024, 1027, 1034, + 1038, 1041, 1044, 1046, 1050, 1056, 1065, 1067, 1075, 1078, + 1081, 1084, 1088, 1091, 1093, 1096, 1099, 1101, 1103, 1105, + 1109, 1112, 1115, 1120, 1124, 1129, 1133, 1136, 1137, 1141, + 1158, 1164, 1167, 1169, 1170, 1171, 1174, 1178, 1179, 1183, + 1187, 1190, 1192, 1196, 1199, 1202, 1206, 1209, 1211, 1213, + 1215, 1218, 1222, 1224, 1227, 1229, 1235, 1238, 1241, 1244, + 1247, 1252, 1255, 1258, 1262, 1264, 1268, 1272, 1274, 1276, + 1281, 1284, 1289, 1292, 1294, 1302, 1315, 1320, 1326, 1328, + 1330, 1343, 1346, 1348, 1350, 1352, 1354, 1356, 1358, 1360, + 1362, 1364, 1366, 1368, 1370, 1372, 1374, 1376, 1378, 1380, + 1382, 1384, 1386, 1390, 1392, 1394, 1411, 1414, 1416, 1417, + 1418, 1419, 1420, 1423, 1435, 1438, 1442, 1445, 1447, 1452, + 1454, 1455, 1458, 1460, 1468, 1470, 1472, 1474, 1478, 1481, + 1485, 1489, 1490, 1491, 1495, 1503, 1504, 1505, 1515, 1517, + 1520, 1522, 1533, 1538, 1540, 1542, 1544, 1546, 1548, 1550, + 1553, 1555, 1566, 1567, 1571, 1575, 1579, 1583, 1585, 1589, + 1591, 1593, 1601, 1603, 1605, 1607, 1611, 1613, 1615, 1617, + 1622, 1624, 1626, 1628, 1631, 1633, 1635, 1679, 1682, 1686, + 1689, 1693, 1696, 1701, 1703, 1707, 1716, 1719, 1726, 1732, + 1736, 1738, 1743, 1745, 1752, 1754, 1758, 1762, 1768, 1772, + 1775, 1779, 1782, 1792, 1795, 1799, 1803, 1806, 1809, 1812, + 1815, 1821, 1827, 1829, 1834, 1836, 1854, 1857, 1862, 1867, + 1875, 1877, 1890, 1894, 1897, 1900, 1905, 1908, 1916, 1919, + 1921, 1923, 1926, 1929, 1944, 1963, 1966, 1968, 1971, 1973, + 1977, 1979, 1983, 1985, 1989, 1992, 1996, 2001, 2002, 2015, + 2022, 2023, 2029, 2034, 2039, 2045, 2046, 2053, 2056, 2060, + 2063, 2067, 2072, 2075, 2079, 2082, 2084, 2086, 2088, 2095, + 2097, 2098, 2099, 2103, 2106, 2110, 2113, 2119, 2121, 2124, + 2127, 2130, 2136, 2139, 2142, 2144, 2146, 2150, 2156, 2162, + 2167, 2173, 2175, 2180, 2183, 2186, 2188, 2190, 2194, 2198, + 2203, 2206, 2211, 2214, 2217, 2223, 2225, 2237, 2241, 2246, + 2272, 2274, 2277, 2279, 2284, 2286, 2288, 2290, 2292, 2294, + 2298, 2306, 2309, 2311, 2315, 2322, 2328, 2334, 2340, 2350, + 2356, 2360, 2367, 2395, 2405, 2411, 2414, 2417, 2419, 2423, + 2425, 2429, 2432, 2436, 2444, 2447, 2449, 2453, 2464, 2478, + 2479, 2480, 2481, 2484, 2493, 2498, 2504, 2506, 2511, 2513, + 2515, 2517, 2519, 2521, 2524, 2534, 2541, 2566, 2572, 2575, + 2578, 2580, 2591, 2596, 2599, 2604, 2607, 2614, 2624, 2627, + 2634, 2644, 2646, 2649, 2651, 2654, 2658, 2663, 2667, 2670, + 2673, 2678, 2681, 2685, 2688, 2690, 2694, 2696, 2703, 2705, + 2708, 2711, 2716, 2720, 2725, 2735, 2738, 2742, 2746, 2755, + 2758, 2760, 2762, 2768, 2770, 2779, 2782, 2784, 2786, 2788, + 2792, 2795, 2798, 2800, 2802, 2804, 2808, 2811, 2822, 2832, + 2834, 2835, 2839, 2847, 2849, 2857, 2860, 2862, 2864, 2866, + 2870, 2873, 2876, 2878, 2880, 2882, 2886, 2889, 2892, 2894, + 2896, 2898, 2900, 2907, 2911, 2916, 2920, 2925, 2927, 2931, + 2934, 2936, 2940, 2942, 2943, 2946, 2948, 2950, 2957, 2968, + 2974, 2980, 2994, 2996, 3000, 3014, 3016, 3018, 3022, 3028, + 3041, 3044, 3049, 3062, 3068, 3070, 3071, 3072, 3080, 3085, + 3094, 3095, 3099, 3102, 3108, 3114, 3117, 3119, 3121, 3123, + 3127, 3131, 3135, 3138, 3142, 3144, 3153, 3156, 3158, 3160, + 3162, 3164, 3166, 3168, 3170, 3174, 3178, 3182, 3186, 3188, + 3190, 3192, 3194, 3196, 3198, 3200, 3202, 3210, 3212, 3213, + 3214, 3217, 3223, 3225, 3230, 3232, 3235, 3248, 3251, 3254, + 3258, 3261, 3268, 3270, 3273, 3275, 3277, 3280, 3283, 3286, + 3289, 3291, 3294, 3298, 3300, 3306, 3308, 3309, 3311, 3316, + 3318, 3320, 3322, 3324, 3327, 3328, 3330, 3333, 3334, 3337, + 3337, 3340, 3340, 3343, 3343, 3345, 3347, 3349, 3351, 3357, + 3363, 3365, 3368, 3371, 3374, 3377, 3383, 3385, 3386, 3389, + 3391, 3392, 3393, 3395, 3398, 3401, 3404, 3410, 3414, 3416, + 3419, 3421, 3424, 3428, 3430, 3433, 3435, 3438, 3455, 3463, + 3466, 3468, 3470, 3474, 3477, 3478, 3486, 3489, 3492, 3495, + 3496, 3502, 3505, 3508, 3510, 3514, 3519, 3522, 3532, 3537, + 3538, 3545, 3548, 3551, 3553, 3556, 3558, 3568, 3582, 3586, + 3589, 3591, 3595, 3599, 3602, 3605, 3607, 3611, 3613, 3620, + 3627, 3630, 3634, 3638, 3642, 3648, 3652, 3657, 3659, 3662, + 3667, 3673, 3684, 3687, 3689, 3693, 3701, 3704, 3708, 3711, + 3713, 3715, 3721, 3726, 3729, 3731, 3733, 3735, 3737, 3739, + 3741, 3743, 3745, 3747, 3749, 3751, 3753, 3755, 3757, 3759, + 3761, 3763, 3765, 3767, 3769, 3771, 3773, 3775, 3777, 3779, + 3781, 3783, 3785, 3787, 3789, 3791, 3794, 3796 }; #endif @@ -4573,107 +4573,107 @@ yyreduce: switch (yyn) { case 2: -#line 434 "parse.y" +#line 435 "parse.y" { finish_translation_unit (); ; break;} case 3: -#line 442 "parse.y" +#line 443 "parse.y" { yyval.ttype = NULL_TREE; ; break;} case 4: -#line 444 "parse.y" +#line 445 "parse.y" { yyval.ttype = NULL_TREE; ggc_collect (); ; break;} case 5: -#line 446 "parse.y" +#line 447 "parse.y" { yyval.ttype = NULL_TREE; ggc_collect (); ; break;} case 8: -#line 455 "parse.y" +#line 456 "parse.y" { have_extern_spec = 1; used_extern_spec = 0; yyval.ttype = NULL_TREE; ; break;} case 9: -#line 460 "parse.y" +#line 461 "parse.y" { have_extern_spec = 0; ; break;} case 10: -#line 465 "parse.y" +#line 466 "parse.y" { yyval.itype = pedantic; pedantic = 0; ; break;} case 12: -#line 474 "parse.y" +#line 475 "parse.y" { if (pending_lang_change) do_pending_lang_change(); type_lookups = NULL_TREE; ; break;} case 13: -#line 477 "parse.y" +#line 478 "parse.y" { if (! toplevel_bindings_p ()) pop_everything (); ; break;} case 14: -#line 483 "parse.y" +#line 484 "parse.y" { if (pending_inlines) do_pending_inlines (); ; break;} case 15: -#line 485 "parse.y" +#line 486 "parse.y" { if (pending_inlines) do_pending_inlines (); ; break;} case 16: -#line 487 "parse.y" +#line 488 "parse.y" { if (pending_inlines) do_pending_inlines (); ; break;} case 17: -#line 489 "parse.y" +#line 490 "parse.y" { if (TREE_CHAIN (yyvsp[-2].ttype)) yyvsp[-2].ttype = combine_strings (yyvsp[-2].ttype); assemble_asm (yyvsp[-2].ttype); ; break;} case 18: -#line 492 "parse.y" +#line 493 "parse.y" { pop_lang_context (); ; break;} case 19: -#line 494 "parse.y" +#line 495 "parse.y" { if (pending_inlines) do_pending_inlines (); pop_lang_context (); ; break;} case 20: -#line 497 "parse.y" +#line 498 "parse.y" { if (pending_inlines) do_pending_inlines (); pop_lang_context (); ; break;} case 21: -#line 500 "parse.y" +#line 501 "parse.y" { push_namespace (yyvsp[-1].ttype); ; break;} case 22: -#line 502 "parse.y" +#line 503 "parse.y" { pop_namespace (); ; break;} case 23: -#line 504 "parse.y" +#line 505 "parse.y" { push_namespace (NULL_TREE); ; break;} case 24: -#line 506 "parse.y" +#line 507 "parse.y" { pop_namespace (); ; break;} case 26: -#line 509 "parse.y" +#line 510 "parse.y" { do_toplevel_using_decl (yyvsp[-1].ttype); ; break;} case 28: -#line 512 "parse.y" +#line 513 "parse.y" { pedantic = yyvsp[-1].itype; ; break;} case 29: -#line 517 "parse.y" +#line 518 "parse.y" { begin_only_namespace_names (); ; break;} case 30: -#line 519 "parse.y" +#line 520 "parse.y" { end_only_namespace_names (); if (lastiddecl) @@ -4682,35 +4682,35 @@ case 30: ; break;} case 31: -#line 529 "parse.y" +#line 530 "parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 32: -#line 531 "parse.y" +#line 532 "parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 33: -#line 533 "parse.y" +#line 534 "parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 34: -#line 538 "parse.y" +#line 539 "parse.y" { yyval.ttype = build_parse_node (SCOPE_REF, yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 35: -#line 540 "parse.y" +#line 541 "parse.y" { yyval.ttype = build_parse_node (SCOPE_REF, global_namespace, yyvsp[0].ttype); ; break;} case 36: -#line 542 "parse.y" +#line 543 "parse.y" { yyval.ttype = build_parse_node (SCOPE_REF, yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 37: -#line 547 "parse.y" +#line 548 "parse.y" { begin_only_namespace_names (); ; break;} case 38: -#line 549 "parse.y" +#line 550 "parse.y" { end_only_namespace_names (); /* If no declaration was found, the using-directive is @@ -4722,7 +4722,7 @@ case 38: ; break;} case 39: -#line 562 "parse.y" +#line 563 "parse.y" { if (TREE_CODE (yyval.ttype) == IDENTIFIER_NODE) yyval.ttype = lastiddecl; @@ -4730,7 +4730,7 @@ case 39: ; break;} case 40: -#line 568 "parse.y" +#line 569 "parse.y" { yyval.ttype = yyvsp[-1].ttype; if (TREE_CODE (yyval.ttype) == IDENTIFIER_NODE) @@ -4739,86 +4739,86 @@ case 40: ; break;} case 43: -#line 579 "parse.y" +#line 580 "parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 44: -#line 581 "parse.y" +#line 582 "parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 45: -#line 586 "parse.y" +#line 587 "parse.y" { push_lang_context (yyvsp[0].ttype); ; break;} case 46: -#line 588 "parse.y" +#line 589 "parse.y" { if (current_lang_name != yyvsp[0].ttype) cp_error ("use of linkage spec `%D' is different from previous spec `%D'", yyvsp[0].ttype, current_lang_name); pop_lang_context (); push_lang_context (yyvsp[0].ttype); ; break;} case 47: -#line 595 "parse.y" +#line 596 "parse.y" { begin_template_parm_list (); ; break;} case 48: -#line 597 "parse.y" +#line 598 "parse.y" { yyval.ttype = end_template_parm_list (yyvsp[-1].ttype); ; break;} case 49: -#line 599 "parse.y" +#line 600 "parse.y" { begin_specialization(); yyval.ttype = NULL_TREE; ; break;} case 50: -#line 605 "parse.y" +#line 606 "parse.y" { yyval.ttype = process_template_parm (NULL_TREE, yyvsp[0].ttype); ; break;} case 51: -#line 607 "parse.y" +#line 608 "parse.y" { yyval.ttype = process_template_parm (yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 52: -#line 612 "parse.y" +#line 613 "parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 53: -#line 614 "parse.y" +#line 615 "parse.y" { yyval.ttype = NULL_TREE; ; break;} case 54: -#line 618 "parse.y" +#line 619 "parse.y" { yyval.ttype = finish_template_type_parm (yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 55: -#line 620 "parse.y" +#line 621 "parse.y" { yyval.ttype = finish_template_type_parm (class_type_node, yyvsp[0].ttype); ; break;} case 56: -#line 625 "parse.y" +#line 626 "parse.y" { yyval.ttype = finish_template_template_parm (yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 57: -#line 637 "parse.y" +#line 638 "parse.y" { yyval.ttype = build_tree_list (NULL_TREE, yyvsp[0].ttype); ; break;} case 58: -#line 639 "parse.y" +#line 640 "parse.y" { yyval.ttype = build_tree_list (groktypename (yyvsp[0].ftype.t), yyvsp[-2].ttype); ; break;} case 59: -#line 641 "parse.y" +#line 642 "parse.y" { yyval.ttype = build_tree_list (NULL_TREE, yyvsp[0].ftype.t); ; break;} case 60: -#line 643 "parse.y" +#line 644 "parse.y" { yyval.ttype = build_tree_list (yyvsp[0].ttype, yyvsp[-2].ftype.t); ; break;} case 61: -#line 645 "parse.y" +#line 646 "parse.y" { yyval.ttype = build_tree_list (NULL_TREE, yyvsp[0].ttype); ; break;} case 62: -#line 647 "parse.y" +#line 648 "parse.y" { if (TREE_CODE (yyvsp[0].ttype) != TEMPLATE_DECL && TREE_CODE (yyvsp[0].ttype) != TEMPLATE_TEMPLATE_PARM @@ -4831,66 +4831,66 @@ case 62: ; break;} case 63: -#line 661 "parse.y" +#line 662 "parse.y" { finish_template_decl (yyvsp[-1].ttype); ; break;} case 64: -#line 663 "parse.y" +#line 664 "parse.y" { finish_template_decl (yyvsp[-1].ttype); ; break;} case 65: -#line 668 "parse.y" +#line 669 "parse.y" { if (pending_inlines) do_pending_inlines (); ; break;} case 66: -#line 670 "parse.y" +#line 671 "parse.y" { if (pending_inlines) do_pending_inlines (); ; break;} case 67: -#line 672 "parse.y" +#line 673 "parse.y" { if (pending_inlines) do_pending_inlines (); ; break;} case 68: -#line 674 "parse.y" +#line 675 "parse.y" { if (pending_inlines) do_pending_inlines (); pop_lang_context (); ; break;} case 69: -#line 677 "parse.y" +#line 678 "parse.y" { if (pending_inlines) do_pending_inlines (); pop_lang_context (); ; break;} case 70: -#line 680 "parse.y" +#line 681 "parse.y" { pedantic = yyvsp[-1].itype; ; break;} case 72: -#line 686 "parse.y" +#line 687 "parse.y" {; break;} case 73: -#line 688 "parse.y" +#line 689 "parse.y" { note_list_got_semicolon (yyvsp[-2].ftype.t); ; break;} case 74: -#line 690 "parse.y" +#line 691 "parse.y" { maybe_process_partial_specialization (yyvsp[-1].ftype.t); note_got_semicolon (yyvsp[-1].ftype.t); ; break;} case 76: -#line 697 "parse.y" +#line 698 "parse.y" {; break;} case 77: -#line 699 "parse.y" +#line 700 "parse.y" { note_list_got_semicolon (yyvsp[-2].ftype.t); ; break;} case 78: -#line 701 "parse.y" +#line 702 "parse.y" { pedwarn ("empty declaration"); ; break;} case 80: -#line 704 "parse.y" +#line 705 "parse.y" { tree t, attrs; split_specs_attrs (yyvsp[-1].ftype.t, &t, &attrs); @@ -4899,125 +4899,125 @@ case 80: ; break;} case 84: -#line 717 "parse.y" +#line 718 "parse.y" { yyval.itype = 0; ; break;} case 85: -#line 719 "parse.y" +#line 720 "parse.y" { yyval.itype = 1; ; break;} case 91: -#line 735 "parse.y" +#line 736 "parse.y" { expand_body (finish_function ((int)yyvsp[-1].itype)); ; break;} case 92: -#line 737 "parse.y" +#line 738 "parse.y" { expand_body (finish_function ((int)yyvsp[0].itype)); ; break;} case 93: -#line 739 "parse.y" +#line 740 "parse.y" { ; break;} case 94: -#line 744 "parse.y" +#line 745 "parse.y" { yyval.ttype = begin_constructor_declarator (yyvsp[-2].ttype, yyvsp[-1].ttype); ; break;} case 95: -#line 746 "parse.y" +#line 747 "parse.y" { yyval.ttype = make_call_declarator (yyvsp[-4].ttype, yyvsp[-3].ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 96: -#line 748 "parse.y" +#line 749 "parse.y" { yyval.ttype = begin_constructor_declarator (yyvsp[-4].ttype, yyvsp[-3].ttype); yyval.ttype = make_call_declarator (yyval.ttype, empty_parms (), yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 97: -#line 752 "parse.y" +#line 753 "parse.y" { yyval.ttype = begin_constructor_declarator (yyvsp[-2].ttype, yyvsp[-1].ttype); ; break;} case 98: -#line 754 "parse.y" +#line 755 "parse.y" { yyval.ttype = make_call_declarator (yyvsp[-4].ttype, yyvsp[-3].ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 99: -#line 756 "parse.y" +#line 757 "parse.y" { yyval.ttype = begin_constructor_declarator (yyvsp[-4].ttype, yyvsp[-3].ttype); yyval.ttype = make_call_declarator (yyval.ttype, empty_parms (), yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 100: -#line 760 "parse.y" +#line 761 "parse.y" { yyval.ttype = begin_constructor_declarator (yyvsp[-2].ttype, yyvsp[-1].ttype); ; break;} case 101: -#line 762 "parse.y" +#line 763 "parse.y" { yyval.ttype = make_call_declarator (yyvsp[-4].ttype, yyvsp[-3].ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 102: -#line 764 "parse.y" +#line 765 "parse.y" { yyval.ttype = begin_constructor_declarator (yyvsp[-4].ttype, yyvsp[-3].ttype); yyval.ttype = make_call_declarator (yyval.ttype, empty_parms (), yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 103: -#line 768 "parse.y" +#line 769 "parse.y" { yyval.ttype = begin_constructor_declarator (yyvsp[-2].ttype, yyvsp[-1].ttype); ; break;} case 104: -#line 770 "parse.y" +#line 771 "parse.y" { yyval.ttype = make_call_declarator (yyvsp[-4].ttype, yyvsp[-3].ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 105: -#line 772 "parse.y" +#line 773 "parse.y" { yyval.ttype = begin_constructor_declarator (yyvsp[-4].ttype, yyvsp[-3].ttype); yyval.ttype = make_call_declarator (yyval.ttype, empty_parms (), yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 106: -#line 779 "parse.y" +#line 780 "parse.y" { check_for_new_type ("return type", yyvsp[-1].ftype); if (!begin_function_definition (yyvsp[-1].ftype.t, yyvsp[0].ttype)) YYERROR1; ; break;} case 107: -#line 783 "parse.y" +#line 784 "parse.y" { if (!begin_function_definition (yyvsp[-1].ftype.t, yyvsp[0].ttype)) YYERROR1; ; break;} case 108: -#line 786 "parse.y" +#line 787 "parse.y" { if (!begin_function_definition (NULL_TREE, yyvsp[0].ttype)) YYERROR1; ; break;} case 109: -#line 789 "parse.y" +#line 790 "parse.y" { if (!begin_function_definition (yyvsp[-1].ftype.t, yyvsp[0].ttype)) YYERROR1; ; break;} case 110: -#line 792 "parse.y" +#line 793 "parse.y" { if (!begin_function_definition (NULL_TREE, yyvsp[0].ttype)) YYERROR1; ; break;} case 111: -#line 798 "parse.y" +#line 799 "parse.y" { yyval.ttype = make_call_declarator (yyvsp[-5].ttype, yyvsp[-3].ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 112: -#line 800 "parse.y" +#line 801 "parse.y" { yyval.ttype = make_call_declarator (yyvsp[-3].ttype, empty_parms (), yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 113: -#line 802 "parse.y" +#line 803 "parse.y" { yyval.ttype = make_call_declarator (yyvsp[-5].ttype, yyvsp[-3].ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 114: -#line 804 "parse.y" +#line 805 "parse.y" { yyval.ttype = make_call_declarator (yyvsp[-3].ttype, empty_parms (), yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 115: -#line 811 "parse.y" +#line 812 "parse.y" { yyval.ttype = parse_method (yyvsp[0].ttype, yyvsp[-1].ftype.t, yyvsp[-1].ftype.lookups); rest_of_mdef: if (! yyval.ttype) @@ -5027,34 +5027,34 @@ case 115: reinit_parse_for_method (yychar, yyval.ttype); ; break;} case 116: -#line 819 "parse.y" +#line 820 "parse.y" { yyval.ttype = parse_method (yyvsp[0].ttype, NULL_TREE, NULL_TREE); goto rest_of_mdef; ; break;} case 117: -#line 822 "parse.y" +#line 823 "parse.y" { yyval.ttype = parse_method (yyvsp[0].ttype, yyvsp[-1].ftype.t, yyvsp[-1].ftype.lookups); goto rest_of_mdef;; break;} case 118: -#line 824 "parse.y" +#line 825 "parse.y" { yyval.ttype = parse_method (yyvsp[0].ttype, yyvsp[-1].ftype.t, yyvsp[-1].ftype.lookups); goto rest_of_mdef;; break;} case 119: -#line 826 "parse.y" +#line 827 "parse.y" { yyval.ttype = parse_method (yyvsp[0].ttype, NULL_TREE, NULL_TREE); goto rest_of_mdef; ; break;} case 120: -#line 829 "parse.y" +#line 830 "parse.y" { yyval.ttype = parse_method (yyvsp[0].ttype, yyvsp[-1].ftype.t, yyvsp[-1].ftype.lookups); goto rest_of_mdef;; break;} case 121: -#line 831 "parse.y" +#line 832 "parse.y" { yyval.ttype = parse_method (yyvsp[0].ttype, NULL_TREE, NULL_TREE); goto rest_of_mdef; ; break;} case 122: -#line 837 "parse.y" +#line 838 "parse.y" { if (! current_function_parms_stored) store_parm_decls (); @@ -5062,27 +5062,58 @@ case 122: ; break;} case 123: -#line 846 "parse.y" +#line 847 "parse.y" { finish_named_return_value (yyval.ttype, yyvsp[0].ttype); ; break;} case 124: -#line 848 "parse.y" +#line 849 "parse.y" { finish_named_return_value (yyval.ttype, yyvsp[-1].ttype); ; break;} case 125: -#line 850 "parse.y" +#line 851 "parse.y" { finish_named_return_value (yyval.ttype, NULL_TREE); ; break;} case 126: -#line 855 "parse.y" +#line 856 "parse.y" { - if (yyvsp[0].itype == 0) - error ("no base initializers given following ':'"); - setup_vtbl_ptr (); + tree member_init_list = NULL_TREE; + tree base_init_list = NULL_TREE; + tree init; + tree next; + int seen_member_init_p; + + if (yyvsp[0].ftype.new_type_flag == 0) + error ("no base or member initializers given following ':'"); + + seen_member_init_p = 0; + for (init = yyvsp[0].ftype.t; init; init = next) + { + next = TREE_CHAIN (init); + if (TREE_CODE (TREE_PURPOSE (init)) == FIELD_DECL) + { + TREE_CHAIN (init) = member_init_list; + member_init_list = init; + seen_member_init_p = 1; + } + else + { + if (warn_reorder && seen_member_init_p) + { + cp_warning ("base initializer for `%T'", + TREE_PURPOSE (init)); + warning (" will be re-ordered to precede member initializations"); + } + + TREE_CHAIN (init) = base_init_list; + base_init_list = init; + } + } + + setup_vtbl_ptr (member_init_list, base_init_list); ; break;} case 127: -#line 864 "parse.y" +#line 896 "parse.y" { if (! current_function_parms_stored) store_parm_decls (); @@ -5097,117 +5128,146 @@ case 127: ; break;} case 128: -#line 880 "parse.y" -{ yyval.itype = 0; ; +#line 912 "parse.y" +{ + yyval.ftype.new_type_flag = 0; + yyval.ftype.t = NULL_TREE; + ; break;} case 129: -#line 882 "parse.y" -{ yyval.itype = 1; ; +#line 917 "parse.y" +{ + yyval.ftype.new_type_flag = 1; + yyval.ftype.t = yyvsp[0].ttype; + ; + break;} +case 130: +#line 922 "parse.y" +{ + if (yyvsp[0].ttype) + { + yyval.ftype.new_type_flag = 1; + TREE_CHAIN (yyvsp[0].ttype) = yyvsp[-2].ftype.t; + yyval.ftype.t = yyvsp[0].ttype; + } + else + yyval.ftype = yyvsp[-2].ftype; + ; break;} case 132: -#line 889 "parse.y" +#line 937 "parse.y" { if (current_class_name) pedwarn ("anachronistic old style base class initializer"); - expand_member_init (current_class_ref, NULL_TREE, yyvsp[-1].ttype); + yyval.ttype = expand_member_init (current_class_ref, NULL_TREE, yyvsp[-1].ttype); ; break;} case 133: -#line 895 "parse.y" +#line 943 "parse.y" { if (current_class_name) pedwarn ("anachronistic old style base class initializer"); - expand_member_init (current_class_ref, NULL_TREE, void_type_node); + yyval.ttype = expand_member_init (current_class_ref, + NULL_TREE, + void_type_node); ; break;} case 134: -#line 901 "parse.y" -{ expand_member_init (current_class_ref, yyvsp[-3].ttype, yyvsp[-1].ttype); ; +#line 951 "parse.y" +{ yyval.ttype = expand_member_init (current_class_ref, yyvsp[-3].ttype, yyvsp[-1].ttype); ; break;} case 135: -#line 903 "parse.y" -{ expand_member_init (current_class_ref, yyvsp[-1].ttype, void_type_node); ; +#line 953 "parse.y" +{ yyval.ttype = expand_member_init (current_class_ref, yyvsp[-1].ttype, + void_type_node); ; break;} case 136: -#line 905 "parse.y" -{ expand_member_init (current_class_ref, yyvsp[-3].ttype, yyvsp[-1].ttype); ; +#line 956 "parse.y" +{ yyval.ttype = expand_member_init (current_class_ref, yyvsp[-3].ttype, yyvsp[-1].ttype); ; break;} case 137: -#line 907 "parse.y" -{ expand_member_init (current_class_ref, yyvsp[-1].ttype, void_type_node); ; +#line 958 "parse.y" +{ yyval.ttype = expand_member_init (current_class_ref, yyvsp[-1].ttype, + void_type_node); ; break;} case 138: -#line 909 "parse.y" -{ expand_member_init (current_class_ref, TYPE_MAIN_DECL (yyvsp[-3].ttype), - yyvsp[-1].ttype); ; +#line 961 "parse.y" +{ yyval.ttype = expand_member_init (current_class_ref, + TYPE_MAIN_DECL (yyvsp[-3].ttype), + yyvsp[-1].ttype); ; break;} case 139: -#line 912 "parse.y" -{ expand_member_init (current_class_ref, TYPE_MAIN_DECL (yyvsp[-1].ttype), - void_type_node); ; +#line 965 "parse.y" +{ yyval.ttype = expand_member_init (current_class_ref, + TYPE_MAIN_DECL (yyvsp[-1].ttype), + void_type_node); ; + break;} +case 140: +#line 969 "parse.y" +{ yyval.ttype = NULL_TREE ; break;} case 152: -#line 939 "parse.y" +#line 994 "parse.y" { do_type_instantiation (yyvsp[-1].ftype.t, NULL_TREE); yyungetc (';', 1); ; break;} case 154: -#line 943 "parse.y" +#line 998 "parse.y" { tree specs = strip_attrs (yyvsp[-1].ftype.t); do_decl_instantiation (specs, yyvsp[0].ttype, NULL_TREE); ; break;} case 156: -#line 947 "parse.y" +#line 1002 "parse.y" { do_decl_instantiation (NULL_TREE, yyvsp[0].ttype, NULL_TREE); ; break;} case 158: -#line 950 "parse.y" +#line 1005 "parse.y" { do_decl_instantiation (NULL_TREE, yyvsp[0].ttype, NULL_TREE); ; break;} case 160: -#line 953 "parse.y" +#line 1008 "parse.y" { do_type_instantiation (yyvsp[-1].ftype.t, yyvsp[-4].ttype); yyungetc (';', 1); ; break;} case 162: -#line 958 "parse.y" +#line 1013 "parse.y" { tree specs = strip_attrs (yyvsp[-1].ftype.t); do_decl_instantiation (specs, yyvsp[0].ttype, yyvsp[-4].ttype); ; break;} case 164: -#line 962 "parse.y" +#line 1017 "parse.y" { do_decl_instantiation (NULL_TREE, yyvsp[0].ttype, yyvsp[-3].ttype); ; break;} case 166: -#line 965 "parse.y" +#line 1020 "parse.y" { do_decl_instantiation (NULL_TREE, yyvsp[0].ttype, yyvsp[-3].ttype); ; break;} case 168: -#line 970 "parse.y" +#line 1025 "parse.y" { begin_explicit_instantiation(); ; break;} case 169: -#line 973 "parse.y" +#line 1028 "parse.y" { end_explicit_instantiation(); ; break;} case 170: -#line 982 "parse.y" +#line 1037 "parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 171: -#line 985 "parse.y" +#line 1040 "parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 174: -#line 993 "parse.y" +#line 1048 "parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 175: -#line 998 "parse.y" +#line 1053 "parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 176: -#line 1002 "parse.y" +#line 1057 "parse.y" { if (yychar == YYEMPTY) yychar = YYLEX; @@ -5217,7 +5277,7 @@ case 176: ; break;} case 178: -#line 1013 "parse.y" +#line 1068 "parse.y" { /* Handle `Class<Class<Type>>' without space in the `>>' */ pedwarn ("`>>' should be `> >' in template class name"); @@ -5225,79 +5285,79 @@ case 178: ; break;} case 179: -#line 1022 "parse.y" +#line 1077 "parse.y" { yyval.ttype = NULL_TREE; ; break;} case 181: -#line 1028 "parse.y" +#line 1083 "parse.y" { yyval.ttype = build_tree_list (NULL_TREE, yyval.ttype); ; break;} case 182: -#line 1030 "parse.y" +#line 1085 "parse.y" { yyval.ttype = chainon (yyval.ttype, build_tree_list (NULL_TREE, yyvsp[0].ttype)); ; break;} case 183: -#line 1035 "parse.y" +#line 1090 "parse.y" { yyval.ttype = groktypename (yyvsp[0].ftype.t); ; break;} case 184: -#line 1037 "parse.y" +#line 1092 "parse.y" { yyval.ttype = lastiddecl; ; break;} case 186: -#line 1043 "parse.y" +#line 1098 "parse.y" { yyval.code = NEGATE_EXPR; ; break;} case 187: -#line 1045 "parse.y" +#line 1100 "parse.y" { yyval.code = CONVERT_EXPR; ; break;} case 188: -#line 1047 "parse.y" +#line 1102 "parse.y" { yyval.code = PREINCREMENT_EXPR; ; break;} case 189: -#line 1049 "parse.y" +#line 1104 "parse.y" { yyval.code = PREDECREMENT_EXPR; ; break;} case 190: -#line 1051 "parse.y" +#line 1106 "parse.y" { yyval.code = TRUTH_NOT_EXPR; ; break;} case 191: -#line 1056 "parse.y" +#line 1111 "parse.y" { yyval.ttype = build_x_compound_expr (yyval.ttype); ; break;} case 193: -#line 1062 "parse.y" +#line 1117 "parse.y" { error ("ISO C++ forbids an empty condition for `%s'", cond_stmt_keyword); yyval.ttype = integer_zero_node; ; break;} case 194: -#line 1066 "parse.y" +#line 1121 "parse.y" { yyval.ttype = yyvsp[-1].ttype; ; break;} case 195: -#line 1071 "parse.y" +#line 1126 "parse.y" { error ("ISO C++ forbids an empty condition for `%s'", cond_stmt_keyword); yyval.ttype = integer_zero_node; ; break;} case 196: -#line 1075 "parse.y" +#line 1130 "parse.y" { yyval.ttype = yyvsp[-1].ttype; ; break;} case 197: -#line 1080 "parse.y" +#line 1135 "parse.y" { yyval.ttype = NULL_TREE; ; break;} case 199: -#line 1083 "parse.y" +#line 1138 "parse.y" { yyval.ttype = NULL_TREE; ; break;} case 200: -#line 1088 "parse.y" +#line 1143 "parse.y" { { tree d; for (d = getdecls (); d; d = TREE_CHAIN (d)) @@ -5314,7 +5374,7 @@ case 200: ; break;} case 201: -#line 1103 "parse.y" +#line 1158 "parse.y" { parse_end_decl (yyvsp[-1].ttype, yyvsp[0].ttype, yyvsp[-3].ttype); yyval.ttype = convert_from_reference (yyvsp[-1].ttype); @@ -5323,180 +5383,180 @@ case 201: ; break;} case 207: -#line 1121 "parse.y" +#line 1176 "parse.y" { yyval.ttype = begin_compound_stmt (1); ; break;} case 208: -#line 1123 "parse.y" +#line 1178 "parse.y" { finish_compound_stmt (1, yyvsp[-1].ttype); ; break;} case 210: -#line 1130 "parse.y" +#line 1185 "parse.y" { yyval.ttype = tree_cons (NULL_TREE, yyval.ttype, build_tree_list (NULL_TREE, yyvsp[0].ttype)); ; break;} case 211: -#line 1133 "parse.y" +#line 1188 "parse.y" { yyval.ttype = tree_cons (NULL_TREE, yyval.ttype, build_tree_list (NULL_TREE, error_mark_node)); ; break;} case 212: -#line 1136 "parse.y" +#line 1191 "parse.y" { chainon (yyval.ttype, build_tree_list (NULL_TREE, yyvsp[0].ttype)); ; break;} case 213: -#line 1138 "parse.y" +#line 1193 "parse.y" { chainon (yyval.ttype, build_tree_list (NULL_TREE, error_mark_node)); ; break;} case 214: -#line 1143 "parse.y" +#line 1198 "parse.y" { yyval.ttype = build_tree_list (NULL_TREE, yyval.ttype); ; break;} case 216: -#line 1149 "parse.y" +#line 1204 "parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 217: -#line 1152 "parse.y" +#line 1207 "parse.y" { yyval.ttype = yyvsp[0].ttype; pedantic = yyvsp[-1].itype; ; break;} case 218: -#line 1155 "parse.y" +#line 1210 "parse.y" { yyval.ttype = build_x_indirect_ref (yyvsp[0].ttype, "unary *"); ; break;} case 219: -#line 1157 "parse.y" +#line 1212 "parse.y" { yyval.ttype = build_x_unary_op (ADDR_EXPR, yyvsp[0].ttype); ; break;} case 220: -#line 1159 "parse.y" +#line 1214 "parse.y" { yyval.ttype = build_x_unary_op (BIT_NOT_EXPR, yyvsp[0].ttype); ; break;} case 221: -#line 1161 "parse.y" +#line 1216 "parse.y" { yyval.ttype = finish_unary_op_expr (yyvsp[-1].code, yyvsp[0].ttype); ; break;} case 222: -#line 1164 "parse.y" +#line 1219 "parse.y" { if (pedantic) pedwarn ("ISO C++ forbids `&&'"); yyval.ttype = finish_label_address_expr (yyvsp[0].ttype); ; break;} case 223: -#line 1168 "parse.y" +#line 1223 "parse.y" { yyval.ttype = expr_sizeof (yyvsp[0].ttype); ; break;} case 224: -#line 1170 "parse.y" +#line 1225 "parse.y" { yyval.ttype = c_sizeof (groktypename (yyvsp[-1].ftype.t)); check_for_new_type ("sizeof", yyvsp[-1].ftype); ; break;} case 225: -#line 1173 "parse.y" +#line 1228 "parse.y" { yyval.ttype = grok_alignof (yyvsp[0].ttype); ; break;} case 226: -#line 1175 "parse.y" +#line 1230 "parse.y" { yyval.ttype = c_alignof (groktypename (yyvsp[-1].ftype.t)); check_for_new_type ("alignof", yyvsp[-1].ftype); ; break;} case 227: -#line 1181 "parse.y" +#line 1236 "parse.y" { yyval.ttype = build_new (NULL_TREE, yyvsp[0].ftype.t, NULL_TREE, yyvsp[-1].itype); check_for_new_type ("new", yyvsp[0].ftype); ; break;} case 228: -#line 1184 "parse.y" +#line 1239 "parse.y" { yyval.ttype = build_new (NULL_TREE, yyvsp[-1].ftype.t, yyvsp[0].ttype, yyvsp[-2].itype); check_for_new_type ("new", yyvsp[-1].ftype); ; break;} case 229: -#line 1187 "parse.y" +#line 1242 "parse.y" { yyval.ttype = build_new (yyvsp[-1].ttype, yyvsp[0].ftype.t, NULL_TREE, yyvsp[-2].itype); check_for_new_type ("new", yyvsp[0].ftype); ; break;} case 230: -#line 1190 "parse.y" +#line 1245 "parse.y" { yyval.ttype = build_new (yyvsp[-2].ttype, yyvsp[-1].ftype.t, yyvsp[0].ttype, yyvsp[-3].itype); check_for_new_type ("new", yyvsp[-1].ftype); ; break;} case 231: -#line 1194 "parse.y" +#line 1249 "parse.y" { yyval.ttype = build_new (NULL_TREE, groktypename(yyvsp[-1].ftype.t), NULL_TREE, yyvsp[-3].itype); check_for_new_type ("new", yyvsp[-1].ftype); ; break;} case 232: -#line 1198 "parse.y" +#line 1253 "parse.y" { yyval.ttype = build_new (NULL_TREE, groktypename(yyvsp[-2].ftype.t), yyvsp[0].ttype, yyvsp[-4].itype); check_for_new_type ("new", yyvsp[-2].ftype); ; break;} case 233: -#line 1201 "parse.y" +#line 1256 "parse.y" { yyval.ttype = build_new (yyvsp[-3].ttype, groktypename(yyvsp[-1].ftype.t), NULL_TREE, yyvsp[-4].itype); check_for_new_type ("new", yyvsp[-1].ftype); ; break;} case 234: -#line 1204 "parse.y" +#line 1259 "parse.y" { yyval.ttype = build_new (yyvsp[-4].ttype, groktypename(yyvsp[-2].ftype.t), yyvsp[0].ttype, yyvsp[-5].itype); check_for_new_type ("new", yyvsp[-2].ftype); ; break;} case 235: -#line 1208 "parse.y" +#line 1263 "parse.y" { yyval.ttype = delete_sanity (yyvsp[0].ttype, NULL_TREE, 0, yyvsp[-1].itype); ; break;} case 236: -#line 1210 "parse.y" +#line 1265 "parse.y" { yyval.ttype = delete_sanity (yyvsp[0].ttype, NULL_TREE, 1, yyvsp[-3].itype); if (yychar == YYEMPTY) yychar = YYLEX; ; break;} case 237: -#line 1214 "parse.y" +#line 1269 "parse.y" { yyval.ttype = delete_sanity (yyvsp[0].ttype, yyvsp[-2].ttype, 2, yyvsp[-4].itype); if (yychar == YYEMPTY) yychar = YYLEX; ; break;} case 238: -#line 1218 "parse.y" +#line 1273 "parse.y" { yyval.ttype = build_x_unary_op (REALPART_EXPR, yyvsp[0].ttype); ; break;} case 239: -#line 1220 "parse.y" +#line 1275 "parse.y" { yyval.ttype = build_x_unary_op (IMAGPART_EXPR, yyvsp[0].ttype); ; break;} case 240: -#line 1222 "parse.y" +#line 1277 "parse.y" { yyval.ttype = build_x_va_arg (yyvsp[-3].ttype, groktypename (yyvsp[-1].ftype.t)); check_for_new_type ("__builtin_va_arg", yyvsp[-1].ftype); ; break;} case 241: -#line 1228 "parse.y" +#line 1283 "parse.y" { yyval.ttype = yyvsp[-1].ttype; ; break;} case 242: -#line 1230 "parse.y" +#line 1285 "parse.y" { cp_pedwarn ("old style placement syntax, use () instead"); yyval.ttype = yyvsp[-1].ttype; ; break;} case 243: -#line 1236 "parse.y" +#line 1291 "parse.y" { yyval.ttype = yyvsp[-1].ttype; ; break;} case 244: -#line 1238 "parse.y" +#line 1293 "parse.y" { yyval.ttype = NULL_TREE; ; break;} case 245: -#line 1240 "parse.y" +#line 1295 "parse.y" { cp_error ("`%T' is not a valid expression", yyvsp[-1].ftype.t); yyval.ttype = error_mark_node; ; break;} case 246: -#line 1248 "parse.y" +#line 1303 "parse.y" { if (pedantic) pedwarn ("ISO C++ forbids initialization of new expression with `='"); @@ -5508,23 +5568,23 @@ case 246: ; break;} case 247: -#line 1262 "parse.y" +#line 1317 "parse.y" { yyvsp[-1].ftype.t = finish_parmlist (build_tree_list (NULL_TREE, yyvsp[-1].ftype.t), 0); yyval.ttype = make_call_declarator (NULL_TREE, yyvsp[-1].ftype.t, NULL_TREE, NULL_TREE); check_for_new_type ("cast", yyvsp[-1].ftype); ; break;} case 248: -#line 1266 "parse.y" +#line 1321 "parse.y" { yyvsp[-1].ftype.t = finish_parmlist (build_tree_list (NULL_TREE, yyvsp[-1].ftype.t), 0); yyval.ttype = make_call_declarator (yyval.ttype, yyvsp[-1].ftype.t, NULL_TREE, NULL_TREE); check_for_new_type ("cast", yyvsp[-1].ftype); ; break;} case 250: -#line 1274 "parse.y" +#line 1329 "parse.y" { yyval.ttype = reparse_absdcl_as_casts (yyval.ttype, yyvsp[0].ttype); ; break;} case 251: -#line 1276 "parse.y" +#line 1331 "parse.y" { tree init = build_nt (CONSTRUCTOR, NULL_TREE, nreverse (yyvsp[-2].ttype)); @@ -5537,113 +5597,113 @@ case 251: ; break;} case 253: -#line 1292 "parse.y" +#line 1347 "parse.y" { yyval.ttype = build_x_binary_op (MEMBER_REF, yyval.ttype, yyvsp[0].ttype); ; break;} case 254: -#line 1294 "parse.y" +#line 1349 "parse.y" { yyval.ttype = build_m_component_ref (yyval.ttype, yyvsp[0].ttype); ; break;} case 255: -#line 1296 "parse.y" +#line 1351 "parse.y" { yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ; break;} case 256: -#line 1298 "parse.y" +#line 1353 "parse.y" { yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ; break;} case 257: -#line 1300 "parse.y" +#line 1355 "parse.y" { yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ; break;} case 258: -#line 1302 "parse.y" +#line 1357 "parse.y" { yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ; break;} case 259: -#line 1304 "parse.y" +#line 1359 "parse.y" { yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ; break;} case 260: -#line 1306 "parse.y" +#line 1361 "parse.y" { yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ; break;} case 261: -#line 1308 "parse.y" +#line 1363 "parse.y" { yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ; break;} case 262: -#line 1310 "parse.y" +#line 1365 "parse.y" { yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ; break;} case 263: -#line 1312 "parse.y" +#line 1367 "parse.y" { yyval.ttype = build_x_binary_op (LT_EXPR, yyval.ttype, yyvsp[0].ttype); ; break;} case 264: -#line 1314 "parse.y" +#line 1369 "parse.y" { yyval.ttype = build_x_binary_op (GT_EXPR, yyval.ttype, yyvsp[0].ttype); ; break;} case 265: -#line 1316 "parse.y" +#line 1371 "parse.y" { yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ; break;} case 266: -#line 1318 "parse.y" +#line 1373 "parse.y" { yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ; break;} case 267: -#line 1320 "parse.y" +#line 1375 "parse.y" { yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ; break;} case 268: -#line 1322 "parse.y" +#line 1377 "parse.y" { yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ; break;} case 269: -#line 1324 "parse.y" +#line 1379 "parse.y" { yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ; break;} case 270: -#line 1326 "parse.y" +#line 1381 "parse.y" { yyval.ttype = build_x_binary_op (TRUTH_ANDIF_EXPR, yyval.ttype, yyvsp[0].ttype); ; break;} case 271: -#line 1328 "parse.y" +#line 1383 "parse.y" { yyval.ttype = build_x_binary_op (TRUTH_ORIF_EXPR, yyval.ttype, yyvsp[0].ttype); ; break;} case 272: -#line 1330 "parse.y" +#line 1385 "parse.y" { yyval.ttype = build_x_conditional_expr (yyval.ttype, yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 273: -#line 1332 "parse.y" +#line 1387 "parse.y" { yyval.ttype = build_x_modify_expr (yyval.ttype, NOP_EXPR, yyvsp[0].ttype); if (yyval.ttype != error_mark_node) C_SET_EXP_ORIGINAL_CODE (yyval.ttype, MODIFY_EXPR); ; break;} case 274: -#line 1336 "parse.y" +#line 1391 "parse.y" { yyval.ttype = build_x_modify_expr (yyval.ttype, yyvsp[-1].code, yyvsp[0].ttype); ; break;} case 275: -#line 1338 "parse.y" +#line 1393 "parse.y" { yyval.ttype = build_throw (NULL_TREE); ; break;} case 276: -#line 1340 "parse.y" +#line 1395 "parse.y" { yyval.ttype = build_throw (yyvsp[0].ttype); ; break;} case 277: -#line 1358 "parse.y" +#line 1413 "parse.y" { yyval.ttype = build_parse_node (BIT_NOT_EXPR, yyvsp[0].ttype); ; break;} case 278: -#line 1360 "parse.y" +#line 1415 "parse.y" { yyval.ttype = build_parse_node (BIT_NOT_EXPR, yyvsp[0].ttype); ; break;} case 284: -#line 1369 "parse.y" +#line 1424 "parse.y" { /* If lastiddecl is a TREE_LIST, it's a baselink, which means that we're in an expression like S::f<int>, so @@ -5656,27 +5716,27 @@ case 284: ; break;} case 285: -#line 1382 "parse.y" +#line 1437 "parse.y" { yyval.ttype = lookup_template_function (yyvsp[-2].ttype, yyvsp[-1].ttype); ; break;} case 286: -#line 1384 "parse.y" +#line 1439 "parse.y" { yyval.ttype = lookup_template_function (yyvsp[-2].ttype, yyvsp[-1].ttype); ; break;} case 287: -#line 1389 "parse.y" +#line 1444 "parse.y" { yyval.ttype = lookup_template_function (yyvsp[-3].ttype, yyvsp[-1].ttype); ; break;} case 288: -#line 1391 "parse.y" +#line 1446 "parse.y" { yyval.ttype = lookup_template_function (yyvsp[-3].ttype, yyvsp[-1].ttype); ; break;} case 289: -#line 1394 "parse.y" +#line 1449 "parse.y" { yyval.ttype = lookup_template_function (yyvsp[-3].ttype, yyvsp[-1].ttype); ; break;} case 294: -#line 1406 "parse.y" +#line 1461 "parse.y" { /* Provide support for '(' attributes '*' declarator ')' etc */ @@ -5684,31 +5744,31 @@ case 294: ; break;} case 296: -#line 1416 "parse.y" +#line 1471 "parse.y" { yyval.ttype = build_parse_node (INDIRECT_REF, yyvsp[0].ttype); ; break;} case 297: -#line 1418 "parse.y" +#line 1473 "parse.y" { yyval.ttype = build_parse_node (ADDR_EXPR, yyvsp[0].ttype); ; break;} case 298: -#line 1420 "parse.y" +#line 1475 "parse.y" { yyval.ttype = yyvsp[-1].ttype; ; break;} case 299: -#line 1425 "parse.y" +#line 1480 "parse.y" { yyval.ttype = lookup_template_function (yyvsp[-3].ttype, yyvsp[-1].ttype); ; break;} case 300: -#line 1427 "parse.y" +#line 1482 "parse.y" { yyval.ttype = lookup_template_function (yyvsp[-3].ttype, yyvsp[-1].ttype); ; break;} case 304: -#line 1437 "parse.y" +#line 1492 "parse.y" { yyval.ttype = finish_decl_parsing (yyvsp[-1].ttype); ; break;} case 305: -#line 1442 "parse.y" +#line 1497 "parse.y" { if (TREE_CODE (yyvsp[0].ttype) == BIT_NOT_EXPR) yyval.ttype = build_x_unary_op (BIT_NOT_EXPR, TREE_OPERAND (yyvsp[0].ttype, 0)); @@ -5717,7 +5777,7 @@ case 305: ; break;} case 308: -#line 1451 "parse.y" +#line 1506 "parse.y" { yyval.ttype = combine_strings (yyval.ttype); /* combine_strings doesn't set up TYPE_MAIN_VARIANT of @@ -5729,20 +5789,20 @@ case 308: ; break;} case 309: -#line 1461 "parse.y" +#line 1516 "parse.y" { yyval.ttype = finish_parenthesized_expr (yyvsp[-1].ttype); ; break;} case 310: -#line 1463 "parse.y" +#line 1518 "parse.y" { yyvsp[-1].ttype = reparse_decl_as_expr (NULL_TREE, yyvsp[-1].ttype); yyval.ttype = finish_parenthesized_expr (yyvsp[-1].ttype); ; break;} case 311: -#line 1466 "parse.y" +#line 1521 "parse.y" { yyval.ttype = error_mark_node; ; break;} case 312: -#line 1468 "parse.y" +#line 1523 "parse.y" { tree scope = current_scope (); if (!scope || TREE_CODE (scope) != FUNCTION_DECL) { @@ -5755,43 +5815,43 @@ case 312: ; break;} case 313: -#line 1479 "parse.y" +#line 1534 "parse.y" { yyval.ttype = finish_stmt_expr (yyvsp[-2].ttype); ; break;} case 314: -#line 1484 "parse.y" +#line 1539 "parse.y" { yyval.ttype = finish_call_expr (yyvsp[-3].ttype, yyvsp[-1].ttype, 1); ; break;} case 315: -#line 1486 "parse.y" +#line 1541 "parse.y" { yyval.ttype = finish_call_expr (yyvsp[-1].ttype, NULL_TREE, 1); ; break;} case 316: -#line 1488 "parse.y" +#line 1543 "parse.y" { yyval.ttype = finish_call_expr (yyvsp[-3].ttype, yyvsp[-1].ttype, 0); ; break;} case 317: -#line 1490 "parse.y" +#line 1545 "parse.y" { yyval.ttype = finish_call_expr (yyvsp[-1].ttype, NULL_TREE, 0); ; break;} case 318: -#line 1492 "parse.y" +#line 1547 "parse.y" { yyval.ttype = grok_array_decl (yyval.ttype, yyvsp[-1].ttype); ; break;} case 319: -#line 1494 "parse.y" +#line 1549 "parse.y" { yyval.ttype = finish_increment_expr (yyvsp[-1].ttype, POSTINCREMENT_EXPR); ; break;} case 320: -#line 1496 "parse.y" +#line 1551 "parse.y" { yyval.ttype = finish_increment_expr (yyvsp[-1].ttype, POSTDECREMENT_EXPR); ; break;} case 321: -#line 1499 "parse.y" +#line 1554 "parse.y" { yyval.ttype = finish_this_expr (); ; break;} case 322: -#line 1501 "parse.y" +#line 1556 "parse.y" { /* This is a C cast in C++'s `functional' notation using the "implicit int" extension so that: @@ -5804,49 +5864,49 @@ case 322: ; break;} case 324: -#line 1513 "parse.y" +#line 1568 "parse.y" { tree type = groktypename (yyvsp[-4].ftype.t); check_for_new_type ("dynamic_cast", yyvsp[-4].ftype); yyval.ttype = build_dynamic_cast (type, yyvsp[-1].ttype); ; break;} case 325: -#line 1517 "parse.y" +#line 1572 "parse.y" { tree type = groktypename (yyvsp[-4].ftype.t); check_for_new_type ("static_cast", yyvsp[-4].ftype); yyval.ttype = build_static_cast (type, yyvsp[-1].ttype); ; break;} case 326: -#line 1521 "parse.y" +#line 1576 "parse.y" { tree type = groktypename (yyvsp[-4].ftype.t); check_for_new_type ("reinterpret_cast", yyvsp[-4].ftype); yyval.ttype = build_reinterpret_cast (type, yyvsp[-1].ttype); ; break;} case 327: -#line 1525 "parse.y" +#line 1580 "parse.y" { tree type = groktypename (yyvsp[-4].ftype.t); check_for_new_type ("const_cast", yyvsp[-4].ftype); yyval.ttype = build_const_cast (type, yyvsp[-1].ttype); ; break;} case 328: -#line 1529 "parse.y" +#line 1584 "parse.y" { yyval.ttype = build_typeid (yyvsp[-1].ttype); ; break;} case 329: -#line 1531 "parse.y" +#line 1586 "parse.y" { tree type = groktypename (yyvsp[-1].ftype.t); check_for_new_type ("typeid", yyvsp[-1].ftype); yyval.ttype = get_typeid (TYPE_MAIN_VARIANT (type)); ; break;} case 330: -#line 1535 "parse.y" +#line 1590 "parse.y" { yyval.ttype = do_scoped_id (yyvsp[0].ttype, 1); ; break;} case 331: -#line 1537 "parse.y" +#line 1592 "parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 332: -#line 1539 "parse.y" +#line 1594 "parse.y" { got_scope = NULL_TREE; if (TREE_CODE (yyvsp[0].ttype) == IDENTIFIER_NODE) @@ -5856,272 +5916,272 @@ case 332: ; break;} case 333: -#line 1547 "parse.y" +#line 1602 "parse.y" { yyval.ttype = build_offset_ref (OP0 (yyval.ttype), OP1 (yyval.ttype)); ; break;} case 334: -#line 1549 "parse.y" +#line 1604 "parse.y" { yyval.ttype = finish_qualified_call_expr (yyvsp[-3].ttype, yyvsp[-1].ttype); ; break;} case 335: -#line 1551 "parse.y" +#line 1606 "parse.y" { yyval.ttype = finish_qualified_call_expr (yyvsp[-1].ttype, NULL_TREE); ; break;} case 336: -#line 1553 "parse.y" +#line 1608 "parse.y" { yyval.ttype = build_x_component_ref (yyval.ttype, yyvsp[0].ttype, NULL_TREE, 1); ; break;} case 337: -#line 1557 "parse.y" +#line 1612 "parse.y" { yyval.ttype = finish_object_call_expr (yyvsp[-3].ttype, yyvsp[-4].ttype, yyvsp[-1].ttype); ; break;} case 338: -#line 1559 "parse.y" +#line 1614 "parse.y" { yyval.ttype = finish_object_call_expr (yyvsp[-1].ttype, yyvsp[-2].ttype, NULL_TREE); ; break;} case 339: -#line 1561 "parse.y" +#line 1616 "parse.y" { yyval.ttype = build_x_component_ref (yyval.ttype, yyvsp[0].ttype, NULL_TREE, 1); ; break;} case 340: -#line 1563 "parse.y" +#line 1618 "parse.y" { if (processing_template_decl) yyval.ttype = build_min_nt (COMPONENT_REF, yyvsp[-1].ttype, yyvsp[0].ttype); else yyval.ttype = build_object_ref (yyval.ttype, OP0 (yyvsp[0].ttype), OP1 (yyvsp[0].ttype)); ; break;} case 341: -#line 1568 "parse.y" +#line 1623 "parse.y" { yyval.ttype = finish_object_call_expr (yyvsp[-3].ttype, yyvsp[-4].ttype, yyvsp[-1].ttype); ; break;} case 342: -#line 1570 "parse.y" +#line 1625 "parse.y" { yyval.ttype = finish_object_call_expr (yyvsp[-1].ttype, yyvsp[-2].ttype, NULL_TREE); ; break;} case 343: -#line 1572 "parse.y" +#line 1627 "parse.y" { yyval.ttype = finish_qualified_object_call_expr (yyvsp[-3].ttype, yyvsp[-4].ttype, yyvsp[-1].ttype); ; break;} case 344: -#line 1574 "parse.y" +#line 1629 "parse.y" { yyval.ttype = finish_qualified_object_call_expr (yyvsp[-1].ttype, yyvsp[-2].ttype, NULL_TREE); ; break;} case 345: -#line 1577 "parse.y" +#line 1632 "parse.y" { yyval.ttype = finish_pseudo_destructor_call_expr (yyvsp[-3].ttype, NULL_TREE, yyvsp[-1].ttype); ; break;} case 346: -#line 1579 "parse.y" +#line 1634 "parse.y" { yyval.ttype = finish_pseudo_destructor_call_expr (yyvsp[-5].ttype, yyvsp[-4].ttype, yyvsp[-1].ttype); ; break;} case 347: -#line 1581 "parse.y" +#line 1636 "parse.y" { yyval.ttype = error_mark_node; ; break;} case 348: -#line 1626 "parse.y" +#line 1681 "parse.y" { yyval.itype = 0; ; break;} case 349: -#line 1628 "parse.y" +#line 1683 "parse.y" { got_scope = NULL_TREE; yyval.itype = 1; ; break;} case 350: -#line 1633 "parse.y" +#line 1688 "parse.y" { yyval.itype = 0; ; break;} case 351: -#line 1635 "parse.y" +#line 1690 "parse.y" { got_scope = NULL_TREE; yyval.itype = 1; ; break;} case 352: -#line 1640 "parse.y" +#line 1695 "parse.y" { yyval.ttype = boolean_true_node; ; break;} case 353: -#line 1642 "parse.y" +#line 1697 "parse.y" { yyval.ttype = boolean_false_node; ; break;} case 355: -#line 1649 "parse.y" +#line 1704 "parse.y" { yyval.ttype = chainon (yyval.ttype, yyvsp[0].ttype); ; break;} case 356: -#line 1654 "parse.y" +#line 1709 "parse.y" { if (! current_function_parms_stored) store_parm_decls (); - setup_vtbl_ptr (); + setup_vtbl_ptr (NULL_TREE, NULL_TREE); ; break;} case 357: -#line 1663 "parse.y" +#line 1718 "parse.y" { got_object = TREE_TYPE (yyval.ttype); ; break;} case 358: -#line 1665 "parse.y" +#line 1720 "parse.y" { yyval.ttype = build_x_arrow (yyval.ttype); got_object = TREE_TYPE (yyval.ttype); ; break;} case 359: -#line 1673 "parse.y" +#line 1728 "parse.y" { if (yyvsp[-2].ftype.t && IS_AGGR_TYPE_CODE (TREE_CODE (yyvsp[-2].ftype.t))) note_got_semicolon (yyvsp[-2].ftype.t); ; break;} case 360: -#line 1678 "parse.y" +#line 1733 "parse.y" { note_list_got_semicolon (yyvsp[-2].ftype.t); ; break;} case 361: -#line 1682 "parse.y" +#line 1737 "parse.y" {; break;} case 362: -#line 1684 "parse.y" +#line 1739 "parse.y" { shadow_tag (yyvsp[-1].ftype.t); note_list_got_semicolon (yyvsp[-1].ftype.t); ; break;} case 363: -#line 1689 "parse.y" +#line 1744 "parse.y" { warning ("empty declaration"); ; break;} case 364: -#line 1691 "parse.y" +#line 1746 "parse.y" { pedantic = yyvsp[-1].itype; ; break;} case 367: -#line 1705 "parse.y" +#line 1760 "parse.y" { yyval.ttype = make_call_declarator (NULL_TREE, empty_parms (), NULL_TREE, NULL_TREE); ; break;} case 368: -#line 1708 "parse.y" +#line 1763 "parse.y" { yyval.ttype = make_call_declarator (yyval.ttype, empty_parms (), NULL_TREE, NULL_TREE); ; break;} case 369: -#line 1715 "parse.y" +#line 1770 "parse.y" { yyval.ftype.t = build_decl_list (yyvsp[-1].ftype.t, yyvsp[0].ttype); yyval.ftype.new_type_flag = yyvsp[-1].ftype.new_type_flag; ; break;} case 370: -#line 1718 "parse.y" +#line 1773 "parse.y" { yyval.ftype.t = build_decl_list (yyvsp[-1].ftype.t, yyvsp[0].ttype); yyval.ftype.new_type_flag = yyvsp[-1].ftype.new_type_flag; ; break;} case 371: -#line 1721 "parse.y" +#line 1776 "parse.y" { yyval.ftype.t = build_decl_list (build_decl_list (NULL_TREE, yyvsp[-1].ftype.t), yyvsp[0].ttype); yyval.ftype.new_type_flag = yyvsp[-1].ftype.new_type_flag; ; break;} case 372: -#line 1725 "parse.y" +#line 1780 "parse.y" { yyval.ftype.t = build_decl_list (yyvsp[0].ftype.t, NULL_TREE); yyval.ftype.new_type_flag = yyvsp[0].ftype.new_type_flag; ; break;} case 373: -#line 1728 "parse.y" +#line 1783 "parse.y" { yyval.ftype.t = build_decl_list (yyvsp[0].ftype.t, NULL_TREE); yyval.ftype.new_type_flag = yyvsp[0].ftype.new_type_flag; ; break;} case 374: -#line 1739 "parse.y" +#line 1794 "parse.y" { yyval.ftype.lookups = type_lookups; ; break;} case 375: -#line 1741 "parse.y" +#line 1796 "parse.y" { yyval.ftype.lookups = type_lookups; ; break;} case 376: -#line 1746 "parse.y" +#line 1801 "parse.y" { yyval.ftype.t = decl_tree_cons (NULL_TREE, yyvsp[0].ftype.t, yyvsp[-1].ftype.t); yyval.ftype.new_type_flag = yyvsp[0].ftype.new_type_flag; ; break;} case 377: -#line 1749 "parse.y" +#line 1804 "parse.y" { yyval.ftype.t = decl_tree_cons (NULL_TREE, yyvsp[-1].ftype.t, yyvsp[0].ttype); yyval.ftype.new_type_flag = yyvsp[-1].ftype.new_type_flag; ; break;} case 378: -#line 1752 "parse.y" +#line 1807 "parse.y" { yyval.ftype.t = decl_tree_cons (NULL_TREE, yyvsp[-2].ftype.t, chainon (yyvsp[-1].ttype, yyvsp[0].ttype)); yyval.ftype.new_type_flag = yyvsp[-2].ftype.new_type_flag; ; break;} case 379: -#line 1755 "parse.y" +#line 1810 "parse.y" { yyval.ftype.t = decl_tree_cons (NULL_TREE, yyvsp[-1].ftype.t, chainon (yyvsp[0].ttype, yyvsp[-2].ftype.t)); yyval.ftype.new_type_flag = yyvsp[-1].ftype.new_type_flag; ; break;} case 380: -#line 1758 "parse.y" +#line 1813 "parse.y" { yyval.ftype.t = decl_tree_cons (NULL_TREE, yyvsp[-1].ftype.t, chainon (yyvsp[0].ttype, yyvsp[-2].ftype.t)); yyval.ftype.new_type_flag = yyvsp[-1].ftype.new_type_flag; ; break;} case 381: -#line 1761 "parse.y" +#line 1816 "parse.y" { yyval.ftype.t = decl_tree_cons (NULL_TREE, yyvsp[-2].ftype.t, chainon (yyvsp[-1].ttype, chainon (yyvsp[0].ttype, yyvsp[-3].ftype.t))); yyval.ftype.new_type_flag = yyvsp[-2].ftype.new_type_flag; ; break;} case 382: -#line 1768 "parse.y" +#line 1823 "parse.y" { if (extra_warnings) warning ("`%s' is not at beginning of declaration", IDENTIFIER_POINTER (yyval.ttype)); yyval.ttype = build_decl_list (NULL_TREE, yyval.ttype); ; break;} case 383: -#line 1773 "parse.y" +#line 1828 "parse.y" { yyval.ttype = decl_tree_cons (NULL_TREE, yyvsp[0].ftype.t, yyval.ttype); ; break;} case 384: -#line 1775 "parse.y" +#line 1830 "parse.y" { if (extra_warnings) warning ("`%s' is not at beginning of declaration", IDENTIFIER_POINTER (yyvsp[0].ttype)); yyval.ttype = decl_tree_cons (NULL_TREE, yyvsp[0].ttype, yyval.ttype); ; break;} case 385: -#line 1780 "parse.y" +#line 1835 "parse.y" { yyval.ttype = decl_tree_cons (yyvsp[0].ttype, NULL_TREE, yyvsp[-1].ttype); ; break;} case 386: -#line 1782 "parse.y" +#line 1837 "parse.y" { yyval.ttype = decl_tree_cons (yyvsp[0].ttype, NULL_TREE, NULL_TREE); ; break;} case 387: -#line 1801 "parse.y" +#line 1856 "parse.y" { yyval.ftype.lookups = NULL_TREE; TREE_STATIC (yyval.ftype.t) = 1; ; break;} case 388: -#line 1803 "parse.y" +#line 1858 "parse.y" { yyval.ftype.t = hash_tree_cons (NULL_TREE, yyvsp[0].ttype, NULL_TREE); yyval.ftype.new_type_flag = 0; yyval.ftype.lookups = NULL_TREE; ; break;} case 389: -#line 1808 "parse.y" +#line 1863 "parse.y" { yyval.ftype.t = hash_tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ftype.t); TREE_STATIC (yyval.ftype.t) = 1; ; break;} case 390: -#line 1813 "parse.y" +#line 1868 "parse.y" { if (extra_warnings && TREE_STATIC (yyval.ftype.t)) warning ("`%s' is not at beginning of declaration", @@ -6131,68 +6191,68 @@ case 390: ; break;} case 391: -#line 1821 "parse.y" +#line 1876 "parse.y" { yyval.ftype.t = hash_tree_cons (yyvsp[0].ttype, NULL_TREE, yyvsp[-1].ftype.t); ; break;} case 392: -#line 1823 "parse.y" +#line 1878 "parse.y" { yyval.ftype.t = hash_tree_cons (yyvsp[0].ttype, NULL_TREE, NULL_TREE); yyval.ftype.new_type_flag = 0; yyval.ftype.lookups = NULL_TREE; ; break;} case 393: -#line 1837 "parse.y" +#line 1892 "parse.y" { yyval.ftype.t = build_decl_list (NULL_TREE, yyvsp[0].ftype.t); yyval.ftype.new_type_flag = yyvsp[0].ftype.new_type_flag; ; break;} case 394: -#line 1840 "parse.y" +#line 1895 "parse.y" { yyval.ftype.t = decl_tree_cons (NULL_TREE, yyvsp[0].ftype.t, yyvsp[-1].ftype.t); yyval.ftype.new_type_flag = yyvsp[0].ftype.new_type_flag; ; break;} case 395: -#line 1843 "parse.y" +#line 1898 "parse.y" { yyval.ftype.t = decl_tree_cons (NULL_TREE, yyvsp[-1].ftype.t, yyvsp[0].ttype); yyval.ftype.new_type_flag = yyvsp[-1].ftype.new_type_flag; ; break;} case 396: -#line 1846 "parse.y" +#line 1901 "parse.y" { yyval.ftype.t = decl_tree_cons (NULL_TREE, yyvsp[-1].ftype.t, chainon (yyvsp[0].ttype, yyvsp[-2].ftype.t)); yyval.ftype.new_type_flag = yyvsp[-1].ftype.new_type_flag; ; break;} case 397: -#line 1852 "parse.y" +#line 1907 "parse.y" { yyval.ttype = build_decl_list (NULL_TREE, yyvsp[0].ftype.t); ; break;} case 398: -#line 1854 "parse.y" +#line 1909 "parse.y" { yyval.ttype = decl_tree_cons (NULL_TREE, yyvsp[0].ftype.t, yyvsp[-1].ttype); ; break;} case 399: -#line 1863 "parse.y" +#line 1918 "parse.y" { yyval.ftype.lookups = NULL_TREE; ; break;} case 400: -#line 1865 "parse.y" +#line 1920 "parse.y" { yyval.ftype.t = yyvsp[0].ttype; yyval.ftype.new_type_flag = 0; yyval.ftype.lookups = NULL_TREE; ; break;} case 401: -#line 1867 "parse.y" +#line 1922 "parse.y" { yyval.ftype.t = yyvsp[0].ttype; yyval.ftype.new_type_flag = 0; yyval.ftype.lookups = NULL_TREE; ; break;} case 402: -#line 1869 "parse.y" +#line 1924 "parse.y" { yyval.ftype.t = finish_typeof (yyvsp[-1].ttype); yyval.ftype.new_type_flag = 0; yyval.ftype.lookups = NULL_TREE; ; break;} case 403: -#line 1872 "parse.y" +#line 1927 "parse.y" { yyval.ftype.t = groktypename (yyvsp[-1].ftype.t); yyval.ftype.new_type_flag = 0; yyval.ftype.lookups = NULL_TREE; ; break;} case 404: -#line 1875 "parse.y" +#line 1930 "parse.y" { tree type = TREE_TYPE (yyvsp[-1].ttype); yyval.ftype.new_type_flag = 0; yyval.ftype.lookups = NULL_TREE; @@ -6209,7 +6269,7 @@ case 404: ; break;} case 405: -#line 1890 "parse.y" +#line 1945 "parse.y" { tree type = groktypename (yyvsp[-1].ftype.t); yyval.ftype.new_type_flag = 0; yyval.ftype.lookups = NULL_TREE; @@ -6226,279 +6286,278 @@ case 405: ; break;} case 406: -#line 1910 "parse.y" +#line 1965 "parse.y" { yyval.ftype.t = yyvsp[0].ttype; yyval.ftype.new_type_flag = 0; ; break;} case 407: -#line 1912 "parse.y" +#line 1967 "parse.y" { yyval.ftype.t = yyvsp[0].ttype; yyval.ftype.new_type_flag = 0; ; break;} case 410: -#line 1919 "parse.y" +#line 1974 "parse.y" { check_multiple_declarators (); ; break;} case 412: -#line 1925 "parse.y" +#line 1980 "parse.y" { check_multiple_declarators (); ; break;} case 414: -#line 1931 "parse.y" +#line 1986 "parse.y" { check_multiple_declarators (); ; break;} case 415: -#line 1936 "parse.y" +#line 1991 "parse.y" { yyval.ttype = NULL_TREE; ; break;} case 416: -#line 1938 "parse.y" +#line 1993 "parse.y" { if (TREE_CHAIN (yyvsp[-1].ttype)) yyvsp[-1].ttype = combine_strings (yyvsp[-1].ttype); yyval.ttype = yyvsp[-1].ttype; ; break;} case 417: -#line 1943 "parse.y" +#line 1998 "parse.y" { yyval.ttype = parse_decl (yyvsp[-3].ttype, yyvsp[-1].ttype, 1); ; break;} case 418: -#line 1946 "parse.y" +#line 2001 "parse.y" { parse_end_decl (yyvsp[-1].ttype, yyvsp[0].ttype, yyvsp[-4].ttype); ; break;} case 419: -#line 1948 "parse.y" +#line 2003 "parse.y" { yyval.ttype = parse_decl (yyvsp[-2].ttype, yyvsp[0].ttype, 0); parse_end_decl (yyval.ttype, NULL_TREE, yyvsp[-1].ttype); ; break;} case 420: -#line 1962 "parse.y" +#line 2017 "parse.y" { yyval.ttype = parse_decl0 (yyvsp[-3].ttype, yyvsp[-4].ftype.t, yyvsp[-4].ftype.lookups, yyvsp[-1].ttype, 1); ; break;} case 421: -#line 1967 "parse.y" +#line 2022 "parse.y" { parse_end_decl (yyvsp[-1].ttype, yyvsp[0].ttype, yyvsp[-4].ttype); ; break;} case 422: -#line 1969 "parse.y" +#line 2024 "parse.y" { tree d = parse_decl0 (yyvsp[-2].ttype, yyvsp[-3].ftype.t, yyvsp[-3].ftype.lookups, yyvsp[0].ttype, 0); parse_end_decl (d, NULL_TREE, yyvsp[-1].ttype); ; break;} case 423: -#line 1976 "parse.y" +#line 2031 "parse.y" {; break;} case 424: -#line 1981 "parse.y" +#line 2036 "parse.y" {; break;} case 425: -#line 1986 "parse.y" +#line 2041 "parse.y" { /* Set things up as initdcl0_innards expects. */ yyvsp[0].ttype = yyvsp[-1].ttype; yyvsp[-1].ttype = NULL_TREE; ; break;} case 426: -#line 1990 "parse.y" +#line 2045 "parse.y" {; break;} case 427: -#line 1992 "parse.y" +#line 2047 "parse.y" { tree d = parse_decl0 (yyvsp[-2].ttype, NULL_TREE, NULL_TREE, yyvsp[0].ttype, 0); parse_end_decl (d, NULL_TREE, yyvsp[-1].ttype); ; break;} case 428: -#line 2000 "parse.y" +#line 2055 "parse.y" { yyval.ttype = NULL_TREE; ; break;} case 429: -#line 2002 "parse.y" +#line 2057 "parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 430: -#line 2007 "parse.y" +#line 2062 "parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 431: -#line 2009 "parse.y" +#line 2064 "parse.y" { yyval.ttype = chainon (yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 432: -#line 2014 "parse.y" +#line 2069 "parse.y" { yyval.ttype = yyvsp[-2].ttype; ; break;} case 433: -#line 2019 "parse.y" +#line 2074 "parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 434: -#line 2021 "parse.y" +#line 2076 "parse.y" { yyval.ttype = chainon (yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 435: -#line 2026 "parse.y" +#line 2081 "parse.y" { yyval.ttype = NULL_TREE; ; break;} case 436: -#line 2028 "parse.y" +#line 2083 "parse.y" { yyval.ttype = build_tree_list (yyvsp[0].ttype, NULL_TREE); ; break;} case 437: -#line 2030 "parse.y" +#line 2085 "parse.y" { yyval.ttype = build_tree_list (yyvsp[-3].ttype, build_tree_list (NULL_TREE, yyvsp[-1].ttype)); ; break;} case 438: -#line 2032 "parse.y" +#line 2087 "parse.y" { yyval.ttype = build_tree_list (yyvsp[-5].ttype, tree_cons (NULL_TREE, yyvsp[-3].ttype, yyvsp[-1].ttype)); ; break;} case 439: -#line 2034 "parse.y" +#line 2089 "parse.y" { yyval.ttype = build_tree_list (yyvsp[-3].ttype, yyvsp[-1].ttype); ; break;} case 444: -#line 2050 "parse.y" +#line 2105 "parse.y" { yyval.ttype = build_tree_list (NULL_TREE, yyvsp[0].ttype); ; break;} case 445: -#line 2052 "parse.y" +#line 2107 "parse.y" { yyval.ttype = chainon (yyvsp[-2].ttype, build_tree_list (NULL_TREE, yyvsp[0].ttype)); ; break;} case 446: -#line 2057 "parse.y" +#line 2112 "parse.y" { yyval.ttype = NULL_TREE; ; break;} case 447: -#line 2059 "parse.y" +#line 2114 "parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 449: -#line 2067 "parse.y" +#line 2122 "parse.y" { yyval.ttype = build_nt (CONSTRUCTOR, NULL_TREE, NULL_TREE); TREE_HAS_CONSTRUCTOR (yyval.ttype) = 1; ; break;} case 450: -#line 2070 "parse.y" +#line 2125 "parse.y" { yyval.ttype = build_nt (CONSTRUCTOR, NULL_TREE, nreverse (yyvsp[-1].ttype)); TREE_HAS_CONSTRUCTOR (yyval.ttype) = 1; ; break;} case 451: -#line 2073 "parse.y" +#line 2128 "parse.y" { yyval.ttype = build_nt (CONSTRUCTOR, NULL_TREE, nreverse (yyvsp[-2].ttype)); TREE_HAS_CONSTRUCTOR (yyval.ttype) = 1; ; break;} case 452: -#line 2076 "parse.y" +#line 2131 "parse.y" { yyval.ttype = NULL_TREE; ; break;} case 453: -#line 2083 "parse.y" +#line 2138 "parse.y" { yyval.ttype = build_tree_list (NULL_TREE, yyval.ttype); ; break;} case 454: -#line 2085 "parse.y" +#line 2140 "parse.y" { yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyval.ttype); ; break;} case 455: -#line 2088 "parse.y" +#line 2143 "parse.y" { yyval.ttype = build_tree_list (yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 456: -#line 2090 "parse.y" +#line 2145 "parse.y" { yyval.ttype = build_tree_list (yyval.ttype, yyvsp[0].ttype); ; break;} case 457: -#line 2092 "parse.y" +#line 2147 "parse.y" { yyval.ttype = tree_cons (yyvsp[-2].ttype, yyvsp[0].ttype, yyval.ttype); ; break;} case 458: -#line 2097 "parse.y" +#line 2152 "parse.y" { start_function (NULL_TREE, yyvsp[0].pi->fndecl, NULL_TREE, (SF_DEFAULT | SF_PRE_PARSED - | SF_INCLASS_INLINE)); - reinit_parse_for_function (); ; + | SF_INCLASS_INLINE)); ; break;} case 459: -#line 2104 "parse.y" +#line 2158 "parse.y" { expand_body (finish_function ((int)yyvsp[-1].itype | 2)); process_next_inline (yyvsp[-3].pi); ; break;} case 460: -#line 2109 "parse.y" +#line 2163 "parse.y" { expand_body (finish_function ((int)yyvsp[0].itype | 2)); process_next_inline (yyvsp[-2].pi); ; break;} case 461: -#line 2114 "parse.y" +#line 2168 "parse.y" { finish_function (2); process_next_inline (yyvsp[-2].pi); ; break;} case 464: -#line 2128 "parse.y" +#line 2182 "parse.y" { replace_defarg (yyvsp[-2].ttype, yyvsp[-1].ttype); ; break;} case 465: -#line 2130 "parse.y" +#line 2184 "parse.y" { replace_defarg (yyvsp[-2].ttype, error_mark_node); ; break;} case 467: -#line 2135 "parse.y" +#line 2189 "parse.y" { do_pending_defargs (); ; break;} case 468: -#line 2137 "parse.y" +#line 2191 "parse.y" { do_pending_defargs (); ; break;} case 469: -#line 2142 "parse.y" +#line 2196 "parse.y" { yyval.ttype = current_enum_type; current_enum_type = start_enum (yyvsp[-1].ttype); ; break;} case 470: -#line 2145 "parse.y" +#line 2199 "parse.y" { yyval.ftype.t = finish_enum (current_enum_type); yyval.ftype.new_type_flag = 1; current_enum_type = yyvsp[-2].ttype; check_for_missing_semicolon (yyval.ftype.t); ; break;} case 471: -#line 2150 "parse.y" +#line 2204 "parse.y" { yyval.ttype = current_enum_type; current_enum_type = start_enum (make_anon_name ()); ; break;} case 472: -#line 2153 "parse.y" +#line 2207 "parse.y" { yyval.ftype.t = finish_enum (current_enum_type); yyval.ftype.new_type_flag = 1; current_enum_type = yyvsp[-2].ttype; check_for_missing_semicolon (yyval.ftype.t); ; break;} case 473: -#line 2158 "parse.y" +#line 2212 "parse.y" { yyval.ftype.t = xref_tag (enum_type_node, yyvsp[0].ttype, 1); yyval.ftype.new_type_flag = 0; ; break;} case 474: -#line 2161 "parse.y" +#line 2215 "parse.y" { yyval.ftype.t = xref_tag (enum_type_node, yyvsp[0].ttype, 1); yyval.ftype.new_type_flag = 0; ; break;} case 475: -#line 2164 "parse.y" +#line 2218 "parse.y" { yyval.ftype.t = yyvsp[0].ttype; yyval.ftype.new_type_flag = 0; if (!processing_template_decl) cp_pedwarn ("using `typename' outside of template"); ; break;} case 476: -#line 2170 "parse.y" +#line 2224 "parse.y" { yyvsp[-1].ftype.t = begin_class_definition (yyvsp[-1].ftype.t); ; break;} case 477: -#line 2172 "parse.y" +#line 2226 "parse.y" { int semi; @@ -6511,13 +6570,13 @@ case 477: ; break;} case 478: -#line 2183 "parse.y" +#line 2237 "parse.y" { begin_inline_definitions (); ; break;} case 479: -#line 2187 "parse.y" +#line 2241 "parse.y" { finish_inline_definitions (); yyval.ftype.t = yyvsp[-3].ttype; @@ -6525,7 +6584,7 @@ case 479: ; break;} case 480: -#line 2193 "parse.y" +#line 2247 "parse.y" { if (yyvsp[0].ftype.new_type_flag && yyvsp[0].ftype.t != error_mark_node) pop_scope (CP_DECL_CONTEXT (TYPE_MAIN_DECL (yyvsp[0].ftype.t))); @@ -6551,51 +6610,51 @@ case 480: ; break;} case 484: -#line 2226 "parse.y" +#line 2280 "parse.y" { if (pedantic && !in_system_header) pedwarn ("comma at end of enumerator list"); ; break;} case 486: -#line 2233 "parse.y" +#line 2287 "parse.y" { error ("storage class specifier `%s' not allowed after struct or class", IDENTIFIER_POINTER (yyvsp[0].ttype)); ; break;} case 487: -#line 2235 "parse.y" +#line 2289 "parse.y" { error ("type specifier `%s' not allowed after struct or class", IDENTIFIER_POINTER (yyvsp[0].ttype)); ; break;} case 488: -#line 2237 "parse.y" +#line 2291 "parse.y" { error ("type qualifier `%s' not allowed after struct or class", IDENTIFIER_POINTER (yyvsp[0].ttype)); ; break;} case 489: -#line 2239 "parse.y" +#line 2293 "parse.y" { error ("no body nor ';' separates two class, struct or union declarations"); ; break;} case 490: -#line 2241 "parse.y" +#line 2295 "parse.y" { yyval.ttype = build_decl_list (yyvsp[0].ttype, yyvsp[-1].ttype); ; break;} case 491: -#line 2246 "parse.y" +#line 2300 "parse.y" { current_aggr = yyvsp[-1].ttype; yyval.ttype = yyvsp[0].ttype; ; break;} case 492: -#line 2254 "parse.y" +#line 2308 "parse.y" { current_aggr = yyval.ttype; yyval.ttype = yyvsp[0].ttype; ; break;} case 493: -#line 2256 "parse.y" +#line 2310 "parse.y" { yyungetc ('{', 1); ; break;} case 494: -#line 2258 "parse.y" +#line 2312 "parse.y" { yyungetc (':', 1); ; break;} case 495: -#line 2263 "parse.y" +#line 2317 "parse.y" { current_aggr = yyvsp[-2].ttype; yyval.ftype.t = handle_class_head (yyvsp[-2].ttype, yyvsp[-1].ttype, yyvsp[0].ttype); @@ -6603,7 +6662,7 @@ case 495: ; break;} case 496: -#line 2269 "parse.y" +#line 2323 "parse.y" { current_aggr = yyvsp[-3].ttype; yyval.ftype.t = handle_class_head (yyvsp[-3].ttype, yyvsp[-1].ttype, yyvsp[0].ttype); @@ -6611,7 +6670,7 @@ case 496: ; break;} case 497: -#line 2275 "parse.y" +#line 2329 "parse.y" { current_aggr = yyvsp[-2].ttype; yyval.ftype.t = handle_class_head (yyvsp[-2].ttype, NULL_TREE, yyvsp[0].ttype); @@ -6619,7 +6678,7 @@ case 497: ; break;} case 498: -#line 2281 "parse.y" +#line 2335 "parse.y" { current_aggr = yyvsp[-1].ttype; yyval.ftype.t = yyvsp[0].ttype; @@ -6627,7 +6686,7 @@ case 498: ; break;} case 499: -#line 2287 "parse.y" +#line 2341 "parse.y" { current_aggr = yyvsp[-2].ttype; yyval.ftype.t = yyvsp[0].ttype; @@ -6637,18 +6696,18 @@ case 499: ; break;} case 500: -#line 2298 "parse.y" +#line 2352 "parse.y" { yyval.ftype.t = xref_tag (current_aggr, yyvsp[0].ttype, 1); yyval.ftype.new_type_flag = 0; ; break;} case 501: -#line 2303 "parse.y" +#line 2357 "parse.y" { yyval.ttype = xref_tag (current_aggr, yyvsp[0].ttype, 0); ; break;} case 502: -#line 2307 "parse.y" +#line 2361 "parse.y" { yyval.ftype.t = yyvsp[-1].ttype; yyval.ftype.new_type_flag = 0; @@ -6657,7 +6716,7 @@ case 502: ; break;} case 503: -#line 2315 "parse.y" +#line 2369 "parse.y" { if (yyvsp[-1].ftype.t != error_mark_node) { @@ -6684,43 +6743,43 @@ case 503: ; break;} case 504: -#line 2343 "parse.y" +#line 2397 "parse.y" { yyval.ttype = xref_tag (yyval.ttype, make_anon_name (), 0); yyungetc ('{', 1); ; break;} case 505: -#line 2353 "parse.y" +#line 2407 "parse.y" { yyval.ftype.t = yyvsp[0].ttype; yyval.ftype.new_type_flag = 0; ; break;} case 507: -#line 2362 "parse.y" +#line 2416 "parse.y" { yyval.ttype = NULL_TREE; ; break;} case 508: -#line 2364 "parse.y" +#line 2418 "parse.y" { yyungetc(':', 1); yyval.ttype = NULL_TREE; ; break;} case 509: -#line 2366 "parse.y" +#line 2420 "parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 511: -#line 2372 "parse.y" +#line 2426 "parse.y" { yyval.ttype = chainon (yyval.ttype, yyvsp[0].ttype); ; break;} case 512: -#line 2377 "parse.y" +#line 2431 "parse.y" { yyval.ttype = finish_base_specifier (access_default_node, yyvsp[0].ttype); ; break;} case 513: -#line 2379 "parse.y" +#line 2433 "parse.y" { yyval.ttype = finish_base_specifier (yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 514: -#line 2384 "parse.y" +#line 2438 "parse.y" { if (yyval.ttype == error_mark_node) ; else if (!TYPE_P (yyval.ttype)) @@ -6729,13 +6788,13 @@ case 514: yyval.ttype = TYPE_MAIN_DECL (yyvsp[0].ttype); ; break;} case 517: -#line 2396 "parse.y" +#line 2450 "parse.y" { if (yyvsp[-1].ttype != ridpointers[(int)RID_VIRTUAL]) cp_error ("`%D' access", yyvsp[-1].ttype); yyval.ttype = access_default_virtual_node; ; break;} case 518: -#line 2400 "parse.y" +#line 2454 "parse.y" { if (yyvsp[-2].ttype != access_default_virtual_node) error ("multiple access specifiers"); @@ -6748,7 +6807,7 @@ case 518: ; break;} case 519: -#line 2411 "parse.y" +#line 2465 "parse.y" { if (yyvsp[-1].ttype != ridpointers[(int)RID_VIRTUAL]) cp_error ("`%D' access", yyvsp[-1].ttype); else if (yyval.ttype == access_public_node) @@ -6762,55 +6821,55 @@ case 519: ; break;} case 524: -#line 2432 "parse.y" +#line 2486 "parse.y" { current_access_specifier = yyvsp[-1].ttype; ; break;} case 525: -#line 2441 "parse.y" +#line 2495 "parse.y" { finish_member_declaration (yyvsp[0].ttype); ; break;} case 526: -#line 2445 "parse.y" +#line 2499 "parse.y" { finish_member_declaration (yyvsp[0].ttype); ; break;} case 528: -#line 2453 "parse.y" +#line 2507 "parse.y" { error ("missing ';' before right brace"); yyungetc ('}', 0); ; break;} case 529: -#line 2458 "parse.y" +#line 2512 "parse.y" { yyval.ttype = finish_method (yyval.ttype); ; break;} case 530: -#line 2460 "parse.y" +#line 2514 "parse.y" { yyval.ttype = finish_method (yyval.ttype); ; break;} case 531: -#line 2462 "parse.y" +#line 2516 "parse.y" { yyval.ttype = finish_method (yyval.ttype); ; break;} case 532: -#line 2464 "parse.y" +#line 2518 "parse.y" { yyval.ttype = finish_method (yyval.ttype); ; break;} case 533: -#line 2466 "parse.y" +#line 2520 "parse.y" { yyval.ttype = NULL_TREE; ; break;} case 534: -#line 2468 "parse.y" +#line 2522 "parse.y" { yyval.ttype = yyvsp[0].ttype; pedantic = yyvsp[-1].itype; ; break;} case 535: -#line 2471 "parse.y" +#line 2525 "parse.y" { if (yyvsp[0].ttype) yyval.ttype = finish_member_template_decl (yyvsp[0].ttype); @@ -6822,14 +6881,14 @@ case 535: ; break;} case 536: -#line 2481 "parse.y" +#line 2535 "parse.y" { yyval.ttype = finish_member_class_template (yyvsp[-1].ftype.t); finish_template_decl (yyvsp[-2].ttype); ; break;} case 537: -#line 2492 "parse.y" +#line 2546 "parse.y" { /* Most of the productions for component_decl only allow the creation of one new member, so we call @@ -6852,7 +6911,7 @@ case 537: ; break;} case 538: -#line 2513 "parse.y" +#line 2567 "parse.y" { if (!yyvsp[0].itype) grok_x_components (yyvsp[-1].ftype.t); @@ -6860,45 +6919,45 @@ case 538: ; break;} case 539: -#line 2519 "parse.y" +#line 2573 "parse.y" { yyval.ttype = grokfield (yyval.ttype, NULL_TREE, yyvsp[0].ttype, yyvsp[-2].ttype, build_tree_list (yyvsp[-1].ttype, NULL_TREE)); ; break;} case 540: -#line 2522 "parse.y" +#line 2576 "parse.y" { yyval.ttype = grokfield (yyval.ttype, NULL_TREE, yyvsp[0].ttype, yyvsp[-2].ttype, build_tree_list (yyvsp[-1].ttype, NULL_TREE)); ; break;} case 541: -#line 2525 "parse.y" +#line 2579 "parse.y" { yyval.ttype = grokbitfield (NULL_TREE, NULL_TREE, yyvsp[0].ttype); ; break;} case 542: -#line 2527 "parse.y" +#line 2581 "parse.y" { yyval.ttype = NULL_TREE; ; break;} case 543: -#line 2538 "parse.y" +#line 2592 "parse.y" { tree specs, attrs; split_specs_attrs (yyvsp[-4].ftype.t, &specs, &attrs); yyval.ttype = grokfield (yyvsp[-3].ttype, specs, yyvsp[0].ttype, yyvsp[-2].ttype, build_tree_list (yyvsp[-1].ttype, attrs)); ; break;} case 544: -#line 2543 "parse.y" +#line 2597 "parse.y" { yyval.ttype = grokfield (yyval.ttype, NULL_TREE, yyvsp[0].ttype, yyvsp[-2].ttype, build_tree_list (yyvsp[-1].ttype, NULL_TREE)); ; break;} case 545: -#line 2546 "parse.y" +#line 2600 "parse.y" { yyval.ttype = do_class_using_decl (yyvsp[0].ttype); ; break;} case 546: -#line 2552 "parse.y" +#line 2606 "parse.y" { yyval.itype = 0; ; break;} case 547: -#line 2554 "parse.y" +#line 2608 "parse.y" { if (PROCESSING_REAL_TEMPLATE_DECL_P ()) yyvsp[0].ttype = finish_member_template_decl (yyvsp[0].ttype); @@ -6907,7 +6966,7 @@ case 547: ; break;} case 548: -#line 2561 "parse.y" +#line 2615 "parse.y" { check_multiple_declarators (); if (PROCESSING_REAL_TEMPLATE_DECL_P ()) @@ -6917,11 +6976,11 @@ case 548: ; break;} case 549: -#line 2572 "parse.y" +#line 2626 "parse.y" { yyval.itype = 0; ; break;} case 550: -#line 2574 "parse.y" +#line 2628 "parse.y" { if (PROCESSING_REAL_TEMPLATE_DECL_P ()) yyvsp[0].ttype = finish_member_template_decl (yyvsp[0].ttype); @@ -6930,7 +6989,7 @@ case 550: ; break;} case 551: -#line 2581 "parse.y" +#line 2635 "parse.y" { check_multiple_declarators (); if (PROCESSING_REAL_TEMPLATE_DECL_P ()) @@ -6940,75 +6999,75 @@ case 551: ; break;} case 556: -#line 2602 "parse.y" +#line 2656 "parse.y" { yyval.ttype = parse_field0 (yyvsp[-3].ttype, yyvsp[-4].ftype.t, yyvsp[-4].ftype.lookups, yyvsp[-1].ttype, yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 557: -#line 2605 "parse.y" +#line 2659 "parse.y" { yyval.ttype = parse_bitfield0 (yyvsp[-3].ttype, yyvsp[-4].ftype.t, yyvsp[-4].ftype.lookups, yyvsp[0].ttype, yyvsp[-1].ttype); ; break;} case 558: -#line 2611 "parse.y" +#line 2665 "parse.y" { yyval.ttype = parse_field0 (yyvsp[-3].ttype, yyvsp[-4].ftype.t, yyvsp[-4].ftype.lookups, yyvsp[-1].ttype, yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 559: -#line 2614 "parse.y" +#line 2668 "parse.y" { yyval.ttype = parse_field0 (yyvsp[-3].ttype, yyvsp[-4].ftype.t, yyvsp[-4].ftype.lookups, yyvsp[-1].ttype, yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 560: -#line 2617 "parse.y" +#line 2671 "parse.y" { yyval.ttype = parse_bitfield0 (yyvsp[-3].ttype, yyvsp[-4].ftype.t, yyvsp[-4].ftype.lookups, yyvsp[0].ttype, yyvsp[-1].ttype); ; break;} case 561: -#line 2620 "parse.y" +#line 2674 "parse.y" { yyval.ttype = parse_bitfield0 (NULL_TREE, yyvsp[-3].ftype.t, yyvsp[-3].ftype.lookups, yyvsp[0].ttype, yyvsp[-1].ttype); ; break;} case 562: -#line 2626 "parse.y" +#line 2680 "parse.y" { yyval.ttype = parse_field (yyvsp[-3].ttype, yyvsp[-1].ttype, yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 563: -#line 2628 "parse.y" +#line 2682 "parse.y" { yyval.ttype = parse_bitfield (yyvsp[-3].ttype, yyvsp[0].ttype, yyvsp[-1].ttype); ; break;} case 564: -#line 2633 "parse.y" +#line 2687 "parse.y" { yyval.ttype = parse_field (yyvsp[-3].ttype, yyvsp[-1].ttype, yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 565: -#line 2635 "parse.y" +#line 2689 "parse.y" { yyval.ttype = parse_bitfield (yyvsp[-3].ttype, yyvsp[0].ttype, yyvsp[-1].ttype); ; break;} case 566: -#line 2637 "parse.y" +#line 2691 "parse.y" { yyval.ttype = parse_bitfield (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ttype); ; break;} case 571: -#line 2656 "parse.y" +#line 2710 "parse.y" { build_enumerator (yyvsp[0].ttype, NULL_TREE, current_enum_type); ; break;} case 572: -#line 2658 "parse.y" +#line 2712 "parse.y" { build_enumerator (yyvsp[-2].ttype, yyvsp[0].ttype, current_enum_type); ; break;} case 573: -#line 2664 "parse.y" +#line 2718 "parse.y" { yyval.ftype.t = build_decl_list (yyvsp[-1].ftype.t, yyvsp[0].ttype); yyval.ftype.new_type_flag = yyvsp[-1].ftype.new_type_flag; ; break;} case 574: -#line 2667 "parse.y" +#line 2721 "parse.y" { yyval.ftype.t = build_decl_list (yyvsp[0].ftype.t, NULL_TREE); yyval.ftype.new_type_flag = yyvsp[0].ftype.new_type_flag; ; break;} case 575: -#line 2672 "parse.y" +#line 2726 "parse.y" { if (pedantic) pedwarn ("ISO C++ forbids array dimensions with parenthesized type in new"); @@ -7018,41 +7077,41 @@ case 575: ; break;} case 576: -#line 2683 "parse.y" +#line 2737 "parse.y" { yyval.ttype = NULL_TREE; ; break;} case 577: -#line 2685 "parse.y" +#line 2739 "parse.y" { yyval.ttype = decl_tree_cons (NULL_TREE, yyvsp[0].ttype, yyval.ttype); ; break;} case 578: -#line 2690 "parse.y" +#line 2744 "parse.y" { yyval.ftype.t = hash_tree_cons (NULL_TREE, yyvsp[0].ttype, NULL_TREE); yyval.ftype.new_type_flag = 0; ; break;} case 579: -#line 2693 "parse.y" +#line 2747 "parse.y" { yyval.ftype.t = hash_tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ftype.t); yyval.ftype.new_type_flag = yyvsp[-1].ftype.new_type_flag; ; break;} case 580: -#line 2703 "parse.y" +#line 2757 "parse.y" { yyval.ttype = yyvsp[-1].ttype; ; break;} case 581: -#line 2705 "parse.y" +#line 2759 "parse.y" { yyval.ttype = yyvsp[-1].ttype; ; break;} case 582: -#line 2707 "parse.y" +#line 2761 "parse.y" { yyval.ttype = empty_parms (); ; break;} case 583: -#line 2709 "parse.y" +#line 2763 "parse.y" { yyval.ttype = NULL_TREE; ; break;} case 585: -#line 2717 "parse.y" +#line 2771 "parse.y" { /* Provide support for '(' attributes '*' declarator ')' etc */ @@ -7060,51 +7119,51 @@ case 585: ; break;} case 586: -#line 2727 "parse.y" +#line 2781 "parse.y" { yyval.ttype = make_pointer_declarator (yyvsp[-1].ftype.t, yyvsp[0].ttype); ; break;} case 587: -#line 2729 "parse.y" +#line 2783 "parse.y" { yyval.ttype = make_reference_declarator (yyvsp[-1].ftype.t, yyvsp[0].ttype); ; break;} case 588: -#line 2731 "parse.y" +#line 2785 "parse.y" { yyval.ttype = make_pointer_declarator (NULL_TREE, yyvsp[0].ttype); ; break;} case 589: -#line 2733 "parse.y" +#line 2787 "parse.y" { yyval.ttype = make_reference_declarator (NULL_TREE, yyvsp[0].ttype); ; break;} case 590: -#line 2735 "parse.y" +#line 2789 "parse.y" { tree arg = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); yyval.ttype = build_parse_node (SCOPE_REF, yyvsp[-2].ttype, arg); ; break;} case 592: -#line 2743 "parse.y" +#line 2797 "parse.y" { yyval.ttype = make_call_declarator (yyval.ttype, yyvsp[-2].ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 593: -#line 2745 "parse.y" +#line 2799 "parse.y" { yyval.ttype = build_parse_node (ARRAY_REF, yyval.ttype, yyvsp[-1].ttype); ; break;} case 594: -#line 2747 "parse.y" +#line 2801 "parse.y" { yyval.ttype = build_parse_node (ARRAY_REF, yyval.ttype, NULL_TREE); ; break;} case 595: -#line 2749 "parse.y" +#line 2803 "parse.y" { yyval.ttype = yyvsp[-1].ttype; ; break;} case 596: -#line 2751 "parse.y" +#line 2805 "parse.y" { push_nested_class (yyvsp[-1].ttype, 3); yyval.ttype = build_parse_node (SCOPE_REF, yyval.ttype, yyvsp[0].ttype); TREE_COMPLEXITY (yyval.ttype) = current_class_depth; ; break;} case 598: -#line 2759 "parse.y" +#line 2813 "parse.y" { if (TREE_CODE (yyvsp[0].ttype) == IDENTIFIER_NODE) { @@ -7116,7 +7175,7 @@ case 598: ; break;} case 599: -#line 2769 "parse.y" +#line 2823 "parse.y" { if (TREE_CODE (yyvsp[0].ttype) == IDENTIFIER_NODE) yyval.ttype = IDENTIFIER_GLOBAL_VALUE (yyvsp[0].ttype); @@ -7126,15 +7185,15 @@ case 599: ; break;} case 602: -#line 2782 "parse.y" +#line 2836 "parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 603: -#line 2787 "parse.y" +#line 2841 "parse.y" { yyval.ttype = get_type_decl (yyvsp[0].ttype); ; break;} case 605: -#line 2796 "parse.y" +#line 2850 "parse.y" { /* Provide support for '(' attributes '*' declarator ')' etc */ @@ -7142,123 +7201,123 @@ case 605: ; break;} case 606: -#line 2805 "parse.y" +#line 2859 "parse.y" { yyval.ttype = make_pointer_declarator (yyvsp[-1].ftype.t, yyvsp[0].ttype); ; break;} case 607: -#line 2807 "parse.y" +#line 2861 "parse.y" { yyval.ttype = make_reference_declarator (yyvsp[-1].ftype.t, yyvsp[0].ttype); ; break;} case 608: -#line 2809 "parse.y" +#line 2863 "parse.y" { yyval.ttype = make_pointer_declarator (NULL_TREE, yyvsp[0].ttype); ; break;} case 609: -#line 2811 "parse.y" +#line 2865 "parse.y" { yyval.ttype = make_reference_declarator (NULL_TREE, yyvsp[0].ttype); ; break;} case 610: -#line 2813 "parse.y" +#line 2867 "parse.y" { tree arg = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); yyval.ttype = build_parse_node (SCOPE_REF, yyvsp[-2].ttype, arg); ; break;} case 612: -#line 2821 "parse.y" +#line 2875 "parse.y" { yyval.ttype = make_pointer_declarator (yyvsp[-1].ftype.t, yyvsp[0].ttype); ; break;} case 613: -#line 2823 "parse.y" +#line 2877 "parse.y" { yyval.ttype = make_reference_declarator (yyvsp[-1].ftype.t, yyvsp[0].ttype); ; break;} case 614: -#line 2825 "parse.y" +#line 2879 "parse.y" { yyval.ttype = make_pointer_declarator (NULL_TREE, yyvsp[0].ttype); ; break;} case 615: -#line 2827 "parse.y" +#line 2881 "parse.y" { yyval.ttype = make_reference_declarator (NULL_TREE, yyvsp[0].ttype); ; break;} case 616: -#line 2829 "parse.y" +#line 2883 "parse.y" { tree arg = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); yyval.ttype = build_parse_node (SCOPE_REF, yyvsp[-2].ttype, arg); ; break;} case 618: -#line 2837 "parse.y" +#line 2891 "parse.y" { yyval.ttype = make_call_declarator (yyval.ttype, yyvsp[-2].ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 619: -#line 2839 "parse.y" +#line 2893 "parse.y" { yyval.ttype = yyvsp[-1].ttype; ; break;} case 620: -#line 2841 "parse.y" +#line 2895 "parse.y" { yyval.ttype = build_parse_node (ARRAY_REF, yyval.ttype, yyvsp[-1].ttype); ; break;} case 621: -#line 2843 "parse.y" +#line 2897 "parse.y" { yyval.ttype = build_parse_node (ARRAY_REF, yyval.ttype, NULL_TREE); ; break;} case 622: -#line 2845 "parse.y" +#line 2899 "parse.y" { enter_scope_of (yyvsp[0].ttype); ; break;} case 623: -#line 2847 "parse.y" +#line 2901 "parse.y" { got_scope = NULL_TREE; yyval.ttype = build_parse_node (SCOPE_REF, yyvsp[-1].ttype, yyvsp[0].ttype); enter_scope_of (yyval.ttype); ; break;} case 624: -#line 2855 "parse.y" +#line 2909 "parse.y" { got_scope = NULL_TREE; yyval.ttype = build_parse_node (SCOPE_REF, yyval.ttype, yyvsp[0].ttype); ; break;} case 625: -#line 2858 "parse.y" +#line 2912 "parse.y" { got_scope = NULL_TREE; yyval.ttype = build_parse_node (SCOPE_REF, yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 626: -#line 2864 "parse.y" +#line 2918 "parse.y" { got_scope = NULL_TREE; yyval.ttype = build_parse_node (SCOPE_REF, yyval.ttype, yyvsp[0].ttype); ; break;} case 627: -#line 2867 "parse.y" +#line 2921 "parse.y" { got_scope = NULL_TREE; yyval.ttype = build_parse_node (SCOPE_REF, yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 629: -#line 2874 "parse.y" +#line 2928 "parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 630: -#line 2879 "parse.y" +#line 2933 "parse.y" { yyval.ttype = build_functional_cast (yyvsp[-3].ftype.t, yyvsp[-1].ttype); ; break;} case 631: -#line 2881 "parse.y" +#line 2935 "parse.y" { yyval.ttype = reparse_decl_as_expr (yyvsp[-3].ftype.t, yyvsp[-1].ttype); ; break;} case 632: -#line 2883 "parse.y" +#line 2937 "parse.y" { yyval.ttype = reparse_absdcl_as_expr (yyvsp[-1].ftype.t, yyvsp[0].ttype); ; break;} case 637: -#line 2895 "parse.y" +#line 2949 "parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 638: -#line 2897 "parse.y" +#line 2951 "parse.y" { got_scope = yyval.ttype = make_typename_type (yyvsp[-3].ttype, yyvsp[-1].ttype, /*complain=*/1); ; break;} case 639: -#line 2905 "parse.y" +#line 2959 "parse.y" { if (TREE_CODE (yyvsp[-1].ttype) == IDENTIFIER_NODE) { @@ -7270,7 +7329,7 @@ case 639: ; break;} case 640: -#line 2915 "parse.y" +#line 2969 "parse.y" { if (TREE_CODE (yyvsp[-1].ttype) == IDENTIFIER_NODE) yyval.ttype = lastiddecl; @@ -7278,7 +7337,7 @@ case 640: ; break;} case 641: -#line 2921 "parse.y" +#line 2975 "parse.y" { if (TREE_CODE (yyval.ttype) == IDENTIFIER_NODE) yyval.ttype = lastiddecl; @@ -7286,15 +7345,15 @@ case 641: ; break;} case 642: -#line 2927 "parse.y" +#line 2981 "parse.y" { got_scope = yyval.ttype = complete_type (TREE_TYPE (yyvsp[-1].ttype)); ; break;} case 644: -#line 2943 "parse.y" +#line 2997 "parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 645: -#line 2948 "parse.y" +#line 3002 "parse.y" { if (TYPE_P (yyvsp[-1].ttype)) yyval.ttype = make_typename_type (yyvsp[-1].ttype, yyvsp[0].ttype, /*complain=*/1); @@ -7309,26 +7368,26 @@ case 645: ; break;} case 646: -#line 2961 "parse.y" +#line 3015 "parse.y" { yyval.ttype = TREE_TYPE (yyvsp[0].ttype); ; break;} case 647: -#line 2963 "parse.y" +#line 3017 "parse.y" { yyval.ttype = make_typename_type (yyvsp[-1].ttype, yyvsp[0].ttype, /*complain=*/1); ; break;} case 648: -#line 2965 "parse.y" +#line 3019 "parse.y" { yyval.ttype = make_typename_type (yyvsp[-2].ttype, yyvsp[0].ttype, /*complain=*/1); ; break;} case 649: -#line 2970 "parse.y" +#line 3024 "parse.y" { if (TREE_CODE (yyvsp[0].ttype) == IDENTIFIER_NODE) cp_error ("`%T' is not a class or namespace", yyvsp[0].ttype); ; break;} case 650: -#line 2975 "parse.y" +#line 3029 "parse.y" { if (TYPE_P (yyvsp[-1].ttype)) yyval.ttype = make_typename_type (yyvsp[-1].ttype, yyvsp[0].ttype, /*complain=*/1); @@ -7343,17 +7402,17 @@ case 650: ; break;} case 651: -#line 2988 "parse.y" +#line 3042 "parse.y" { got_scope = yyval.ttype = make_typename_type (yyvsp[-2].ttype, yyvsp[-1].ttype, /*complain=*/1); ; break;} case 652: -#line 2991 "parse.y" +#line 3045 "parse.y" { got_scope = yyval.ttype = make_typename_type (yyvsp[-3].ttype, yyvsp[-1].ttype, /*complain=*/1); ; break;} case 653: -#line 2997 "parse.y" +#line 3051 "parse.y" { if (TREE_CODE (yyvsp[-1].ttype) != IDENTIFIER_NODE) yyvsp[-1].ttype = lastiddecl; @@ -7367,7 +7426,7 @@ case 653: ; break;} case 654: -#line 3009 "parse.y" +#line 3063 "parse.y" { if (TREE_CODE (yyvsp[-1].ttype) != IDENTIFIER_NODE) yyval.ttype = lastiddecl; @@ -7375,11 +7434,11 @@ case 654: ; break;} case 655: -#line 3015 "parse.y" +#line 3069 "parse.y" { got_scope = yyval.ttype = complete_type (TREE_TYPE (yyval.ttype)); ; break;} case 658: -#line 3019 "parse.y" +#line 3073 "parse.y" { if (TREE_CODE (yyval.ttype) == IDENTIFIER_NODE) yyval.ttype = lastiddecl; @@ -7387,11 +7446,11 @@ case 658: ; break;} case 659: -#line 3028 "parse.y" +#line 3082 "parse.y" { yyval.ttype = build_min_nt (TEMPLATE_ID_EXPR, yyvsp[-3].ttype, yyvsp[-1].ttype); ; break;} case 660: -#line 3033 "parse.y" +#line 3087 "parse.y" { if (TREE_CODE (yyvsp[0].ttype) == IDENTIFIER_NODE) yyval.ttype = IDENTIFIER_GLOBAL_VALUE (yyvsp[0].ttype); @@ -7401,59 +7460,59 @@ case 660: ; break;} case 662: -#line 3042 "parse.y" +#line 3096 "parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 663: -#line 3047 "parse.y" +#line 3101 "parse.y" { got_scope = NULL_TREE; ; break;} case 664: -#line 3049 "parse.y" +#line 3103 "parse.y" { yyval.ttype = yyvsp[-1].ttype; got_scope = NULL_TREE; ; break;} case 665: -#line 3056 "parse.y" +#line 3110 "parse.y" { got_scope = void_type_node; ; break;} case 666: -#line 3062 "parse.y" +#line 3116 "parse.y" { yyval.ttype = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 667: -#line 3064 "parse.y" +#line 3118 "parse.y" { yyval.ttype = make_pointer_declarator (yyvsp[0].ttype, NULL_TREE); ; break;} case 668: -#line 3066 "parse.y" +#line 3120 "parse.y" { yyval.ttype = make_reference_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 669: -#line 3068 "parse.y" +#line 3122 "parse.y" { yyval.ttype = make_reference_declarator (yyvsp[0].ttype, NULL_TREE); ; break;} case 670: -#line 3070 "parse.y" +#line 3124 "parse.y" { tree arg = make_pointer_declarator (yyvsp[0].ttype, NULL_TREE); yyval.ttype = build_parse_node (SCOPE_REF, yyvsp[-1].ttype, arg); ; break;} case 671: -#line 3074 "parse.y" +#line 3128 "parse.y" { tree arg = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); yyval.ttype = build_parse_node (SCOPE_REF, yyvsp[-2].ttype, arg); ; break;} case 673: -#line 3083 "parse.y" +#line 3137 "parse.y" { yyval.ttype = build_parse_node (ARRAY_REF, NULL_TREE, yyvsp[-1].ttype); ; break;} case 674: -#line 3085 "parse.y" +#line 3139 "parse.y" { yyval.ttype = build_parse_node (ARRAY_REF, yyval.ttype, yyvsp[-1].ttype); ; break;} case 676: -#line 3091 "parse.y" +#line 3145 "parse.y" { /* Provide support for '(' attributes '*' declarator ')' etc */ @@ -7461,96 +7520,96 @@ case 676: ; break;} case 677: -#line 3101 "parse.y" +#line 3155 "parse.y" { yyval.ttype = make_pointer_declarator (yyvsp[-1].ftype.t, yyvsp[0].ttype); ; break;} case 678: -#line 3103 "parse.y" +#line 3157 "parse.y" { yyval.ttype = make_pointer_declarator (NULL_TREE, yyvsp[0].ttype); ; break;} case 679: -#line 3105 "parse.y" +#line 3159 "parse.y" { yyval.ttype = make_pointer_declarator (yyvsp[0].ftype.t, NULL_TREE); ; break;} case 680: -#line 3107 "parse.y" +#line 3161 "parse.y" { yyval.ttype = make_pointer_declarator (NULL_TREE, NULL_TREE); ; break;} case 681: -#line 3109 "parse.y" +#line 3163 "parse.y" { yyval.ttype = make_reference_declarator (yyvsp[-1].ftype.t, yyvsp[0].ttype); ; break;} case 682: -#line 3111 "parse.y" +#line 3165 "parse.y" { yyval.ttype = make_reference_declarator (NULL_TREE, yyvsp[0].ttype); ; break;} case 683: -#line 3113 "parse.y" +#line 3167 "parse.y" { yyval.ttype = make_reference_declarator (yyvsp[0].ftype.t, NULL_TREE); ; break;} case 684: -#line 3115 "parse.y" +#line 3169 "parse.y" { yyval.ttype = make_reference_declarator (NULL_TREE, NULL_TREE); ; break;} case 685: -#line 3117 "parse.y" +#line 3171 "parse.y" { tree arg = make_pointer_declarator (yyvsp[0].ttype, NULL_TREE); yyval.ttype = build_parse_node (SCOPE_REF, yyvsp[-1].ttype, arg); ; break;} case 686: -#line 3121 "parse.y" +#line 3175 "parse.y" { tree arg = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); yyval.ttype = build_parse_node (SCOPE_REF, yyvsp[-2].ttype, arg); ; break;} case 688: -#line 3130 "parse.y" +#line 3184 "parse.y" { yyval.ttype = yyvsp[-1].ttype; ; break;} case 689: -#line 3133 "parse.y" +#line 3187 "parse.y" { yyval.ttype = make_call_declarator (yyval.ttype, yyvsp[-3].ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 690: -#line 3135 "parse.y" +#line 3189 "parse.y" { yyval.ttype = make_call_declarator (yyval.ttype, empty_parms (), yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 691: -#line 3137 "parse.y" +#line 3191 "parse.y" { yyval.ttype = build_parse_node (ARRAY_REF, yyval.ttype, yyvsp[-1].ttype); ; break;} case 692: -#line 3139 "parse.y" +#line 3193 "parse.y" { yyval.ttype = build_parse_node (ARRAY_REF, yyval.ttype, NULL_TREE); ; break;} case 693: -#line 3141 "parse.y" +#line 3195 "parse.y" { yyval.ttype = make_call_declarator (NULL_TREE, yyvsp[-3].ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 694: -#line 3143 "parse.y" +#line 3197 "parse.y" { set_quals_and_spec (yyval.ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 695: -#line 3145 "parse.y" +#line 3199 "parse.y" { set_quals_and_spec (yyval.ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 696: -#line 3147 "parse.y" +#line 3201 "parse.y" { yyval.ttype = build_parse_node (ARRAY_REF, NULL_TREE, yyvsp[-1].ttype); ; break;} case 697: -#line 3149 "parse.y" +#line 3203 "parse.y" { yyval.ttype = build_parse_node (ARRAY_REF, NULL_TREE, NULL_TREE); ; break;} case 704: -#line 3172 "parse.y" +#line 3226 "parse.y" { if (pedantic) pedwarn ("ISO C++ forbids label declarations"); ; break;} case 707: -#line 3183 "parse.y" +#line 3237 "parse.y" { while (yyvsp[-1].ttype) { @@ -7560,193 +7619,193 @@ case 707: ; break;} case 708: -#line 3196 "parse.y" +#line 3250 "parse.y" {; break;} case 710: -#line 3202 "parse.y" +#line 3256 "parse.y" { yyval.ttype = begin_compound_stmt (0); ; break;} case 711: -#line 3204 "parse.y" +#line 3258 "parse.y" { yyval.ttype = finish_compound_stmt (0, yyvsp[-1].ttype); ; break;} case 712: -#line 3209 "parse.y" +#line 3263 "parse.y" { yyval.ttype = begin_if_stmt (); cond_stmt_keyword = "if"; ; break;} case 713: -#line 3214 "parse.y" +#line 3268 "parse.y" { finish_if_stmt_cond (yyvsp[0].ttype, yyvsp[-1].ttype); ; break;} case 714: -#line 3216 "parse.y" +#line 3270 "parse.y" { yyval.ttype = finish_then_clause (yyvsp[-3].ttype); ; break;} case 716: -#line 3221 "parse.y" +#line 3275 "parse.y" { yyval.ttype = begin_compound_stmt (0); ; break;} case 717: -#line 3223 "parse.y" +#line 3277 "parse.y" { yyval.ttype = finish_compound_stmt (0, yyvsp[-1].ttype); ; break;} case 718: -#line 3228 "parse.y" +#line 3282 "parse.y" {; break;} case 720: -#line 3234 "parse.y" +#line 3288 "parse.y" { finish_stmt (); ; break;} case 721: -#line 3236 "parse.y" +#line 3290 "parse.y" { finish_expr_stmt (yyvsp[-1].ttype); ; break;} case 722: -#line 3238 "parse.y" +#line 3292 "parse.y" { begin_else_clause (); ; break;} case 723: -#line 3240 "parse.y" +#line 3294 "parse.y" { finish_else_clause (yyvsp[-3].ttype); finish_if_stmt (); ; break;} case 724: -#line 3245 "parse.y" +#line 3299 "parse.y" { finish_if_stmt (); ; break;} case 725: -#line 3247 "parse.y" +#line 3301 "parse.y" { yyval.ttype = begin_while_stmt (); cond_stmt_keyword = "while"; ; break;} case 726: -#line 3252 "parse.y" +#line 3306 "parse.y" { finish_while_stmt_cond (yyvsp[0].ttype, yyvsp[-1].ttype); ; break;} case 727: -#line 3254 "parse.y" +#line 3308 "parse.y" { finish_while_stmt (yyvsp[-3].ttype); ; break;} case 728: -#line 3256 "parse.y" +#line 3310 "parse.y" { yyval.ttype = begin_do_stmt (); ; break;} case 729: -#line 3258 "parse.y" +#line 3312 "parse.y" { finish_do_body (yyvsp[-2].ttype); cond_stmt_keyword = "do"; ; break;} case 730: -#line 3263 "parse.y" +#line 3317 "parse.y" { finish_do_stmt (yyvsp[-1].ttype, yyvsp[-5].ttype); ; break;} case 731: -#line 3265 "parse.y" +#line 3319 "parse.y" { yyval.ttype = begin_for_stmt (); ; break;} case 732: -#line 3267 "parse.y" +#line 3321 "parse.y" { finish_for_init_stmt (yyvsp[-2].ttype); ; break;} case 733: -#line 3269 "parse.y" +#line 3323 "parse.y" { finish_for_cond (yyvsp[-1].ttype, yyvsp[-5].ttype); ; break;} case 734: -#line 3271 "parse.y" +#line 3325 "parse.y" { finish_for_expr (yyvsp[-1].ttype, yyvsp[-8].ttype); ; break;} case 735: -#line 3273 "parse.y" +#line 3327 "parse.y" { finish_for_stmt (yyvsp[-3].ttype, yyvsp[-10].ttype); ; break;} case 736: -#line 3275 "parse.y" +#line 3329 "parse.y" { yyval.ttype = begin_switch_stmt (); ; break;} case 737: -#line 3277 "parse.y" +#line 3331 "parse.y" { finish_switch_cond (yyvsp[-1].ttype, yyvsp[-3].ttype); ; break;} case 738: -#line 3279 "parse.y" +#line 3333 "parse.y" { finish_switch_stmt (yyvsp[-3].ttype, yyvsp[-5].ttype); ; break;} case 739: -#line 3281 "parse.y" +#line 3335 "parse.y" { finish_case_label (yyvsp[-1].ttype, NULL_TREE); ; break;} case 741: -#line 3284 "parse.y" +#line 3338 "parse.y" { finish_case_label (yyvsp[-3].ttype, yyvsp[-1].ttype); ; break;} case 743: -#line 3287 "parse.y" +#line 3341 "parse.y" { finish_case_label (NULL_TREE, NULL_TREE); ; break;} case 745: -#line 3290 "parse.y" +#line 3344 "parse.y" { finish_break_stmt (); ; break;} case 746: -#line 3292 "parse.y" +#line 3346 "parse.y" { finish_continue_stmt (); ; break;} case 747: -#line 3294 "parse.y" +#line 3348 "parse.y" { finish_return_stmt (NULL_TREE); ; break;} case 748: -#line 3296 "parse.y" +#line 3350 "parse.y" { finish_return_stmt (yyvsp[-1].ttype); ; break;} case 749: -#line 3298 "parse.y" +#line 3352 "parse.y" { finish_asm_stmt (yyvsp[-4].ttype, yyvsp[-2].ttype, NULL_TREE, NULL_TREE, NULL_TREE); ; break;} case 750: -#line 3304 "parse.y" +#line 3358 "parse.y" { finish_asm_stmt (yyvsp[-6].ttype, yyvsp[-4].ttype, yyvsp[-2].ttype, NULL_TREE, NULL_TREE); ; break;} case 751: -#line 3310 "parse.y" +#line 3364 "parse.y" { finish_asm_stmt (yyvsp[-8].ttype, yyvsp[-6].ttype, yyvsp[-4].ttype, yyvsp[-2].ttype, NULL_TREE); ; break;} case 752: -#line 3312 "parse.y" +#line 3366 "parse.y" { finish_asm_stmt (yyvsp[-6].ttype, yyvsp[-4].ttype, NULL_TREE, yyvsp[-2].ttype, NULL_TREE); ; break;} case 753: -#line 3316 "parse.y" +#line 3370 "parse.y" { finish_asm_stmt (yyvsp[-10].ttype, yyvsp[-8].ttype, yyvsp[-6].ttype, yyvsp[-4].ttype, yyvsp[-2].ttype); ; break;} case 754: -#line 3319 "parse.y" +#line 3373 "parse.y" { finish_asm_stmt (yyvsp[-8].ttype, yyvsp[-6].ttype, NULL_TREE, yyvsp[-4].ttype, yyvsp[-2].ttype); ; break;} case 755: -#line 3322 "parse.y" +#line 3376 "parse.y" { finish_asm_stmt (yyvsp[-8].ttype, yyvsp[-6].ttype, yyvsp[-4].ttype, NULL_TREE, yyvsp[-2].ttype); ; break;} case 756: -#line 3324 "parse.y" +#line 3378 "parse.y" { if (pedantic) pedwarn ("ISO C++ forbids computed gotos"); @@ -7754,67 +7813,67 @@ case 756: ; break;} case 757: -#line 3330 "parse.y" +#line 3384 "parse.y" { finish_goto_stmt (yyvsp[-1].ttype); ; break;} case 759: -#line 3333 "parse.y" +#line 3387 "parse.y" { error ("label must be followed by statement"); yyungetc ('}', 0); ; break;} case 760: -#line 3336 "parse.y" +#line 3390 "parse.y" { finish_stmt (); ; break;} case 763: -#line 3340 "parse.y" +#line 3394 "parse.y" { do_local_using_decl (yyvsp[0].ttype); ; break;} case 765: -#line 3346 "parse.y" +#line 3400 "parse.y" { yyval.ttype = begin_function_try_block (); ; break;} case 766: -#line 3348 "parse.y" +#line 3402 "parse.y" { finish_function_try_block (yyvsp[-2].ttype); ; break;} case 767: -#line 3350 "parse.y" +#line 3404 "parse.y" { finish_function_handler_sequence (yyvsp[-4].ttype); yyval.itype = yyvsp[-3].itype; ; break;} case 768: -#line 3358 "parse.y" +#line 3412 "parse.y" { yyval.ttype = begin_try_block (); ; break;} case 769: -#line 3360 "parse.y" +#line 3414 "parse.y" { finish_try_block (yyvsp[-1].ttype); ; break;} case 770: -#line 3362 "parse.y" +#line 3416 "parse.y" { finish_handler_sequence (yyvsp[-3].ttype); ; break;} case 773: -#line 3372 "parse.y" +#line 3426 "parse.y" { yyval.ttype = begin_handler(); ; break;} case 774: -#line 3374 "parse.y" +#line 3428 "parse.y" { yyval.ttype = finish_handler_parms (yyvsp[0].ttype, yyvsp[-1].ttype); ; break;} case 775: -#line 3376 "parse.y" +#line 3430 "parse.y" { finish_handler (yyvsp[-1].ttype, yyvsp[-3].ttype); ; break;} case 778: -#line 3386 "parse.y" +#line 3440 "parse.y" { yyval.ttype = NULL_TREE; ; break;} case 779: -#line 3402 "parse.y" +#line 3456 "parse.y" { check_for_new_type ("inside exception declarations", yyvsp[-1].ftype); yyval.ttype = start_handler_parms (TREE_PURPOSE (yyvsp[-1].ftype.t), @@ -7822,97 +7881,97 @@ case 779: ; break;} case 780: -#line 3411 "parse.y" +#line 3465 "parse.y" { finish_label_stmt (yyvsp[-1].ttype); ; break;} case 781: -#line 3413 "parse.y" +#line 3467 "parse.y" { finish_label_stmt (yyvsp[-1].ttype); ; break;} case 782: -#line 3415 "parse.y" +#line 3469 "parse.y" { finish_label_stmt (yyvsp[-1].ttype); ; break;} case 783: -#line 3417 "parse.y" +#line 3471 "parse.y" { finish_label_stmt (yyvsp[-1].ttype); ; break;} case 784: -#line 3422 "parse.y" +#line 3476 "parse.y" { finish_expr_stmt (yyvsp[-1].ttype); ; break;} case 786: -#line 3425 "parse.y" +#line 3479 "parse.y" { if (pedantic) pedwarn ("ISO C++ forbids compound statements inside for initializations"); ; break;} case 787: -#line 3434 "parse.y" +#line 3488 "parse.y" { yyval.ttype = NULL_TREE; ; break;} case 789: -#line 3440 "parse.y" +#line 3494 "parse.y" { yyval.ttype = NULL_TREE; ; break;} case 791: -#line 3443 "parse.y" +#line 3497 "parse.y" { yyval.ttype = NULL_TREE; ; break;} case 792: -#line 3450 "parse.y" +#line 3504 "parse.y" { yyval.ttype = NULL_TREE; ; break;} case 795: -#line 3457 "parse.y" +#line 3511 "parse.y" { yyval.ttype = chainon (yyval.ttype, yyvsp[0].ttype); ; break;} case 796: -#line 3462 "parse.y" +#line 3516 "parse.y" { yyval.ttype = build_tree_list (yyval.ttype, yyvsp[-1].ttype); ; break;} case 797: -#line 3467 "parse.y" +#line 3521 "parse.y" { yyval.ttype = tree_cons (NULL_TREE, yyval.ttype, NULL_TREE); ; break;} case 798: -#line 3469 "parse.y" +#line 3523 "parse.y" { yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyval.ttype); ; break;} case 799: -#line 3480 "parse.y" +#line 3534 "parse.y" { yyval.ttype = empty_parms(); ; break;} case 801: -#line 3485 "parse.y" +#line 3539 "parse.y" { yyval.ttype = finish_parmlist (build_tree_list (NULL_TREE, yyvsp[0].ftype.t), 0); check_for_new_type ("inside parameter list", yyvsp[0].ftype); ; break;} case 802: -#line 3493 "parse.y" +#line 3547 "parse.y" { yyval.ttype = finish_parmlist (yyval.ttype, 0); ; break;} case 803: -#line 3495 "parse.y" +#line 3549 "parse.y" { yyval.ttype = finish_parmlist (yyvsp[-1].ttype, 1); ; break;} case 804: -#line 3498 "parse.y" +#line 3552 "parse.y" { yyval.ttype = finish_parmlist (yyvsp[-1].ttype, 1); ; break;} case 805: -#line 3500 "parse.y" +#line 3554 "parse.y" { yyval.ttype = finish_parmlist (build_tree_list (NULL_TREE, yyvsp[-1].ftype.t), 1); ; break;} case 806: -#line 3503 "parse.y" +#line 3557 "parse.y" { yyval.ttype = finish_parmlist (NULL_TREE, 1); ; break;} case 807: -#line 3505 "parse.y" +#line 3559 "parse.y" { /* This helps us recover from really nasty parse errors, for example, a missing right @@ -7924,7 +7983,7 @@ case 807: ; break;} case 808: -#line 3515 "parse.y" +#line 3569 "parse.y" { /* This helps us recover from really nasty parse errors, for example, a missing right @@ -7937,99 +7996,99 @@ case 808: ; break;} case 809: -#line 3530 "parse.y" +#line 3584 "parse.y" { maybe_snarf_defarg (); ; break;} case 810: -#line 3532 "parse.y" +#line 3586 "parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 813: -#line 3543 "parse.y" +#line 3597 "parse.y" { check_for_new_type ("in a parameter list", yyvsp[0].ftype); yyval.ttype = build_tree_list (NULL_TREE, yyvsp[0].ftype.t); ; break;} case 814: -#line 3546 "parse.y" +#line 3600 "parse.y" { check_for_new_type ("in a parameter list", yyvsp[-1].ftype); yyval.ttype = build_tree_list (yyvsp[0].ttype, yyvsp[-1].ftype.t); ; break;} case 815: -#line 3549 "parse.y" +#line 3603 "parse.y" { check_for_new_type ("in a parameter list", yyvsp[0].ftype); yyval.ttype = chainon (yyval.ttype, yyvsp[0].ftype.t); ; break;} case 816: -#line 3552 "parse.y" +#line 3606 "parse.y" { yyval.ttype = chainon (yyval.ttype, build_tree_list (NULL_TREE, yyvsp[0].ttype)); ; break;} case 817: -#line 3554 "parse.y" +#line 3608 "parse.y" { yyval.ttype = chainon (yyval.ttype, build_tree_list (yyvsp[0].ttype, yyvsp[-2].ttype)); ; break;} case 819: -#line 3560 "parse.y" +#line 3614 "parse.y" { check_for_new_type ("in a parameter list", yyvsp[-1].ftype); yyval.ttype = build_tree_list (NULL_TREE, yyvsp[-1].ftype.t); ; break;} case 820: -#line 3570 "parse.y" +#line 3624 "parse.y" { tree specs = strip_attrs (yyvsp[-1].ftype.t); yyval.ftype.new_type_flag = yyvsp[-1].ftype.new_type_flag; yyval.ftype.t = build_tree_list (specs, yyvsp[0].ttype); ; break;} case 821: -#line 3574 "parse.y" +#line 3628 "parse.y" { yyval.ftype.t = build_tree_list (yyvsp[-1].ftype.t, yyvsp[0].ttype); yyval.ftype.new_type_flag = yyvsp[-1].ftype.new_type_flag; ; break;} case 822: -#line 3577 "parse.y" +#line 3631 "parse.y" { yyval.ftype.t = build_tree_list (build_decl_list (NULL_TREE, yyvsp[-1].ftype.t), yyvsp[0].ttype); yyval.ftype.new_type_flag = yyvsp[-1].ftype.new_type_flag; ; break;} case 823: -#line 3581 "parse.y" +#line 3635 "parse.y" { tree specs = strip_attrs (yyvsp[-1].ftype.t); yyval.ftype.t = build_tree_list (specs, yyvsp[0].ttype); yyval.ftype.new_type_flag = yyvsp[-1].ftype.new_type_flag; ; break;} case 824: -#line 3585 "parse.y" +#line 3639 "parse.y" { tree specs = strip_attrs (yyvsp[0].ftype.t); yyval.ftype.t = build_tree_list (specs, NULL_TREE); yyval.ftype.new_type_flag = yyvsp[0].ftype.new_type_flag; ; break;} case 825: -#line 3589 "parse.y" +#line 3643 "parse.y" { tree specs = strip_attrs (yyvsp[-1].ftype.t); yyval.ftype.t = build_tree_list (specs, yyvsp[0].ttype); yyval.ftype.new_type_flag = 0; ; break;} case 826: -#line 3596 "parse.y" +#line 3650 "parse.y" { yyval.ftype.t = build_tree_list (NULL_TREE, yyvsp[0].ftype.t); yyval.ftype.new_type_flag = yyvsp[0].ftype.new_type_flag; ; break;} case 827: -#line 3599 "parse.y" +#line 3653 "parse.y" { yyval.ftype.t = build_tree_list (yyvsp[0].ttype, yyvsp[-1].ftype.t); yyval.ftype.new_type_flag = yyvsp[-1].ftype.new_type_flag; ; break;} case 830: -#line 3610 "parse.y" +#line 3664 "parse.y" { see_typename (); ; break;} case 831: -#line 3615 "parse.y" +#line 3669 "parse.y" { error ("type specifier omitted for parameter"); yyval.ttype = build_tree_list (integer_type_node, NULL_TREE); ; break;} case 832: -#line 3620 "parse.y" +#line 3674 "parse.y" { error ("type specifier omitted for parameter"); if (TREE_CODE (yyval.ttype) == SCOPE_REF @@ -8040,192 +8099,192 @@ case 832: ; break;} case 833: -#line 3632 "parse.y" +#line 3686 "parse.y" { yyval.ttype = NULL_TREE; ; break;} case 834: -#line 3634 "parse.y" +#line 3688 "parse.y" { yyval.ttype = yyvsp[-1].ttype; ; break;} case 835: -#line 3636 "parse.y" +#line 3690 "parse.y" { yyval.ttype = empty_except_spec; ; break;} case 836: -#line 3641 "parse.y" +#line 3695 "parse.y" { check_for_new_type ("exception specifier", yyvsp[0].ftype); yyval.ttype = groktypename (yyvsp[0].ftype.t); ; break;} case 837: -#line 3649 "parse.y" +#line 3703 "parse.y" { yyval.ttype = add_exception_specifier (NULL_TREE, yyvsp[0].ttype, 1); ; break;} case 838: -#line 3651 "parse.y" +#line 3705 "parse.y" { yyval.ttype = add_exception_specifier (yyvsp[-2].ttype, yyvsp[0].ttype, 1); ; break;} case 839: -#line 3656 "parse.y" +#line 3710 "parse.y" { yyval.ttype = NULL_TREE; ; break;} case 840: -#line 3658 "parse.y" +#line 3712 "parse.y" { yyval.ttype = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 841: -#line 3660 "parse.y" +#line 3714 "parse.y" { yyval.ttype = make_reference_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 842: -#line 3662 "parse.y" +#line 3716 "parse.y" { tree arg = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); yyval.ttype = build_parse_node (SCOPE_REF, yyvsp[-2].ttype, arg); ; break;} case 843: -#line 3669 "parse.y" +#line 3723 "parse.y" { got_scope = NULL_TREE; ; break;} case 844: -#line 3674 "parse.y" +#line 3728 "parse.y" { yyval.ttype = ansi_opname (MULT_EXPR); ; break;} case 845: -#line 3676 "parse.y" +#line 3730 "parse.y" { yyval.ttype = ansi_opname (TRUNC_DIV_EXPR); ; break;} case 846: -#line 3678 "parse.y" +#line 3732 "parse.y" { yyval.ttype = ansi_opname (TRUNC_MOD_EXPR); ; break;} case 847: -#line 3680 "parse.y" +#line 3734 "parse.y" { yyval.ttype = ansi_opname (PLUS_EXPR); ; break;} case 848: -#line 3682 "parse.y" +#line 3736 "parse.y" { yyval.ttype = ansi_opname (MINUS_EXPR); ; break;} case 849: -#line 3684 "parse.y" +#line 3738 "parse.y" { yyval.ttype = ansi_opname (BIT_AND_EXPR); ; break;} case 850: -#line 3686 "parse.y" +#line 3740 "parse.y" { yyval.ttype = ansi_opname (BIT_IOR_EXPR); ; break;} case 851: -#line 3688 "parse.y" +#line 3742 "parse.y" { yyval.ttype = ansi_opname (BIT_XOR_EXPR); ; break;} case 852: -#line 3690 "parse.y" +#line 3744 "parse.y" { yyval.ttype = ansi_opname (BIT_NOT_EXPR); ; break;} case 853: -#line 3692 "parse.y" +#line 3746 "parse.y" { yyval.ttype = ansi_opname (COMPOUND_EXPR); ; break;} case 854: -#line 3694 "parse.y" +#line 3748 "parse.y" { yyval.ttype = ansi_opname (yyvsp[0].code); ; break;} case 855: -#line 3696 "parse.y" +#line 3750 "parse.y" { yyval.ttype = ansi_opname (LT_EXPR); ; break;} case 856: -#line 3698 "parse.y" +#line 3752 "parse.y" { yyval.ttype = ansi_opname (GT_EXPR); ; break;} case 857: -#line 3700 "parse.y" +#line 3754 "parse.y" { yyval.ttype = ansi_opname (yyvsp[0].code); ; break;} case 858: -#line 3702 "parse.y" +#line 3756 "parse.y" { yyval.ttype = ansi_assopname (yyvsp[0].code); ; break;} case 859: -#line 3704 "parse.y" +#line 3758 "parse.y" { yyval.ttype = ansi_assopname (NOP_EXPR); ; break;} case 860: -#line 3706 "parse.y" +#line 3760 "parse.y" { yyval.ttype = ansi_opname (yyvsp[0].code); ; break;} case 861: -#line 3708 "parse.y" +#line 3762 "parse.y" { yyval.ttype = ansi_opname (yyvsp[0].code); ; break;} case 862: -#line 3710 "parse.y" +#line 3764 "parse.y" { yyval.ttype = ansi_opname (POSTINCREMENT_EXPR); ; break;} case 863: -#line 3712 "parse.y" +#line 3766 "parse.y" { yyval.ttype = ansi_opname (PREDECREMENT_EXPR); ; break;} case 864: -#line 3714 "parse.y" +#line 3768 "parse.y" { yyval.ttype = ansi_opname (TRUTH_ANDIF_EXPR); ; break;} case 865: -#line 3716 "parse.y" +#line 3770 "parse.y" { yyval.ttype = ansi_opname (TRUTH_ORIF_EXPR); ; break;} case 866: -#line 3718 "parse.y" +#line 3772 "parse.y" { yyval.ttype = ansi_opname (TRUTH_NOT_EXPR); ; break;} case 867: -#line 3720 "parse.y" +#line 3774 "parse.y" { yyval.ttype = ansi_opname (COND_EXPR); ; break;} case 868: -#line 3722 "parse.y" +#line 3776 "parse.y" { yyval.ttype = ansi_opname (yyvsp[0].code); ; break;} case 869: -#line 3724 "parse.y" +#line 3778 "parse.y" { yyval.ttype = ansi_opname (COMPONENT_REF); ; break;} case 870: -#line 3726 "parse.y" +#line 3780 "parse.y" { yyval.ttype = ansi_opname (MEMBER_REF); ; break;} case 871: -#line 3728 "parse.y" +#line 3782 "parse.y" { yyval.ttype = ansi_opname (CALL_EXPR); ; break;} case 872: -#line 3730 "parse.y" +#line 3784 "parse.y" { yyval.ttype = ansi_opname (ARRAY_REF); ; break;} case 873: -#line 3732 "parse.y" +#line 3786 "parse.y" { yyval.ttype = ansi_opname (NEW_EXPR); ; break;} case 874: -#line 3734 "parse.y" +#line 3788 "parse.y" { yyval.ttype = ansi_opname (DELETE_EXPR); ; break;} case 875: -#line 3736 "parse.y" +#line 3790 "parse.y" { yyval.ttype = ansi_opname (VEC_NEW_EXPR); ; break;} case 876: -#line 3738 "parse.y" +#line 3792 "parse.y" { yyval.ttype = ansi_opname (VEC_DELETE_EXPR); ; break;} case 877: -#line 3741 "parse.y" +#line 3795 "parse.y" { yyval.ttype = grokoptypename (yyvsp[-1].ftype.t, yyvsp[0].ttype); ; break;} case 878: -#line 3743 "parse.y" +#line 3797 "parse.y" { yyval.ttype = ansi_opname (ERROR_MARK); ; break;} } @@ -8450,7 +8509,7 @@ yyerrhandle: } return 1; } -#line 3746 "parse.y" +#line 3800 "parse.y" #ifdef SPEW_DEBUG diff --git a/gcc/cp/parse.y b/gcc/cp/parse.y index 6f26be4..5d0ff07 100644 --- a/gcc/cp/parse.y +++ b/gcc/cp/parse.y @@ -389,7 +389,8 @@ cp_parse_init () %type <itype> new delete /* %type <ttype> primary_no_id */ %type <ttype> maybe_parmlist -%type <itype> member_init_list +%type <ttype> member_init +%type <ftype> member_init_list %type <ttype> template_header template_parm_list template_parm %type <ttype> template_type_parm template_template_parm %type <code> template_close_bracket @@ -853,9 +854,40 @@ return_init: base_init: ':' .set_base_init member_init_list { - if ($3 == 0) - error ("no base initializers given following ':'"); - setup_vtbl_ptr (); + tree member_init_list = NULL_TREE; + tree base_init_list = NULL_TREE; + tree init; + tree next; + int seen_member_init_p; + + if ($3.new_type_flag == 0) + error ("no base or member initializers given following ':'"); + + seen_member_init_p = 0; + for (init = $3.t; init; init = next) + { + next = TREE_CHAIN (init); + if (TREE_CODE (TREE_PURPOSE (init)) == FIELD_DECL) + { + TREE_CHAIN (init) = member_init_list; + member_init_list = init; + seen_member_init_p = 1; + } + else + { + if (warn_reorder && seen_member_init_p) + { + cp_warning ("base initializer for `%T'", + TREE_PURPOSE (init)); + warning (" will be re-ordered to precede member initializations"); + } + + TREE_CHAIN (init) = base_init_list; + base_init_list = init; + } + } + + setup_vtbl_ptr (member_init_list, base_init_list); } ; @@ -877,10 +909,26 @@ base_init: member_init_list: /* empty */ - { $$ = 0; } + { + $$.new_type_flag = 0; + $$.t = NULL_TREE; + } | member_init - { $$ = 1; } + { + $$.new_type_flag = 1; + $$.t = $1; + } | member_init_list ',' member_init + { + if ($3) + { + $$.new_type_flag = 1; + TREE_CHAIN ($3) = $1.t; + $$.t = $3; + } + else + $$ = $1; + } | member_init_list error ; @@ -889,29 +937,36 @@ member_init: { if (current_class_name) pedwarn ("anachronistic old style base class initializer"); - expand_member_init (current_class_ref, NULL_TREE, $2); + $$ = expand_member_init (current_class_ref, NULL_TREE, $2); } | LEFT_RIGHT { if (current_class_name) pedwarn ("anachronistic old style base class initializer"); - expand_member_init (current_class_ref, NULL_TREE, void_type_node); + $$ = expand_member_init (current_class_ref, + NULL_TREE, + void_type_node); } | notype_identifier '(' nonnull_exprlist ')' - { expand_member_init (current_class_ref, $1, $3); } + { $$ = expand_member_init (current_class_ref, $1, $3); } | notype_identifier LEFT_RIGHT - { expand_member_init (current_class_ref, $1, void_type_node); } + { $$ = expand_member_init (current_class_ref, $1, + void_type_node); } | nonnested_type '(' nonnull_exprlist ')' - { expand_member_init (current_class_ref, $1, $3); } + { $$ = expand_member_init (current_class_ref, $1, $3); } | nonnested_type LEFT_RIGHT - { expand_member_init (current_class_ref, $1, void_type_node); } + { $$ = expand_member_init (current_class_ref, $1, + void_type_node); } | typename_sub '(' nonnull_exprlist ')' - { expand_member_init (current_class_ref, TYPE_MAIN_DECL ($1), - $3); } + { $$ = expand_member_init (current_class_ref, + TYPE_MAIN_DECL ($1), + $3); } | typename_sub LEFT_RIGHT - { expand_member_init (current_class_ref, TYPE_MAIN_DECL ($1), - void_type_node); } + { $$ = expand_member_init (current_class_ref, + TYPE_MAIN_DECL ($1), + void_type_node); } | error + { $$ = NULL_TREE } ; identifier: @@ -1654,7 +1709,7 @@ nodecls: { if (! current_function_parms_stored) store_parm_decls (); - setup_vtbl_ptr (); + setup_vtbl_ptr (NULL_TREE, NULL_TREE); } ; @@ -2096,8 +2151,7 @@ fn.defpen: PRE_PARSED_FUNCTION_DECL { start_function (NULL_TREE, $1->fndecl, NULL_TREE, (SF_DEFAULT | SF_PRE_PARSED - | SF_INCLASS_INLINE)); - reinit_parse_for_function (); } + | SF_INCLASS_INLINE)); } pending_inline: fn.defpen maybe_return_init ctor_initializer_opt compstmt_or_error diff --git a/gcc/cp/pt.c b/gcc/cp/pt.c index 6286d8f..902ebc5 100644 --- a/gcc/cp/pt.c +++ b/gcc/cp/pt.c @@ -104,7 +104,7 @@ static int push_tinst_level PARAMS ((tree)); static void reopen_tinst_level PARAMS ((tree)); static tree classtype_mangled_name PARAMS ((tree)); static char *mangle_class_name_for_template PARAMS ((char *, tree, tree)); -static tree tsubst_expr_values PARAMS ((tree, tree)); +static tree tsubst_initializer_list PARAMS ((tree, tree)); static int list_eq PARAMS ((tree, tree)); static tree get_class_bindings PARAMS ((tree, tree, tree)); static tree coerce_template_parms PARAMS ((tree, tree, tree, int, int)); @@ -3009,7 +3009,7 @@ convert_nontype_argument (type, expr) || !at_least_as_qualified_p (type_referred_to, expr_type) || !real_lvalue_p (expr)) - expr = error_mark_node; + return error_mark_node; } mark_addressable (expr); @@ -7145,14 +7145,19 @@ tsubst_expr (t, args, complain, in_decl) break; case CTOR_INITIALIZER: - prep_stmt (t); - current_member_init_list - = tsubst_expr_values (TREE_OPERAND (t, 0), args); - current_base_init_list - = tsubst_expr_values (TREE_OPERAND (t, 1), args); - setup_vtbl_ptr (); - tsubst_expr (TREE_CHAIN (t), args, complain, in_decl); - break; + { + tree member_init_list; + tree base_init_list; + + prep_stmt (t); + member_init_list + = tsubst_initializer_list (TREE_OPERAND (t, 0), args); + base_init_list + = tsubst_initializer_list (TREE_OPERAND (t, 1), args); + setup_vtbl_ptr (member_init_list, base_init_list); + tsubst_expr (TREE_CHAIN (t), args, complain, in_decl); + break; + } case RETURN_STMT: prep_stmt (t); @@ -9837,12 +9842,13 @@ instantiate_pending_templates () return instantiated_something; } -/* Substitute ARGVEC into T, which is a TREE_LIST. In particular, it - is an initializer list: the TREE_PURPOSEs are DECLs, and the - TREE_VALUEs are initializer values. Used by instantiate_decl. */ +/* Substitute ARGVEC into T, which is a list of initializers for + either base class or a non-static data member. The TREE_PURPOSEs + are DECLs, and the TREE_VALUEs are the initializer values. Used by + instantiate_decl. */ static tree -tsubst_expr_values (t, argvec) +tsubst_initializer_list (t, argvec) tree t, argvec; { tree first = NULL_TREE; @@ -9850,11 +9856,24 @@ tsubst_expr_values (t, argvec) for (; t; t = TREE_CHAIN (t)) { - tree pur = tsubst_copy (TREE_PURPOSE (t), argvec, - /*complain=*/1, NULL_TREE); - tree val = tsubst_expr (TREE_VALUE (t), argvec, /*complain=*/1, - NULL_TREE); - *p = build_tree_list (pur, val); + tree decl; + tree init; + tree val; + + decl = tsubst_copy (TREE_PURPOSE (t), argvec, /*complain=*/1, + NULL_TREE); + init = tsubst_expr (TREE_VALUE (t), argvec, /*complain=*/1, + NULL_TREE); + + if (!init) + ; + else if (TREE_CODE (init) == TREE_LIST) + for (val = init; val; val = TREE_CHAIN (val)) + TREE_VALUE (val) = convert_from_reference (TREE_VALUE (val)); + else + init = convert_from_reference (init); + + *p = build_tree_list (decl, init); p = &TREE_CHAIN (*p); } return first; diff --git a/gcc/cp/semantics.c b/gcc/cp/semantics.c index 49dc5dd..2621b8b 100644 --- a/gcc/cp/semantics.c +++ b/gcc/cp/semantics.c @@ -1235,7 +1235,9 @@ finish_named_return_value (return_id, init) more than one virtual function call is made this function. */ void -setup_vtbl_ptr () +setup_vtbl_ptr (member_init_list, base_init_list) + tree member_init_list; + tree base_init_list; { my_friendly_assert (doing_semantic_analysis_p (), 19990919); @@ -1248,7 +1250,7 @@ setup_vtbl_ptr () if (processing_template_decl) add_tree (build_min_nt (CTOR_INITIALIZER, - current_member_init_list, current_base_init_list)); + member_init_list, base_init_list)); else { tree ctor_stmt; @@ -1259,7 +1261,7 @@ setup_vtbl_ptr () add_tree (ctor_stmt); /* And actually initialize the base-classes and members. */ - emit_base_init (); + emit_base_init (member_init_list, base_init_list); } } else if (DECL_DESTRUCTOR_P (current_function_decl) @@ -1776,7 +1778,6 @@ begin_function_definition (decl_specs, declarator) deferred_type_access_control (); type_lookups = error_mark_node; - reinit_parse_for_function (); /* The things we're about to see are not directly qualified by any template headers we've seen thus far. */ reset_specialization (); diff --git a/gcc/testsuite/g++.old-deja/g++.pt/ref3.C b/gcc/testsuite/g++.old-deja/g++.pt/ref3.C new file mode 100644 index 0000000..27f7cd2 --- /dev/null +++ b/gcc/testsuite/g++.old-deja/g++.pt/ref3.C @@ -0,0 +1,21 @@ +// Origin: John Wilkinson <jfw@sgi.com> + +template <class T, int& Size> +struct Base { + Base() : obj(Size) {} + T obj; +}; + +int globalInt = 5; + +struct A { + A(int arg) : ia(arg) {} + int ia; +}; + +int main() +{ + Base<A, globalInt> ob; + if (ob.obj.ia != 5) + return 1; +} |