aboutsummaryrefslogtreecommitdiff
path: root/gcc/cp
diff options
context:
space:
mode:
Diffstat (limited to 'gcc/cp')
-rw-r--r--gcc/cp/ChangeLog20
-rw-r--r--gcc/cp/class.c27
-rw-r--r--gcc/cp/cp-tree.h9
-rw-r--r--gcc/cp/decl.c25
-rw-r--r--gcc/cp/parse.c1562
-rw-r--r--gcc/cp/parse.y10
-rw-r--r--gcc/cp/pt.c11
-rw-r--r--gcc/cp/semantics.c22
8 files changed, 877 insertions, 809 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index 29c3ce5..4d991fd 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,3 +1,23 @@
+1998-05-20 Mark Mitchell <mmitchell@usa.net>
+
+ * class.c (delete_duplicate_fields_1): Use DECL_DECLARES_TYPE_P
+ to look for type declarations.
+ (finish_struct): Deal with templates on the CLASSTYPE_TAGS list.
+ * cp-tree.h (DECL_DECLARES_TYPE_P): New macro.
+ (finish_member_class_template): Declare.
+ * decl.c (pushtag): Put member class templates on the
+ CLASSTYPE_TAGS list, just as for ordinary member classes.
+ (pushdecl_class_level): Use DECL_DECLARES_TYPE_P.
+ (lookup_tag): Look for IDENTIFIER_CLASS_VALUEs, just as with
+ IDENTIFIER_NAMESPACE_VALUEs.
+ * parse.y (component_decl): Move code to ...
+ * semantics.c (finish_member_class_template): New function.
+ Don't put member class templates on the list of components for a
+ class.
+ * parse.c: Regenerated.
+ * pt.c (classtype_mangled_name): Don't try DECL_CONTEXT on types.
+ In fact, don't use DECL_CONTEXT at all here.
+
1998-05-20 Martin von Loewis <loewis@informatik.hu-berlin.de>
* decl.c (record_unknown_type): New function.
diff --git a/gcc/cp/class.c b/gcc/cp/class.c
index 3d018e5..36eb589 100644
--- a/gcc/cp/class.c
+++ b/gcc/cp/class.c
@@ -1240,15 +1240,15 @@ delete_duplicate_fields_1 (field, fields)
|| TREE_CODE (x) == CONST_DECL)
cp_error_at ("duplicate field `%D' (as enum and non-enum)",
x);
- else if (TREE_CODE (field) == TYPE_DECL
- && TREE_CODE (x) == TYPE_DECL)
+ else if (DECL_DECLARES_TYPE_P (field)
+ && DECL_DECLARES_TYPE_P (x))
{
- if (TREE_TYPE (field) == TREE_TYPE (x))
+ if (comptypes (TREE_TYPE (field), TREE_TYPE (x), 1))
continue;
cp_error_at ("duplicate nested type `%D'", x);
}
- else if (TREE_CODE (field) == TYPE_DECL
- || TREE_CODE (x) == TYPE_DECL)
+ else if (DECL_DECLARES_TYPE_P (field)
+ || DECL_DECLARES_TYPE_P (x))
{
/* Hide tag decls. */
if ((TREE_CODE (field) == TYPE_DECL
@@ -4392,9 +4392,14 @@ finish_struct (t, list_of_fieldlists, attributes, warn_anon)
CLASSTYPE_TAGS (t) = x = nreverse (CLASSTYPE_TAGS (t));
while (x)
{
+ tree tag_type = TREE_VALUE (x);
tree tag = TYPE_MAIN_DECL (TREE_VALUE (x));
- TREE_NONLOCAL_FLAG (TREE_VALUE (x)) = 0;
+ if (IS_AGGR_TYPE_CODE (TREE_CODE (tag_type))
+ && CLASSTYPE_IS_TEMPLATE (tag_type))
+ tag = CLASSTYPE_TI_TEMPLATE (tag_type);
+
+ TREE_NONLOCAL_FLAG (tag_type) = 0;
x = TREE_CHAIN (x);
last_x = chainon (last_x, tag);
}
@@ -4744,10 +4749,16 @@ pushclass (type, modify)
for (tags = CLASSTYPE_TAGS (type); tags; tags = TREE_CHAIN (tags))
{
- TREE_NONLOCAL_FLAG (TREE_VALUE (tags)) = 1;
+ tree tag_type = TREE_VALUE (tags);
+
+ TREE_NONLOCAL_FLAG (tag_type) = 1;
if (! TREE_PURPOSE (tags))
continue;
- pushtag (TREE_PURPOSE (tags), TREE_VALUE (tags), 0);
+ if (! (IS_AGGR_TYPE_CODE (TREE_CODE (tag_type))
+ && CLASSTYPE_IS_TEMPLATE (tag_type)))
+ pushtag (TREE_PURPOSE (tags), tag_type, 0);
+ else
+ pushdecl_class_level (CLASSTYPE_TI_TEMPLATE (tag_type));
}
current_function_decl = this_fndecl;
diff --git a/gcc/cp/cp-tree.h b/gcc/cp/cp-tree.h
index 12ca027..abcd31c 100644
--- a/gcc/cp/cp-tree.h
+++ b/gcc/cp/cp-tree.h
@@ -737,6 +737,10 @@ struct lang_type
#define SET_CLASSTYPE_MARKED6(NODE) (CLASSTYPE_MARKED6(NODE) = 1)
#define CLEAR_CLASSTYPE_MARKED6(NODE) (CLASSTYPE_MARKED6(NODE) = 0)
+/* A list of the nested tag-types (class, struct, union, or enum)
+ found within this class. The TREE_PURPOSE of each node is the name
+ of the type; the TREE_VALUE is the type itself. This list includes
+ nested member class templates. */
#define CLASSTYPE_TAGS(NODE) (TYPE_LANG_SPECIFIC(NODE)->tags)
/* If this class has any bases, this is the number of the base class from
@@ -1474,6 +1478,10 @@ extern int flag_new_for_scope;
&& TREE_CODE (DECL_TEMPLATE_RESULT (NODE)) == TYPE_DECL \
&& !DECL_TEMPLATE_TEMPLATE_PARM_P (NODE))
+/* Nonzero if NODE which declares a type. */
+#define DECL_DECLARES_TYPE_P(NODE) \
+ (TREE_CODE (NODE) == TYPE_DECL || DECL_CLASS_TEMPLATE_P (NODE))
+
/* A `primary' template is one that has its own template header. A
member function of a class template is a template, but not primary.
A member template is primary. Friend templates are primary, too. */
@@ -2690,6 +2698,7 @@ extern tree begin_class_definition PROTO((tree));
extern tree finish_class_definition PROTO((tree, tree, tree, int));
extern void finish_default_args PROTO((void));
extern void begin_inline_definitions PROTO((void));
+extern tree finish_member_class_template PROTO((tree, tree));
/* in sig.c */
extern tree build_signature_pointer_type PROTO((tree, int, int));
diff --git a/gcc/cp/decl.c b/gcc/cp/decl.c
index c067fe2..94de1da 100644
--- a/gcc/cp/decl.c
+++ b/gcc/cp/decl.c
@@ -2303,8 +2303,19 @@ pushtag (name, type, globalize)
if appropriate. */
if (!globalize && b->pseudo_global &&
b->level_chain->parm_flag == 2)
- pushdecl_with_scope (CLASSTYPE_TI_TEMPLATE (type),
- b->level_chain);
+ {
+ pushdecl_with_scope (CLASSTYPE_TI_TEMPLATE (type),
+ b->level_chain);
+ /* Put this tag on the list of tags for the class,
+ since that won't happen below because B is not
+ the class binding level, but is instead the
+ pseudo-global level. */
+ b->level_chain->tags =
+ saveable_tree_cons (name, type, b->level_chain->tags);
+ TREE_NONLOCAL_FLAG (type) = 1;
+ if (TYPE_SIZE (current_class_type) == NULL_TREE)
+ CLASSTYPE_TAGS (current_class_type) = b->level_chain->tags;
+ }
}
if (b->parm_flag == 2)
@@ -3756,7 +3767,7 @@ pushdecl_class_level (x)
/* Don't complain about inherited names. */
&& id_in_current_class (name)
/* Or shadowed tags. */
- && !(TREE_CODE (icv) == TYPE_DECL
+ && !(DECL_DECLARES_TYPE_P (icv)
&& DECL_CONTEXT (icv) == current_class_type))
{
cp_error ("declaration of identifier `%D' as `%#D'", name, x);
@@ -4469,9 +4480,11 @@ lookup_tag (form, name, binding_level, thislevel_only)
{
if (level->pseudo_global)
{
- tree t = IDENTIFIER_NAMESPACE_VALUE (name);
- if (t && TREE_CODE (t) == TEMPLATE_DECL
- && TREE_CODE (DECL_TEMPLATE_RESULT (t)) == TYPE_DECL)
+ tree t = IDENTIFIER_CLASS_VALUE (name);
+ if (t && DECL_CLASS_TEMPLATE_P (t))
+ return TREE_TYPE (t);
+ t = IDENTIFIER_NAMESPACE_VALUE (name);
+ if (t && DECL_CLASS_TEMPLATE_P (t))
return TREE_TYPE (t);
}
return NULL_TREE;
diff --git a/gcc/cp/parse.c b/gcc/cp/parse.c
index 276dbb7..2fa5fdf 100644
--- a/gcc/cp/parse.c
+++ b/gcc/cp/parse.c
@@ -152,9 +152,9 @@ empty_parms ()
}
-#line 91 "parse.y"
+#line 92 "parse.y"
typedef union {long itype; tree ttype; char *strtype; enum tree_code code; flagged_type_tree ftype; } YYSTYPE;
-#line 280 "parse.y"
+#line 281 "parse.y"
/* List of types and structure classes of the current declaration. */
static tree current_declspecs = NULL_TREE;
@@ -623,90 +623,90 @@ static const short yyrhs[] = { -1,
#if YYDEBUG != 0
static const short yyrline[] = { 0,
- 328, 330, 338, 341, 342, 346, 348, 351, 356, 360,
- 366, 370, 373, 377, 380, 382, 384, 387, 389, 392,
- 395, 397, 399, 401, 403, 405, 407, 416, 420, 423,
- 425, 429, 431, 432, 434, 438, 441, 447, 450, 452,
- 457, 460, 464, 467, 470, 473, 477, 482, 492, 494,
- 496, 498, 500, 513, 522, 532, 534, 536, 540, 542,
- 543, 550, 551, 552, 555, 558, 562, 564, 565, 568,
- 570, 573, 576, 578, 582, 585, 587, 591, 593, 595,
- 599, 601, 603, 607, 609, 611, 617, 621, 624, 627,
- 630, 635, 638, 640, 642, 648, 658, 660, 663, 666,
- 668, 671, 675, 684, 687, 689, 693, 706, 726, 729,
- 731, 732, 735, 742, 748, 750, 752, 754, 756, 759,
- 764, 766, 767, 768, 769, 772, 774, 775, 778, 780,
- 781, 784, 789, 789, 793, 793, 796, 796, 799, 799,
- 803, 803, 808, 808, 811, 811, 814, 816, 819, 826,
- 833, 839, 842, 851, 853, 861, 864, 867, 870, 874,
- 877, 880, 883, 885, 887, 889, 893, 896, 899, 904,
- 908, 913, 917, 920, 922, 926, 945, 952, 955, 957,
- 958, 959, 962, 966, 967, 971, 975, 978, 980, 984,
- 987, 990, 994, 997, 999, 1001, 1003, 1006, 1010, 1012,
- 1014, 1016, 1022, 1025, 1028, 1031, 1043, 1048, 1052, 1056,
- 1061, 1063, 1067, 1071, 1073, 1082, 1086, 1089, 1092, 1097,
- 1100, 1102, 1110, 1123, 1128, 1134, 1136, 1138, 1151, 1154,
- 1156, 1158, 1160, 1162, 1164, 1166, 1168, 1170, 1172, 1174,
- 1176, 1178, 1180, 1182, 1184, 1186, 1188, 1190, 1192, 1194,
- 1198, 1200, 1202, 1219, 1222, 1223, 1224, 1225, 1226, 1229,
- 1232, 1235, 1239, 1242, 1244, 1249, 1251, 1252, 1255, 1257,
- 1259, 1261, 1265, 1268, 1272, 1274, 1275, 1276, 1280, 1288,
- 1289, 1290, 1298, 1300, 1303, 1305, 1315, 1317, 1319, 1321,
- 1323, 1325, 1328, 1330, 1374, 1375, 1379, 1383, 1387, 1391,
- 1393, 1397, 1399, 1401, 1409, 1411, 1413, 1415, 1419, 1421,
- 1423, 1425, 1430, 1432, 1434, 1436, 1439, 1441, 1443, 1487,
- 1490, 1494, 1497, 1501, 1504, 1509, 1511, 1515, 1528, 1531,
- 1538, 1545, 1550, 1552, 1557, 1559, 1566, 1568, 1572, 1576,
- 1582, 1586, 1589, 1592, 1595, 1605, 1607, 1610, 1614, 1617,
- 1620, 1623, 1626, 1632, 1638, 1640, 1645, 1647, 1656, 1659,
- 1661, 1664, 1670, 1672, 1682, 1686, 1689, 1692, 1697, 1700,
- 1708, 1710, 1712, 1714, 1717, 1720, 1735, 1754, 1757, 1759,
- 1762, 1764, 1767, 1769, 1772, 1774, 1777, 1780, 1784, 1790,
- 1791, 1803, 1810, 1813, 1819, 1823, 1828, 1834, 1835, 1843,
- 1846, 1850, 1853, 1857, 1862, 1865, 1869, 1872, 1874, 1876,
- 1878, 1885, 1887, 1888, 1889, 1893, 1896, 1900, 1903, 1909,
- 1911, 1914, 1917, 1920, 1926, 1929, 1932, 1934, 1936, 1940,
- 1946, 1954, 1956, 1960, 1962, 1967, 1970, 1973, 1975, 1977,
- 1981, 1985, 1990, 1994, 1997, 2002, 2006, 2009, 2012, 2016,
- 2028, 2030, 2033, 2053, 2055, 2058, 2060, 2065, 2067, 2069,
- 2071, 2073, 2077, 2082, 2087, 2093, 2098, 2103, 2105, 2109,
- 2114, 2117, 2124, 2152, 2158, 2160, 2163, 2166, 2168, 2172,
- 2174, 2178, 2204, 2233, 2236, 2237, 2258, 2281, 2283, 2287,
- 2298, 2312, 2317, 2324, 2327, 2335, 2346, 2355, 2359, 2374,
- 2377, 2382, 2384, 2386, 2388, 2390, 2392, 2395, 2397, 2409,
- 2415, 2417, 2420, 2423, 2425, 2436, 2441, 2444, 2449, 2452,
- 2453, 2464, 2467, 2468, 2479, 2481, 2484, 2486, 2489, 2496,
- 2504, 2511, 2517, 2523, 2531, 2535, 2540, 2544, 2547, 2556,
- 2558, 2562, 2565, 2570, 2574, 2580, 2591, 2594, 2598, 2602,
- 2610, 2615, 2621, 2624, 2626, 2628, 2634, 2637, 2639, 2641,
- 2643, 2647, 2650, 2668, 2678, 2680, 2681, 2685, 2690, 2693,
- 2695, 2697, 2699, 2703, 2709, 2712, 2714, 2716, 2718, 2722,
- 2725, 2728, 2730, 2732, 2734, 2738, 2741, 2744, 2746, 2748,
- 2750, 2757, 2768, 2772, 2777, 2781, 2786, 2788, 2792, 2795,
- 2797, 2801, 2803, 2804, 2807, 2809, 2811, 2817, 2832, 2838,
- 2844, 2858, 2860, 2864, 2878, 2880, 2882, 2886, 2892, 2905,
- 2907, 2911, 2924, 2930, 2932, 2933, 2934, 2942, 2947, 2956,
- 2957, 2961, 2964, 2970, 2976, 2979, 2981, 2983, 2985, 2989,
- 2993, 2997, 3000, 3005, 3008, 3010, 3012, 3014, 3016, 3018,
- 3020, 3022, 3026, 3030, 3034, 3038, 3039, 3041, 3043, 3045,
- 3047, 3049, 3051, 3053, 3055, 3063, 3065, 3066, 3067, 3070,
- 3076, 3078, 3083, 3085, 3088, 3102, 3105, 3108, 3112, 3115,
- 3122, 3124, 3127, 3129, 3131, 3134, 3137, 3140, 3143, 3145,
- 3148, 3152, 3154, 3160, 3162, 3163, 3165, 3170, 3172, 3174,
- 3176, 3178, 3181, 3182, 3184, 3187, 3188, 3191, 3191, 3194,
- 3194, 3197, 3197, 3199, 3201, 3203, 3205, 3211, 3217, 3220,
- 3223, 3229, 3231, 3233, 3237, 3239, 3242, 3249, 3255, 3264,
- 3268, 3270, 3273, 3275, 3278, 3282, 3284, 3287, 3289, 3292,
- 3309, 3315, 3323, 3325, 3327, 3331, 3334, 3335, 3343, 3347,
- 3351, 3354, 3355, 3361, 3364, 3367, 3369, 3373, 3378, 3381,
- 3391, 3396, 3397, 3404, 3407, 3410, 3412, 3415, 3417, 3427,
- 3441, 3445, 3448, 3450, 3454, 3458, 3461, 3464, 3466, 3470,
- 3472, 3479, 3486, 3489, 3492, 3496, 3500, 3506, 3510, 3515,
- 3517, 3520, 3525, 3531, 3542, 3545, 3547, 3551, 3556, 3558,
- 3565, 3568, 3570, 3572, 3578, 3583, 3586, 3588, 3590, 3592,
- 3594, 3596, 3598, 3600, 3602, 3604, 3606, 3608, 3610, 3612,
- 3614, 3616, 3618, 3620, 3622, 3624, 3626, 3628, 3630, 3632,
- 3634, 3636, 3638, 3640, 3642, 3644, 3646, 3648, 3651, 3653
+ 329, 331, 339, 342, 343, 347, 349, 352, 357, 361,
+ 367, 371, 374, 378, 381, 383, 385, 388, 390, 393,
+ 396, 398, 400, 402, 404, 406, 408, 417, 421, 424,
+ 426, 430, 432, 433, 435, 439, 442, 448, 451, 453,
+ 458, 461, 465, 468, 471, 474, 478, 483, 493, 495,
+ 497, 499, 501, 514, 523, 533, 535, 537, 541, 543,
+ 544, 551, 552, 553, 556, 559, 563, 565, 566, 569,
+ 571, 574, 577, 579, 583, 586, 588, 592, 594, 596,
+ 600, 602, 604, 608, 610, 612, 618, 622, 625, 628,
+ 631, 636, 639, 641, 643, 649, 659, 661, 664, 667,
+ 669, 672, 676, 685, 688, 690, 694, 707, 727, 730,
+ 732, 733, 736, 743, 749, 751, 753, 755, 757, 760,
+ 765, 767, 768, 769, 770, 773, 775, 776, 779, 781,
+ 782, 785, 790, 790, 794, 794, 797, 797, 800, 800,
+ 804, 804, 809, 809, 812, 812, 815, 817, 820, 827,
+ 834, 840, 843, 852, 854, 862, 865, 868, 871, 875,
+ 878, 881, 884, 886, 888, 890, 894, 897, 900, 905,
+ 909, 914, 918, 921, 923, 927, 946, 953, 956, 958,
+ 959, 960, 963, 967, 968, 972, 976, 979, 981, 985,
+ 988, 991, 995, 998, 1000, 1002, 1004, 1007, 1011, 1013,
+ 1015, 1017, 1023, 1026, 1029, 1032, 1044, 1049, 1053, 1057,
+ 1062, 1064, 1068, 1072, 1074, 1083, 1087, 1090, 1093, 1098,
+ 1101, 1103, 1111, 1124, 1129, 1135, 1137, 1139, 1152, 1155,
+ 1157, 1159, 1161, 1163, 1165, 1167, 1169, 1171, 1173, 1175,
+ 1177, 1179, 1181, 1183, 1185, 1187, 1189, 1191, 1193, 1195,
+ 1199, 1201, 1203, 1220, 1223, 1224, 1225, 1226, 1227, 1230,
+ 1233, 1236, 1240, 1243, 1245, 1250, 1252, 1253, 1256, 1258,
+ 1260, 1262, 1266, 1269, 1273, 1275, 1276, 1277, 1281, 1289,
+ 1290, 1291, 1299, 1301, 1304, 1306, 1316, 1318, 1320, 1322,
+ 1324, 1326, 1329, 1331, 1375, 1376, 1380, 1384, 1388, 1392,
+ 1394, 1398, 1400, 1402, 1410, 1412, 1414, 1416, 1420, 1422,
+ 1424, 1426, 1431, 1433, 1435, 1437, 1440, 1442, 1444, 1488,
+ 1491, 1495, 1498, 1502, 1505, 1510, 1512, 1516, 1529, 1532,
+ 1539, 1546, 1551, 1553, 1558, 1560, 1567, 1569, 1573, 1577,
+ 1583, 1587, 1590, 1593, 1596, 1606, 1608, 1611, 1615, 1618,
+ 1621, 1624, 1627, 1633, 1639, 1641, 1646, 1648, 1657, 1660,
+ 1662, 1665, 1671, 1673, 1683, 1687, 1690, 1693, 1698, 1701,
+ 1709, 1711, 1713, 1715, 1718, 1721, 1736, 1755, 1758, 1760,
+ 1763, 1765, 1768, 1770, 1773, 1775, 1778, 1781, 1785, 1791,
+ 1792, 1804, 1811, 1814, 1820, 1824, 1829, 1835, 1836, 1844,
+ 1847, 1851, 1854, 1858, 1863, 1866, 1870, 1873, 1875, 1877,
+ 1879, 1886, 1888, 1889, 1890, 1894, 1897, 1901, 1904, 1910,
+ 1912, 1915, 1918, 1921, 1927, 1930, 1933, 1935, 1937, 1941,
+ 1947, 1955, 1957, 1961, 1963, 1968, 1971, 1974, 1976, 1978,
+ 1982, 1986, 1991, 1995, 1998, 2003, 2007, 2010, 2013, 2017,
+ 2029, 2031, 2034, 2054, 2056, 2059, 2061, 2066, 2068, 2070,
+ 2072, 2074, 2078, 2083, 2088, 2094, 2099, 2104, 2106, 2110,
+ 2115, 2118, 2125, 2153, 2159, 2161, 2164, 2167, 2169, 2173,
+ 2175, 2179, 2205, 2234, 2237, 2238, 2259, 2282, 2284, 2288,
+ 2299, 2313, 2318, 2325, 2328, 2336, 2347, 2356, 2360, 2375,
+ 2378, 2383, 2385, 2387, 2389, 2391, 2393, 2396, 2398, 2402,
+ 2408, 2410, 2413, 2416, 2418, 2429, 2434, 2437, 2442, 2445,
+ 2446, 2457, 2460, 2461, 2472, 2474, 2477, 2479, 2482, 2489,
+ 2497, 2504, 2510, 2516, 2524, 2528, 2533, 2537, 2540, 2549,
+ 2551, 2555, 2558, 2563, 2567, 2573, 2584, 2587, 2591, 2595,
+ 2603, 2608, 2614, 2617, 2619, 2621, 2627, 2630, 2632, 2634,
+ 2636, 2640, 2643, 2661, 2671, 2673, 2674, 2678, 2683, 2686,
+ 2688, 2690, 2692, 2696, 2702, 2705, 2707, 2709, 2711, 2715,
+ 2718, 2721, 2723, 2725, 2727, 2731, 2734, 2737, 2739, 2741,
+ 2743, 2750, 2761, 2765, 2770, 2774, 2779, 2781, 2785, 2788,
+ 2790, 2794, 2796, 2797, 2800, 2802, 2804, 2810, 2825, 2831,
+ 2837, 2851, 2853, 2857, 2871, 2873, 2875, 2879, 2885, 2898,
+ 2900, 2904, 2917, 2923, 2925, 2926, 2927, 2935, 2940, 2949,
+ 2950, 2954, 2957, 2963, 2969, 2972, 2974, 2976, 2978, 2982,
+ 2986, 2990, 2993, 2998, 3001, 3003, 3005, 3007, 3009, 3011,
+ 3013, 3015, 3019, 3023, 3027, 3031, 3032, 3034, 3036, 3038,
+ 3040, 3042, 3044, 3046, 3048, 3056, 3058, 3059, 3060, 3063,
+ 3069, 3071, 3076, 3078, 3081, 3095, 3098, 3101, 3105, 3108,
+ 3115, 3117, 3120, 3122, 3124, 3127, 3130, 3133, 3136, 3138,
+ 3141, 3145, 3147, 3153, 3155, 3156, 3158, 3163, 3165, 3167,
+ 3169, 3171, 3174, 3175, 3177, 3180, 3181, 3184, 3184, 3187,
+ 3187, 3190, 3190, 3192, 3194, 3196, 3198, 3204, 3210, 3213,
+ 3216, 3222, 3224, 3226, 3230, 3232, 3235, 3242, 3248, 3257,
+ 3261, 3263, 3266, 3268, 3271, 3275, 3277, 3280, 3282, 3285,
+ 3302, 3308, 3316, 3318, 3320, 3324, 3327, 3328, 3336, 3340,
+ 3344, 3347, 3348, 3354, 3357, 3360, 3362, 3366, 3371, 3374,
+ 3384, 3389, 3390, 3397, 3400, 3403, 3405, 3408, 3410, 3420,
+ 3434, 3438, 3441, 3443, 3447, 3451, 3454, 3457, 3459, 3463,
+ 3465, 3472, 3479, 3482, 3485, 3489, 3493, 3499, 3503, 3508,
+ 3510, 3513, 3518, 3524, 3535, 3538, 3540, 3544, 3549, 3551,
+ 3558, 3561, 3563, 3565, 3571, 3576, 3579, 3581, 3583, 3585,
+ 3587, 3589, 3591, 3593, 3595, 3597, 3599, 3601, 3603, 3605,
+ 3607, 3609, 3611, 3613, 3615, 3617, 3619, 3621, 3623, 3625,
+ 3627, 3629, 3631, 3633, 3635, 3637, 3639, 3641, 3644, 3646
};
#endif
@@ -3987,102 +3987,102 @@ yyreduce:
switch (yyn) {
case 2:
-#line 331 "parse.y"
+#line 332 "parse.y"
{ finish_translation_unit (); ;
break;}
case 3:
-#line 339 "parse.y"
+#line 340 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 4:
-#line 341 "parse.y"
+#line 342 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 5:
-#line 343 "parse.y"
+#line 344 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 8:
-#line 352 "parse.y"
+#line 353 "parse.y"
{ have_extern_spec = 1;
used_extern_spec = 0;
yyval.ttype = NULL_TREE; ;
break;}
case 9:
-#line 357 "parse.y"
+#line 358 "parse.y"
{ have_extern_spec = 0; ;
break;}
case 10:
-#line 362 "parse.y"
+#line 363 "parse.y"
{ yyval.itype = pedantic;
pedantic = 0; ;
break;}
case 12:
-#line 371 "parse.y"
+#line 372 "parse.y"
{ if (pending_lang_change) do_pending_lang_change(); ;
break;}
case 13:
-#line 373 "parse.y"
+#line 374 "parse.y"
{ if (! toplevel_bindings_p () && ! pseudo_global_level_p())
pop_everything (); ;
break;}
case 14:
-#line 379 "parse.y"
+#line 380 "parse.y"
{ if (pending_inlines) do_pending_inlines (); ;
break;}
case 15:
-#line 381 "parse.y"
+#line 382 "parse.y"
{ if (pending_inlines) do_pending_inlines (); ;
break;}
case 16:
-#line 383 "parse.y"
+#line 384 "parse.y"
{ if (pending_inlines) do_pending_inlines (); ;
break;}
case 17:
-#line 385 "parse.y"
+#line 386 "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 388 "parse.y"
+#line 389 "parse.y"
{ pop_lang_context (); ;
break;}
case 19:
-#line 390 "parse.y"
+#line 391 "parse.y"
{ if (pending_inlines) do_pending_inlines ();
pop_lang_context (); ;
break;}
case 20:
-#line 393 "parse.y"
+#line 394 "parse.y"
{ if (pending_inlines) do_pending_inlines ();
pop_lang_context (); ;
break;}
case 21:
-#line 396 "parse.y"
+#line 397 "parse.y"
{ push_namespace (yyvsp[-1].ttype); ;
break;}
case 22:
-#line 398 "parse.y"
+#line 399 "parse.y"
{ pop_namespace (); ;
break;}
case 23:
-#line 400 "parse.y"
+#line 401 "parse.y"
{ push_namespace (NULL_TREE); ;
break;}
case 24:
-#line 402 "parse.y"
+#line 403 "parse.y"
{ pop_namespace (); ;
break;}
case 25:
-#line 404 "parse.y"
+#line 405 "parse.y"
{ do_namespace_alias (yyvsp[-3].ttype, yyvsp[-1].ttype); ;
break;}
case 26:
-#line 406 "parse.y"
+#line 407 "parse.y"
{ do_toplevel_using_decl (yyvsp[-1].ttype); ;
break;}
case 27:
-#line 408 "parse.y"
+#line 409 "parse.y"
{
/* If no declaration was found, the using-directive is
invalid. Since that was not reported, we need the
@@ -4093,102 +4093,102 @@ case 27:
;
break;}
case 28:
-#line 417 "parse.y"
+#line 418 "parse.y"
{ pedantic = yyvsp[-1].itype; ;
break;}
case 29:
-#line 422 "parse.y"
+#line 423 "parse.y"
{ yyval.ttype = yyvsp[0].ttype; ;
break;}
case 30:
-#line 424 "parse.y"
+#line 425 "parse.y"
{ yyval.ttype = yyvsp[0].ttype; ;
break;}
case 31:
-#line 426 "parse.y"
+#line 427 "parse.y"
{ yyval.ttype = yyvsp[0].ttype; ;
break;}
case 34:
-#line 433 "parse.y"
+#line 434 "parse.y"
{ yyval.ttype = yyvsp[0].ttype; ;
break;}
case 35:
-#line 435 "parse.y"
+#line 436 "parse.y"
{ yyval.ttype = yyvsp[0].ttype; ;
break;}
case 36:
-#line 440 "parse.y"
+#line 441 "parse.y"
{ push_lang_context (yyvsp[0].ttype); ;
break;}
case 37:
-#line 442 "parse.y"
+#line 443 "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 38:
-#line 449 "parse.y"
+#line 450 "parse.y"
{ begin_template_parm_list (); ;
break;}
case 39:
-#line 451 "parse.y"
+#line 452 "parse.y"
{ yyval.ttype = end_template_parm_list (yyvsp[-1].ttype); ;
break;}
case 40:
-#line 453 "parse.y"
+#line 454 "parse.y"
{ begin_specialization();
yyval.ttype = NULL_TREE; ;
break;}
case 41:
-#line 459 "parse.y"
+#line 460 "parse.y"
{ yyval.ttype = process_template_parm (NULL_TREE, yyvsp[0].ttype); ;
break;}
case 42:
-#line 461 "parse.y"
+#line 462 "parse.y"
{ yyval.ttype = process_template_parm (yyvsp[-2].ttype, yyvsp[0].ttype); ;
break;}
case 43:
-#line 466 "parse.y"
+#line 467 "parse.y"
{ yyval.ttype = yyvsp[0].ttype; ;
break;}
case 44:
-#line 468 "parse.y"
+#line 469 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 45:
-#line 472 "parse.y"
+#line 473 "parse.y"
{ yyval.ttype = finish_template_type_parm (yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 46:
-#line 474 "parse.y"
+#line 475 "parse.y"
{ yyval.ttype = finish_template_type_parm (class_type_node, yyvsp[0].ttype); ;
break;}
case 47:
-#line 479 "parse.y"
+#line 480 "parse.y"
{ yyval.ttype = finish_template_template_parm (yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 48:
-#line 491 "parse.y"
+#line 492 "parse.y"
{ yyval.ttype = build_tree_list (NULL_TREE, yyvsp[0].ttype); ;
break;}
case 49:
-#line 493 "parse.y"
+#line 494 "parse.y"
{ yyval.ttype = build_tree_list (groktypename (yyvsp[0].ftype.t), yyvsp[-2].ttype); ;
break;}
case 50:
-#line 495 "parse.y"
+#line 496 "parse.y"
{ yyval.ttype = build_tree_list (NULL_TREE, yyvsp[0].ftype.t); ;
break;}
case 51:
-#line 497 "parse.y"
+#line 498 "parse.y"
{ yyval.ttype = build_tree_list (yyvsp[0].ttype, yyvsp[-2].ftype.t); ;
break;}
case 52:
-#line 499 "parse.y"
+#line 500 "parse.y"
{ yyval.ttype = build_tree_list (NULL_TREE, yyvsp[0].ttype); ;
break;}
case 53:
-#line 501 "parse.y"
+#line 502 "parse.y"
{
if (TREE_CODE (yyvsp[0].ttype) != TEMPLATE_DECL
&& TREE_CODE (yyvsp[0].ttype) != TEMPLATE_TEMPLATE_PARM
@@ -4201,7 +4201,7 @@ case 53:
;
break;}
case 54:
-#line 516 "parse.y"
+#line 517 "parse.y"
{
if (yyvsp[-1].ttype)
end_template_decl ();
@@ -4210,7 +4210,7 @@ case 54:
;
break;}
case 55:
-#line 524 "parse.y"
+#line 525 "parse.y"
{
if (yyvsp[-1].ttype)
end_template_decl ();
@@ -4219,21 +4219,21 @@ case 55:
;
break;}
case 57:
-#line 535 "parse.y"
+#line 536 "parse.y"
{;
break;}
case 58:
-#line 537 "parse.y"
+#line 538 "parse.y"
{
note_list_got_semicolon (yyvsp[-2].ftype.t);
;
break;}
case 59:
-#line 541 "parse.y"
+#line 542 "parse.y"
{ pedwarn ("empty declaration"); ;
break;}
case 61:
-#line 544 "parse.y"
+#line 545 "parse.y"
{
tree t, attrs;
split_specs_attrs (yyvsp[-1].ftype.t, &t, &attrs);
@@ -4242,124 +4242,124 @@ case 61:
;
break;}
case 65:
-#line 557 "parse.y"
+#line 558 "parse.y"
{ yyval.itype = 0; ;
break;}
case 66:
-#line 559 "parse.y"
+#line 560 "parse.y"
{ yyval.itype = 1; ;
break;}
case 72:
-#line 575 "parse.y"
+#line 576 "parse.y"
{ finish_function (lineno, (int)yyvsp[-1].itype, 0); ;
break;}
case 73:
-#line 577 "parse.y"
+#line 578 "parse.y"
{ ;
break;}
case 74:
-#line 579 "parse.y"
+#line 580 "parse.y"
{ ;
break;}
case 75:
-#line 584 "parse.y"
+#line 585 "parse.y"
{ yyval.ttype = begin_constructor_declarator (yyvsp[-2].ttype, yyvsp[-1].ttype); ;
break;}
case 76:
-#line 586 "parse.y"
+#line 587 "parse.y"
{ yyval.ttype = make_call_declarator (yyvsp[-4].ttype, yyvsp[-3].ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 77:
-#line 588 "parse.y"
+#line 589 "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 78:
-#line 592 "parse.y"
+#line 593 "parse.y"
{ yyval.ttype = begin_constructor_declarator (yyvsp[-2].ttype, yyvsp[-1].ttype); ;
break;}
case 79:
-#line 594 "parse.y"
+#line 595 "parse.y"
{ yyval.ttype = make_call_declarator (yyvsp[-4].ttype, yyvsp[-3].ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 80:
-#line 596 "parse.y"
+#line 597 "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 81:
-#line 600 "parse.y"
+#line 601 "parse.y"
{ yyval.ttype = begin_constructor_declarator (yyvsp[-2].ttype, yyvsp[-1].ttype); ;
break;}
case 82:
-#line 602 "parse.y"
+#line 603 "parse.y"
{ yyval.ttype = make_call_declarator (yyvsp[-4].ttype, yyvsp[-3].ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 83:
-#line 604 "parse.y"
+#line 605 "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 84:
-#line 608 "parse.y"
+#line 609 "parse.y"
{ yyval.ttype = begin_constructor_declarator (yyvsp[-2].ttype, yyvsp[-1].ttype); ;
break;}
case 85:
-#line 610 "parse.y"
+#line 611 "parse.y"
{ yyval.ttype = make_call_declarator (yyvsp[-4].ttype, yyvsp[-3].ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 86:
-#line 612 "parse.y"
+#line 613 "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 87:
-#line 619 "parse.y"
+#line 620 "parse.y"
{ if (!begin_function_definition (yyvsp[-1].ftype.t, yyvsp[0].ttype))
YYERROR1; ;
break;}
case 88:
-#line 622 "parse.y"
+#line 623 "parse.y"
{ if (!begin_function_definition (yyvsp[-1].ttype, yyvsp[0].ttype))
YYERROR1; ;
break;}
case 89:
-#line 625 "parse.y"
+#line 626 "parse.y"
{ if (!begin_function_definition (NULL_TREE, yyvsp[0].ttype))
YYERROR1; ;
break;}
case 90:
-#line 628 "parse.y"
+#line 629 "parse.y"
{ if (!begin_function_definition (yyvsp[-1].ttype, yyvsp[0].ttype))
YYERROR1; ;
break;}
case 91:
-#line 631 "parse.y"
+#line 632 "parse.y"
{ if (!begin_function_definition (NULL_TREE, yyvsp[0].ttype))
YYERROR1; ;
break;}
case 92:
-#line 637 "parse.y"
+#line 638 "parse.y"
{ yyval.ttype = make_call_declarator (yyvsp[-5].ttype, yyvsp[-3].ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 93:
-#line 639 "parse.y"
+#line 640 "parse.y"
{ yyval.ttype = make_call_declarator (yyvsp[-3].ttype, empty_parms (), yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 94:
-#line 641 "parse.y"
+#line 642 "parse.y"
{ yyval.ttype = make_call_declarator (yyvsp[-5].ttype, yyvsp[-3].ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 95:
-#line 643 "parse.y"
+#line 644 "parse.y"
{ yyval.ttype = make_call_declarator (yyvsp[-3].ttype, empty_parms (), yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 96:
-#line 650 "parse.y"
+#line 651 "parse.y"
{ tree specs = strip_attrs (yyvsp[-1].ttype);
yyval.ttype = start_method (specs, yyvsp[0].ttype);
rest_of_mdef:
@@ -4370,34 +4370,34 @@ case 96:
reinit_parse_for_method (yychar, yyval.ttype); ;
break;}
case 97:
-#line 659 "parse.y"
+#line 660 "parse.y"
{ yyval.ttype = start_method (NULL_TREE, yyvsp[0].ttype); goto rest_of_mdef; ;
break;}
case 98:
-#line 661 "parse.y"
+#line 662 "parse.y"
{ tree specs = strip_attrs (yyvsp[-1].ftype.t);
yyval.ttype = start_method (specs, yyvsp[0].ttype); goto rest_of_mdef; ;
break;}
case 99:
-#line 664 "parse.y"
+#line 665 "parse.y"
{ tree specs = strip_attrs (yyvsp[-1].ttype);
yyval.ttype = start_method (specs, yyvsp[0].ttype); goto rest_of_mdef; ;
break;}
case 100:
-#line 667 "parse.y"
+#line 668 "parse.y"
{ yyval.ttype = start_method (NULL_TREE, yyval.ttype); goto rest_of_mdef; ;
break;}
case 101:
-#line 669 "parse.y"
+#line 670 "parse.y"
{ tree specs = strip_attrs (yyvsp[-1].ttype);
yyval.ttype = start_method (specs, yyvsp[0].ttype); goto rest_of_mdef; ;
break;}
case 102:
-#line 672 "parse.y"
+#line 673 "parse.y"
{ yyval.ttype = start_method (NULL_TREE, yyval.ttype); goto rest_of_mdef; ;
break;}
case 103:
-#line 677 "parse.y"
+#line 678 "parse.y"
{
if (! current_function_parms_stored)
store_parm_decls ();
@@ -4405,19 +4405,19 @@ case 103:
;
break;}
case 104:
-#line 686 "parse.y"
+#line 687 "parse.y"
{ store_return_init (yyval.ttype, yyvsp[0].ttype); ;
break;}
case 105:
-#line 688 "parse.y"
+#line 689 "parse.y"
{ store_return_init (yyval.ttype, yyvsp[-1].ttype); ;
break;}
case 106:
-#line 690 "parse.y"
+#line 691 "parse.y"
{ store_return_init (yyval.ttype, NULL_TREE); ;
break;}
case 107:
-#line 695 "parse.y"
+#line 696 "parse.y"
{
if (yyvsp[0].itype == 0)
error ("no base initializers given following ':'");
@@ -4429,7 +4429,7 @@ case 107:
;
break;}
case 108:
-#line 708 "parse.y"
+#line 709 "parse.y"
{
if (! current_function_parms_stored)
store_parm_decls ();
@@ -4448,15 +4448,15 @@ case 108:
;
break;}
case 109:
-#line 728 "parse.y"
+#line 729 "parse.y"
{ yyval.itype = 0; ;
break;}
case 110:
-#line 730 "parse.y"
+#line 731 "parse.y"
{ yyval.itype = 1; ;
break;}
case 113:
-#line 737 "parse.y"
+#line 738 "parse.y"
{
if (current_class_name)
pedwarn ("anachronistic old style base class initializer");
@@ -4464,7 +4464,7 @@ case 113:
;
break;}
case 114:
-#line 743 "parse.y"
+#line 744 "parse.y"
{
if (current_class_name)
pedwarn ("anachronistic old style base class initializer");
@@ -4472,77 +4472,77 @@ case 114:
;
break;}
case 115:
-#line 749 "parse.y"
+#line 750 "parse.y"
{ expand_member_init (current_class_ref, yyvsp[-3].ttype, yyvsp[-1].ttype); ;
break;}
case 116:
-#line 751 "parse.y"
+#line 752 "parse.y"
{ expand_member_init (current_class_ref, yyvsp[-1].ttype, void_type_node); ;
break;}
case 117:
-#line 753 "parse.y"
+#line 754 "parse.y"
{ expand_member_init (current_class_ref, yyvsp[-3].ttype, yyvsp[-1].ttype); ;
break;}
case 118:
-#line 755 "parse.y"
+#line 756 "parse.y"
{ expand_member_init (current_class_ref, yyvsp[-1].ttype, void_type_node); ;
break;}
case 119:
-#line 757 "parse.y"
+#line 758 "parse.y"
{ expand_member_init (current_class_ref, TYPE_MAIN_DECL (yyvsp[-3].ttype),
yyvsp[-1].ttype); ;
break;}
case 120:
-#line 760 "parse.y"
+#line 761 "parse.y"
{ expand_member_init (current_class_ref, TYPE_MAIN_DECL (yyvsp[-1].ttype),
void_type_node); ;
break;}
case 132:
-#line 786 "parse.y"
+#line 787 "parse.y"
{ do_type_instantiation (yyvsp[-1].ftype.t, NULL_TREE);
yyungetc (';', 1); ;
break;}
case 134:
-#line 790 "parse.y"
+#line 791 "parse.y"
{ tree specs = strip_attrs (yyvsp[-1].ftype.t);
do_decl_instantiation (specs, yyvsp[0].ttype, NULL_TREE); ;
break;}
case 136:
-#line 794 "parse.y"
+#line 795 "parse.y"
{ do_decl_instantiation (NULL_TREE, yyvsp[0].ttype, NULL_TREE); ;
break;}
case 138:
-#line 797 "parse.y"
+#line 798 "parse.y"
{ do_decl_instantiation (NULL_TREE, yyvsp[0].ttype, NULL_TREE); ;
break;}
case 140:
-#line 800 "parse.y"
+#line 801 "parse.y"
{ do_type_instantiation (yyvsp[-1].ftype.t, yyvsp[-4].ttype);
yyungetc (';', 1); ;
break;}
case 142:
-#line 805 "parse.y"
+#line 806 "parse.y"
{ tree specs = strip_attrs (yyvsp[-1].ftype.t);
do_decl_instantiation (specs, yyvsp[0].ttype, yyvsp[-4].ttype); ;
break;}
case 144:
-#line 809 "parse.y"
+#line 810 "parse.y"
{ do_decl_instantiation (NULL_TREE, yyvsp[0].ttype, yyvsp[-3].ttype); ;
break;}
case 146:
-#line 812 "parse.y"
+#line 813 "parse.y"
{ do_decl_instantiation (NULL_TREE, yyvsp[0].ttype, yyvsp[-3].ttype); ;
break;}
case 148:
-#line 817 "parse.y"
+#line 818 "parse.y"
{ begin_explicit_instantiation(); ;
break;}
case 149:
-#line 820 "parse.y"
+#line 821 "parse.y"
{ end_explicit_instantiation(); ;
break;}
case 150:
-#line 828 "parse.y"
+#line 829 "parse.y"
{
yyval.ttype = lookup_template_class (yyvsp[-3].ttype, yyvsp[-1].ttype, NULL_TREE, NULL_TREE);
if (yyval.ttype != error_mark_node)
@@ -4550,7 +4550,7 @@ case 150:
;
break;}
case 151:
-#line 834 "parse.y"
+#line 835 "parse.y"
{
yyval.ttype = lookup_template_class (yyvsp[-3].ttype, yyvsp[-1].ttype, NULL_TREE, NULL_TREE);
if (yyval.ttype != error_mark_node)
@@ -4558,7 +4558,7 @@ case 151:
;
break;}
case 153:
-#line 844 "parse.y"
+#line 845 "parse.y"
{
yyval.ttype = lookup_template_class (yyvsp[-3].ttype, yyvsp[-1].ttype, NULL_TREE, NULL_TREE);
if (yyval.ttype != error_mark_node)
@@ -4566,7 +4566,7 @@ case 153:
;
break;}
case 155:
-#line 854 "parse.y"
+#line 855 "parse.y"
{
/* Handle `Class<Class<Type>>' without space in the `>>' */
pedwarn ("`>>' should be `> >' in template class name");
@@ -4574,79 +4574,79 @@ case 155:
;
break;}
case 156:
-#line 863 "parse.y"
+#line 864 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 158:
-#line 869 "parse.y"
+#line 870 "parse.y"
{ yyval.ttype = build_tree_list (NULL_TREE, yyval.ttype); ;
break;}
case 159:
-#line 871 "parse.y"
+#line 872 "parse.y"
{ yyval.ttype = chainon (yyval.ttype, build_tree_list (NULL_TREE, yyvsp[0].ttype)); ;
break;}
case 160:
-#line 876 "parse.y"
+#line 877 "parse.y"
{ yyval.ttype = groktypename (yyvsp[0].ftype.t); ;
break;}
case 162:
-#line 882 "parse.y"
+#line 883 "parse.y"
{ yyval.code = NEGATE_EXPR; ;
break;}
case 163:
-#line 884 "parse.y"
+#line 885 "parse.y"
{ yyval.code = CONVERT_EXPR; ;
break;}
case 164:
-#line 886 "parse.y"
+#line 887 "parse.y"
{ yyval.code = PREINCREMENT_EXPR; ;
break;}
case 165:
-#line 888 "parse.y"
+#line 889 "parse.y"
{ yyval.code = PREDECREMENT_EXPR; ;
break;}
case 166:
-#line 890 "parse.y"
+#line 891 "parse.y"
{ yyval.code = TRUTH_NOT_EXPR; ;
break;}
case 167:
-#line 895 "parse.y"
+#line 896 "parse.y"
{ yyval.ttype = build_x_compound_expr (yyval.ttype); ;
break;}
case 169:
-#line 901 "parse.y"
+#line 902 "parse.y"
{ error ("ANSI C++ forbids an empty condition for `%s'",
cond_stmt_keyword);
yyval.ttype = integer_zero_node; ;
break;}
case 170:
-#line 905 "parse.y"
+#line 906 "parse.y"
{ yyval.ttype = yyvsp[-1].ttype; ;
break;}
case 171:
-#line 910 "parse.y"
+#line 911 "parse.y"
{ error ("ANSI C++ forbids an empty condition for `%s'",
cond_stmt_keyword);
yyval.ttype = integer_zero_node; ;
break;}
case 172:
-#line 914 "parse.y"
+#line 915 "parse.y"
{ yyval.ttype = yyvsp[-1].ttype; ;
break;}
case 173:
-#line 919 "parse.y"
+#line 920 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 174:
-#line 921 "parse.y"
+#line 922 "parse.y"
{ yyval.ttype = condition_conversion (yyval.ttype); ;
break;}
case 175:
-#line 923 "parse.y"
+#line 924 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 176:
-#line 928 "parse.y"
+#line 929 "parse.y"
{ {
tree d;
for (d = getdecls (); d; d = TREE_CHAIN (d))
@@ -4665,7 +4665,7 @@ case 176:
;
break;}
case 177:
-#line 945 "parse.y"
+#line 946 "parse.y"
{
cp_finish_decl (yyvsp[-1].ttype, yyvsp[0].ttype, yyvsp[-3].ttype, 1, LOOKUP_ONLYCONVERTING);
resume_momentary (yyvsp[-2].itype);
@@ -4675,182 +4675,182 @@ case 177:
;
break;}
case 183:
-#line 964 "parse.y"
+#line 965 "parse.y"
{ yyval.ttype = begin_compound_stmt (1); ;
break;}
case 184:
-#line 966 "parse.y"
+#line 967 "parse.y"
{ finish_compound_stmt (1, yyvsp[-1].ttype); ;
break;}
case 186:
-#line 973 "parse.y"
+#line 974 "parse.y"
{ yyval.ttype = expr_tree_cons (NULL_TREE, yyval.ttype,
build_expr_list (NULL_TREE, yyvsp[0].ttype)); ;
break;}
case 187:
-#line 976 "parse.y"
+#line 977 "parse.y"
{ yyval.ttype = expr_tree_cons (NULL_TREE, yyval.ttype,
build_expr_list (NULL_TREE, error_mark_node)); ;
break;}
case 188:
-#line 979 "parse.y"
+#line 980 "parse.y"
{ chainon (yyval.ttype, build_expr_list (NULL_TREE, yyvsp[0].ttype)); ;
break;}
case 189:
-#line 981 "parse.y"
+#line 982 "parse.y"
{ chainon (yyval.ttype, build_expr_list (NULL_TREE, error_mark_node)); ;
break;}
case 190:
-#line 986 "parse.y"
+#line 987 "parse.y"
{ yyval.ttype = build_expr_list (NULL_TREE, yyval.ttype); ;
break;}
case 192:
-#line 992 "parse.y"
+#line 993 "parse.y"
{ yyval.ttype = yyvsp[0].ttype; ;
break;}
case 193:
-#line 995 "parse.y"
+#line 996 "parse.y"
{ yyval.ttype = yyvsp[0].ttype;
pedantic = yyvsp[-1].itype; ;
break;}
case 194:
-#line 998 "parse.y"
+#line 999 "parse.y"
{ yyval.ttype = build_x_indirect_ref (yyvsp[0].ttype, "unary *"); ;
break;}
case 195:
-#line 1000 "parse.y"
+#line 1001 "parse.y"
{ yyval.ttype = build_x_unary_op (ADDR_EXPR, yyvsp[0].ttype); ;
break;}
case 196:
-#line 1002 "parse.y"
+#line 1003 "parse.y"
{ yyval.ttype = build_x_unary_op (BIT_NOT_EXPR, yyvsp[0].ttype); ;
break;}
case 197:
-#line 1004 "parse.y"
+#line 1005 "parse.y"
{ yyval.ttype = finish_unary_op_expr (yyvsp[-1].code, yyvsp[0].ttype); ;
break;}
case 198:
-#line 1007 "parse.y"
+#line 1008 "parse.y"
{ if (pedantic)
pedwarn ("ANSI C++ forbids `&&'");
yyval.ttype = finish_label_address_expr (yyvsp[0].ttype); ;
break;}
case 199:
-#line 1011 "parse.y"
+#line 1012 "parse.y"
{ yyval.ttype = expr_sizeof (yyvsp[0].ttype); ;
break;}
case 200:
-#line 1013 "parse.y"
+#line 1014 "parse.y"
{ yyval.ttype = c_sizeof (groktypename (yyvsp[-1].ftype.t)); ;
break;}
case 201:
-#line 1015 "parse.y"
+#line 1016 "parse.y"
{ yyval.ttype = grok_alignof (yyvsp[0].ttype); ;
break;}
case 202:
-#line 1017 "parse.y"
+#line 1018 "parse.y"
{ yyval.ttype = c_alignof (groktypename (yyvsp[-1].ftype.t));
check_for_new_type ("alignof", yyvsp[-1].ftype); ;
break;}
case 203:
-#line 1023 "parse.y"
+#line 1024 "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 204:
-#line 1026 "parse.y"
+#line 1027 "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 205:
-#line 1029 "parse.y"
+#line 1030 "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 206:
-#line 1032 "parse.y"
+#line 1033 "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 207:
-#line 1045 "parse.y"
+#line 1046 "parse.y"
{ yyval.ttype = build_new (NULL_TREE, groktypename(yyvsp[-1].ftype.t),
NULL_TREE, yyvsp[-4].itype);
check_for_new_type ("new", yyvsp[-1].ftype); ;
break;}
case 208:
-#line 1050 "parse.y"
+#line 1051 "parse.y"
{ yyval.ttype = build_new (NULL_TREE, groktypename(yyvsp[-2].ftype.t), yyvsp[0].ttype, yyvsp[-5].itype);
check_for_new_type ("new", yyvsp[-2].ftype); ;
break;}
case 209:
-#line 1054 "parse.y"
+#line 1055 "parse.y"
{ yyval.ttype = build_new (yyvsp[-4].ttype, groktypename(yyvsp[-1].ftype.t), NULL_TREE, yyvsp[-5].itype);
check_for_new_type ("new", yyvsp[-1].ftype); ;
break;}
case 210:
-#line 1058 "parse.y"
+#line 1059 "parse.y"
{ yyval.ttype = build_new (yyvsp[-5].ttype, groktypename(yyvsp[-2].ftype.t), yyvsp[0].ttype, yyvsp[-6].itype);
check_for_new_type ("new", yyvsp[-2].ftype); ;
break;}
case 211:
-#line 1062 "parse.y"
+#line 1063 "parse.y"
{ yyval.ttype = delete_sanity (yyvsp[0].ttype, NULL_TREE, 0, yyvsp[-1].itype); ;
break;}
case 212:
-#line 1064 "parse.y"
+#line 1065 "parse.y"
{ yyval.ttype = delete_sanity (yyvsp[0].ttype, NULL_TREE, 1, yyvsp[-3].itype);
if (yychar == YYEMPTY)
yychar = YYLEX; ;
break;}
case 213:
-#line 1068 "parse.y"
+#line 1069 "parse.y"
{ yyval.ttype = delete_sanity (yyvsp[0].ttype, yyvsp[-2].ttype, 2, yyvsp[-4].itype);
if (yychar == YYEMPTY)
yychar = YYLEX; ;
break;}
case 214:
-#line 1072 "parse.y"
+#line 1073 "parse.y"
{ yyval.ttype = build_x_unary_op (REALPART_EXPR, yyvsp[0].ttype); ;
break;}
case 215:
-#line 1074 "parse.y"
+#line 1075 "parse.y"
{ yyval.ttype = build_x_unary_op (IMAGPART_EXPR, yyvsp[0].ttype); ;
break;}
case 216:
-#line 1084 "parse.y"
+#line 1085 "parse.y"
{ finish_new_placement (NULL_TREE, yyvsp[-2].itype); ;
break;}
case 217:
-#line 1087 "parse.y"
+#line 1088 "parse.y"
{ yyval.itype = begin_new_placement (); ;
break;}
case 218:
-#line 1091 "parse.y"
+#line 1092 "parse.y"
{ yyval.ttype = finish_new_placement (yyvsp[-1].ttype, yyvsp[-2].itype); ;
break;}
case 219:
-#line 1093 "parse.y"
+#line 1094 "parse.y"
{ cp_pedwarn ("old style placement syntax, use () instead");
yyval.ttype = finish_new_placement (yyvsp[-1].ttype, yyvsp[-2].itype); ;
break;}
case 220:
-#line 1099 "parse.y"
+#line 1100 "parse.y"
{ yyval.ttype = yyvsp[-1].ttype; ;
break;}
case 221:
-#line 1101 "parse.y"
+#line 1102 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 222:
-#line 1103 "parse.y"
+#line 1104 "parse.y"
{
cp_error ("`%T' is not a valid expression", yyvsp[-1].ftype.t);
yyval.ttype = error_mark_node;
;
break;}
case 223:
-#line 1111 "parse.y"
+#line 1112 "parse.y"
{
if (pedantic)
pedwarn ("ANSI C++ forbids initialization of new expression with `='");
@@ -4862,23 +4862,23 @@ case 223:
;
break;}
case 224:
-#line 1125 "parse.y"
+#line 1126 "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 225:
-#line 1129 "parse.y"
+#line 1130 "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 227:
-#line 1137 "parse.y"
+#line 1138 "parse.y"
{ yyval.ttype = reparse_absdcl_as_casts (yyval.ttype, yyvsp[0].ttype); ;
break;}
case 228:
-#line 1139 "parse.y"
+#line 1140 "parse.y"
{
tree init = build_nt (CONSTRUCTOR, NULL_TREE,
nreverse (yyvsp[-2].ttype));
@@ -4891,157 +4891,157 @@ case 228:
;
break;}
case 230:
-#line 1155 "parse.y"
+#line 1156 "parse.y"
{ yyval.ttype = build_x_binary_op (MEMBER_REF, yyval.ttype, yyvsp[0].ttype); ;
break;}
case 231:
-#line 1157 "parse.y"
+#line 1158 "parse.y"
{ yyval.ttype = build_m_component_ref (yyval.ttype, yyvsp[0].ttype); ;
break;}
case 232:
-#line 1159 "parse.y"
+#line 1160 "parse.y"
{ yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ;
break;}
case 233:
-#line 1161 "parse.y"
+#line 1162 "parse.y"
{ yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ;
break;}
case 234:
-#line 1163 "parse.y"
+#line 1164 "parse.y"
{ yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ;
break;}
case 235:
-#line 1165 "parse.y"
+#line 1166 "parse.y"
{ yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ;
break;}
case 236:
-#line 1167 "parse.y"
+#line 1168 "parse.y"
{ yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ;
break;}
case 237:
-#line 1169 "parse.y"
+#line 1170 "parse.y"
{ yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ;
break;}
case 238:
-#line 1171 "parse.y"
+#line 1172 "parse.y"
{ yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ;
break;}
case 239:
-#line 1173 "parse.y"
+#line 1174 "parse.y"
{ yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ;
break;}
case 240:
-#line 1175 "parse.y"
+#line 1176 "parse.y"
{ yyval.ttype = build_x_binary_op (LT_EXPR, yyval.ttype, yyvsp[0].ttype); ;
break;}
case 241:
-#line 1177 "parse.y"
+#line 1178 "parse.y"
{ yyval.ttype = build_x_binary_op (GT_EXPR, yyval.ttype, yyvsp[0].ttype); ;
break;}
case 242:
-#line 1179 "parse.y"
+#line 1180 "parse.y"
{ yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ;
break;}
case 243:
-#line 1181 "parse.y"
+#line 1182 "parse.y"
{ yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ;
break;}
case 244:
-#line 1183 "parse.y"
+#line 1184 "parse.y"
{ yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ;
break;}
case 245:
-#line 1185 "parse.y"
+#line 1186 "parse.y"
{ yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ;
break;}
case 246:
-#line 1187 "parse.y"
+#line 1188 "parse.y"
{ yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ;
break;}
case 247:
-#line 1189 "parse.y"
+#line 1190 "parse.y"
{ yyval.ttype = build_x_binary_op (TRUTH_ANDIF_EXPR, yyval.ttype, yyvsp[0].ttype); ;
break;}
case 248:
-#line 1191 "parse.y"
+#line 1192 "parse.y"
{ yyval.ttype = build_x_binary_op (TRUTH_ORIF_EXPR, yyval.ttype, yyvsp[0].ttype); ;
break;}
case 249:
-#line 1193 "parse.y"
+#line 1194 "parse.y"
{ yyval.ttype = build_x_conditional_expr (yyval.ttype, yyvsp[-2].ttype, yyvsp[0].ttype); ;
break;}
case 250:
-#line 1195 "parse.y"
+#line 1196 "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 251:
-#line 1199 "parse.y"
+#line 1200 "parse.y"
{ yyval.ttype = build_x_modify_expr (yyval.ttype, yyvsp[-1].code, yyvsp[0].ttype); ;
break;}
case 252:
-#line 1201 "parse.y"
+#line 1202 "parse.y"
{ yyval.ttype = build_throw (NULL_TREE); ;
break;}
case 253:
-#line 1203 "parse.y"
+#line 1204 "parse.y"
{ yyval.ttype = build_throw (yyvsp[0].ttype); ;
break;}
case 254:
-#line 1221 "parse.y"
+#line 1222 "parse.y"
{ yyval.ttype = build_parse_node (BIT_NOT_EXPR, yyvsp[0].ttype); ;
break;}
case 260:
-#line 1230 "parse.y"
+#line 1231 "parse.y"
{ yyval.ttype = do_identifier (yyvsp[-1].ttype, 1); ;
break;}
case 261:
-#line 1234 "parse.y"
+#line 1235 "parse.y"
{ yyval.ttype = lookup_template_function (yyvsp[-2].ttype, yyvsp[-1].ttype); ;
break;}
case 262:
-#line 1236 "parse.y"
+#line 1237 "parse.y"
{ yyval.ttype = lookup_template_function (yyvsp[-2].ttype, yyvsp[-1].ttype); ;
break;}
case 263:
-#line 1241 "parse.y"
+#line 1242 "parse.y"
{ yyval.ttype = lookup_template_function (yyvsp[-3].ttype, yyvsp[-1].ttype); ;
break;}
case 264:
-#line 1243 "parse.y"
+#line 1244 "parse.y"
{ yyval.ttype = lookup_template_function (yyvsp[-3].ttype, yyvsp[-1].ttype); ;
break;}
case 265:
-#line 1246 "parse.y"
+#line 1247 "parse.y"
{ yyval.ttype = lookup_template_function (yyvsp[-3].ttype, yyvsp[-1].ttype); ;
break;}
case 270:
-#line 1258 "parse.y"
+#line 1259 "parse.y"
{ yyval.ttype = build_parse_node (INDIRECT_REF, yyvsp[0].ttype); ;
break;}
case 271:
-#line 1260 "parse.y"
+#line 1261 "parse.y"
{ yyval.ttype = build_parse_node (ADDR_EXPR, yyvsp[0].ttype); ;
break;}
case 272:
-#line 1262 "parse.y"
+#line 1263 "parse.y"
{ yyval.ttype = yyvsp[-1].ttype; ;
break;}
case 273:
-#line 1267 "parse.y"
+#line 1268 "parse.y"
{ yyval.ttype = lookup_template_function (yyvsp[-3].ttype, yyvsp[-1].ttype); ;
break;}
case 274:
-#line 1269 "parse.y"
+#line 1270 "parse.y"
{ yyval.ttype = lookup_template_function (yyvsp[-3].ttype, yyvsp[-1].ttype); ;
break;}
case 278:
-#line 1277 "parse.y"
+#line 1278 "parse.y"
{ yyval.ttype = finish_decl_parsing (yyvsp[-1].ttype); ;
break;}
case 279:
-#line 1282 "parse.y"
+#line 1283 "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));
@@ -5050,7 +5050,7 @@ case 279:
;
break;}
case 282:
-#line 1291 "parse.y"
+#line 1292 "parse.y"
{
if (processing_template_decl)
push_obstacks (&permanent_obstack, &permanent_obstack);
@@ -5060,20 +5060,20 @@ case 282:
;
break;}
case 283:
-#line 1299 "parse.y"
+#line 1300 "parse.y"
{ yyval.ttype = finish_parenthesized_expr (yyvsp[-1].ttype); ;
break;}
case 284:
-#line 1301 "parse.y"
+#line 1302 "parse.y"
{ yyvsp[-1].ttype = reparse_decl_as_expr (NULL_TREE, yyvsp[-1].ttype);
yyval.ttype = finish_parenthesized_expr (yyvsp[-1].ttype); ;
break;}
case 285:
-#line 1304 "parse.y"
+#line 1305 "parse.y"
{ yyval.ttype = error_mark_node; ;
break;}
case 286:
-#line 1306 "parse.y"
+#line 1307 "parse.y"
{ if (current_function_decl == 0)
{
error ("braced-group within expression allowed only inside a function");
@@ -5085,35 +5085,35 @@ case 286:
;
break;}
case 287:
-#line 1316 "parse.y"
+#line 1317 "parse.y"
{ yyval.ttype = finish_stmt_expr (yyvsp[-2].ttype, yyvsp[-1].ttype); ;
break;}
case 288:
-#line 1318 "parse.y"
+#line 1319 "parse.y"
{ yyval.ttype = finish_call_expr (yyvsp[-3].ttype, yyvsp[-1].ttype); ;
break;}
case 289:
-#line 1320 "parse.y"
+#line 1321 "parse.y"
{ yyval.ttype = finish_call_expr (yyvsp[-1].ttype, NULL_TREE); ;
break;}
case 290:
-#line 1322 "parse.y"
+#line 1323 "parse.y"
{ yyval.ttype = grok_array_decl (yyval.ttype, yyvsp[-1].ttype); ;
break;}
case 291:
-#line 1324 "parse.y"
+#line 1325 "parse.y"
{ yyval.ttype = finish_increment_expr (yyvsp[-1].ttype, POSTINCREMENT_EXPR); ;
break;}
case 292:
-#line 1326 "parse.y"
+#line 1327 "parse.y"
{ yyval.ttype = finish_increment_expr (yyvsp[-1].ttype, POSTDECREMENT_EXPR); ;
break;}
case 293:
-#line 1329 "parse.y"
+#line 1330 "parse.y"
{ yyval.ttype = finish_this_expr (); ;
break;}
case 294:
-#line 1331 "parse.y"
+#line 1332 "parse.y"
{
tree type = NULL_TREE;
tree id = yyval.ttype;
@@ -5159,49 +5159,49 @@ case 294:
;
break;}
case 296:
-#line 1376 "parse.y"
+#line 1377 "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 297:
-#line 1380 "parse.y"
+#line 1381 "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 298:
-#line 1384 "parse.y"
+#line 1385 "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 299:
-#line 1388 "parse.y"
+#line 1389 "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 300:
-#line 1392 "parse.y"
+#line 1393 "parse.y"
{ yyval.ttype = build_x_typeid (yyvsp[-1].ttype); ;
break;}
case 301:
-#line 1394 "parse.y"
+#line 1395 "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 302:
-#line 1398 "parse.y"
+#line 1399 "parse.y"
{ yyval.ttype = do_scoped_id (yyvsp[0].ttype, 1); ;
break;}
case 303:
-#line 1400 "parse.y"
+#line 1401 "parse.y"
{ yyval.ttype = yyvsp[0].ttype; ;
break;}
case 304:
-#line 1402 "parse.y"
+#line 1403 "parse.y"
{
got_scope = NULL_TREE;
if (TREE_CODE (yyvsp[0].ttype) == IDENTIFIER_NODE)
@@ -5211,102 +5211,102 @@ case 304:
;
break;}
case 305:
-#line 1410 "parse.y"
+#line 1411 "parse.y"
{ yyval.ttype = build_offset_ref (OP0 (yyval.ttype), OP1 (yyval.ttype)); ;
break;}
case 306:
-#line 1412 "parse.y"
+#line 1413 "parse.y"
{ yyval.ttype = finish_globally_qualified_member_call_expr (yyvsp[-3].ttype, yyvsp[-1].ttype); ;
break;}
case 307:
-#line 1414 "parse.y"
+#line 1415 "parse.y"
{ yyval.ttype = finish_globally_qualified_member_call_expr (yyvsp[-1].ttype, NULL_TREE); ;
break;}
case 308:
-#line 1416 "parse.y"
+#line 1417 "parse.y"
{
yyval.ttype = build_x_component_ref (yyval.ttype, yyvsp[0].ttype, NULL_TREE, 1);
;
break;}
case 309:
-#line 1420 "parse.y"
+#line 1421 "parse.y"
{ yyval.ttype = finish_object_call_expr (yyvsp[-3].ttype, yyvsp[-4].ttype, yyvsp[-1].ttype); ;
break;}
case 310:
-#line 1422 "parse.y"
+#line 1423 "parse.y"
{ yyval.ttype = finish_object_call_expr (yyvsp[-1].ttype, yyvsp[-2].ttype, NULL_TREE); ;
break;}
case 311:
-#line 1424 "parse.y"
+#line 1425 "parse.y"
{ yyval.ttype = build_x_component_ref (yyval.ttype, yyvsp[0].ttype, NULL_TREE, 1); ;
break;}
case 312:
-#line 1426 "parse.y"
+#line 1427 "parse.y"
{ if (processing_template_decl)
yyval.ttype = build_min_nt (COMPONENT_REF, yyvsp[-1].ttype, copy_to_permanent (yyvsp[0].ttype));
else
yyval.ttype = build_object_ref (yyval.ttype, OP0 (yyvsp[0].ttype), OP1 (yyvsp[0].ttype)); ;
break;}
case 313:
-#line 1431 "parse.y"
+#line 1432 "parse.y"
{ yyval.ttype = finish_object_call_expr (yyvsp[-3].ttype, yyvsp[-4].ttype, yyvsp[-1].ttype); ;
break;}
case 314:
-#line 1433 "parse.y"
+#line 1434 "parse.y"
{ yyval.ttype = finish_object_call_expr (yyvsp[-1].ttype, yyvsp[-2].ttype, NULL_TREE); ;
break;}
case 315:
-#line 1435 "parse.y"
+#line 1436 "parse.y"
{ yyval.ttype = finish_qualified_object_call_expr (yyvsp[-3].ttype, yyvsp[-4].ttype, yyvsp[-1].ttype); ;
break;}
case 316:
-#line 1437 "parse.y"
+#line 1438 "parse.y"
{ yyval.ttype = finish_qualified_object_call_expr (yyvsp[-1].ttype, yyvsp[-2].ttype, NULL_TREE); ;
break;}
case 317:
-#line 1440 "parse.y"
+#line 1441 "parse.y"
{ yyval.ttype = finish_pseudo_destructor_call_expr (yyvsp[-3].ttype, NULL_TREE, yyvsp[-1].ttype); ;
break;}
case 318:
-#line 1442 "parse.y"
+#line 1443 "parse.y"
{ yyval.ttype = finish_pseudo_destructor_call_expr (yyvsp[-5].ttype, yyvsp[-4].ttype, yyvsp[-1].ttype); ;
break;}
case 319:
-#line 1444 "parse.y"
+#line 1445 "parse.y"
{
yyval.ttype = error_mark_node;
;
break;}
case 320:
-#line 1489 "parse.y"
+#line 1490 "parse.y"
{ yyval.itype = 0; ;
break;}
case 321:
-#line 1491 "parse.y"
+#line 1492 "parse.y"
{ got_scope = NULL_TREE; yyval.itype = 1; ;
break;}
case 322:
-#line 1496 "parse.y"
+#line 1497 "parse.y"
{ yyval.itype = 0; ;
break;}
case 323:
-#line 1498 "parse.y"
+#line 1499 "parse.y"
{ got_scope = NULL_TREE; yyval.itype = 1; ;
break;}
case 324:
-#line 1503 "parse.y"
+#line 1504 "parse.y"
{ yyval.ttype = boolean_true_node; ;
break;}
case 325:
-#line 1505 "parse.y"
+#line 1506 "parse.y"
{ yyval.ttype = boolean_false_node; ;
break;}
case 327:
-#line 1512 "parse.y"
+#line 1513 "parse.y"
{ yyval.ttype = chainon (yyval.ttype, yyvsp[0].ttype); ;
break;}
case 328:
-#line 1517 "parse.y"
+#line 1518 "parse.y"
{
if (! current_function_parms_stored)
store_parm_decls ();
@@ -5318,18 +5318,18 @@ case 328:
;
break;}
case 329:
-#line 1530 "parse.y"
+#line 1531 "parse.y"
{ got_object = TREE_TYPE (yyval.ttype); ;
break;}
case 330:
-#line 1532 "parse.y"
+#line 1533 "parse.y"
{
yyval.ttype = build_x_arrow (yyval.ttype);
got_object = TREE_TYPE (yyval.ttype);
;
break;}
case 331:
-#line 1540 "parse.y"
+#line 1541 "parse.y"
{
resume_momentary (yyvsp[-1].itype);
if (yyvsp[-2].ftype.t && IS_AGGR_TYPE_CODE (TREE_CODE (yyvsp[-2].ftype.t)))
@@ -5337,138 +5337,138 @@ case 331:
;
break;}
case 332:
-#line 1546 "parse.y"
+#line 1547 "parse.y"
{
resume_momentary (yyvsp[-1].itype);
note_list_got_semicolon (yyvsp[-2].ftype.t);
;
break;}
case 333:
-#line 1551 "parse.y"
+#line 1552 "parse.y"
{ resume_momentary (yyvsp[-1].itype); ;
break;}
case 334:
-#line 1553 "parse.y"
+#line 1554 "parse.y"
{
shadow_tag (yyvsp[-1].ftype.t);
note_list_got_semicolon (yyvsp[-1].ftype.t);
;
break;}
case 335:
-#line 1558 "parse.y"
+#line 1559 "parse.y"
{ warning ("empty declaration"); ;
break;}
case 336:
-#line 1560 "parse.y"
+#line 1561 "parse.y"
{ pedantic = yyvsp[-1].itype; ;
break;}
case 339:
-#line 1574 "parse.y"
+#line 1575 "parse.y"
{ yyval.ttype = make_call_declarator (NULL_TREE, empty_parms (),
NULL_TREE, NULL_TREE); ;
break;}
case 340:
-#line 1577 "parse.y"
+#line 1578 "parse.y"
{ yyval.ttype = make_call_declarator (yyval.ttype, empty_parms (), NULL_TREE,
NULL_TREE); ;
break;}
case 341:
-#line 1584 "parse.y"
+#line 1585 "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 342:
-#line 1587 "parse.y"
+#line 1588 "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 343:
-#line 1590 "parse.y"
+#line 1591 "parse.y"
{ yyval.ftype.t = build_decl_list (get_decl_list (yyvsp[-1].ftype.t), yyvsp[0].ttype);
yyval.ftype.new_type_flag = yyvsp[-1].ftype.new_type_flag; ;
break;}
case 344:
-#line 1593 "parse.y"
+#line 1594 "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 345:
-#line 1596 "parse.y"
+#line 1597 "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 348:
-#line 1612 "parse.y"
+#line 1613 "parse.y"
{ yyval.ftype.t = decl_tree_cons (NULL_TREE, yyvsp[0].ftype.t, yyvsp[-1].ttype);
yyval.ftype.new_type_flag = yyvsp[0].ftype.new_type_flag; ;
break;}
case 349:
-#line 1615 "parse.y"
+#line 1616 "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 350:
-#line 1618 "parse.y"
+#line 1619 "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 351:
-#line 1621 "parse.y"
+#line 1622 "parse.y"
{ yyval.ftype.t = decl_tree_cons (NULL_TREE, yyvsp[-1].ftype.t, chainon (yyvsp[0].ttype, yyvsp[-2].ttype));
yyval.ftype.new_type_flag = yyvsp[-1].ftype.new_type_flag; ;
break;}
case 352:
-#line 1624 "parse.y"
+#line 1625 "parse.y"
{ yyval.ftype.t = decl_tree_cons (NULL_TREE, yyvsp[-1].ftype.t, chainon (yyvsp[0].ttype, yyvsp[-2].ttype));
yyval.ftype.new_type_flag = yyvsp[-1].ftype.new_type_flag; ;
break;}
case 353:
-#line 1627 "parse.y"
+#line 1628 "parse.y"
{ yyval.ftype.t = decl_tree_cons (NULL_TREE, yyvsp[-2].ftype.t,
chainon (yyvsp[-1].ttype, chainon (yyvsp[0].ttype, yyvsp[-3].ttype)));
yyval.ftype.new_type_flag = yyvsp[-2].ftype.new_type_flag; ;
break;}
case 354:
-#line 1634 "parse.y"
+#line 1635 "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 355:
-#line 1639 "parse.y"
+#line 1640 "parse.y"
{ yyval.ttype = decl_tree_cons (NULL_TREE, yyvsp[0].ftype.t, yyval.ttype); ;
break;}
case 356:
-#line 1641 "parse.y"
+#line 1642 "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 357:
-#line 1646 "parse.y"
+#line 1647 "parse.y"
{ yyval.ttype = decl_tree_cons (yyvsp[0].ttype, NULL_TREE, yyvsp[-1].ttype); ;
break;}
case 358:
-#line 1648 "parse.y"
+#line 1649 "parse.y"
{ yyval.ttype = decl_tree_cons (yyvsp[0].ttype, NULL_TREE, NULL_TREE); ;
break;}
case 359:
-#line 1658 "parse.y"
+#line 1659 "parse.y"
{ yyval.ttype = yyvsp[0].ftype.t; TREE_STATIC (yyval.ttype) = 1; ;
break;}
case 360:
-#line 1660 "parse.y"
+#line 1661 "parse.y"
{ yyval.ttype = IDENTIFIER_AS_LIST (yyval.ttype); ;
break;}
case 361:
-#line 1662 "parse.y"
+#line 1663 "parse.y"
{ yyval.ttype = decl_tree_cons (NULL_TREE, yyvsp[0].ttype, yyval.ttype);
TREE_STATIC (yyval.ttype) = 1; ;
break;}
case 362:
-#line 1665 "parse.y"
+#line 1666 "parse.y"
{ if (extra_warnings && TREE_STATIC (yyval.ttype))
warning ("`%s' is not at beginning of declaration",
IDENTIFIER_POINTER (yyvsp[0].ttype));
@@ -5476,61 +5476,61 @@ case 362:
TREE_STATIC (yyval.ttype) = TREE_STATIC (yyvsp[-1].ttype); ;
break;}
case 363:
-#line 1671 "parse.y"
+#line 1672 "parse.y"
{ yyval.ttype = decl_tree_cons (yyvsp[0].ttype, NULL_TREE, yyvsp[-1].ttype); ;
break;}
case 364:
-#line 1673 "parse.y"
+#line 1674 "parse.y"
{ yyval.ttype = decl_tree_cons (yyvsp[0].ttype, NULL_TREE, NULL_TREE); ;
break;}
case 365:
-#line 1684 "parse.y"
+#line 1685 "parse.y"
{ yyval.ftype.t = get_decl_list (yyvsp[0].ftype.t);
yyval.ftype.new_type_flag = yyvsp[0].ftype.new_type_flag; ;
break;}
case 366:
-#line 1687 "parse.y"
+#line 1688 "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 367:
-#line 1690 "parse.y"
+#line 1691 "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 368:
-#line 1693 "parse.y"
+#line 1694 "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[-2].ftype.new_type_flag; ;
break;}
case 369:
-#line 1699 "parse.y"
+#line 1700 "parse.y"
{ yyval.ttype = build_decl_list (NULL_TREE, yyvsp[0].ftype.t); ;
break;}
case 370:
-#line 1701 "parse.y"
+#line 1702 "parse.y"
{ yyval.ttype = decl_tree_cons (NULL_TREE, yyvsp[0].ftype.t, yyvsp[-1].ttype); ;
break;}
case 372:
-#line 1711 "parse.y"
+#line 1712 "parse.y"
{ yyval.ftype.t = yyvsp[0].ttype; yyval.ftype.new_type_flag = 0; ;
break;}
case 373:
-#line 1713 "parse.y"
+#line 1714 "parse.y"
{ yyval.ftype.t = yyvsp[0].ttype; yyval.ftype.new_type_flag = 0; ;
break;}
case 374:
-#line 1715 "parse.y"
+#line 1716 "parse.y"
{ yyval.ftype.t = TREE_TYPE (yyvsp[-1].ttype);
yyval.ftype.new_type_flag = 0; ;
break;}
case 375:
-#line 1718 "parse.y"
+#line 1719 "parse.y"
{ yyval.ftype.t = groktypename (yyvsp[-1].ftype.t);
yyval.ftype.new_type_flag = 0; ;
break;}
case 376:
-#line 1721 "parse.y"
+#line 1722 "parse.y"
{ tree type = TREE_TYPE (yyvsp[-1].ttype);
yyval.ftype.new_type_flag = 0;
@@ -5547,7 +5547,7 @@ case 376:
;
break;}
case 377:
-#line 1736 "parse.y"
+#line 1737 "parse.y"
{ tree type = groktypename (yyvsp[-1].ftype.t);
yyval.ftype.new_type_flag = 0;
@@ -5564,188 +5564,188 @@ case 377:
;
break;}
case 378:
-#line 1756 "parse.y"
+#line 1757 "parse.y"
{ yyval.ftype.t = yyvsp[0].ttype; yyval.ftype.new_type_flag = 0; ;
break;}
case 379:
-#line 1758 "parse.y"
+#line 1759 "parse.y"
{ yyval.ftype.t = yyvsp[0].ttype; yyval.ftype.new_type_flag = 0; ;
break;}
case 387:
-#line 1779 "parse.y"
+#line 1780 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 388:
-#line 1781 "parse.y"
+#line 1782 "parse.y"
{ if (TREE_CHAIN (yyvsp[-1].ttype)) yyvsp[-1].ttype = combine_strings (yyvsp[-1].ttype); yyval.ttype = yyvsp[-1].ttype; ;
break;}
case 389:
-#line 1786 "parse.y"
+#line 1787 "parse.y"
{ yyval.ttype = start_decl (yyvsp[-3].ttype, current_declspecs, 1,
yyvsp[-1].ttype, prefix_attributes); ;
break;}
case 390:
-#line 1790 "parse.y"
+#line 1791 "parse.y"
{ cp_finish_decl (yyvsp[-1].ttype, yyvsp[0].ttype, yyvsp[-4].ttype, 1, LOOKUP_ONLYCONVERTING); ;
break;}
case 391:
-#line 1792 "parse.y"
+#line 1793 "parse.y"
{ yyval.ttype = start_decl (yyvsp[-2].ttype, current_declspecs, 0,
yyvsp[0].ttype, prefix_attributes);
cp_finish_decl (yyval.ttype, NULL_TREE, yyvsp[-1].ttype, 1, 0); ;
break;}
case 392:
-#line 1805 "parse.y"
+#line 1806 "parse.y"
{ yyvsp[0].itype = parse_decl (yyvsp[-3].ttype, yyvsp[-4].ttype,
yyvsp[-1].ttype, 1, &yyval.ttype); ;
break;}
case 393:
-#line 1810 "parse.y"
+#line 1811 "parse.y"
{ cp_finish_decl (yyvsp[-1].ttype, yyvsp[0].ttype, yyvsp[-4].ttype, 1,
LOOKUP_ONLYCONVERTING);
yyval.itype = yyvsp[-2].itype; ;
break;}
case 394:
-#line 1814 "parse.y"
+#line 1815 "parse.y"
{ tree d;
yyval.itype = parse_decl (yyvsp[-2].ttype, yyvsp[-3].ttype, yyvsp[0].ttype, 0, &d);
cp_finish_decl (d, NULL_TREE, yyvsp[-1].ttype, 1, 0); ;
break;}
case 395:
-#line 1821 "parse.y"
+#line 1822 "parse.y"
{ yyval.itype = yyvsp[0].itype; ;
break;}
case 396:
-#line 1825 "parse.y"
+#line 1826 "parse.y"
{ yyval.itype = yyvsp[0].itype; ;
break;}
case 397:
-#line 1830 "parse.y"
+#line 1831 "parse.y"
{ /* Set things up as initdcl0_innards expects. */
yyval.ttype = yyvsp[-1].ttype;
yyvsp[-1].ttype = NULL_TREE; ;
break;}
case 398:
-#line 1834 "parse.y"
+#line 1835 "parse.y"
{;
break;}
case 399:
-#line 1836 "parse.y"
+#line 1837 "parse.y"
{ tree d;
parse_decl(yyvsp[-2].ttype, NULL_TREE, yyvsp[0].ttype, 0, &d);
cp_finish_decl (d, NULL_TREE, yyvsp[-1].ttype, 1, 0); ;
break;}
case 400:
-#line 1845 "parse.y"
+#line 1846 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 401:
-#line 1847 "parse.y"
+#line 1848 "parse.y"
{ yyval.ttype = yyvsp[0].ttype; ;
break;}
case 402:
-#line 1852 "parse.y"
+#line 1853 "parse.y"
{ yyval.ttype = yyvsp[0].ttype; ;
break;}
case 403:
-#line 1854 "parse.y"
+#line 1855 "parse.y"
{ yyval.ttype = chainon (yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 404:
-#line 1859 "parse.y"
+#line 1860 "parse.y"
{ yyval.ttype = yyvsp[-2].ttype; ;
break;}
case 405:
-#line 1864 "parse.y"
+#line 1865 "parse.y"
{ yyval.ttype = yyvsp[0].ttype; ;
break;}
case 406:
-#line 1866 "parse.y"
+#line 1867 "parse.y"
{ yyval.ttype = chainon (yyvsp[-2].ttype, yyvsp[0].ttype); ;
break;}
case 407:
-#line 1871 "parse.y"
+#line 1872 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 408:
-#line 1873 "parse.y"
+#line 1874 "parse.y"
{ yyval.ttype = build_tree_list (yyvsp[0].ttype, NULL_TREE); ;
break;}
case 409:
-#line 1875 "parse.y"
+#line 1876 "parse.y"
{ yyval.ttype = build_tree_list (yyvsp[-3].ttype, build_tree_list (NULL_TREE, yyvsp[-1].ttype)); ;
break;}
case 410:
-#line 1877 "parse.y"
+#line 1878 "parse.y"
{ yyval.ttype = build_tree_list (yyvsp[-5].ttype, tree_cons (NULL_TREE, yyvsp[-3].ttype, yyvsp[-1].ttype)); ;
break;}
case 411:
-#line 1879 "parse.y"
+#line 1880 "parse.y"
{ yyval.ttype = build_tree_list (yyvsp[-3].ttype, yyvsp[-1].ttype); ;
break;}
case 416:
-#line 1895 "parse.y"
+#line 1896 "parse.y"
{ yyval.ttype = build_tree_list (NULL_TREE, yyvsp[0].ttype); ;
break;}
case 417:
-#line 1897 "parse.y"
+#line 1898 "parse.y"
{ yyval.ttype = chainon (yyvsp[-2].ttype, build_tree_list (NULL_TREE, yyvsp[0].ttype)); ;
break;}
case 418:
-#line 1902 "parse.y"
+#line 1903 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 419:
-#line 1904 "parse.y"
+#line 1905 "parse.y"
{ yyval.ttype = yyvsp[0].ttype; ;
break;}
case 421:
-#line 1912 "parse.y"
+#line 1913 "parse.y"
{ yyval.ttype = build_nt (CONSTRUCTOR, NULL_TREE, NULL_TREE);
TREE_HAS_CONSTRUCTOR (yyval.ttype) = 1; ;
break;}
case 422:
-#line 1915 "parse.y"
+#line 1916 "parse.y"
{ yyval.ttype = build_nt (CONSTRUCTOR, NULL_TREE, nreverse (yyvsp[-1].ttype));
TREE_HAS_CONSTRUCTOR (yyval.ttype) = 1; ;
break;}
case 423:
-#line 1918 "parse.y"
+#line 1919 "parse.y"
{ yyval.ttype = build_nt (CONSTRUCTOR, NULL_TREE, nreverse (yyvsp[-2].ttype));
TREE_HAS_CONSTRUCTOR (yyval.ttype) = 1; ;
break;}
case 424:
-#line 1921 "parse.y"
+#line 1922 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 425:
-#line 1928 "parse.y"
+#line 1929 "parse.y"
{ yyval.ttype = build_tree_list (NULL_TREE, yyval.ttype); ;
break;}
case 426:
-#line 1930 "parse.y"
+#line 1931 "parse.y"
{ yyval.ttype = expr_tree_cons (NULL_TREE, yyvsp[0].ttype, yyval.ttype); ;
break;}
case 427:
-#line 1933 "parse.y"
+#line 1934 "parse.y"
{ yyval.ttype = build_expr_list (yyvsp[-2].ttype, yyvsp[0].ttype); ;
break;}
case 428:
-#line 1935 "parse.y"
+#line 1936 "parse.y"
{ yyval.ttype = build_expr_list (yyval.ttype, yyvsp[0].ttype); ;
break;}
case 429:
-#line 1937 "parse.y"
+#line 1938 "parse.y"
{ yyval.ttype = expr_tree_cons (yyvsp[-2].ttype, yyvsp[0].ttype, yyval.ttype); ;
break;}
case 430:
-#line 1942 "parse.y"
+#line 1943 "parse.y"
{ start_function (NULL_TREE, TREE_VALUE (yyvsp[0].ttype),
NULL_TREE, 1);
reinit_parse_for_function (); ;
break;}
case 431:
-#line 1948 "parse.y"
+#line 1949 "parse.y"
{
int nested = (hack_decl_function_context
(current_function_decl) != NULL_TREE);
@@ -5754,82 +5754,82 @@ case 431:
;
break;}
case 432:
-#line 1955 "parse.y"
+#line 1956 "parse.y"
{ process_next_inline (yyvsp[-2].ttype); ;
break;}
case 433:
-#line 1957 "parse.y"
+#line 1958 "parse.y"
{ process_next_inline (yyvsp[-2].ttype); ;
break;}
case 436:
-#line 1969 "parse.y"
+#line 1970 "parse.y"
{ replace_defarg (yyvsp[-2].ttype, yyvsp[-1].ttype); ;
break;}
case 437:
-#line 1971 "parse.y"
+#line 1972 "parse.y"
{ replace_defarg (yyvsp[-2].ttype, error_mark_node); ;
break;}
case 439:
-#line 1976 "parse.y"
+#line 1977 "parse.y"
{ do_pending_defargs (); ;
break;}
case 440:
-#line 1978 "parse.y"
+#line 1979 "parse.y"
{ do_pending_defargs (); ;
break;}
case 441:
-#line 1983 "parse.y"
+#line 1984 "parse.y"
{ yyvsp[0].itype = suspend_momentary ();
yyval.ttype = start_enum (yyvsp[-1].ttype); ;
break;}
case 442:
-#line 1986 "parse.y"
+#line 1987 "parse.y"
{ yyval.ftype.t = finish_enum (yyvsp[-3].ttype, yyvsp[-2].ttype);
yyval.ftype.new_type_flag = 1;
resume_momentary ((int) yyvsp[-4].itype);
check_for_missing_semicolon (yyvsp[-3].ttype); ;
break;}
case 443:
-#line 1991 "parse.y"
+#line 1992 "parse.y"
{ yyval.ftype.t = finish_enum (start_enum (yyvsp[-2].ttype), NULL_TREE);
yyval.ftype.new_type_flag = 1;
check_for_missing_semicolon (yyval.ftype.t); ;
break;}
case 444:
-#line 1995 "parse.y"
+#line 1996 "parse.y"
{ yyvsp[0].itype = suspend_momentary ();
yyval.ttype = start_enum (make_anon_name ()); ;
break;}
case 445:
-#line 1998 "parse.y"
+#line 1999 "parse.y"
{ yyval.ftype.t = finish_enum (yyvsp[-3].ttype, yyvsp[-2].ttype);
resume_momentary ((int) yyvsp[-5].itype);
check_for_missing_semicolon (yyvsp[-3].ttype);
yyval.ftype.new_type_flag = 1; ;
break;}
case 446:
-#line 2003 "parse.y"
+#line 2004 "parse.y"
{ yyval.ftype.t = finish_enum (start_enum (make_anon_name()), NULL_TREE);
yyval.ftype.new_type_flag = 1;
check_for_missing_semicolon (yyval.ftype.t); ;
break;}
case 447:
-#line 2007 "parse.y"
+#line 2008 "parse.y"
{ yyval.ftype.t = xref_tag (enum_type_node, yyvsp[0].ttype, NULL_TREE, 1);
yyval.ftype.new_type_flag = 0; ;
break;}
case 448:
-#line 2010 "parse.y"
+#line 2011 "parse.y"
{ yyval.ftype.t = xref_tag (enum_type_node, yyvsp[0].ttype, NULL_TREE, 1);
yyval.ftype.new_type_flag = 0; ;
break;}
case 449:
-#line 2013 "parse.y"
+#line 2014 "parse.y"
{ yyval.ftype.t = yyvsp[0].ttype;
yyval.ftype.new_type_flag = 0; ;
break;}
case 450:
-#line 2018 "parse.y"
+#line 2019 "parse.y"
{
int semi;
@@ -5841,17 +5841,17 @@ case 450:
;
break;}
case 451:
-#line 2028 "parse.y"
+#line 2029 "parse.y"
{ finish_default_args (); ;
break;}
case 452:
-#line 2030 "parse.y"
+#line 2031 "parse.y"
{ yyval.ftype.t = yyvsp[-3].ttype;
yyval.ftype.new_type_flag = 1;
begin_inline_definitions (); ;
break;}
case 453:
-#line 2034 "parse.y"
+#line 2035 "parse.y"
{
yyval.ftype.new_type_flag = 0;
if (TYPE_BINFO (yyvsp[0].ttype) == NULL_TREE)
@@ -5871,73 +5871,73 @@ case 453:
;
break;}
case 457:
-#line 2061 "parse.y"
+#line 2062 "parse.y"
{ if (pedantic && !in_system_header)
pedwarn ("comma at end of enumerator list"); ;
break;}
case 459:
-#line 2068 "parse.y"
+#line 2069 "parse.y"
{ error ("storage class specifier `%s' not allowed after struct or class", IDENTIFIER_POINTER (yyvsp[0].ttype)); ;
break;}
case 460:
-#line 2070 "parse.y"
+#line 2071 "parse.y"
{ error ("type specifier `%s' not allowed after struct or class", IDENTIFIER_POINTER (yyvsp[0].ttype)); ;
break;}
case 461:
-#line 2072 "parse.y"
+#line 2073 "parse.y"
{ error ("type qualifier `%s' not allowed after struct or class", IDENTIFIER_POINTER (yyvsp[0].ttype)); ;
break;}
case 462:
-#line 2074 "parse.y"
+#line 2075 "parse.y"
{ error ("no body nor ';' separates two class, struct or union declarations"); ;
break;}
case 463:
-#line 2079 "parse.y"
+#line 2080 "parse.y"
{ current_aggr = yyval.ttype; yyval.ttype = yyvsp[0].ttype; ;
break;}
case 464:
-#line 2084 "parse.y"
+#line 2085 "parse.y"
{ current_aggr = yyval.ttype; yyval.ttype = yyvsp[0].ttype; ;
break;}
case 465:
-#line 2089 "parse.y"
+#line 2090 "parse.y"
{
current_aggr = yyvsp[-2].ttype;
yyval.ttype = handle_class_head (yyvsp[-2].ttype, yyvsp[-1].ttype, yyvsp[0].ttype);
;
break;}
case 466:
-#line 2094 "parse.y"
+#line 2095 "parse.y"
{
current_aggr = yyvsp[-3].ttype;
yyval.ttype = handle_class_head (yyvsp[-3].ttype, yyvsp[-1].ttype, yyvsp[0].ttype);
;
break;}
case 467:
-#line 2099 "parse.y"
+#line 2100 "parse.y"
{
current_aggr = yyvsp[-2].ttype;
yyval.ttype = handle_class_head (yyvsp[-2].ttype, NULL_TREE, yyvsp[0].ttype);
;
break;}
case 468:
-#line 2104 "parse.y"
+#line 2105 "parse.y"
{ current_aggr = yyval.ttype; yyval.ttype = yyvsp[0].ttype; ;
break;}
case 469:
-#line 2106 "parse.y"
+#line 2107 "parse.y"
{ current_aggr = yyval.ttype; yyval.ttype = yyvsp[0].ttype; ;
break;}
case 470:
-#line 2111 "parse.y"
+#line 2112 "parse.y"
{ yyval.ttype = xref_tag (current_aggr, yyvsp[0].ttype, NULL_TREE, 0); ;
break;}
case 471:
-#line 2116 "parse.y"
+#line 2117 "parse.y"
{ yyval.ttype = xref_tag (current_aggr, yyvsp[0].ttype, NULL_TREE, 1); ;
break;}
case 472:
-#line 2119 "parse.y"
+#line 2120 "parse.y"
{
yyval.ttype = yyvsp[-1].ttype;
if (yyvsp[0].ttype)
@@ -5945,7 +5945,7 @@ case 472:
;
break;}
case 473:
-#line 2125 "parse.y"
+#line 2126 "parse.y"
{
yyval.ttype = TREE_TYPE (yyvsp[-1].ttype);
if (TREE_INT_CST_LOW (current_aggr) == union_type
@@ -5973,28 +5973,28 @@ case 473:
;
break;}
case 474:
-#line 2154 "parse.y"
+#line 2155 "parse.y"
{ yyval.ttype = xref_tag (yyval.ttype, make_anon_name (), NULL_TREE, 0);
yyungetc ('{', 1); ;
break;}
case 477:
-#line 2165 "parse.y"
+#line 2166 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 478:
-#line 2167 "parse.y"
+#line 2168 "parse.y"
{ yyungetc(':', 1); yyval.ttype = NULL_TREE; ;
break;}
case 479:
-#line 2169 "parse.y"
+#line 2170 "parse.y"
{ yyval.ttype = yyvsp[0].ttype; ;
break;}
case 481:
-#line 2175 "parse.y"
+#line 2176 "parse.y"
{ yyval.ttype = chainon (yyval.ttype, yyvsp[0].ttype); ;
break;}
case 482:
-#line 2180 "parse.y"
+#line 2181 "parse.y"
{
tree type = TREE_TYPE (yyvsp[0].ttype);
if (! is_aggr_type (type, 1))
@@ -6021,7 +6021,7 @@ case 482:
;
break;}
case 483:
-#line 2205 "parse.y"
+#line 2206 "parse.y"
{
tree type = TREE_TYPE (yyvsp[0].ttype);
if (current_aggr == signature_type_node)
@@ -6050,11 +6050,11 @@ case 483:
;
break;}
case 484:
-#line 2235 "parse.y"
+#line 2236 "parse.y"
{ yyval.ttype = TYPE_MAIN_DECL (yyvsp[0].ttype); ;
break;}
case 486:
-#line 2238 "parse.y"
+#line 2239 "parse.y"
{
if (current_aggr == signature_type_node)
{
@@ -6077,7 +6077,7 @@ case 486:
;
break;}
case 487:
-#line 2259 "parse.y"
+#line 2260 "parse.y"
{
if (current_aggr == signature_type_node)
{
@@ -6100,13 +6100,13 @@ case 487:
;
break;}
case 489:
-#line 2284 "parse.y"
+#line 2285 "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 490:
-#line 2288 "parse.y"
+#line 2289 "parse.y"
{
if (yyvsp[-2].ttype != access_default_virtual_node)
error ("multiple access specifiers");
@@ -6119,7 +6119,7 @@ case 490:
;
break;}
case 491:
-#line 2299 "parse.y"
+#line 2300 "parse.y"
{ if (yyvsp[-1].ttype != ridpointers[(int)RID_VIRTUAL])
cp_error ("`%D' access", yyvsp[-1].ttype);
else if (yyval.ttype == access_public_node)
@@ -6133,21 +6133,21 @@ case 491:
;
break;}
case 492:
-#line 2314 "parse.y"
+#line 2315 "parse.y"
{ yyvsp[-1].ttype = begin_class_definition (yyvsp[-1].ttype); ;
break;}
case 493:
-#line 2319 "parse.y"
+#line 2320 "parse.y"
{
yyval.ttype = build_self_reference ();
;
break;}
case 494:
-#line 2326 "parse.y"
+#line 2327 "parse.y"
{ if (yyval.ttype) yyval.ttype = build_tree_list (access_public_node, yyval.ttype); ;
break;}
case 495:
-#line 2328 "parse.y"
+#line 2329 "parse.y"
{
if (current_aggr == signature_type_node)
yyval.ttype = build_tree_list (access_public_node, yyvsp[0].ttype);
@@ -6157,7 +6157,7 @@ case 495:
;
break;}
case 496:
-#line 2336 "parse.y"
+#line 2337 "parse.y"
{
tree visspec = yyvsp[-2].ttype;
@@ -6170,19 +6170,19 @@ case 496:
;
break;}
case 497:
-#line 2347 "parse.y"
+#line 2348 "parse.y"
{
if (current_aggr == signature_type_node)
error ("access specifier not allowed in signature");
;
break;}
case 498:
-#line 2357 "parse.y"
+#line 2358 "parse.y"
{ if (yyval.ttype == void_type_node) yyval.ttype = NULL_TREE;
;
break;}
case 499:
-#line 2360 "parse.y"
+#line 2361 "parse.y"
{ /* In pushdecl, we created a reverse list of names
in this binding level. Make sure that the chain
of what we're trying to add isn't the item itself
@@ -6197,103 +6197,95 @@ case 499:
;
break;}
case 500:
-#line 2376 "parse.y"
+#line 2377 "parse.y"
{ ;
break;}
case 501:
-#line 2378 "parse.y"
+#line 2379 "parse.y"
{ error ("missing ';' before right brace");
yyungetc ('}', 0); ;
break;}
case 502:
-#line 2383 "parse.y"
+#line 2384 "parse.y"
{ yyval.ttype = finish_method (yyval.ttype); ;
break;}
case 503:
-#line 2385 "parse.y"
+#line 2386 "parse.y"
{ yyval.ttype = finish_method (yyval.ttype); ;
break;}
case 504:
-#line 2387 "parse.y"
+#line 2388 "parse.y"
{ yyval.ttype = finish_method (yyval.ttype); ;
break;}
case 505:
-#line 2389 "parse.y"
+#line 2390 "parse.y"
{ yyval.ttype = finish_method (yyval.ttype); ;
break;}
case 506:
-#line 2391 "parse.y"
+#line 2392 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 507:
-#line 2393 "parse.y"
+#line 2394 "parse.y"
{ yyval.ttype = yyvsp[0].ttype;
pedantic = yyvsp[-1].itype; ;
break;}
case 508:
-#line 2396 "parse.y"
+#line 2397 "parse.y"
{ yyval.ttype = finish_member_template_decl (yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 509:
-#line 2398 "parse.y"
-{
- note_list_got_semicolon (yyvsp[-1].ftype.t);
- grok_x_components (yyvsp[-1].ftype.t, NULL_TREE);
- if (TYPE_CONTEXT (TREE_VALUE (yyvsp[-1].ftype.t)) != current_class_type)
- /* The component was in fact a friend
- declaration. */
- yyvsp[-1].ftype.t = NULL_TREE;
- yyval.ttype = finish_member_template_decl (yyvsp[-2].ttype, yyvsp[-1].ftype.t);
- ;
+#line 2399 "parse.y"
+{ yyval.ttype = finish_member_class_template (yyvsp[-2].ttype, yyvsp[-1].ftype.t); ;
break;}
case 510:
-#line 2414 "parse.y"
+#line 2407 "parse.y"
{ yyval.ttype = grok_x_components (yyvsp[-1].ftype.t, yyvsp[0].ttype); ;
break;}
case 511:
-#line 2416 "parse.y"
+#line 2409 "parse.y"
{ yyval.ttype = grok_x_components (yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 512:
-#line 2418 "parse.y"
+#line 2411 "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 513:
-#line 2421 "parse.y"
+#line 2414 "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 514:
-#line 2424 "parse.y"
+#line 2417 "parse.y"
{ yyval.ttype = grokbitfield (NULL_TREE, NULL_TREE, yyvsp[0].ttype); ;
break;}
case 515:
-#line 2426 "parse.y"
+#line 2419 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 516:
-#line 2437 "parse.y"
+#line 2430 "parse.y"
{ tree specs, attrs;
split_specs_attrs (yyvsp[-4].ttype, &specs, &attrs);
yyval.ttype = grokfield (yyvsp[-3].ttype, specs, yyvsp[0].ttype, yyvsp[-2].ttype,
build_tree_list (yyvsp[-1].ttype, attrs)); ;
break;}
case 517:
-#line 2442 "parse.y"
+#line 2435 "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 518:
-#line 2445 "parse.y"
+#line 2438 "parse.y"
{ yyval.ttype = do_class_using_decl (yyvsp[0].ttype); ;
break;}
case 519:
-#line 2451 "parse.y"
+#line 2444 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 521:
-#line 2454 "parse.y"
+#line 2447 "parse.y"
{
/* In this context, void_type_node encodes
friends. They have been recorded elsewhere. */
@@ -6304,11 +6296,11 @@ case 521:
;
break;}
case 522:
-#line 2466 "parse.y"
+#line 2459 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 524:
-#line 2469 "parse.y"
+#line 2462 "parse.y"
{
/* In this context, void_type_node encodes
friends. They have been recorded elsewhere. */
@@ -6319,7 +6311,7 @@ case 524:
;
break;}
case 529:
-#line 2491 "parse.y"
+#line 2484 "parse.y"
{ split_specs_attrs (yyvsp[-4].ttype, &current_declspecs,
&prefix_attributes);
yyvsp[-4].ttype = current_declspecs;
@@ -6327,7 +6319,7 @@ case 529:
build_tree_list (yyvsp[-1].ttype, prefix_attributes)); ;
break;}
case 530:
-#line 2497 "parse.y"
+#line 2490 "parse.y"
{ split_specs_attrs (yyvsp[-4].ttype, &current_declspecs,
&prefix_attributes);
yyvsp[-4].ttype = current_declspecs;
@@ -6335,7 +6327,7 @@ case 530:
cplus_decl_attributes (yyval.ttype, yyvsp[0].ttype, prefix_attributes); ;
break;}
case 531:
-#line 2506 "parse.y"
+#line 2499 "parse.y"
{ split_specs_attrs (yyvsp[-4].ttype, &current_declspecs,
&prefix_attributes);
yyvsp[-4].ttype = current_declspecs;
@@ -6343,7 +6335,7 @@ case 531:
build_tree_list (yyvsp[-1].ttype, prefix_attributes)); ;
break;}
case 532:
-#line 2512 "parse.y"
+#line 2505 "parse.y"
{ split_specs_attrs (yyvsp[-4].ttype, &current_declspecs,
&prefix_attributes);
yyvsp[-4].ttype = current_declspecs;
@@ -6351,7 +6343,7 @@ case 532:
build_tree_list (yyvsp[-1].ttype, prefix_attributes)); ;
break;}
case 533:
-#line 2518 "parse.y"
+#line 2511 "parse.y"
{ split_specs_attrs (yyvsp[-4].ttype, &current_declspecs,
&prefix_attributes);
yyvsp[-4].ttype = current_declspecs;
@@ -6359,7 +6351,7 @@ case 533:
cplus_decl_attributes (yyval.ttype, yyvsp[0].ttype, prefix_attributes); ;
break;}
case 534:
-#line 2524 "parse.y"
+#line 2517 "parse.y"
{ split_specs_attrs (yyvsp[-3].ttype, &current_declspecs,
&prefix_attributes);
yyvsp[-3].ttype = current_declspecs;
@@ -6367,54 +6359,54 @@ case 534:
cplus_decl_attributes (yyval.ttype, yyvsp[0].ttype, prefix_attributes); ;
break;}
case 535:
-#line 2533 "parse.y"
+#line 2526 "parse.y"
{ yyval.ttype = grokfield (yyval.ttype, current_declspecs, yyvsp[0].ttype, yyvsp[-2].ttype,
build_tree_list (yyvsp[-1].ttype, prefix_attributes)); ;
break;}
case 536:
-#line 2536 "parse.y"
+#line 2529 "parse.y"
{ yyval.ttype = grokbitfield (yyval.ttype, current_declspecs, yyvsp[-1].ttype);
cplus_decl_attributes (yyval.ttype, yyvsp[0].ttype, prefix_attributes); ;
break;}
case 537:
-#line 2542 "parse.y"
+#line 2535 "parse.y"
{ yyval.ttype = grokfield (yyval.ttype, current_declspecs, yyvsp[0].ttype, yyvsp[-2].ttype,
build_tree_list (yyvsp[-1].ttype, prefix_attributes)); ;
break;}
case 538:
-#line 2545 "parse.y"
+#line 2538 "parse.y"
{ yyval.ttype = grokbitfield (yyval.ttype, current_declspecs, yyvsp[-1].ttype);
cplus_decl_attributes (yyval.ttype, yyvsp[0].ttype, prefix_attributes); ;
break;}
case 539:
-#line 2548 "parse.y"
+#line 2541 "parse.y"
{ yyval.ttype = grokbitfield (NULL_TREE, current_declspecs, yyvsp[-1].ttype);
cplus_decl_attributes (yyval.ttype, yyvsp[0].ttype, prefix_attributes); ;
break;}
case 541:
-#line 2559 "parse.y"
+#line 2552 "parse.y"
{ TREE_CHAIN (yyvsp[0].ttype) = yyval.ttype; yyval.ttype = yyvsp[0].ttype; ;
break;}
case 542:
-#line 2564 "parse.y"
+#line 2557 "parse.y"
{ yyval.ttype = build_enumerator (yyval.ttype, NULL_TREE); ;
break;}
case 543:
-#line 2566 "parse.y"
+#line 2559 "parse.y"
{ yyval.ttype = build_enumerator (yyval.ttype, yyvsp[0].ttype); ;
break;}
case 544:
-#line 2572 "parse.y"
+#line 2565 "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 545:
-#line 2575 "parse.y"
+#line 2568 "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 546:
-#line 2582 "parse.y"
+#line 2575 "parse.y"
{
if (pedantic)
pedwarn ("ANSI C++ forbids array dimensions with parenthesized type in new");
@@ -6424,71 +6416,71 @@ case 546:
;
break;}
case 547:
-#line 2593 "parse.y"
+#line 2586 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 548:
-#line 2595 "parse.y"
+#line 2588 "parse.y"
{ yyval.ttype = decl_tree_cons (NULL_TREE, yyvsp[0].ttype, yyval.ttype); ;
break;}
case 549:
-#line 2600 "parse.y"
+#line 2593 "parse.y"
{ yyval.ftype.t = IDENTIFIER_AS_LIST (yyvsp[0].ttype);
yyval.ftype.new_type_flag = 0; ;
break;}
case 550:
-#line 2603 "parse.y"
+#line 2596 "parse.y"
{ yyval.ftype.t = decl_tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ftype.t);
yyval.ftype.new_type_flag = yyvsp[-1].ftype.new_type_flag; ;
break;}
case 551:
-#line 2612 "parse.y"
+#line 2605 "parse.y"
{ yyval.itype = suspend_momentary (); ;
break;}
case 552:
-#line 2617 "parse.y"
+#line 2610 "parse.y"
{ resume_momentary ((int) yyvsp[-1].itype); yyval.ttype = yyvsp[0].ttype; ;
break;}
case 553:
-#line 2623 "parse.y"
+#line 2616 "parse.y"
{ resume_momentary ((int) yyvsp[-3].itype); yyval.ttype = yyvsp[-1].ttype; ;
break;}
case 554:
-#line 2625 "parse.y"
+#line 2618 "parse.y"
{ resume_momentary ((int) yyvsp[-3].itype); yyval.ttype = yyvsp[-1].ttype; ;
break;}
case 555:
-#line 2627 "parse.y"
+#line 2620 "parse.y"
{ resume_momentary ((int) yyvsp[-1].itype); yyval.ttype = empty_parms (); ;
break;}
case 556:
-#line 2629 "parse.y"
+#line 2622 "parse.y"
{ resume_momentary ((int) yyvsp[-3].itype); yyval.ttype = NULL_TREE; ;
break;}
case 557:
-#line 2636 "parse.y"
+#line 2629 "parse.y"
{ yyval.ttype = make_pointer_declarator (yyvsp[-1].ftype.t, yyvsp[0].ttype); ;
break;}
case 558:
-#line 2638 "parse.y"
+#line 2631 "parse.y"
{ yyval.ttype = make_reference_declarator (yyvsp[-1].ftype.t, yyvsp[0].ttype); ;
break;}
case 559:
-#line 2640 "parse.y"
+#line 2633 "parse.y"
{ yyval.ttype = make_pointer_declarator (NULL_TREE, yyvsp[0].ttype); ;
break;}
case 560:
-#line 2642 "parse.y"
+#line 2635 "parse.y"
{ yyval.ttype = make_reference_declarator (NULL_TREE, yyvsp[0].ttype); ;
break;}
case 561:
-#line 2644 "parse.y"
+#line 2637 "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 563:
-#line 2652 "parse.y"
+#line 2645 "parse.y"
{
if (TREE_CODE (yyvsp[0].ttype) == IDENTIFIER_NODE)
{
@@ -6507,7 +6499,7 @@ case 563:
;
break;}
case 564:
-#line 2669 "parse.y"
+#line 2662 "parse.y"
{
if (TREE_CODE (yyvsp[0].ttype) == IDENTIFIER_NODE)
yyval.ttype = IDENTIFIER_GLOBAL_VALUE (yyvsp[0].ttype);
@@ -6517,97 +6509,97 @@ case 564:
;
break;}
case 567:
-#line 2682 "parse.y"
+#line 2675 "parse.y"
{ yyval.ttype = yyvsp[0].ttype; ;
break;}
case 568:
-#line 2687 "parse.y"
+#line 2680 "parse.y"
{ yyval.ttype = get_type_decl (yyvsp[0].ttype); ;
break;}
case 569:
-#line 2692 "parse.y"
+#line 2685 "parse.y"
{ yyval.ttype = make_call_declarator (yyval.ttype, yyvsp[-2].ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 570:
-#line 2694 "parse.y"
+#line 2687 "parse.y"
{ yyval.ttype = build_parse_node (ARRAY_REF, yyval.ttype, yyvsp[-1].ttype); ;
break;}
case 571:
-#line 2696 "parse.y"
+#line 2689 "parse.y"
{ yyval.ttype = build_parse_node (ARRAY_REF, yyval.ttype, NULL_TREE); ;
break;}
case 572:
-#line 2698 "parse.y"
+#line 2691 "parse.y"
{ yyval.ttype = yyvsp[-1].ttype; ;
break;}
case 573:
-#line 2700 "parse.y"
+#line 2693 "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 575:
-#line 2711 "parse.y"
+#line 2704 "parse.y"
{ yyval.ttype = make_pointer_declarator (yyvsp[-1].ftype.t, yyvsp[0].ttype); ;
break;}
case 576:
-#line 2713 "parse.y"
+#line 2706 "parse.y"
{ yyval.ttype = make_reference_declarator (yyvsp[-1].ftype.t, yyvsp[0].ttype); ;
break;}
case 577:
-#line 2715 "parse.y"
+#line 2708 "parse.y"
{ yyval.ttype = make_pointer_declarator (NULL_TREE, yyvsp[0].ttype); ;
break;}
case 578:
-#line 2717 "parse.y"
+#line 2710 "parse.y"
{ yyval.ttype = make_reference_declarator (NULL_TREE, yyvsp[0].ttype); ;
break;}
case 579:
-#line 2719 "parse.y"
+#line 2712 "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 581:
-#line 2727 "parse.y"
+#line 2720 "parse.y"
{ yyval.ttype = make_pointer_declarator (yyvsp[-1].ftype.t, yyvsp[0].ttype); ;
break;}
case 582:
-#line 2729 "parse.y"
+#line 2722 "parse.y"
{ yyval.ttype = make_reference_declarator (yyvsp[-1].ftype.t, yyvsp[0].ttype); ;
break;}
case 583:
-#line 2731 "parse.y"
+#line 2724 "parse.y"
{ yyval.ttype = make_pointer_declarator (NULL_TREE, yyvsp[0].ttype); ;
break;}
case 584:
-#line 2733 "parse.y"
+#line 2726 "parse.y"
{ yyval.ttype = make_reference_declarator (NULL_TREE, yyvsp[0].ttype); ;
break;}
case 585:
-#line 2735 "parse.y"
+#line 2728 "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 587:
-#line 2743 "parse.y"
+#line 2736 "parse.y"
{ yyval.ttype = make_call_declarator (yyval.ttype, yyvsp[-2].ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 588:
-#line 2745 "parse.y"
+#line 2738 "parse.y"
{ yyval.ttype = yyvsp[-1].ttype; ;
break;}
case 589:
-#line 2747 "parse.y"
+#line 2740 "parse.y"
{ yyval.ttype = build_parse_node (ARRAY_REF, yyval.ttype, yyvsp[-1].ttype); ;
break;}
case 590:
-#line 2749 "parse.y"
+#line 2742 "parse.y"
{ yyval.ttype = build_parse_node (ARRAY_REF, yyval.ttype, NULL_TREE); ;
break;}
case 591:
-#line 2751 "parse.y"
+#line 2744 "parse.y"
{ if (OP0 (yyval.ttype) != current_class_type)
{
push_nested_class (OP0 (yyval.ttype), 3);
@@ -6616,7 +6608,7 @@ case 591:
;
break;}
case 592:
-#line 2758 "parse.y"
+#line 2751 "parse.y"
{ got_scope = NULL_TREE;
yyval.ttype = build_parse_node (SCOPE_REF, yyvsp[-1].ttype, yyvsp[0].ttype);
if (yyvsp[-1].ttype != current_class_type)
@@ -6627,51 +6619,51 @@ case 592:
;
break;}
case 593:
-#line 2770 "parse.y"
+#line 2763 "parse.y"
{ got_scope = NULL_TREE;
yyval.ttype = build_parse_node (SCOPE_REF, yyval.ttype, yyvsp[0].ttype); ;
break;}
case 594:
-#line 2773 "parse.y"
+#line 2766 "parse.y"
{ got_scope = NULL_TREE;
yyval.ttype = build_parse_node (SCOPE_REF, yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 595:
-#line 2779 "parse.y"
+#line 2772 "parse.y"
{ got_scope = NULL_TREE;
yyval.ttype = build_parse_node (SCOPE_REF, yyval.ttype, yyvsp[0].ttype); ;
break;}
case 596:
-#line 2782 "parse.y"
+#line 2775 "parse.y"
{ got_scope = NULL_TREE;
yyval.ttype = build_parse_node (SCOPE_REF, yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 598:
-#line 2789 "parse.y"
+#line 2782 "parse.y"
{ yyval.ttype = yyvsp[0].ttype; ;
break;}
case 599:
-#line 2794 "parse.y"
+#line 2787 "parse.y"
{ yyval.ttype = build_functional_cast (yyvsp[-3].ftype.t, yyvsp[-1].ttype); ;
break;}
case 600:
-#line 2796 "parse.y"
+#line 2789 "parse.y"
{ yyval.ttype = reparse_decl_as_expr (yyvsp[-3].ftype.t, yyvsp[-1].ttype); ;
break;}
case 601:
-#line 2798 "parse.y"
+#line 2791 "parse.y"
{ yyval.ttype = reparse_absdcl_as_expr (yyvsp[-1].ftype.t, yyvsp[0].ttype); ;
break;}
case 606:
-#line 2810 "parse.y"
+#line 2803 "parse.y"
{ yyval.ttype = yyvsp[0].ttype; ;
break;}
case 607:
-#line 2812 "parse.y"
+#line 2805 "parse.y"
{ got_scope = yyval.ttype = make_typename_type (yyvsp[-3].ttype, yyvsp[-1].ttype); ;
break;}
case 608:
-#line 2819 "parse.y"
+#line 2812 "parse.y"
{
if (TREE_CODE (yyvsp[-1].ttype) == IDENTIFIER_NODE)
{
@@ -6687,7 +6679,7 @@ case 608:
;
break;}
case 609:
-#line 2833 "parse.y"
+#line 2826 "parse.y"
{
if (TREE_CODE (yyvsp[-1].ttype) == IDENTIFIER_NODE)
yyval.ttype = lastiddecl;
@@ -6695,7 +6687,7 @@ case 609:
;
break;}
case 610:
-#line 2839 "parse.y"
+#line 2832 "parse.y"
{
if (TREE_CODE (yyval.ttype) == IDENTIFIER_NODE)
yyval.ttype = lastiddecl;
@@ -6703,15 +6695,15 @@ case 610:
;
break;}
case 611:
-#line 2845 "parse.y"
+#line 2838 "parse.y"
{ got_scope = yyval.ttype = complete_type (TREE_TYPE (yyvsp[-1].ttype)); ;
break;}
case 613:
-#line 2861 "parse.y"
+#line 2854 "parse.y"
{ yyval.ttype = yyvsp[0].ttype; ;
break;}
case 614:
-#line 2866 "parse.y"
+#line 2859 "parse.y"
{
if (TREE_CODE_CLASS (TREE_CODE (yyvsp[-1].ttype)) == 't')
yyval.ttype = make_typename_type (yyvsp[-1].ttype, yyvsp[0].ttype);
@@ -6726,26 +6718,26 @@ case 614:
;
break;}
case 615:
-#line 2879 "parse.y"
+#line 2872 "parse.y"
{ yyval.ttype = TREE_TYPE (yyvsp[0].ttype); ;
break;}
case 616:
-#line 2881 "parse.y"
+#line 2874 "parse.y"
{ yyval.ttype = make_typename_type (yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 617:
-#line 2883 "parse.y"
+#line 2876 "parse.y"
{ yyval.ttype = make_typename_type (yyvsp[-2].ttype, yyvsp[0].ttype); ;
break;}
case 618:
-#line 2888 "parse.y"
+#line 2881 "parse.y"
{
if (TREE_CODE (yyvsp[0].ttype) == IDENTIFIER_NODE)
cp_error ("`%T' is not a class or namespace", yyvsp[0].ttype);
;
break;}
case 619:
-#line 2893 "parse.y"
+#line 2886 "parse.y"
{
if (TREE_CODE_CLASS (TREE_CODE (yyvsp[-1].ttype)) == 't')
yyval.ttype = make_typename_type (yyvsp[-1].ttype, yyvsp[0].ttype);
@@ -6760,15 +6752,15 @@ case 619:
;
break;}
case 620:
-#line 2906 "parse.y"
+#line 2899 "parse.y"
{ got_scope = yyval.ttype = make_typename_type (yyvsp[-2].ttype, yyvsp[-1].ttype); ;
break;}
case 621:
-#line 2908 "parse.y"
+#line 2901 "parse.y"
{ got_scope = yyval.ttype = make_typename_type (yyvsp[-3].ttype, yyvsp[-1].ttype); ;
break;}
case 622:
-#line 2913 "parse.y"
+#line 2906 "parse.y"
{
if (TREE_CODE (yyvsp[-1].ttype) != IDENTIFIER_NODE)
yyvsp[-1].ttype = lastiddecl;
@@ -6782,7 +6774,7 @@ case 622:
;
break;}
case 623:
-#line 2925 "parse.y"
+#line 2918 "parse.y"
{
if (TREE_CODE (yyvsp[-1].ttype) != IDENTIFIER_NODE)
yyval.ttype = lastiddecl;
@@ -6790,11 +6782,11 @@ case 623:
;
break;}
case 624:
-#line 2931 "parse.y"
+#line 2924 "parse.y"
{ got_scope = yyval.ttype = complete_type (TREE_TYPE (yyval.ttype)); ;
break;}
case 627:
-#line 2935 "parse.y"
+#line 2928 "parse.y"
{
if (TREE_CODE (yyval.ttype) == IDENTIFIER_NODE)
yyval.ttype = lastiddecl;
@@ -6802,11 +6794,11 @@ case 627:
;
break;}
case 628:
-#line 2944 "parse.y"
+#line 2937 "parse.y"
{ yyval.ttype = build_min_nt (TEMPLATE_ID_EXPR, yyvsp[-3].ttype, yyvsp[-1].ttype); ;
break;}
case 629:
-#line 2949 "parse.y"
+#line 2942 "parse.y"
{
if (TREE_CODE (yyvsp[0].ttype) == IDENTIFIER_NODE)
yyval.ttype = IDENTIFIER_GLOBAL_VALUE (yyvsp[0].ttype);
@@ -6816,148 +6808,148 @@ case 629:
;
break;}
case 631:
-#line 2958 "parse.y"
+#line 2951 "parse.y"
{ yyval.ttype = yyvsp[0].ttype; ;
break;}
case 632:
-#line 2963 "parse.y"
+#line 2956 "parse.y"
{ got_scope = NULL_TREE; ;
break;}
case 633:
-#line 2965 "parse.y"
+#line 2958 "parse.y"
{ yyval.ttype = yyvsp[-1].ttype; got_scope = NULL_TREE; ;
break;}
case 634:
-#line 2972 "parse.y"
+#line 2965 "parse.y"
{ got_scope = void_type_node; ;
break;}
case 635:
-#line 2978 "parse.y"
+#line 2971 "parse.y"
{ yyval.ttype = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 636:
-#line 2980 "parse.y"
+#line 2973 "parse.y"
{ yyval.ttype = make_pointer_declarator (yyvsp[0].ttype, NULL_TREE); ;
break;}
case 637:
-#line 2982 "parse.y"
+#line 2975 "parse.y"
{ yyval.ttype = make_reference_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 638:
-#line 2984 "parse.y"
+#line 2977 "parse.y"
{ yyval.ttype = make_reference_declarator (yyvsp[0].ttype, NULL_TREE); ;
break;}
case 639:
-#line 2986 "parse.y"
+#line 2979 "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 640:
-#line 2990 "parse.y"
+#line 2983 "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 642:
-#line 2999 "parse.y"
+#line 2992 "parse.y"
{ yyval.ttype = build_parse_node (ARRAY_REF, NULL_TREE, yyvsp[-1].ttype); ;
break;}
case 643:
-#line 3001 "parse.y"
+#line 2994 "parse.y"
{ yyval.ttype = build_parse_node (ARRAY_REF, yyval.ttype, yyvsp[-1].ttype); ;
break;}
case 644:
-#line 3007 "parse.y"
+#line 3000 "parse.y"
{ yyval.ttype = make_pointer_declarator (yyvsp[-1].ftype.t, yyvsp[0].ttype); ;
break;}
case 645:
-#line 3009 "parse.y"
+#line 3002 "parse.y"
{ yyval.ttype = make_pointer_declarator (NULL_TREE, yyvsp[0].ttype); ;
break;}
case 646:
-#line 3011 "parse.y"
+#line 3004 "parse.y"
{ yyval.ttype = make_pointer_declarator (yyvsp[0].ftype.t, NULL_TREE); ;
break;}
case 647:
-#line 3013 "parse.y"
+#line 3006 "parse.y"
{ yyval.ttype = make_pointer_declarator (NULL_TREE, NULL_TREE); ;
break;}
case 648:
-#line 3015 "parse.y"
+#line 3008 "parse.y"
{ yyval.ttype = make_reference_declarator (yyvsp[-1].ftype.t, yyvsp[0].ttype); ;
break;}
case 649:
-#line 3017 "parse.y"
+#line 3010 "parse.y"
{ yyval.ttype = make_reference_declarator (NULL_TREE, yyvsp[0].ttype); ;
break;}
case 650:
-#line 3019 "parse.y"
+#line 3012 "parse.y"
{ yyval.ttype = make_reference_declarator (yyvsp[0].ftype.t, NULL_TREE); ;
break;}
case 651:
-#line 3021 "parse.y"
+#line 3014 "parse.y"
{ yyval.ttype = make_reference_declarator (NULL_TREE, NULL_TREE); ;
break;}
case 652:
-#line 3023 "parse.y"
+#line 3016 "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 653:
-#line 3027 "parse.y"
+#line 3020 "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 655:
-#line 3036 "parse.y"
+#line 3029 "parse.y"
{ yyval.ttype = yyvsp[-1].ttype; ;
break;}
case 657:
-#line 3040 "parse.y"
+#line 3033 "parse.y"
{ yyval.ttype = make_call_declarator (yyval.ttype, yyvsp[-3].ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 658:
-#line 3042 "parse.y"
+#line 3035 "parse.y"
{ yyval.ttype = make_call_declarator (yyval.ttype, empty_parms (), yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 659:
-#line 3044 "parse.y"
+#line 3037 "parse.y"
{ yyval.ttype = build_parse_node (ARRAY_REF, yyval.ttype, yyvsp[-1].ttype); ;
break;}
case 660:
-#line 3046 "parse.y"
+#line 3039 "parse.y"
{ yyval.ttype = build_parse_node (ARRAY_REF, yyval.ttype, NULL_TREE); ;
break;}
case 661:
-#line 3048 "parse.y"
+#line 3041 "parse.y"
{ yyval.ttype = make_call_declarator (NULL_TREE, yyvsp[-3].ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 662:
-#line 3050 "parse.y"
+#line 3043 "parse.y"
{ set_quals_and_spec (yyval.ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 663:
-#line 3052 "parse.y"
+#line 3045 "parse.y"
{ set_quals_and_spec (yyval.ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 664:
-#line 3054 "parse.y"
+#line 3047 "parse.y"
{ yyval.ttype = build_parse_node (ARRAY_REF, NULL_TREE, yyvsp[-1].ttype); ;
break;}
case 665:
-#line 3056 "parse.y"
+#line 3049 "parse.y"
{ yyval.ttype = build_parse_node (ARRAY_REF, NULL_TREE, NULL_TREE); ;
break;}
case 672:
-#line 3079 "parse.y"
+#line 3072 "parse.y"
{ if (pedantic)
pedwarn ("ANSI C++ forbids label declarations"); ;
break;}
case 675:
-#line 3090 "parse.y"
+#line 3083 "parse.y"
{ tree link;
for (link = yyvsp[-1].ttype; link; link = TREE_CHAIN (link))
{
@@ -6968,181 +6960,181 @@ case 675:
;
break;}
case 676:
-#line 3104 "parse.y"
+#line 3097 "parse.y"
{;
break;}
case 678:
-#line 3110 "parse.y"
+#line 3103 "parse.y"
{ yyval.ttype = begin_compound_stmt (0); ;
break;}
case 679:
-#line 3112 "parse.y"
+#line 3105 "parse.y"
{ yyval.ttype = finish_compound_stmt (0, yyvsp[-1].ttype); ;
break;}
case 680:
-#line 3117 "parse.y"
+#line 3110 "parse.y"
{
yyval.ttype = begin_if_stmt ();
cond_stmt_keyword = "if";
;
break;}
case 681:
-#line 3122 "parse.y"
+#line 3115 "parse.y"
{ finish_if_stmt_cond (yyvsp[0].ttype, yyvsp[-1].ttype); ;
break;}
case 682:
-#line 3124 "parse.y"
+#line 3117 "parse.y"
{ yyval.ttype = finish_then_clause (yyvsp[-3].ttype); ;
break;}
case 684:
-#line 3129 "parse.y"
+#line 3122 "parse.y"
{ yyval.ttype = begin_compound_stmt (0); ;
break;}
case 685:
-#line 3131 "parse.y"
+#line 3124 "parse.y"
{ yyval.ttype = finish_compound_stmt (0, yyvsp[-1].ttype); ;
break;}
case 686:
-#line 3136 "parse.y"
+#line 3129 "parse.y"
{;
break;}
case 688:
-#line 3142 "parse.y"
+#line 3135 "parse.y"
{ finish_stmt (); ;
break;}
case 689:
-#line 3144 "parse.y"
+#line 3137 "parse.y"
{ finish_expr_stmt (yyvsp[-1].ttype); ;
break;}
case 690:
-#line 3146 "parse.y"
+#line 3139 "parse.y"
{ begin_else_clause (); ;
break;}
case 691:
-#line 3148 "parse.y"
+#line 3141 "parse.y"
{
finish_else_clause (yyvsp[-3].ttype);
finish_if_stmt ();
;
break;}
case 692:
-#line 3153 "parse.y"
+#line 3146 "parse.y"
{ finish_if_stmt (); ;
break;}
case 693:
-#line 3155 "parse.y"
+#line 3148 "parse.y"
{
yyval.ttype = begin_while_stmt ();
cond_stmt_keyword = "while";
;
break;}
case 694:
-#line 3160 "parse.y"
+#line 3153 "parse.y"
{ finish_while_stmt_cond (yyvsp[0].ttype, yyvsp[-1].ttype); ;
break;}
case 695:
-#line 3162 "parse.y"
+#line 3155 "parse.y"
{ finish_while_stmt (yyvsp[-3].ttype); ;
break;}
case 696:
-#line 3164 "parse.y"
+#line 3157 "parse.y"
{ yyval.ttype = begin_do_stmt (); ;
break;}
case 697:
-#line 3166 "parse.y"
+#line 3159 "parse.y"
{
finish_do_body (yyvsp[-2].ttype);
cond_stmt_keyword = "do";
;
break;}
case 698:
-#line 3171 "parse.y"
+#line 3164 "parse.y"
{ finish_do_stmt (yyvsp[-1].ttype, yyvsp[-5].ttype); ;
break;}
case 699:
-#line 3173 "parse.y"
+#line 3166 "parse.y"
{ yyval.ttype = begin_for_stmt (); ;
break;}
case 700:
-#line 3175 "parse.y"
+#line 3168 "parse.y"
{ finish_for_init_stmt (yyvsp[-2].ttype); ;
break;}
case 701:
-#line 3177 "parse.y"
+#line 3170 "parse.y"
{ finish_for_cond (yyvsp[-1].ttype, yyvsp[-5].ttype); ;
break;}
case 702:
-#line 3179 "parse.y"
+#line 3172 "parse.y"
{ finish_for_expr (yyvsp[-1].ttype, yyvsp[-8].ttype); ;
break;}
case 703:
-#line 3181 "parse.y"
+#line 3174 "parse.y"
{ finish_for_stmt (yyvsp[-3].ttype, yyvsp[-10].ttype); ;
break;}
case 704:
-#line 3183 "parse.y"
+#line 3176 "parse.y"
{ begin_switch_stmt (); ;
break;}
case 705:
-#line 3185 "parse.y"
+#line 3178 "parse.y"
{ yyval.ttype = finish_switch_cond (yyvsp[-1].ttype); ;
break;}
case 706:
-#line 3187 "parse.y"
+#line 3180 "parse.y"
{ finish_switch_stmt (yyvsp[-3].ttype, yyvsp[-1].ttype); ;
break;}
case 707:
-#line 3189 "parse.y"
+#line 3182 "parse.y"
{ finish_case_label (yyvsp[-1].ttype, NULL_TREE); ;
break;}
case 709:
-#line 3192 "parse.y"
+#line 3185 "parse.y"
{ finish_case_label (yyvsp[-3].ttype, yyvsp[-1].ttype); ;
break;}
case 711:
-#line 3195 "parse.y"
+#line 3188 "parse.y"
{ finish_case_label (NULL_TREE, NULL_TREE); ;
break;}
case 713:
-#line 3198 "parse.y"
+#line 3191 "parse.y"
{ finish_break_stmt (); ;
break;}
case 714:
-#line 3200 "parse.y"
+#line 3193 "parse.y"
{ finish_continue_stmt (); ;
break;}
case 715:
-#line 3202 "parse.y"
+#line 3195 "parse.y"
{ finish_return_stmt (NULL_TREE); ;
break;}
case 716:
-#line 3204 "parse.y"
+#line 3197 "parse.y"
{ finish_return_stmt (yyvsp[-1].ttype); ;
break;}
case 717:
-#line 3206 "parse.y"
+#line 3199 "parse.y"
{
finish_asm_stmt (yyvsp[-4].ttype, yyvsp[-2].ttype, NULL_TREE, NULL_TREE,
NULL_TREE);
;
break;}
case 718:
-#line 3212 "parse.y"
+#line 3205 "parse.y"
{
finish_asm_stmt (yyvsp[-6].ttype, yyvsp[-4].ttype, yyvsp[-2].ttype, NULL_TREE,
NULL_TREE);
;
break;}
case 719:
-#line 3218 "parse.y"
+#line 3211 "parse.y"
{ finish_asm_stmt (yyvsp[-8].ttype, yyvsp[-6].ttype, yyvsp[-4].ttype, yyvsp[-2].ttype, NULL_TREE); ;
break;}
case 720:
-#line 3222 "parse.y"
+#line 3215 "parse.y"
{ finish_asm_stmt (yyvsp[-10].ttype, yyvsp[-8].ttype, yyvsp[-6].ttype, yyvsp[-4].ttype, yyvsp[-2].ttype); ;
break;}
case 721:
-#line 3224 "parse.y"
+#line 3217 "parse.y"
{
if (pedantic)
pedwarn ("ANSI C++ forbids computed gotos");
@@ -7150,25 +7142,25 @@ case 721:
;
break;}
case 722:
-#line 3230 "parse.y"
+#line 3223 "parse.y"
{ finish_goto_stmt (yyvsp[-1].ttype); ;
break;}
case 723:
-#line 3232 "parse.y"
+#line 3225 "parse.y"
{ finish_stmt (); ;
break;}
case 724:
-#line 3234 "parse.y"
+#line 3227 "parse.y"
{ error ("label must be followed by statement");
yyungetc ('}', 0);
finish_stmt (); ;
break;}
case 725:
-#line 3238 "parse.y"
+#line 3231 "parse.y"
{ finish_stmt (); ;
break;}
case 727:
-#line 3244 "parse.y"
+#line 3237 "parse.y"
{
if (! current_function_parms_stored)
store_parm_decls ();
@@ -7176,14 +7168,14 @@ case 727:
;
break;}
case 728:
-#line 3250 "parse.y"
+#line 3243 "parse.y"
{
expand_start_all_catch ();
expand_start_catch (NULL);
;
break;}
case 729:
-#line 3255 "parse.y"
+#line 3248 "parse.y"
{
int nested = (hack_decl_function_context
(current_function_decl) != NULL_TREE);
@@ -7193,41 +7185,41 @@ case 729:
;
break;}
case 730:
-#line 3266 "parse.y"
+#line 3259 "parse.y"
{ yyval.ttype = begin_try_block (); ;
break;}
case 731:
-#line 3268 "parse.y"
+#line 3261 "parse.y"
{ finish_try_block (yyvsp[-1].ttype); ;
break;}
case 732:
-#line 3270 "parse.y"
+#line 3263 "parse.y"
{ finish_handler_sequence (yyvsp[-3].ttype); ;
break;}
case 735:
-#line 3280 "parse.y"
+#line 3273 "parse.y"
{ yyval.ttype = begin_handler(); ;
break;}
case 736:
-#line 3282 "parse.y"
+#line 3275 "parse.y"
{ finish_handler_parms (yyvsp[-1].ttype); ;
break;}
case 737:
-#line 3284 "parse.y"
+#line 3277 "parse.y"
{ finish_handler (yyvsp[-3].ttype); ;
break;}
case 740:
-#line 3294 "parse.y"
+#line 3287 "parse.y"
{ expand_start_catch_block (NULL_TREE, NULL_TREE); ;
break;}
case 741:
-#line 3310 "parse.y"
+#line 3303 "parse.y"
{ check_for_new_type ("inside exception declarations", yyvsp[-1].ftype);
expand_start_catch_block (TREE_PURPOSE (yyvsp[-1].ftype.t),
TREE_VALUE (yyvsp[-1].ftype.t)); ;
break;}
case 742:
-#line 3317 "parse.y"
+#line 3310 "parse.y"
{ tree label;
do_label:
label = define_label (input_filename, lineno, yyvsp[-1].ttype);
@@ -7236,98 +7228,98 @@ case 742:
;
break;}
case 743:
-#line 3324 "parse.y"
+#line 3317 "parse.y"
{ goto do_label; ;
break;}
case 744:
-#line 3326 "parse.y"
+#line 3319 "parse.y"
{ goto do_label; ;
break;}
case 745:
-#line 3328 "parse.y"
+#line 3321 "parse.y"
{ goto do_label; ;
break;}
case 746:
-#line 3333 "parse.y"
+#line 3326 "parse.y"
{ if (yyvsp[-1].ttype) cplus_expand_expr_stmt (yyvsp[-1].ttype); ;
break;}
case 748:
-#line 3336 "parse.y"
+#line 3329 "parse.y"
{ if (pedantic)
pedwarn ("ANSI C++ forbids compound statements inside for initializations");
;
break;}
case 749:
-#line 3345 "parse.y"
+#line 3338 "parse.y"
{ emit_line_note (input_filename, lineno);
yyval.ttype = NULL_TREE; ;
break;}
case 750:
-#line 3348 "parse.y"
+#line 3341 "parse.y"
{ emit_line_note (input_filename, lineno); ;
break;}
case 751:
-#line 3353 "parse.y"
+#line 3346 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 753:
-#line 3356 "parse.y"
+#line 3349 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 754:
-#line 3363 "parse.y"
+#line 3356 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 757:
-#line 3370 "parse.y"
+#line 3363 "parse.y"
{ yyval.ttype = chainon (yyval.ttype, yyvsp[0].ttype); ;
break;}
case 758:
-#line 3375 "parse.y"
+#line 3368 "parse.y"
{ yyval.ttype = build_tree_list (yyval.ttype, yyvsp[-1].ttype); ;
break;}
case 759:
-#line 3380 "parse.y"
+#line 3373 "parse.y"
{ yyval.ttype = tree_cons (NULL_TREE, yyval.ttype, NULL_TREE); ;
break;}
case 760:
-#line 3382 "parse.y"
+#line 3375 "parse.y"
{ yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyval.ttype); ;
break;}
case 761:
-#line 3393 "parse.y"
+#line 3386 "parse.y"
{
yyval.ttype = empty_parms();
;
break;}
case 763:
-#line 3398 "parse.y"
+#line 3391 "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 764:
-#line 3406 "parse.y"
+#line 3399 "parse.y"
{ yyval.ttype = finish_parmlist (yyval.ttype, 0); ;
break;}
case 765:
-#line 3408 "parse.y"
+#line 3401 "parse.y"
{ yyval.ttype = finish_parmlist (yyvsp[-1].ttype, 1); ;
break;}
case 766:
-#line 3411 "parse.y"
+#line 3404 "parse.y"
{ yyval.ttype = finish_parmlist (yyvsp[-1].ttype, 1); ;
break;}
case 767:
-#line 3413 "parse.y"
+#line 3406 "parse.y"
{ yyval.ttype = finish_parmlist (build_tree_list (NULL_TREE,
yyvsp[-1].ftype.t), 1); ;
break;}
case 768:
-#line 3416 "parse.y"
+#line 3409 "parse.y"
{ yyval.ttype = finish_parmlist (NULL_TREE, 1); ;
break;}
case 769:
-#line 3418 "parse.y"
+#line 3411 "parse.y"
{
/* This helps us recover from really nasty
parse errors, for example, a missing right
@@ -7339,7 +7331,7 @@ case 769:
;
break;}
case 770:
-#line 3428 "parse.y"
+#line 3421 "parse.y"
{
/* This helps us recover from really nasty
parse errors, for example, a missing right
@@ -7352,98 +7344,98 @@ case 770:
;
break;}
case 771:
-#line 3443 "parse.y"
+#line 3436 "parse.y"
{ maybe_snarf_defarg (); ;
break;}
case 772:
-#line 3445 "parse.y"
+#line 3438 "parse.y"
{ yyval.ttype = yyvsp[0].ttype; ;
break;}
case 775:
-#line 3456 "parse.y"
+#line 3449 "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 776:
-#line 3459 "parse.y"
+#line 3452 "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 777:
-#line 3462 "parse.y"
+#line 3455 "parse.y"
{ check_for_new_type ("in a parameter list", yyvsp[0].ftype);
yyval.ttype = chainon (yyval.ttype, yyvsp[0].ftype.t); ;
break;}
case 778:
-#line 3465 "parse.y"
+#line 3458 "parse.y"
{ yyval.ttype = chainon (yyval.ttype, build_tree_list (NULL_TREE, yyvsp[0].ttype)); ;
break;}
case 779:
-#line 3467 "parse.y"
+#line 3460 "parse.y"
{ yyval.ttype = chainon (yyval.ttype, build_tree_list (yyvsp[0].ttype, yyvsp[-2].ttype)); ;
break;}
case 781:
-#line 3473 "parse.y"
+#line 3466 "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 782:
-#line 3483 "parse.y"
+#line 3476 "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 783:
-#line 3487 "parse.y"
+#line 3480 "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 784:
-#line 3490 "parse.y"
+#line 3483 "parse.y"
{ yyval.ftype.t = build_tree_list (get_decl_list (yyvsp[-1].ftype.t), yyvsp[0].ttype);
yyval.ftype.new_type_flag = yyvsp[-1].ftype.new_type_flag; ;
break;}
case 785:
-#line 3493 "parse.y"
+#line 3486 "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 786:
-#line 3497 "parse.y"
+#line 3490 "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 787:
-#line 3501 "parse.y"
+#line 3494 "parse.y"
{ tree specs = strip_attrs (yyvsp[-1].ttype);
yyval.ftype.t = build_tree_list (specs, yyvsp[0].ttype);
yyval.ftype.new_type_flag = 0; ;
break;}
case 788:
-#line 3508 "parse.y"
+#line 3501 "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 789:
-#line 3511 "parse.y"
+#line 3504 "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 792:
-#line 3522 "parse.y"
+#line 3515 "parse.y"
{ see_typename (); ;
break;}
case 793:
-#line 3527 "parse.y"
+#line 3520 "parse.y"
{
error ("type specifier omitted for parameter");
yyval.ttype = build_tree_list (integer_type_node, NULL_TREE);
;
break;}
case 794:
-#line 3532 "parse.y"
+#line 3525 "parse.y"
{
error ("type specifier omitted for parameter");
if (TREE_CODE (yyval.ttype) == SCOPE_REF
@@ -7454,188 +7446,188 @@ case 794:
;
break;}
case 795:
-#line 3544 "parse.y"
+#line 3537 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 796:
-#line 3546 "parse.y"
+#line 3539 "parse.y"
{ yyval.ttype = yyvsp[-1].ttype; ;
break;}
case 797:
-#line 3548 "parse.y"
+#line 3541 "parse.y"
{ yyval.ttype = build_decl_list (NULL_TREE, NULL_TREE); ;
break;}
case 798:
-#line 3553 "parse.y"
+#line 3546 "parse.y"
{ yyval.ttype = build_decl_list (NULL_TREE, groktypename(yyvsp[0].ftype.t)); ;
break;}
case 800:
-#line 3559 "parse.y"
+#line 3552 "parse.y"
{
TREE_CHAIN (yyvsp[0].ttype) = yyval.ttype;
yyval.ttype = yyvsp[0].ttype;
;
break;}
case 801:
-#line 3567 "parse.y"
+#line 3560 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 802:
-#line 3569 "parse.y"
+#line 3562 "parse.y"
{ yyval.ttype = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 803:
-#line 3571 "parse.y"
+#line 3564 "parse.y"
{ yyval.ttype = make_reference_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 804:
-#line 3573 "parse.y"
+#line 3566 "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 805:
-#line 3580 "parse.y"
+#line 3573 "parse.y"
{ got_scope = NULL_TREE; ;
break;}
case 806:
-#line 3585 "parse.y"
+#line 3578 "parse.y"
{ yyval.ttype = ansi_opname[MULT_EXPR]; ;
break;}
case 807:
-#line 3587 "parse.y"
+#line 3580 "parse.y"
{ yyval.ttype = ansi_opname[TRUNC_DIV_EXPR]; ;
break;}
case 808:
-#line 3589 "parse.y"
+#line 3582 "parse.y"
{ yyval.ttype = ansi_opname[TRUNC_MOD_EXPR]; ;
break;}
case 809:
-#line 3591 "parse.y"
+#line 3584 "parse.y"
{ yyval.ttype = ansi_opname[PLUS_EXPR]; ;
break;}
case 810:
-#line 3593 "parse.y"
+#line 3586 "parse.y"
{ yyval.ttype = ansi_opname[MINUS_EXPR]; ;
break;}
case 811:
-#line 3595 "parse.y"
+#line 3588 "parse.y"
{ yyval.ttype = ansi_opname[BIT_AND_EXPR]; ;
break;}
case 812:
-#line 3597 "parse.y"
+#line 3590 "parse.y"
{ yyval.ttype = ansi_opname[BIT_IOR_EXPR]; ;
break;}
case 813:
-#line 3599 "parse.y"
+#line 3592 "parse.y"
{ yyval.ttype = ansi_opname[BIT_XOR_EXPR]; ;
break;}
case 814:
-#line 3601 "parse.y"
+#line 3594 "parse.y"
{ yyval.ttype = ansi_opname[BIT_NOT_EXPR]; ;
break;}
case 815:
-#line 3603 "parse.y"
+#line 3596 "parse.y"
{ yyval.ttype = ansi_opname[COMPOUND_EXPR]; ;
break;}
case 816:
-#line 3605 "parse.y"
+#line 3598 "parse.y"
{ yyval.ttype = ansi_opname[yyvsp[0].code]; ;
break;}
case 817:
-#line 3607 "parse.y"
+#line 3600 "parse.y"
{ yyval.ttype = ansi_opname[LT_EXPR]; ;
break;}
case 818:
-#line 3609 "parse.y"
+#line 3602 "parse.y"
{ yyval.ttype = ansi_opname[GT_EXPR]; ;
break;}
case 819:
-#line 3611 "parse.y"
+#line 3604 "parse.y"
{ yyval.ttype = ansi_opname[yyvsp[0].code]; ;
break;}
case 820:
-#line 3613 "parse.y"
+#line 3606 "parse.y"
{ yyval.ttype = ansi_assopname[yyvsp[0].code]; ;
break;}
case 821:
-#line 3615 "parse.y"
+#line 3608 "parse.y"
{ yyval.ttype = ansi_opname [MODIFY_EXPR]; ;
break;}
case 822:
-#line 3617 "parse.y"
+#line 3610 "parse.y"
{ yyval.ttype = ansi_opname[yyvsp[0].code]; ;
break;}
case 823:
-#line 3619 "parse.y"
+#line 3612 "parse.y"
{ yyval.ttype = ansi_opname[yyvsp[0].code]; ;
break;}
case 824:
-#line 3621 "parse.y"
+#line 3614 "parse.y"
{ yyval.ttype = ansi_opname[POSTINCREMENT_EXPR]; ;
break;}
case 825:
-#line 3623 "parse.y"
+#line 3616 "parse.y"
{ yyval.ttype = ansi_opname[PREDECREMENT_EXPR]; ;
break;}
case 826:
-#line 3625 "parse.y"
+#line 3618 "parse.y"
{ yyval.ttype = ansi_opname[TRUTH_ANDIF_EXPR]; ;
break;}
case 827:
-#line 3627 "parse.y"
+#line 3620 "parse.y"
{ yyval.ttype = ansi_opname[TRUTH_ORIF_EXPR]; ;
break;}
case 828:
-#line 3629 "parse.y"
+#line 3622 "parse.y"
{ yyval.ttype = ansi_opname[TRUTH_NOT_EXPR]; ;
break;}
case 829:
-#line 3631 "parse.y"
+#line 3624 "parse.y"
{ yyval.ttype = ansi_opname[COND_EXPR]; ;
break;}
case 830:
-#line 3633 "parse.y"
+#line 3626 "parse.y"
{ yyval.ttype = ansi_opname[yyvsp[0].code]; ;
break;}
case 831:
-#line 3635 "parse.y"
+#line 3628 "parse.y"
{ yyval.ttype = ansi_opname[COMPONENT_REF]; ;
break;}
case 832:
-#line 3637 "parse.y"
+#line 3630 "parse.y"
{ yyval.ttype = ansi_opname[MEMBER_REF]; ;
break;}
case 833:
-#line 3639 "parse.y"
+#line 3632 "parse.y"
{ yyval.ttype = ansi_opname[CALL_EXPR]; ;
break;}
case 834:
-#line 3641 "parse.y"
+#line 3634 "parse.y"
{ yyval.ttype = ansi_opname[ARRAY_REF]; ;
break;}
case 835:
-#line 3643 "parse.y"
+#line 3636 "parse.y"
{ yyval.ttype = ansi_opname[NEW_EXPR]; ;
break;}
case 836:
-#line 3645 "parse.y"
+#line 3638 "parse.y"
{ yyval.ttype = ansi_opname[DELETE_EXPR]; ;
break;}
case 837:
-#line 3647 "parse.y"
+#line 3640 "parse.y"
{ yyval.ttype = ansi_opname[VEC_NEW_EXPR]; ;
break;}
case 838:
-#line 3649 "parse.y"
+#line 3642 "parse.y"
{ yyval.ttype = ansi_opname[VEC_DELETE_EXPR]; ;
break;}
case 839:
-#line 3652 "parse.y"
+#line 3645 "parse.y"
{ yyval.ttype = grokoptypename (yyvsp[-1].ftype.t, yyvsp[0].ttype); ;
break;}
case 840:
-#line 3654 "parse.y"
+#line 3647 "parse.y"
{ yyval.ttype = ansi_opname[ERROR_MARK]; ;
break;}
}
@@ -7836,7 +7828,7 @@ yyerrhandle:
yystate = yyn;
goto yynewstate;
}
-#line 3657 "parse.y"
+#line 3650 "parse.y"
#ifdef SPEW_DEBUG
diff --git a/gcc/cp/parse.y b/gcc/cp/parse.y
index 70af50b..ac2f526 100644
--- a/gcc/cp/parse.y
+++ b/gcc/cp/parse.y
@@ -2396,15 +2396,7 @@ component_decl:
| template_header component_decl
{ $$ = finish_member_template_decl ($1, $2); }
| template_header typed_declspecs ';'
- {
- note_list_got_semicolon ($2.t);
- grok_x_components ($2.t, NULL_TREE);
- if (TYPE_CONTEXT (TREE_VALUE ($2.t)) != current_class_type)
- /* The component was in fact a friend
- declaration. */
- $2.t = NULL_TREE;
- $$ = finish_member_template_decl ($1, $2.t);
- }
+ { $$ = finish_member_class_template ($1, $2.t); }
;
component_decl_1:
diff --git a/gcc/cp/pt.c b/gcc/cp/pt.c
index 43ab3d2..7550271 100644
--- a/gcc/cp/pt.c
+++ b/gcc/cp/pt.c
@@ -2733,10 +2733,19 @@ classtype_mangled_name (t)
&& PRIMARY_TEMPLATE_P (CLASSTYPE_TI_TEMPLATE (t)))
{
tree name = DECL_NAME (CLASSTYPE_TI_TEMPLATE (t));
+ /* We do not pass in the context here since that is only needed
+ when mangling the name of instantiations, not the primary
+ template declaration. In reality, it should not be needed
+ then either, but the way lookup_template_class operates
+ requires the context for the moment. In the long run,
+ lookup_template_class should not be looking for existing
+ instantiations by matching mangled names, but rather by
+ matching the templates, and then scanning the instantiation
+ list. */
char *mangled_name = mangle_class_name_for_template
(IDENTIFIER_POINTER (name),
DECL_INNERMOST_TEMPLATE_PARMS (CLASSTYPE_TI_TEMPLATE (t)),
- CLASSTYPE_TI_ARGS (t), DECL_CONTEXT (t));
+ CLASSTYPE_TI_ARGS (t), NULL_TREE);
tree id = get_identifier (mangled_name);
IDENTIFIER_TEMPLATE (id) = name;
return id;
diff --git a/gcc/cp/semantics.c b/gcc/cp/semantics.c
index 2501642..4ee2de4 100644
--- a/gcc/cp/semantics.c
+++ b/gcc/cp/semantics.c
@@ -1337,3 +1337,25 @@ begin_inline_definitions ()
/* Undo the begin_tree in begin_class_definition. */
end_tree ();
}
+
+/* Finish processing the declaration of a member class template
+ TYPES whose template parameters are given by PARMS. */
+
+tree
+finish_member_class_template (parms, types)
+ tree parms;
+ tree types;
+{
+ note_list_got_semicolon (types);
+ grok_x_components (types, NULL_TREE);
+ if (TYPE_CONTEXT (TREE_VALUE (types)) != current_class_type)
+ /* The component was in fact a friend declaration. We avoid
+ finish_member_template_decl performing certain checks by
+ unsetting TYPES. */
+ types = NULL_TREE;
+ finish_member_template_decl (parms, types);
+ /* As with other component type declarations, we do
+ not store the new DECL on the list of
+ component_decls. */
+ return NULL_TREE;
+}