aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMark Mitchell <mark@markmitchell.com>1998-08-28 12:06:56 +0000
committerMark Mitchell <mmitchel@gcc.gnu.org>1998-08-28 12:06:56 +0000
commitea6021e832a937087583f9c1b1ca1f3220ef5bd3 (patch)
tree55daae681e7c466aee112a03fce6c8db72ee25e4
parent9231189b62413d0e5427371eb97cd7961ec8be34 (diff)
downloadgcc-ea6021e832a937087583f9c1b1ca1f3220ef5bd3.zip
gcc-ea6021e832a937087583f9c1b1ca1f3220ef5bd3.tar.gz
gcc-ea6021e832a937087583f9c1b1ca1f3220ef5bd3.tar.bz2
cp-tree.h (finish_base_specifier): New function.
* cp-tree.h (finish_base_specifier): New function. * parse.y (base_class): Use it. * semantics.c (finish_base_specifier): Define it. * parse.y (structsp): Warn on use of typename outside of template declarations. From-SVN: r22055
-rw-r--r--gcc/cp/ChangeLog9
-rw-r--r--gcc/cp/cp-tree.h1
-rw-r--r--gcc/cp/parse.c818
-rw-r--r--gcc/cp/parse.y75
-rw-r--r--gcc/cp/semantics.c50
-rw-r--r--gcc/testsuite/g++.old-deja/g++.pt/typename10.C7
6 files changed, 457 insertions, 503 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index c048dab..8e486ca 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,3 +1,12 @@
+1998-08-28 Mark Mitchell <mark@markmitchell.com>
+
+ * cp-tree.h (finish_base_specifier): New function.
+ * parse.y (base_class): Use it.
+ * semantics.c (finish_base_specifier): Define it.
+
+ * parse.y (structsp): Warn on use of typename outside of template
+ declarations.
+
1998-08-27 Jason Merrill <jason@yorick.cygnus.com>
* lex.c (handle_cp_pragma): Remove #pragma vtable.
diff --git a/gcc/cp/cp-tree.h b/gcc/cp/cp-tree.h
index 5ce5dd9..8829b39 100644
--- a/gcc/cp/cp-tree.h
+++ b/gcc/cp/cp-tree.h
@@ -2943,6 +2943,7 @@ extern tree finish_member_class_template PROTO((tree, tree));
extern void finish_template_decl PROTO((tree));
extern tree finish_template_type PROTO((tree, tree, int));
extern void enter_scope_of PROTO((tree));
+extern tree finish_base_specifier PROTO((tree, tree, int));
/* in sig.c */
extern tree build_signature_pointer_type PROTO((tree, int, int));
diff --git a/gcc/cp/parse.c b/gcc/cp/parse.c
index f64a24f..f7fa3be 100644
--- a/gcc/cp/parse.c
+++ b/gcc/cp/parse.c
@@ -683,46 +683,46 @@ static const short yyrline[] = { 0,
1973, 1977, 1980, 1986, 1988, 1991, 1994, 1997, 2003, 2006,
2009, 2011, 2013, 2017, 2023, 2031, 2033, 2037, 2039, 2044,
2047, 2050, 2052, 2054, 2058, 2062, 2068, 2072, 2075, 2081,
- 2085, 2088, 2091, 2095, 2107, 2109, 2112, 2132, 2134, 2137,
- 2139, 2144, 2146, 2148, 2150, 2152, 2154, 2158, 2163, 2166,
- 2168, 2172, 2178, 2183, 2188, 2190, 2194, 2199, 2202, 2209,
- 2226, 2232, 2234, 2237, 2240, 2242, 2246, 2248, 2252, 2285,
- 2321, 2324, 2325, 2346, 2369, 2371, 2375, 2386, 2400, 2405,
- 2412, 2415, 2423, 2434, 2443, 2447, 2462, 2465, 2470, 2472,
- 2474, 2476, 2478, 2480, 2483, 2485, 2489, 2495, 2497, 2500,
- 2503, 2505, 2516, 2521, 2524, 2529, 2532, 2533, 2544, 2547,
- 2548, 2559, 2561, 2564, 2566, 2569, 2576, 2584, 2591, 2597,
- 2603, 2611, 2615, 2620, 2624, 2627, 2636, 2638, 2642, 2645,
- 2650, 2654, 2660, 2671, 2674, 2678, 2682, 2690, 2695, 2701,
- 2704, 2706, 2708, 2714, 2717, 2719, 2721, 2723, 2727, 2730,
- 2748, 2758, 2760, 2761, 2765, 2770, 2773, 2775, 2777, 2779,
- 2783, 2789, 2792, 2794, 2796, 2798, 2802, 2805, 2808, 2810,
- 2812, 2814, 2818, 2821, 2824, 2826, 2828, 2830, 2832, 2839,
- 2843, 2848, 2852, 2857, 2859, 2863, 2866, 2868, 2872, 2874,
- 2875, 2878, 2880, 2882, 2888, 2903, 2909, 2915, 2929, 2931,
- 2935, 2949, 2951, 2953, 2957, 2963, 2976, 2978, 2982, 2995,
- 3001, 3003, 3004, 3005, 3013, 3018, 3027, 3028, 3032, 3035,
- 3041, 3047, 3050, 3052, 3054, 3056, 3060, 3064, 3068, 3071,
- 3076, 3079, 3081, 3083, 3085, 3087, 3089, 3091, 3093, 3097,
- 3101, 3105, 3109, 3110, 3112, 3114, 3116, 3118, 3120, 3122,
- 3124, 3126, 3134, 3136, 3137, 3138, 3141, 3147, 3149, 3154,
- 3156, 3159, 3173, 3176, 3179, 3183, 3186, 3193, 3195, 3198,
- 3200, 3202, 3205, 3208, 3211, 3214, 3216, 3219, 3223, 3225,
- 3231, 3233, 3234, 3236, 3241, 3243, 3245, 3247, 3249, 3252,
- 3253, 3255, 3258, 3259, 3262, 3262, 3265, 3265, 3268, 3268,
- 3270, 3272, 3274, 3276, 3282, 3288, 3291, 3294, 3300, 3302,
- 3304, 3308, 3310, 3311, 3312, 3314, 3317, 3324, 3329, 3337,
- 3341, 3343, 3346, 3348, 3351, 3355, 3357, 3360, 3362, 3365,
- 3382, 3388, 3396, 3398, 3400, 3404, 3407, 3408, 3416, 3420,
- 3424, 3427, 3428, 3434, 3437, 3440, 3442, 3446, 3451, 3454,
- 3464, 3469, 3470, 3477, 3480, 3483, 3485, 3488, 3490, 3500,
- 3514, 3518, 3521, 3523, 3527, 3531, 3534, 3537, 3539, 3543,
- 3545, 3552, 3559, 3562, 3565, 3569, 3573, 3579, 3583, 3588,
- 3590, 3593, 3598, 3604, 3615, 3618, 3620, 3624, 3629, 3631,
- 3638, 3641, 3643, 3645, 3651, 3656, 3659, 3661, 3663, 3665,
- 3667, 3669, 3671, 3673, 3675, 3677, 3679, 3681, 3683, 3685,
- 3687, 3689, 3691, 3693, 3695, 3697, 3699, 3701, 3703, 3705,
- 3707, 3709, 3711, 3713, 3715, 3717, 3719, 3721, 3724, 3726
+ 2085, 2088, 2091, 2097, 2109, 2111, 2114, 2134, 2136, 2139,
+ 2141, 2146, 2148, 2150, 2152, 2154, 2156, 2160, 2165, 2168,
+ 2170, 2174, 2180, 2185, 2190, 2192, 2196, 2201, 2204, 2211,
+ 2228, 2234, 2236, 2239, 2242, 2244, 2248, 2250, 2254, 2259,
+ 2265, 2268, 2269, 2290, 2313, 2315, 2319, 2330, 2344, 2349,
+ 2356, 2359, 2367, 2378, 2387, 2391, 2406, 2409, 2414, 2416,
+ 2418, 2420, 2422, 2424, 2427, 2429, 2433, 2439, 2441, 2444,
+ 2447, 2449, 2460, 2465, 2468, 2473, 2476, 2477, 2488, 2491,
+ 2492, 2503, 2505, 2508, 2510, 2513, 2520, 2528, 2535, 2541,
+ 2547, 2555, 2559, 2564, 2568, 2571, 2580, 2582, 2586, 2589,
+ 2594, 2598, 2604, 2615, 2618, 2622, 2626, 2634, 2639, 2645,
+ 2648, 2650, 2652, 2658, 2661, 2663, 2665, 2667, 2671, 2674,
+ 2692, 2702, 2704, 2705, 2709, 2714, 2717, 2719, 2721, 2723,
+ 2727, 2733, 2736, 2738, 2740, 2742, 2746, 2749, 2752, 2754,
+ 2756, 2758, 2762, 2765, 2768, 2770, 2772, 2774, 2776, 2783,
+ 2787, 2792, 2796, 2801, 2803, 2807, 2810, 2812, 2816, 2818,
+ 2819, 2822, 2824, 2826, 2832, 2847, 2853, 2859, 2873, 2875,
+ 2879, 2893, 2895, 2897, 2901, 2907, 2920, 2922, 2926, 2939,
+ 2945, 2947, 2948, 2949, 2957, 2962, 2971, 2972, 2976, 2979,
+ 2985, 2991, 2994, 2996, 2998, 3000, 3004, 3008, 3012, 3015,
+ 3020, 3023, 3025, 3027, 3029, 3031, 3033, 3035, 3037, 3041,
+ 3045, 3049, 3053, 3054, 3056, 3058, 3060, 3062, 3064, 3066,
+ 3068, 3070, 3078, 3080, 3081, 3082, 3085, 3091, 3093, 3098,
+ 3100, 3103, 3117, 3120, 3123, 3127, 3130, 3137, 3139, 3142,
+ 3144, 3146, 3149, 3152, 3155, 3158, 3160, 3163, 3167, 3169,
+ 3175, 3177, 3178, 3180, 3185, 3187, 3189, 3191, 3193, 3196,
+ 3197, 3199, 3202, 3203, 3206, 3206, 3209, 3209, 3212, 3212,
+ 3214, 3216, 3218, 3220, 3226, 3232, 3235, 3238, 3244, 3246,
+ 3248, 3252, 3254, 3255, 3256, 3258, 3261, 3268, 3273, 3281,
+ 3285, 3287, 3290, 3292, 3295, 3299, 3301, 3304, 3306, 3309,
+ 3326, 3332, 3340, 3342, 3344, 3348, 3351, 3352, 3360, 3364,
+ 3368, 3371, 3372, 3378, 3381, 3384, 3386, 3390, 3395, 3398,
+ 3408, 3413, 3414, 3421, 3424, 3427, 3429, 3432, 3434, 3444,
+ 3458, 3462, 3465, 3467, 3471, 3475, 3478, 3481, 3483, 3487,
+ 3489, 3496, 3503, 3506, 3509, 3513, 3517, 3523, 3527, 3532,
+ 3534, 3537, 3542, 3548, 3559, 3562, 3564, 3568, 3573, 3575,
+ 3582, 3585, 3587, 3589, 3595, 3600, 3603, 3605, 3607, 3609,
+ 3611, 3613, 3615, 3617, 3619, 3621, 3623, 3625, 3627, 3629,
+ 3631, 3633, 3635, 3637, 3639, 3641, 3643, 3645, 3647, 3649,
+ 3651, 3653, 3655, 3657, 3659, 3661, 3663, 3665, 3668, 3670
};
#endif
@@ -6014,10 +6014,12 @@ case 472:
case 473:
#line 2092 "parse.y"
{ yyval.ftype.t = yyvsp[0].ttype;
- yyval.ftype.new_type_flag = 0; ;
+ yyval.ftype.new_type_flag = 0;
+ if (!processing_template_decl)
+ cp_pedwarn ("using `typename' outside of template"); ;
break;}
case 474:
-#line 2097 "parse.y"
+#line 2099 "parse.y"
{
int semi;
@@ -6029,17 +6031,17 @@ case 474:
;
break;}
case 475:
-#line 2107 "parse.y"
+#line 2109 "parse.y"
{ finish_default_args (); ;
break;}
case 476:
-#line 2109 "parse.y"
+#line 2111 "parse.y"
{ yyval.ftype.t = yyvsp[-3].ttype;
yyval.ftype.new_type_flag = 1;
begin_inline_definitions (); ;
break;}
case 477:
-#line 2113 "parse.y"
+#line 2115 "parse.y"
{
yyval.ftype.new_type_flag = 0;
if (TYPE_BINFO (yyvsp[0].ttype) == NULL_TREE)
@@ -6059,85 +6061,85 @@ case 477:
;
break;}
case 481:
-#line 2140 "parse.y"
+#line 2142 "parse.y"
{ if (pedantic && !in_system_header)
pedwarn ("comma at end of enumerator list"); ;
break;}
case 483:
-#line 2147 "parse.y"
+#line 2149 "parse.y"
{ error ("storage class specifier `%s' not allowed after struct or class", IDENTIFIER_POINTER (yyvsp[0].ttype)); ;
break;}
case 484:
-#line 2149 "parse.y"
+#line 2151 "parse.y"
{ error ("type specifier `%s' not allowed after struct or class", IDENTIFIER_POINTER (yyvsp[0].ttype)); ;
break;}
case 485:
-#line 2151 "parse.y"
+#line 2153 "parse.y"
{ error ("type qualifier `%s' not allowed after struct or class", IDENTIFIER_POINTER (yyvsp[0].ttype)); ;
break;}
case 486:
-#line 2153 "parse.y"
+#line 2155 "parse.y"
{ error ("no body nor ';' separates two class, struct or union declarations"); ;
break;}
case 487:
-#line 2155 "parse.y"
+#line 2157 "parse.y"
{ yyval.ttype = build_decl_list (yyvsp[0].ttype, yyvsp[-1].ttype); ;
break;}
case 488:
-#line 2160 "parse.y"
+#line 2162 "parse.y"
{ current_aggr = yyval.ttype; yyval.ttype = yyvsp[0].ttype; ;
break;}
case 489:
-#line 2165 "parse.y"
+#line 2167 "parse.y"
{ current_aggr = yyval.ttype; yyval.ttype = yyvsp[0].ttype; ;
break;}
case 490:
-#line 2167 "parse.y"
+#line 2169 "parse.y"
{ yyungetc ('{', 1); ;
break;}
case 491:
-#line 2169 "parse.y"
+#line 2171 "parse.y"
{ yyungetc (':', 1); ;
break;}
case 492:
-#line 2174 "parse.y"
+#line 2176 "parse.y"
{
current_aggr = yyvsp[-2].ttype;
yyval.ttype = handle_class_head (yyvsp[-2].ttype, yyvsp[-1].ttype, yyvsp[0].ttype);
;
break;}
case 493:
-#line 2179 "parse.y"
+#line 2181 "parse.y"
{
current_aggr = yyvsp[-3].ttype;
yyval.ttype = handle_class_head (yyvsp[-3].ttype, yyvsp[-1].ttype, yyvsp[0].ttype);
;
break;}
case 494:
-#line 2184 "parse.y"
+#line 2186 "parse.y"
{
current_aggr = yyvsp[-2].ttype;
yyval.ttype = handle_class_head (yyvsp[-2].ttype, NULL_TREE, yyvsp[0].ttype);
;
break;}
case 495:
-#line 2189 "parse.y"
+#line 2191 "parse.y"
{ current_aggr = yyval.ttype; yyval.ttype = yyvsp[0].ttype; ;
break;}
case 496:
-#line 2191 "parse.y"
+#line 2193 "parse.y"
{ current_aggr = yyval.ttype; yyval.ttype = yyvsp[0].ttype; ;
break;}
case 497:
-#line 2196 "parse.y"
+#line 2198 "parse.y"
{ yyval.ttype = xref_tag (current_aggr, yyvsp[0].ttype, 0); ;
break;}
case 498:
-#line 2201 "parse.y"
+#line 2203 "parse.y"
{ yyval.ttype = xref_tag (current_aggr, yyvsp[0].ttype, 1); ;
break;}
case 499:
-#line 2204 "parse.y"
+#line 2206 "parse.y"
{
yyval.ttype = yyvsp[-1].ttype;
if (yyvsp[0].ttype)
@@ -6145,7 +6147,7 @@ case 499:
;
break;}
case 500:
-#line 2210 "parse.y"
+#line 2212 "parse.y"
{
yyval.ttype = TREE_TYPE (yyvsp[-1].ttype);
if (TREE_INT_CST_LOW (current_aggr) == union_type
@@ -6162,102 +6164,44 @@ case 500:
;
break;}
case 501:
-#line 2228 "parse.y"
+#line 2230 "parse.y"
{ yyval.ttype = xref_tag (yyval.ttype, make_anon_name (), 0);
yyungetc ('{', 1); ;
break;}
case 504:
-#line 2239 "parse.y"
+#line 2241 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 505:
-#line 2241 "parse.y"
+#line 2243 "parse.y"
{ yyungetc(':', 1); yyval.ttype = NULL_TREE; ;
break;}
case 506:
-#line 2243 "parse.y"
+#line 2245 "parse.y"
{ yyval.ttype = yyvsp[0].ttype; ;
break;}
case 508:
-#line 2249 "parse.y"
+#line 2251 "parse.y"
{ yyval.ttype = chainon (yyval.ttype, yyvsp[0].ttype); ;
break;}
case 509:
-#line 2254 "parse.y"
-{
- tree type;
- if (yyvsp[0].ttype == NULL_TREE)
- {
- error ("invalid base class");
- type = error_mark_node;
- }
- else
- type = TREE_TYPE (yyvsp[0].ttype);
- if (! is_aggr_type (type, 1))
- yyval.ttype = NULL_TREE;
- else if (current_aggr == signature_type_node
- && (! type) && (! IS_SIGNATURE (type)))
- {
- error ("class name not allowed as base signature");
- yyval.ttype = NULL_TREE;
- }
- else if (current_aggr == signature_type_node)
- {
- sorry ("signature inheritance, base type `%s' ignored",
- IDENTIFIER_POINTER (yyval.ttype));
- yyval.ttype = build_tree_list (access_public_node, type);
- }
- else if (type && IS_SIGNATURE (type))
- {
- error ("signature name not allowed as base class");
- yyval.ttype = NULL_TREE;
- }
- else
- yyval.ttype = build_tree_list (access_default_node, type);
- ;
+#line 2256 "parse.y"
+{ yyval.ttype = finish_base_specifier (access_default_node, yyvsp[0].ttype,
+ current_aggr
+ == signature_type_node); ;
break;}
case 510:
-#line 2286 "parse.y"
-{
- tree type;
- if (yyvsp[0].ttype == NULL_TREE)
- {
- error ("invalid base class");
- type = error_mark_node;
- }
- else
- type = TREE_TYPE (yyvsp[0].ttype);
- if (current_aggr == signature_type_node)
- error ("access and source specifiers not allowed in signature");
- if (! is_aggr_type (type, 1))
- yyval.ttype = NULL_TREE;
- else if (current_aggr == signature_type_node
- && (! type) && (! IS_SIGNATURE (type)))
- {
- error ("class name not allowed as base signature");
- yyval.ttype = NULL_TREE;
- }
- else if (current_aggr == signature_type_node)
- {
- sorry ("signature inheritance, base type `%s' ignored",
- IDENTIFIER_POINTER (yyval.ttype));
- yyval.ttype = build_tree_list (access_public_node, type);
- }
- else if (type && IS_SIGNATURE (type))
- {
- error ("signature name not allowed as base class");
- yyval.ttype = NULL_TREE;
- }
- else
- yyval.ttype = build_tree_list (yyval.ttype, type);
- ;
+#line 2260 "parse.y"
+{ yyval.ttype = finish_base_specifier (yyvsp[-2].ttype, yyvsp[0].ttype,
+ current_aggr
+ == signature_type_node); ;
break;}
case 511:
-#line 2323 "parse.y"
+#line 2267 "parse.y"
{ yyval.ttype = TYPE_MAIN_DECL (yyvsp[0].ttype); ;
break;}
case 513:
-#line 2326 "parse.y"
+#line 2270 "parse.y"
{
if (current_aggr == signature_type_node)
{
@@ -6280,7 +6224,7 @@ case 513:
;
break;}
case 514:
-#line 2347 "parse.y"
+#line 2291 "parse.y"
{
if (current_aggr == signature_type_node)
{
@@ -6303,13 +6247,13 @@ case 514:
;
break;}
case 516:
-#line 2372 "parse.y"
+#line 2316 "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 517:
-#line 2376 "parse.y"
+#line 2320 "parse.y"
{
if (yyvsp[-2].ttype != access_default_virtual_node)
error ("multiple access specifiers");
@@ -6322,7 +6266,7 @@ case 517:
;
break;}
case 518:
-#line 2387 "parse.y"
+#line 2331 "parse.y"
{ if (yyvsp[-1].ttype != ridpointers[(int)RID_VIRTUAL])
cp_error ("`%D' access", yyvsp[-1].ttype);
else if (yyval.ttype == access_public_node)
@@ -6336,21 +6280,21 @@ case 518:
;
break;}
case 519:
-#line 2402 "parse.y"
+#line 2346 "parse.y"
{ yyvsp[-1].ttype = begin_class_definition (yyvsp[-1].ttype); ;
break;}
case 520:
-#line 2407 "parse.y"
+#line 2351 "parse.y"
{
yyval.ttype = build_self_reference ();
;
break;}
case 521:
-#line 2414 "parse.y"
+#line 2358 "parse.y"
{ if (yyval.ttype) yyval.ttype = build_tree_list (access_public_node, yyval.ttype); ;
break;}
case 522:
-#line 2416 "parse.y"
+#line 2360 "parse.y"
{
if (current_aggr == signature_type_node)
yyval.ttype = build_tree_list (access_public_node, yyvsp[0].ttype);
@@ -6360,7 +6304,7 @@ case 522:
;
break;}
case 523:
-#line 2424 "parse.y"
+#line 2368 "parse.y"
{
tree visspec = yyvsp[-2].ttype;
@@ -6373,19 +6317,19 @@ case 523:
;
break;}
case 524:
-#line 2435 "parse.y"
+#line 2379 "parse.y"
{
if (current_aggr == signature_type_node)
error ("access specifier not allowed in signature");
;
break;}
case 525:
-#line 2445 "parse.y"
+#line 2389 "parse.y"
{ if (yyval.ttype == void_type_node) yyval.ttype = NULL_TREE;
;
break;}
case 526:
-#line 2448 "parse.y"
+#line 2392 "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
@@ -6400,95 +6344,95 @@ case 526:
;
break;}
case 527:
-#line 2464 "parse.y"
+#line 2408 "parse.y"
{ ;
break;}
case 528:
-#line 2466 "parse.y"
+#line 2410 "parse.y"
{ error ("missing ';' before right brace");
yyungetc ('}', 0); ;
break;}
case 529:
-#line 2471 "parse.y"
+#line 2415 "parse.y"
{ yyval.ttype = finish_method (yyval.ttype); ;
break;}
case 530:
-#line 2473 "parse.y"
+#line 2417 "parse.y"
{ yyval.ttype = finish_method (yyval.ttype); ;
break;}
case 531:
-#line 2475 "parse.y"
+#line 2419 "parse.y"
{ yyval.ttype = finish_method (yyval.ttype); ;
break;}
case 532:
-#line 2477 "parse.y"
+#line 2421 "parse.y"
{ yyval.ttype = finish_method (yyval.ttype); ;
break;}
case 533:
-#line 2479 "parse.y"
+#line 2423 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 534:
-#line 2481 "parse.y"
+#line 2425 "parse.y"
{ yyval.ttype = yyvsp[0].ttype;
pedantic = yyvsp[-1].itype; ;
break;}
case 535:
-#line 2484 "parse.y"
+#line 2428 "parse.y"
{ yyval.ttype = finish_member_template_decl (yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 536:
-#line 2486 "parse.y"
+#line 2430 "parse.y"
{ yyval.ttype = finish_member_class_template (yyvsp[-2].ttype, yyvsp[-1].ftype.t); ;
break;}
case 537:
-#line 2494 "parse.y"
+#line 2438 "parse.y"
{ yyval.ttype = grok_x_components (yyvsp[-1].ftype.t, yyvsp[0].ttype); ;
break;}
case 538:
-#line 2496 "parse.y"
+#line 2440 "parse.y"
{ yyval.ttype = grok_x_components (yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 539:
-#line 2498 "parse.y"
+#line 2442 "parse.y"
{ yyval.ttype = grokfield (yyval.ttype, NULL_TREE, yyvsp[0].ttype, yyvsp[-2].ttype,
build_tree_list (yyvsp[-1].ttype, NULL_TREE)); ;
break;}
case 540:
-#line 2501 "parse.y"
+#line 2445 "parse.y"
{ yyval.ttype = grokfield (yyval.ttype, NULL_TREE, yyvsp[0].ttype, yyvsp[-2].ttype,
build_tree_list (yyvsp[-1].ttype, NULL_TREE)); ;
break;}
case 541:
-#line 2504 "parse.y"
+#line 2448 "parse.y"
{ yyval.ttype = grokbitfield (NULL_TREE, NULL_TREE, yyvsp[0].ttype); ;
break;}
case 542:
-#line 2506 "parse.y"
+#line 2450 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 543:
-#line 2517 "parse.y"
+#line 2461 "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 544:
-#line 2522 "parse.y"
+#line 2466 "parse.y"
{ yyval.ttype = grokfield (yyval.ttype, NULL_TREE, yyvsp[0].ttype, yyvsp[-2].ttype,
build_tree_list (yyvsp[-1].ttype, NULL_TREE)); ;
break;}
case 545:
-#line 2525 "parse.y"
+#line 2469 "parse.y"
{ yyval.ttype = do_class_using_decl (yyvsp[0].ttype); ;
break;}
case 546:
-#line 2531 "parse.y"
+#line 2475 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 548:
-#line 2534 "parse.y"
+#line 2478 "parse.y"
{
/* In this context, void_type_node encodes
friends. They have been recorded elsewhere. */
@@ -6499,11 +6443,11 @@ case 548:
;
break;}
case 549:
-#line 2546 "parse.y"
+#line 2490 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 551:
-#line 2549 "parse.y"
+#line 2493 "parse.y"
{
/* In this context, void_type_node encodes
friends. They have been recorded elsewhere. */
@@ -6514,7 +6458,7 @@ case 551:
;
break;}
case 556:
-#line 2571 "parse.y"
+#line 2515 "parse.y"
{ split_specs_attrs (yyvsp[-4].ttype, &current_declspecs,
&prefix_attributes);
yyvsp[-4].ttype = current_declspecs;
@@ -6522,7 +6466,7 @@ case 556:
build_tree_list (yyvsp[-1].ttype, prefix_attributes)); ;
break;}
case 557:
-#line 2577 "parse.y"
+#line 2521 "parse.y"
{ split_specs_attrs (yyvsp[-4].ttype, &current_declspecs,
&prefix_attributes);
yyvsp[-4].ttype = current_declspecs;
@@ -6530,7 +6474,7 @@ case 557:
cplus_decl_attributes (yyval.ttype, yyvsp[0].ttype, prefix_attributes); ;
break;}
case 558:
-#line 2586 "parse.y"
+#line 2530 "parse.y"
{ split_specs_attrs (yyvsp[-4].ttype, &current_declspecs,
&prefix_attributes);
yyvsp[-4].ttype = current_declspecs;
@@ -6538,7 +6482,7 @@ case 558:
build_tree_list (yyvsp[-1].ttype, prefix_attributes)); ;
break;}
case 559:
-#line 2592 "parse.y"
+#line 2536 "parse.y"
{ split_specs_attrs (yyvsp[-4].ttype, &current_declspecs,
&prefix_attributes);
yyvsp[-4].ttype = current_declspecs;
@@ -6546,7 +6490,7 @@ case 559:
build_tree_list (yyvsp[-1].ttype, prefix_attributes)); ;
break;}
case 560:
-#line 2598 "parse.y"
+#line 2542 "parse.y"
{ split_specs_attrs (yyvsp[-4].ttype, &current_declspecs,
&prefix_attributes);
yyvsp[-4].ttype = current_declspecs;
@@ -6554,7 +6498,7 @@ case 560:
cplus_decl_attributes (yyval.ttype, yyvsp[0].ttype, prefix_attributes); ;
break;}
case 561:
-#line 2604 "parse.y"
+#line 2548 "parse.y"
{ split_specs_attrs (yyvsp[-3].ttype, &current_declspecs,
&prefix_attributes);
yyvsp[-3].ttype = current_declspecs;
@@ -6562,54 +6506,54 @@ case 561:
cplus_decl_attributes (yyval.ttype, yyvsp[0].ttype, prefix_attributes); ;
break;}
case 562:
-#line 2613 "parse.y"
+#line 2557 "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 563:
-#line 2616 "parse.y"
+#line 2560 "parse.y"
{ yyval.ttype = grokbitfield (yyval.ttype, current_declspecs, yyvsp[-1].ttype);
cplus_decl_attributes (yyval.ttype, yyvsp[0].ttype, prefix_attributes); ;
break;}
case 564:
-#line 2622 "parse.y"
+#line 2566 "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 565:
-#line 2625 "parse.y"
+#line 2569 "parse.y"
{ yyval.ttype = grokbitfield (yyval.ttype, current_declspecs, yyvsp[-1].ttype);
cplus_decl_attributes (yyval.ttype, yyvsp[0].ttype, prefix_attributes); ;
break;}
case 566:
-#line 2628 "parse.y"
+#line 2572 "parse.y"
{ yyval.ttype = grokbitfield (NULL_TREE, current_declspecs, yyvsp[-1].ttype);
cplus_decl_attributes (yyval.ttype, yyvsp[0].ttype, prefix_attributes); ;
break;}
case 568:
-#line 2639 "parse.y"
+#line 2583 "parse.y"
{ TREE_CHAIN (yyvsp[0].ttype) = yyval.ttype; yyval.ttype = yyvsp[0].ttype; ;
break;}
case 569:
-#line 2644 "parse.y"
+#line 2588 "parse.y"
{ yyval.ttype = build_enumerator (yyval.ttype, NULL_TREE); ;
break;}
case 570:
-#line 2646 "parse.y"
+#line 2590 "parse.y"
{ yyval.ttype = build_enumerator (yyval.ttype, yyvsp[0].ttype); ;
break;}
case 571:
-#line 2652 "parse.y"
+#line 2596 "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 572:
-#line 2655 "parse.y"
+#line 2599 "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 573:
-#line 2662 "parse.y"
+#line 2606 "parse.y"
{
if (pedantic)
pedwarn ("ANSI C++ forbids array dimensions with parenthesized type in new");
@@ -6619,71 +6563,71 @@ case 573:
;
break;}
case 574:
-#line 2673 "parse.y"
+#line 2617 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 575:
-#line 2675 "parse.y"
+#line 2619 "parse.y"
{ yyval.ttype = decl_tree_cons (NULL_TREE, yyvsp[0].ttype, yyval.ttype); ;
break;}
case 576:
-#line 2680 "parse.y"
+#line 2624 "parse.y"
{ yyval.ftype.t = IDENTIFIER_AS_LIST (yyvsp[0].ttype);
yyval.ftype.new_type_flag = 0; ;
break;}
case 577:
-#line 2683 "parse.y"
+#line 2627 "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 578:
-#line 2692 "parse.y"
+#line 2636 "parse.y"
{ yyval.itype = suspend_momentary (); ;
break;}
case 579:
-#line 2697 "parse.y"
+#line 2641 "parse.y"
{ resume_momentary ((int) yyvsp[-1].itype); yyval.ttype = yyvsp[0].ttype; ;
break;}
case 580:
-#line 2703 "parse.y"
+#line 2647 "parse.y"
{ resume_momentary ((int) yyvsp[-3].itype); yyval.ttype = yyvsp[-1].ttype; ;
break;}
case 581:
-#line 2705 "parse.y"
+#line 2649 "parse.y"
{ resume_momentary ((int) yyvsp[-3].itype); yyval.ttype = yyvsp[-1].ttype; ;
break;}
case 582:
-#line 2707 "parse.y"
+#line 2651 "parse.y"
{ resume_momentary ((int) yyvsp[-1].itype); yyval.ttype = empty_parms (); ;
break;}
case 583:
-#line 2709 "parse.y"
+#line 2653 "parse.y"
{ resume_momentary ((int) yyvsp[-3].itype); yyval.ttype = NULL_TREE; ;
break;}
case 584:
-#line 2716 "parse.y"
+#line 2660 "parse.y"
{ yyval.ttype = make_pointer_declarator (yyvsp[-1].ftype.t, yyvsp[0].ttype); ;
break;}
case 585:
-#line 2718 "parse.y"
+#line 2662 "parse.y"
{ yyval.ttype = make_reference_declarator (yyvsp[-1].ftype.t, yyvsp[0].ttype); ;
break;}
case 586:
-#line 2720 "parse.y"
+#line 2664 "parse.y"
{ yyval.ttype = make_pointer_declarator (NULL_TREE, yyvsp[0].ttype); ;
break;}
case 587:
-#line 2722 "parse.y"
+#line 2666 "parse.y"
{ yyval.ttype = make_reference_declarator (NULL_TREE, yyvsp[0].ttype); ;
break;}
case 588:
-#line 2724 "parse.y"
+#line 2668 "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 590:
-#line 2732 "parse.y"
+#line 2676 "parse.y"
{
if (TREE_CODE (yyvsp[0].ttype) == IDENTIFIER_NODE)
{
@@ -6702,7 +6646,7 @@ case 590:
;
break;}
case 591:
-#line 2749 "parse.y"
+#line 2693 "parse.y"
{
if (TREE_CODE (yyvsp[0].ttype) == IDENTIFIER_NODE)
yyval.ttype = IDENTIFIER_GLOBAL_VALUE (yyvsp[0].ttype);
@@ -6712,152 +6656,152 @@ case 591:
;
break;}
case 594:
-#line 2762 "parse.y"
+#line 2706 "parse.y"
{ yyval.ttype = yyvsp[0].ttype; ;
break;}
case 595:
-#line 2767 "parse.y"
+#line 2711 "parse.y"
{ yyval.ttype = get_type_decl (yyvsp[0].ttype); ;
break;}
case 596:
-#line 2772 "parse.y"
+#line 2716 "parse.y"
{ yyval.ttype = make_call_declarator (yyval.ttype, yyvsp[-2].ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 597:
-#line 2774 "parse.y"
+#line 2718 "parse.y"
{ yyval.ttype = build_parse_node (ARRAY_REF, yyval.ttype, yyvsp[-1].ttype); ;
break;}
case 598:
-#line 2776 "parse.y"
+#line 2720 "parse.y"
{ yyval.ttype = build_parse_node (ARRAY_REF, yyval.ttype, NULL_TREE); ;
break;}
case 599:
-#line 2778 "parse.y"
+#line 2722 "parse.y"
{ yyval.ttype = yyvsp[-1].ttype; ;
break;}
case 600:
-#line 2780 "parse.y"
+#line 2724 "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 602:
-#line 2791 "parse.y"
+#line 2735 "parse.y"
{ yyval.ttype = make_pointer_declarator (yyvsp[-1].ftype.t, yyvsp[0].ttype); ;
break;}
case 603:
-#line 2793 "parse.y"
+#line 2737 "parse.y"
{ yyval.ttype = make_reference_declarator (yyvsp[-1].ftype.t, yyvsp[0].ttype); ;
break;}
case 604:
-#line 2795 "parse.y"
+#line 2739 "parse.y"
{ yyval.ttype = make_pointer_declarator (NULL_TREE, yyvsp[0].ttype); ;
break;}
case 605:
-#line 2797 "parse.y"
+#line 2741 "parse.y"
{ yyval.ttype = make_reference_declarator (NULL_TREE, yyvsp[0].ttype); ;
break;}
case 606:
-#line 2799 "parse.y"
+#line 2743 "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 608:
-#line 2807 "parse.y"
+#line 2751 "parse.y"
{ yyval.ttype = make_pointer_declarator (yyvsp[-1].ftype.t, yyvsp[0].ttype); ;
break;}
case 609:
-#line 2809 "parse.y"
+#line 2753 "parse.y"
{ yyval.ttype = make_reference_declarator (yyvsp[-1].ftype.t, yyvsp[0].ttype); ;
break;}
case 610:
-#line 2811 "parse.y"
+#line 2755 "parse.y"
{ yyval.ttype = make_pointer_declarator (NULL_TREE, yyvsp[0].ttype); ;
break;}
case 611:
-#line 2813 "parse.y"
+#line 2757 "parse.y"
{ yyval.ttype = make_reference_declarator (NULL_TREE, yyvsp[0].ttype); ;
break;}
case 612:
-#line 2815 "parse.y"
+#line 2759 "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 614:
-#line 2823 "parse.y"
+#line 2767 "parse.y"
{ yyval.ttype = make_call_declarator (yyval.ttype, yyvsp[-2].ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 615:
-#line 2825 "parse.y"
+#line 2769 "parse.y"
{ yyval.ttype = yyvsp[-1].ttype; ;
break;}
case 616:
-#line 2827 "parse.y"
+#line 2771 "parse.y"
{ yyval.ttype = build_parse_node (ARRAY_REF, yyval.ttype, yyvsp[-1].ttype); ;
break;}
case 617:
-#line 2829 "parse.y"
+#line 2773 "parse.y"
{ yyval.ttype = build_parse_node (ARRAY_REF, yyval.ttype, NULL_TREE); ;
break;}
case 618:
-#line 2831 "parse.y"
+#line 2775 "parse.y"
{ enter_scope_of (yyvsp[0].ttype); ;
break;}
case 619:
-#line 2833 "parse.y"
+#line 2777 "parse.y"
{ got_scope = NULL_TREE;
yyval.ttype = build_parse_node (SCOPE_REF, yyvsp[-1].ttype, yyvsp[0].ttype);
enter_scope_of (yyval.ttype);
;
break;}
case 620:
-#line 2841 "parse.y"
+#line 2785 "parse.y"
{ got_scope = NULL_TREE;
yyval.ttype = build_parse_node (SCOPE_REF, yyval.ttype, yyvsp[0].ttype); ;
break;}
case 621:
-#line 2844 "parse.y"
+#line 2788 "parse.y"
{ got_scope = NULL_TREE;
yyval.ttype = build_parse_node (SCOPE_REF, yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 622:
-#line 2850 "parse.y"
+#line 2794 "parse.y"
{ got_scope = NULL_TREE;
yyval.ttype = build_parse_node (SCOPE_REF, yyval.ttype, yyvsp[0].ttype); ;
break;}
case 623:
-#line 2853 "parse.y"
+#line 2797 "parse.y"
{ got_scope = NULL_TREE;
yyval.ttype = build_parse_node (SCOPE_REF, yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 625:
-#line 2860 "parse.y"
+#line 2804 "parse.y"
{ yyval.ttype = yyvsp[0].ttype; ;
break;}
case 626:
-#line 2865 "parse.y"
+#line 2809 "parse.y"
{ yyval.ttype = build_functional_cast (yyvsp[-3].ftype.t, yyvsp[-1].ttype); ;
break;}
case 627:
-#line 2867 "parse.y"
+#line 2811 "parse.y"
{ yyval.ttype = reparse_decl_as_expr (yyvsp[-3].ftype.t, yyvsp[-1].ttype); ;
break;}
case 628:
-#line 2869 "parse.y"
+#line 2813 "parse.y"
{ yyval.ttype = reparse_absdcl_as_expr (yyvsp[-1].ftype.t, yyvsp[0].ttype); ;
break;}
case 633:
-#line 2881 "parse.y"
+#line 2825 "parse.y"
{ yyval.ttype = yyvsp[0].ttype; ;
break;}
case 634:
-#line 2883 "parse.y"
+#line 2827 "parse.y"
{ got_scope = yyval.ttype = make_typename_type (yyvsp[-3].ttype, yyvsp[-1].ttype); ;
break;}
case 635:
-#line 2890 "parse.y"
+#line 2834 "parse.y"
{
if (TREE_CODE (yyvsp[-1].ttype) == IDENTIFIER_NODE)
{
@@ -6873,7 +6817,7 @@ case 635:
;
break;}
case 636:
-#line 2904 "parse.y"
+#line 2848 "parse.y"
{
if (TREE_CODE (yyvsp[-1].ttype) == IDENTIFIER_NODE)
yyval.ttype = lastiddecl;
@@ -6881,7 +6825,7 @@ case 636:
;
break;}
case 637:
-#line 2910 "parse.y"
+#line 2854 "parse.y"
{
if (TREE_CODE (yyval.ttype) == IDENTIFIER_NODE)
yyval.ttype = lastiddecl;
@@ -6889,15 +6833,15 @@ case 637:
;
break;}
case 638:
-#line 2916 "parse.y"
+#line 2860 "parse.y"
{ got_scope = yyval.ttype = complete_type (TREE_TYPE (yyvsp[-1].ttype)); ;
break;}
case 640:
-#line 2932 "parse.y"
+#line 2876 "parse.y"
{ yyval.ttype = yyvsp[0].ttype; ;
break;}
case 641:
-#line 2937 "parse.y"
+#line 2881 "parse.y"
{
if (TREE_CODE_CLASS (TREE_CODE (yyvsp[-1].ttype)) == 't')
yyval.ttype = make_typename_type (yyvsp[-1].ttype, yyvsp[0].ttype);
@@ -6912,26 +6856,26 @@ case 641:
;
break;}
case 642:
-#line 2950 "parse.y"
+#line 2894 "parse.y"
{ yyval.ttype = TREE_TYPE (yyvsp[0].ttype); ;
break;}
case 643:
-#line 2952 "parse.y"
+#line 2896 "parse.y"
{ yyval.ttype = make_typename_type (yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 644:
-#line 2954 "parse.y"
+#line 2898 "parse.y"
{ yyval.ttype = make_typename_type (yyvsp[-2].ttype, yyvsp[0].ttype); ;
break;}
case 645:
-#line 2959 "parse.y"
+#line 2903 "parse.y"
{
if (TREE_CODE (yyvsp[0].ttype) == IDENTIFIER_NODE)
cp_error ("`%T' is not a class or namespace", yyvsp[0].ttype);
;
break;}
case 646:
-#line 2964 "parse.y"
+#line 2908 "parse.y"
{
if (TREE_CODE_CLASS (TREE_CODE (yyvsp[-1].ttype)) == 't')
yyval.ttype = make_typename_type (yyvsp[-1].ttype, yyvsp[0].ttype);
@@ -6946,15 +6890,15 @@ case 646:
;
break;}
case 647:
-#line 2977 "parse.y"
+#line 2921 "parse.y"
{ got_scope = yyval.ttype = make_typename_type (yyvsp[-2].ttype, yyvsp[-1].ttype); ;
break;}
case 648:
-#line 2979 "parse.y"
+#line 2923 "parse.y"
{ got_scope = yyval.ttype = make_typename_type (yyvsp[-3].ttype, yyvsp[-1].ttype); ;
break;}
case 649:
-#line 2984 "parse.y"
+#line 2928 "parse.y"
{
if (TREE_CODE (yyvsp[-1].ttype) != IDENTIFIER_NODE)
yyvsp[-1].ttype = lastiddecl;
@@ -6968,7 +6912,7 @@ case 649:
;
break;}
case 650:
-#line 2996 "parse.y"
+#line 2940 "parse.y"
{
if (TREE_CODE (yyvsp[-1].ttype) != IDENTIFIER_NODE)
yyval.ttype = lastiddecl;
@@ -6976,11 +6920,11 @@ case 650:
;
break;}
case 651:
-#line 3002 "parse.y"
+#line 2946 "parse.y"
{ got_scope = yyval.ttype = complete_type (TREE_TYPE (yyval.ttype)); ;
break;}
case 654:
-#line 3006 "parse.y"
+#line 2950 "parse.y"
{
if (TREE_CODE (yyval.ttype) == IDENTIFIER_NODE)
yyval.ttype = lastiddecl;
@@ -6988,11 +6932,11 @@ case 654:
;
break;}
case 655:
-#line 3015 "parse.y"
+#line 2959 "parse.y"
{ yyval.ttype = build_min_nt (TEMPLATE_ID_EXPR, yyvsp[-3].ttype, yyvsp[-1].ttype); ;
break;}
case 656:
-#line 3020 "parse.y"
+#line 2964 "parse.y"
{
if (TREE_CODE (yyvsp[0].ttype) == IDENTIFIER_NODE)
yyval.ttype = IDENTIFIER_GLOBAL_VALUE (yyvsp[0].ttype);
@@ -7002,148 +6946,148 @@ case 656:
;
break;}
case 658:
-#line 3029 "parse.y"
+#line 2973 "parse.y"
{ yyval.ttype = yyvsp[0].ttype; ;
break;}
case 659:
-#line 3034 "parse.y"
+#line 2978 "parse.y"
{ got_scope = NULL_TREE; ;
break;}
case 660:
-#line 3036 "parse.y"
+#line 2980 "parse.y"
{ yyval.ttype = yyvsp[-1].ttype; got_scope = NULL_TREE; ;
break;}
case 661:
-#line 3043 "parse.y"
+#line 2987 "parse.y"
{ got_scope = void_type_node; ;
break;}
case 662:
-#line 3049 "parse.y"
+#line 2993 "parse.y"
{ yyval.ttype = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 663:
-#line 3051 "parse.y"
+#line 2995 "parse.y"
{ yyval.ttype = make_pointer_declarator (yyvsp[0].ttype, NULL_TREE); ;
break;}
case 664:
-#line 3053 "parse.y"
+#line 2997 "parse.y"
{ yyval.ttype = make_reference_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 665:
-#line 3055 "parse.y"
+#line 2999 "parse.y"
{ yyval.ttype = make_reference_declarator (yyvsp[0].ttype, NULL_TREE); ;
break;}
case 666:
-#line 3057 "parse.y"
+#line 3001 "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 667:
-#line 3061 "parse.y"
+#line 3005 "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 669:
-#line 3070 "parse.y"
+#line 3014 "parse.y"
{ yyval.ttype = build_parse_node (ARRAY_REF, NULL_TREE, yyvsp[-1].ttype); ;
break;}
case 670:
-#line 3072 "parse.y"
+#line 3016 "parse.y"
{ yyval.ttype = build_parse_node (ARRAY_REF, yyval.ttype, yyvsp[-1].ttype); ;
break;}
case 671:
-#line 3078 "parse.y"
+#line 3022 "parse.y"
{ yyval.ttype = make_pointer_declarator (yyvsp[-1].ftype.t, yyvsp[0].ttype); ;
break;}
case 672:
-#line 3080 "parse.y"
+#line 3024 "parse.y"
{ yyval.ttype = make_pointer_declarator (NULL_TREE, yyvsp[0].ttype); ;
break;}
case 673:
-#line 3082 "parse.y"
+#line 3026 "parse.y"
{ yyval.ttype = make_pointer_declarator (yyvsp[0].ftype.t, NULL_TREE); ;
break;}
case 674:
-#line 3084 "parse.y"
+#line 3028 "parse.y"
{ yyval.ttype = make_pointer_declarator (NULL_TREE, NULL_TREE); ;
break;}
case 675:
-#line 3086 "parse.y"
+#line 3030 "parse.y"
{ yyval.ttype = make_reference_declarator (yyvsp[-1].ftype.t, yyvsp[0].ttype); ;
break;}
case 676:
-#line 3088 "parse.y"
+#line 3032 "parse.y"
{ yyval.ttype = make_reference_declarator (NULL_TREE, yyvsp[0].ttype); ;
break;}
case 677:
-#line 3090 "parse.y"
+#line 3034 "parse.y"
{ yyval.ttype = make_reference_declarator (yyvsp[0].ftype.t, NULL_TREE); ;
break;}
case 678:
-#line 3092 "parse.y"
+#line 3036 "parse.y"
{ yyval.ttype = make_reference_declarator (NULL_TREE, NULL_TREE); ;
break;}
case 679:
-#line 3094 "parse.y"
+#line 3038 "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 680:
-#line 3098 "parse.y"
+#line 3042 "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 682:
-#line 3107 "parse.y"
+#line 3051 "parse.y"
{ yyval.ttype = yyvsp[-1].ttype; ;
break;}
case 684:
-#line 3111 "parse.y"
+#line 3055 "parse.y"
{ yyval.ttype = make_call_declarator (yyval.ttype, yyvsp[-3].ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 685:
-#line 3113 "parse.y"
+#line 3057 "parse.y"
{ yyval.ttype = make_call_declarator (yyval.ttype, empty_parms (), yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 686:
-#line 3115 "parse.y"
+#line 3059 "parse.y"
{ yyval.ttype = build_parse_node (ARRAY_REF, yyval.ttype, yyvsp[-1].ttype); ;
break;}
case 687:
-#line 3117 "parse.y"
+#line 3061 "parse.y"
{ yyval.ttype = build_parse_node (ARRAY_REF, yyval.ttype, NULL_TREE); ;
break;}
case 688:
-#line 3119 "parse.y"
+#line 3063 "parse.y"
{ yyval.ttype = make_call_declarator (NULL_TREE, yyvsp[-3].ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 689:
-#line 3121 "parse.y"
+#line 3065 "parse.y"
{ set_quals_and_spec (yyval.ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 690:
-#line 3123 "parse.y"
+#line 3067 "parse.y"
{ set_quals_and_spec (yyval.ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 691:
-#line 3125 "parse.y"
+#line 3069 "parse.y"
{ yyval.ttype = build_parse_node (ARRAY_REF, NULL_TREE, yyvsp[-1].ttype); ;
break;}
case 692:
-#line 3127 "parse.y"
+#line 3071 "parse.y"
{ yyval.ttype = build_parse_node (ARRAY_REF, NULL_TREE, NULL_TREE); ;
break;}
case 699:
-#line 3150 "parse.y"
+#line 3094 "parse.y"
{ if (pedantic)
pedwarn ("ANSI C++ forbids label declarations"); ;
break;}
case 702:
-#line 3161 "parse.y"
+#line 3105 "parse.y"
{ tree link;
for (link = yyvsp[-1].ttype; link; link = TREE_CHAIN (link))
{
@@ -7154,181 +7098,181 @@ case 702:
;
break;}
case 703:
-#line 3175 "parse.y"
+#line 3119 "parse.y"
{;
break;}
case 705:
-#line 3181 "parse.y"
+#line 3125 "parse.y"
{ yyval.ttype = begin_compound_stmt (0); ;
break;}
case 706:
-#line 3183 "parse.y"
+#line 3127 "parse.y"
{ yyval.ttype = finish_compound_stmt (0, yyvsp[-1].ttype); ;
break;}
case 707:
-#line 3188 "parse.y"
+#line 3132 "parse.y"
{
yyval.ttype = begin_if_stmt ();
cond_stmt_keyword = "if";
;
break;}
case 708:
-#line 3193 "parse.y"
+#line 3137 "parse.y"
{ finish_if_stmt_cond (yyvsp[0].ttype, yyvsp[-1].ttype); ;
break;}
case 709:
-#line 3195 "parse.y"
+#line 3139 "parse.y"
{ yyval.ttype = finish_then_clause (yyvsp[-3].ttype); ;
break;}
case 711:
-#line 3200 "parse.y"
+#line 3144 "parse.y"
{ yyval.ttype = begin_compound_stmt (0); ;
break;}
case 712:
-#line 3202 "parse.y"
+#line 3146 "parse.y"
{ yyval.ttype = finish_compound_stmt (0, yyvsp[-1].ttype); ;
break;}
case 713:
-#line 3207 "parse.y"
+#line 3151 "parse.y"
{;
break;}
case 715:
-#line 3213 "parse.y"
+#line 3157 "parse.y"
{ finish_stmt (); ;
break;}
case 716:
-#line 3215 "parse.y"
+#line 3159 "parse.y"
{ finish_expr_stmt (yyvsp[-1].ttype); ;
break;}
case 717:
-#line 3217 "parse.y"
+#line 3161 "parse.y"
{ begin_else_clause (); ;
break;}
case 718:
-#line 3219 "parse.y"
+#line 3163 "parse.y"
{
finish_else_clause (yyvsp[-3].ttype);
finish_if_stmt ();
;
break;}
case 719:
-#line 3224 "parse.y"
+#line 3168 "parse.y"
{ finish_if_stmt (); ;
break;}
case 720:
-#line 3226 "parse.y"
+#line 3170 "parse.y"
{
yyval.ttype = begin_while_stmt ();
cond_stmt_keyword = "while";
;
break;}
case 721:
-#line 3231 "parse.y"
+#line 3175 "parse.y"
{ finish_while_stmt_cond (yyvsp[0].ttype, yyvsp[-1].ttype); ;
break;}
case 722:
-#line 3233 "parse.y"
+#line 3177 "parse.y"
{ finish_while_stmt (yyvsp[-3].ttype); ;
break;}
case 723:
-#line 3235 "parse.y"
+#line 3179 "parse.y"
{ yyval.ttype = begin_do_stmt (); ;
break;}
case 724:
-#line 3237 "parse.y"
+#line 3181 "parse.y"
{
finish_do_body (yyvsp[-2].ttype);
cond_stmt_keyword = "do";
;
break;}
case 725:
-#line 3242 "parse.y"
+#line 3186 "parse.y"
{ finish_do_stmt (yyvsp[-1].ttype, yyvsp[-5].ttype); ;
break;}
case 726:
-#line 3244 "parse.y"
+#line 3188 "parse.y"
{ yyval.ttype = begin_for_stmt (); ;
break;}
case 727:
-#line 3246 "parse.y"
+#line 3190 "parse.y"
{ finish_for_init_stmt (yyvsp[-2].ttype); ;
break;}
case 728:
-#line 3248 "parse.y"
+#line 3192 "parse.y"
{ finish_for_cond (yyvsp[-1].ttype, yyvsp[-5].ttype); ;
break;}
case 729:
-#line 3250 "parse.y"
+#line 3194 "parse.y"
{ finish_for_expr (yyvsp[-1].ttype, yyvsp[-8].ttype); ;
break;}
case 730:
-#line 3252 "parse.y"
+#line 3196 "parse.y"
{ finish_for_stmt (yyvsp[-3].ttype, yyvsp[-10].ttype); ;
break;}
case 731:
-#line 3254 "parse.y"
+#line 3198 "parse.y"
{ begin_switch_stmt (); ;
break;}
case 732:
-#line 3256 "parse.y"
+#line 3200 "parse.y"
{ yyval.ttype = finish_switch_cond (yyvsp[-1].ttype); ;
break;}
case 733:
-#line 3258 "parse.y"
+#line 3202 "parse.y"
{ finish_switch_stmt (yyvsp[-3].ttype, yyvsp[-1].ttype); ;
break;}
case 734:
-#line 3260 "parse.y"
+#line 3204 "parse.y"
{ finish_case_label (yyvsp[-1].ttype, NULL_TREE); ;
break;}
case 736:
-#line 3263 "parse.y"
+#line 3207 "parse.y"
{ finish_case_label (yyvsp[-3].ttype, yyvsp[-1].ttype); ;
break;}
case 738:
-#line 3266 "parse.y"
+#line 3210 "parse.y"
{ finish_case_label (NULL_TREE, NULL_TREE); ;
break;}
case 740:
-#line 3269 "parse.y"
+#line 3213 "parse.y"
{ finish_break_stmt (); ;
break;}
case 741:
-#line 3271 "parse.y"
+#line 3215 "parse.y"
{ finish_continue_stmt (); ;
break;}
case 742:
-#line 3273 "parse.y"
+#line 3217 "parse.y"
{ finish_return_stmt (NULL_TREE); ;
break;}
case 743:
-#line 3275 "parse.y"
+#line 3219 "parse.y"
{ finish_return_stmt (yyvsp[-1].ttype); ;
break;}
case 744:
-#line 3277 "parse.y"
+#line 3221 "parse.y"
{
finish_asm_stmt (yyvsp[-4].ttype, yyvsp[-2].ttype, NULL_TREE, NULL_TREE,
NULL_TREE);
;
break;}
case 745:
-#line 3283 "parse.y"
+#line 3227 "parse.y"
{
finish_asm_stmt (yyvsp[-6].ttype, yyvsp[-4].ttype, yyvsp[-2].ttype, NULL_TREE,
NULL_TREE);
;
break;}
case 746:
-#line 3289 "parse.y"
+#line 3233 "parse.y"
{ finish_asm_stmt (yyvsp[-8].ttype, yyvsp[-6].ttype, yyvsp[-4].ttype, yyvsp[-2].ttype, NULL_TREE); ;
break;}
case 747:
-#line 3293 "parse.y"
+#line 3237 "parse.y"
{ finish_asm_stmt (yyvsp[-10].ttype, yyvsp[-8].ttype, yyvsp[-6].ttype, yyvsp[-4].ttype, yyvsp[-2].ttype); ;
break;}
case 748:
-#line 3295 "parse.y"
+#line 3239 "parse.y"
{
if (pedantic)
pedwarn ("ANSI C++ forbids computed gotos");
@@ -7336,29 +7280,29 @@ case 748:
;
break;}
case 749:
-#line 3301 "parse.y"
+#line 3245 "parse.y"
{ finish_goto_stmt (yyvsp[-1].ttype); ;
break;}
case 750:
-#line 3303 "parse.y"
+#line 3247 "parse.y"
{ finish_stmt (); ;
break;}
case 751:
-#line 3305 "parse.y"
+#line 3249 "parse.y"
{ error ("label must be followed by statement");
yyungetc ('}', 0);
finish_stmt (); ;
break;}
case 752:
-#line 3309 "parse.y"
+#line 3253 "parse.y"
{ finish_stmt (); ;
break;}
case 755:
-#line 3313 "parse.y"
+#line 3257 "parse.y"
{ do_local_using_decl (yyvsp[0].ttype); ;
break;}
case 757:
-#line 3319 "parse.y"
+#line 3263 "parse.y"
{
if (! current_function_parms_stored)
store_parm_decls ();
@@ -7366,13 +7310,13 @@ case 757:
;
break;}
case 758:
-#line 3325 "parse.y"
+#line 3269 "parse.y"
{
expand_start_all_catch ();
;
break;}
case 759:
-#line 3329 "parse.y"
+#line 3273 "parse.y"
{
int nested = (hack_decl_function_context
(current_function_decl) != NULL_TREE);
@@ -7381,41 +7325,41 @@ case 759:
;
break;}
case 760:
-#line 3339 "parse.y"
+#line 3283 "parse.y"
{ yyval.ttype = begin_try_block (); ;
break;}
case 761:
-#line 3341 "parse.y"
+#line 3285 "parse.y"
{ finish_try_block (yyvsp[-1].ttype); ;
break;}
case 762:
-#line 3343 "parse.y"
+#line 3287 "parse.y"
{ finish_handler_sequence (yyvsp[-3].ttype); ;
break;}
case 765:
-#line 3353 "parse.y"
+#line 3297 "parse.y"
{ yyval.ttype = begin_handler(); ;
break;}
case 766:
-#line 3355 "parse.y"
+#line 3299 "parse.y"
{ finish_handler_parms (yyvsp[-1].ttype); ;
break;}
case 767:
-#line 3357 "parse.y"
+#line 3301 "parse.y"
{ finish_handler (yyvsp[-3].ttype); ;
break;}
case 770:
-#line 3367 "parse.y"
+#line 3311 "parse.y"
{ expand_start_catch_block (NULL_TREE, NULL_TREE); ;
break;}
case 771:
-#line 3383 "parse.y"
+#line 3327 "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 772:
-#line 3390 "parse.y"
+#line 3334 "parse.y"
{ tree label;
do_label:
label = define_label (input_filename, lineno, yyvsp[-1].ttype);
@@ -7424,98 +7368,98 @@ case 772:
;
break;}
case 773:
-#line 3397 "parse.y"
+#line 3341 "parse.y"
{ goto do_label; ;
break;}
case 774:
-#line 3399 "parse.y"
+#line 3343 "parse.y"
{ goto do_label; ;
break;}
case 775:
-#line 3401 "parse.y"
+#line 3345 "parse.y"
{ goto do_label; ;
break;}
case 776:
-#line 3406 "parse.y"
+#line 3350 "parse.y"
{ if (yyvsp[-1].ttype) cplus_expand_expr_stmt (yyvsp[-1].ttype); ;
break;}
case 778:
-#line 3409 "parse.y"
+#line 3353 "parse.y"
{ if (pedantic)
pedwarn ("ANSI C++ forbids compound statements inside for initializations");
;
break;}
case 779:
-#line 3418 "parse.y"
+#line 3362 "parse.y"
{ emit_line_note (input_filename, lineno);
yyval.ttype = NULL_TREE; ;
break;}
case 780:
-#line 3421 "parse.y"
+#line 3365 "parse.y"
{ emit_line_note (input_filename, lineno); ;
break;}
case 781:
-#line 3426 "parse.y"
+#line 3370 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 783:
-#line 3429 "parse.y"
+#line 3373 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 784:
-#line 3436 "parse.y"
+#line 3380 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 787:
-#line 3443 "parse.y"
+#line 3387 "parse.y"
{ yyval.ttype = chainon (yyval.ttype, yyvsp[0].ttype); ;
break;}
case 788:
-#line 3448 "parse.y"
+#line 3392 "parse.y"
{ yyval.ttype = build_tree_list (yyval.ttype, yyvsp[-1].ttype); ;
break;}
case 789:
-#line 3453 "parse.y"
+#line 3397 "parse.y"
{ yyval.ttype = tree_cons (NULL_TREE, yyval.ttype, NULL_TREE); ;
break;}
case 790:
-#line 3455 "parse.y"
+#line 3399 "parse.y"
{ yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyval.ttype); ;
break;}
case 791:
-#line 3466 "parse.y"
+#line 3410 "parse.y"
{
yyval.ttype = empty_parms();
;
break;}
case 793:
-#line 3471 "parse.y"
+#line 3415 "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 794:
-#line 3479 "parse.y"
+#line 3423 "parse.y"
{ yyval.ttype = finish_parmlist (yyval.ttype, 0); ;
break;}
case 795:
-#line 3481 "parse.y"
+#line 3425 "parse.y"
{ yyval.ttype = finish_parmlist (yyvsp[-1].ttype, 1); ;
break;}
case 796:
-#line 3484 "parse.y"
+#line 3428 "parse.y"
{ yyval.ttype = finish_parmlist (yyvsp[-1].ttype, 1); ;
break;}
case 797:
-#line 3486 "parse.y"
+#line 3430 "parse.y"
{ yyval.ttype = finish_parmlist (build_tree_list (NULL_TREE,
yyvsp[-1].ftype.t), 1); ;
break;}
case 798:
-#line 3489 "parse.y"
+#line 3433 "parse.y"
{ yyval.ttype = finish_parmlist (NULL_TREE, 1); ;
break;}
case 799:
-#line 3491 "parse.y"
+#line 3435 "parse.y"
{
/* This helps us recover from really nasty
parse errors, for example, a missing right
@@ -7527,7 +7471,7 @@ case 799:
;
break;}
case 800:
-#line 3501 "parse.y"
+#line 3445 "parse.y"
{
/* This helps us recover from really nasty
parse errors, for example, a missing right
@@ -7540,98 +7484,98 @@ case 800:
;
break;}
case 801:
-#line 3516 "parse.y"
+#line 3460 "parse.y"
{ maybe_snarf_defarg (); ;
break;}
case 802:
-#line 3518 "parse.y"
+#line 3462 "parse.y"
{ yyval.ttype = yyvsp[0].ttype; ;
break;}
case 805:
-#line 3529 "parse.y"
+#line 3473 "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 806:
-#line 3532 "parse.y"
+#line 3476 "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 807:
-#line 3535 "parse.y"
+#line 3479 "parse.y"
{ check_for_new_type ("in a parameter list", yyvsp[0].ftype);
yyval.ttype = chainon (yyval.ttype, yyvsp[0].ftype.t); ;
break;}
case 808:
-#line 3538 "parse.y"
+#line 3482 "parse.y"
{ yyval.ttype = chainon (yyval.ttype, build_tree_list (NULL_TREE, yyvsp[0].ttype)); ;
break;}
case 809:
-#line 3540 "parse.y"
+#line 3484 "parse.y"
{ yyval.ttype = chainon (yyval.ttype, build_tree_list (yyvsp[0].ttype, yyvsp[-2].ttype)); ;
break;}
case 811:
-#line 3546 "parse.y"
+#line 3490 "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 812:
-#line 3556 "parse.y"
+#line 3500 "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 813:
-#line 3560 "parse.y"
+#line 3504 "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 814:
-#line 3563 "parse.y"
+#line 3507 "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 815:
-#line 3566 "parse.y"
+#line 3510 "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 816:
-#line 3570 "parse.y"
+#line 3514 "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 817:
-#line 3574 "parse.y"
+#line 3518 "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 818:
-#line 3581 "parse.y"
+#line 3525 "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 819:
-#line 3584 "parse.y"
+#line 3528 "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 822:
-#line 3595 "parse.y"
+#line 3539 "parse.y"
{ see_typename (); ;
break;}
case 823:
-#line 3600 "parse.y"
+#line 3544 "parse.y"
{
error ("type specifier omitted for parameter");
yyval.ttype = build_tree_list (integer_type_node, NULL_TREE);
;
break;}
case 824:
-#line 3605 "parse.y"
+#line 3549 "parse.y"
{
error ("type specifier omitted for parameter");
if (TREE_CODE (yyval.ttype) == SCOPE_REF
@@ -7642,188 +7586,188 @@ case 824:
;
break;}
case 825:
-#line 3617 "parse.y"
+#line 3561 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 826:
-#line 3619 "parse.y"
+#line 3563 "parse.y"
{ yyval.ttype = yyvsp[-1].ttype; ;
break;}
case 827:
-#line 3621 "parse.y"
+#line 3565 "parse.y"
{ yyval.ttype = build_decl_list (NULL_TREE, NULL_TREE); ;
break;}
case 828:
-#line 3626 "parse.y"
+#line 3570 "parse.y"
{ yyval.ttype = build_decl_list (NULL_TREE, groktypename(yyvsp[0].ftype.t)); ;
break;}
case 830:
-#line 3632 "parse.y"
+#line 3576 "parse.y"
{
TREE_CHAIN (yyvsp[0].ttype) = yyval.ttype;
yyval.ttype = yyvsp[0].ttype;
;
break;}
case 831:
-#line 3640 "parse.y"
+#line 3584 "parse.y"
{ yyval.ttype = NULL_TREE; ;
break;}
case 832:
-#line 3642 "parse.y"
+#line 3586 "parse.y"
{ yyval.ttype = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 833:
-#line 3644 "parse.y"
+#line 3588 "parse.y"
{ yyval.ttype = make_reference_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ;
break;}
case 834:
-#line 3646 "parse.y"
+#line 3590 "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 835:
-#line 3653 "parse.y"
+#line 3597 "parse.y"
{ got_scope = NULL_TREE; ;
break;}
case 836:
-#line 3658 "parse.y"
+#line 3602 "parse.y"
{ yyval.ttype = ansi_opname[MULT_EXPR]; ;
break;}
case 837:
-#line 3660 "parse.y"
+#line 3604 "parse.y"
{ yyval.ttype = ansi_opname[TRUNC_DIV_EXPR]; ;
break;}
case 838:
-#line 3662 "parse.y"
+#line 3606 "parse.y"
{ yyval.ttype = ansi_opname[TRUNC_MOD_EXPR]; ;
break;}
case 839:
-#line 3664 "parse.y"
+#line 3608 "parse.y"
{ yyval.ttype = ansi_opname[PLUS_EXPR]; ;
break;}
case 840:
-#line 3666 "parse.y"
+#line 3610 "parse.y"
{ yyval.ttype = ansi_opname[MINUS_EXPR]; ;
break;}
case 841:
-#line 3668 "parse.y"
+#line 3612 "parse.y"
{ yyval.ttype = ansi_opname[BIT_AND_EXPR]; ;
break;}
case 842:
-#line 3670 "parse.y"
+#line 3614 "parse.y"
{ yyval.ttype = ansi_opname[BIT_IOR_EXPR]; ;
break;}
case 843:
-#line 3672 "parse.y"
+#line 3616 "parse.y"
{ yyval.ttype = ansi_opname[BIT_XOR_EXPR]; ;
break;}
case 844:
-#line 3674 "parse.y"
+#line 3618 "parse.y"
{ yyval.ttype = ansi_opname[BIT_NOT_EXPR]; ;
break;}
case 845:
-#line 3676 "parse.y"
+#line 3620 "parse.y"
{ yyval.ttype = ansi_opname[COMPOUND_EXPR]; ;
break;}
case 846:
-#line 3678 "parse.y"
+#line 3622 "parse.y"
{ yyval.ttype = ansi_opname[yyvsp[0].code]; ;
break;}
case 847:
-#line 3680 "parse.y"
+#line 3624 "parse.y"
{ yyval.ttype = ansi_opname[LT_EXPR]; ;
break;}
case 848:
-#line 3682 "parse.y"
+#line 3626 "parse.y"
{ yyval.ttype = ansi_opname[GT_EXPR]; ;
break;}
case 849:
-#line 3684 "parse.y"
+#line 3628 "parse.y"
{ yyval.ttype = ansi_opname[yyvsp[0].code]; ;
break;}
case 850:
-#line 3686 "parse.y"
+#line 3630 "parse.y"
{ yyval.ttype = ansi_assopname[yyvsp[0].code]; ;
break;}
case 851:
-#line 3688 "parse.y"
+#line 3632 "parse.y"
{ yyval.ttype = ansi_opname [MODIFY_EXPR]; ;
break;}
case 852:
-#line 3690 "parse.y"
+#line 3634 "parse.y"
{ yyval.ttype = ansi_opname[yyvsp[0].code]; ;
break;}
case 853:
-#line 3692 "parse.y"
+#line 3636 "parse.y"
{ yyval.ttype = ansi_opname[yyvsp[0].code]; ;
break;}
case 854:
-#line 3694 "parse.y"
+#line 3638 "parse.y"
{ yyval.ttype = ansi_opname[POSTINCREMENT_EXPR]; ;
break;}
case 855:
-#line 3696 "parse.y"
+#line 3640 "parse.y"
{ yyval.ttype = ansi_opname[PREDECREMENT_EXPR]; ;
break;}
case 856:
-#line 3698 "parse.y"
+#line 3642 "parse.y"
{ yyval.ttype = ansi_opname[TRUTH_ANDIF_EXPR]; ;
break;}
case 857:
-#line 3700 "parse.y"
+#line 3644 "parse.y"
{ yyval.ttype = ansi_opname[TRUTH_ORIF_EXPR]; ;
break;}
case 858:
-#line 3702 "parse.y"
+#line 3646 "parse.y"
{ yyval.ttype = ansi_opname[TRUTH_NOT_EXPR]; ;
break;}
case 859:
-#line 3704 "parse.y"
+#line 3648 "parse.y"
{ yyval.ttype = ansi_opname[COND_EXPR]; ;
break;}
case 860:
-#line 3706 "parse.y"
+#line 3650 "parse.y"
{ yyval.ttype = ansi_opname[yyvsp[0].code]; ;
break;}
case 861:
-#line 3708 "parse.y"
+#line 3652 "parse.y"
{ yyval.ttype = ansi_opname[COMPONENT_REF]; ;
break;}
case 862:
-#line 3710 "parse.y"
+#line 3654 "parse.y"
{ yyval.ttype = ansi_opname[MEMBER_REF]; ;
break;}
case 863:
-#line 3712 "parse.y"
+#line 3656 "parse.y"
{ yyval.ttype = ansi_opname[CALL_EXPR]; ;
break;}
case 864:
-#line 3714 "parse.y"
+#line 3658 "parse.y"
{ yyval.ttype = ansi_opname[ARRAY_REF]; ;
break;}
case 865:
-#line 3716 "parse.y"
+#line 3660 "parse.y"
{ yyval.ttype = ansi_opname[NEW_EXPR]; ;
break;}
case 866:
-#line 3718 "parse.y"
+#line 3662 "parse.y"
{ yyval.ttype = ansi_opname[DELETE_EXPR]; ;
break;}
case 867:
-#line 3720 "parse.y"
+#line 3664 "parse.y"
{ yyval.ttype = ansi_opname[VEC_NEW_EXPR]; ;
break;}
case 868:
-#line 3722 "parse.y"
+#line 3666 "parse.y"
{ yyval.ttype = ansi_opname[VEC_DELETE_EXPR]; ;
break;}
case 869:
-#line 3725 "parse.y"
+#line 3669 "parse.y"
{ yyval.ttype = grokoptypename (yyvsp[-1].ftype.t, yyvsp[0].ttype); ;
break;}
case 870:
-#line 3727 "parse.y"
+#line 3671 "parse.y"
{ yyval.ttype = ansi_opname[ERROR_MARK]; ;
break;}
}
@@ -8024,7 +7968,7 @@ yyerrhandle:
yystate = yyn;
goto yynewstate;
}
-#line 3730 "parse.y"
+#line 3674 "parse.y"
#ifdef SPEW_DEBUG
diff --git a/gcc/cp/parse.y b/gcc/cp/parse.y
index 022e50b..3aca19f 100644
--- a/gcc/cp/parse.y
+++ b/gcc/cp/parse.y
@@ -2090,7 +2090,9 @@ structsp:
$$.new_type_flag = 0; }
| TYPENAME_KEYWORD typename_sub
{ $$.t = $2;
- $$.new_type_flag = 0; }
+ $$.new_type_flag = 0;
+ if (!processing_template_decl)
+ cp_pedwarn ("using `typename' outside of template"); }
/* C++ extensions, merged with C to avoid shift/reduce conflicts */
| class_head left_curly
opt.component_decl_list '}' maybe_attribute
@@ -2251,71 +2253,13 @@ base_class_list:
base_class:
base_class.1
- {
- tree type;
- if ($1 == NULL_TREE)
- {
- error ("invalid base class");
- type = error_mark_node;
- }
- else
- type = TREE_TYPE ($1);
- if (! is_aggr_type (type, 1))
- $$ = NULL_TREE;
- else if (current_aggr == signature_type_node
- && (! type) && (! IS_SIGNATURE (type)))
- {
- error ("class name not allowed as base signature");
- $$ = NULL_TREE;
- }
- else if (current_aggr == signature_type_node)
- {
- sorry ("signature inheritance, base type `%s' ignored",
- IDENTIFIER_POINTER ($$));
- $$ = build_tree_list (access_public_node, type);
- }
- else if (type && IS_SIGNATURE (type))
- {
- error ("signature name not allowed as base class");
- $$ = NULL_TREE;
- }
- else
- $$ = build_tree_list (access_default_node, type);
- }
+ { $$ = finish_base_specifier (access_default_node, $1,
+ current_aggr
+ == signature_type_node); }
| base_class_access_list see_typename base_class.1
- {
- tree type;
- if ($3 == NULL_TREE)
- {
- error ("invalid base class");
- type = error_mark_node;
- }
- else
- type = TREE_TYPE ($3);
- if (current_aggr == signature_type_node)
- error ("access and source specifiers not allowed in signature");
- if (! is_aggr_type (type, 1))
- $$ = NULL_TREE;
- else if (current_aggr == signature_type_node
- && (! type) && (! IS_SIGNATURE (type)))
- {
- error ("class name not allowed as base signature");
- $$ = NULL_TREE;
- }
- else if (current_aggr == signature_type_node)
- {
- sorry ("signature inheritance, base type `%s' ignored",
- IDENTIFIER_POINTER ($$));
- $$ = build_tree_list (access_public_node, type);
- }
- else if (type && IS_SIGNATURE (type))
- {
- error ("signature name not allowed as base class");
- $$ = NULL_TREE;
- }
- else
- $$ = build_tree_list ($$, type);
- }
+ { $$ = finish_base_specifier ($1, $3,
+ current_aggr
+ == signature_type_node); }
;
base_class.1:
@@ -2868,7 +2812,6 @@ functional_cast:
| typespec fcast_or_absdcl %prec EMPTY
{ $$ = reparse_absdcl_as_expr ($1.t, $2); }
;
-
type_name:
TYPENAME
| SELFNAME
diff --git a/gcc/cp/semantics.c b/gcc/cp/semantics.c
index 2442826..6bb3cd0 100644
--- a/gcc/cp/semantics.c
+++ b/gcc/cp/semantics.c
@@ -1436,3 +1436,53 @@ enter_scope_of (sr)
TREE_COMPLEXITY (sr) = current_class_depth;
}
}
+
+/* Finish processing a BASE_CLASS with the indicated ACCESS_SPECIFIER.
+ Return a TREE_LIST containing the ACCESS_SPECIFIER and the
+ BASE_CLASS, or NULL_TREE if an error occurred. The
+ ACCESSS_SPECIFIER is one of
+ access_{default,public,protected_private}[_virtual]_node.*/
+
+tree
+finish_base_specifier (access_specifier, base_class,
+ current_aggr_is_signature)
+ tree access_specifier;
+ tree base_class;
+ int current_aggr_is_signature;
+{
+ tree type;
+ tree result;
+
+ if (base_class == NULL_TREE)
+ {
+ error ("invalid base class");
+ type = error_mark_node;
+ }
+ else
+ type = TREE_TYPE (base_class);
+ if (current_aggr_is_signature && access_specifier)
+ error ("access and source specifiers not allowed in signature");
+ if (! is_aggr_type (type, 1))
+ result = NULL_TREE;
+ else if (current_aggr_is_signature
+ && (! type) && (! IS_SIGNATURE (type)))
+ {
+ error ("class name not allowed as base signature");
+ result = NULL_TREE;
+ }
+ else if (current_aggr_is_signature)
+ {
+ sorry ("signature inheritance, base type `%s' ignored",
+ IDENTIFIER_POINTER (access_specifier));
+ result = build_tree_list (access_public_node, type);
+ }
+ else if (type && IS_SIGNATURE (type))
+ {
+ error ("signature name not allowed as base class");
+ result = NULL_TREE;
+ }
+ else
+ result = build_tree_list (access_specifier, type);
+
+ return result;
+}
diff --git a/gcc/testsuite/g++.old-deja/g++.pt/typename10.C b/gcc/testsuite/g++.old-deja/g++.pt/typename10.C
new file mode 100644
index 0000000..1b122b2
--- /dev/null
+++ b/gcc/testsuite/g++.old-deja/g++.pt/typename10.C
@@ -0,0 +1,7 @@
+// Build don't link:
+
+struct S {
+ typedef int I;
+};
+
+void f(typename S::I); // ERROR - using typename outside of template