summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMarcus Holland-Moritz <mhx-perl@gmx.net>2005-02-10 20:50:31 +0000
committerMarcus Holland-Moritz <mhx-perl@gmx.net>2005-02-10 20:50:31 +0000
commita758b0b5fd9985d853637e2aa988519329533771 (patch)
tree13ac72625becca6611085c6ca03fe28f7bd0cfff
parent2080282f2af44db6021d1dce04e81f0141289f86 (diff)
downloadperl-a758b0b5fd9985d853637e2aa988519329533771.tar.gz
[perl #34101] not() || 1 produces segmentation fault
Fixed by making not() behave like not(0). This is also the way not() behaved before it started segfaulting in 5.6.0. p4raw-id: //depot/perl@23960
-rw-r--r--MANIFEST1
-rw-r--r--perly.act573
-rw-r--r--perly.h8
-rw-r--r--perly.tab64
-rw-r--r--perly.y3
-rw-r--r--t/op/not.t13
6 files changed, 339 insertions, 323 deletions
diff --git a/MANIFEST b/MANIFEST
index db8a898fb0..2938dee09d 100644
--- a/MANIFEST
+++ b/MANIFEST
@@ -2718,6 +2718,7 @@ t/op/mkdir.t See if mkdir works
t/op/mydef.t See if "my $_" works
t/op/my_stash.t See if my Package works
t/op/my.t See if lexical scoping works
+t/op/not.t See if not works
t/op/numconvert.t See if accessing fields does not change numeric values
t/op/oct.t See if oct and hex work
t/op/ord.t See if ord works
diff --git a/perly.act b/perly.act
index bfb3922285..9adab55e9d 100644
--- a/perly.act
+++ b/perly.act
@@ -1,75 +1,75 @@
case 2:
#line 97 "perly.y"
- { yyval.ival = yyvsp[-1].ival; newPROG(block_end(yyvsp[-1].ival,yyvsp[0].opval)); ;}
+ { (yyval.ival) = (yyvsp[-1].ival); newPROG(block_end((yyvsp[-1].ival),(yyvsp[0].opval))); ;}
break;
case 3:
#line 102 "perly.y"
- { if (PL_copline > (line_t)yyvsp[-3].ival)
- PL_copline = (line_t)yyvsp[-3].ival;
- yyval.opval = block_end(yyvsp[-2].ival, yyvsp[-1].opval); ;}
+ { if (PL_copline > (line_t)(yyvsp[-3].ival))
+ PL_copline = (line_t)(yyvsp[-3].ival);
+ (yyval.opval) = block_end((yyvsp[-2].ival), (yyvsp[-1].opval)); ;}
break;
case 4:
#line 108 "perly.y"
- { yyval.ival = block_start(TRUE); ;}
+ { (yyval.ival) = block_start(TRUE); ;}
break;
case 5:
#line 112 "perly.y"
{
- PL_expect = XSTATE; yyval.ival = block_start(TRUE);
+ PL_expect = XSTATE; (yyval.ival) = block_start(TRUE);
;}
break;
case 6:
#line 119 "perly.y"
- { if (PL_copline > (line_t)yyvsp[-3].ival)
- PL_copline = (line_t)yyvsp[-3].ival;
- yyval.opval = block_end(yyvsp[-2].ival, yyvsp[-1].opval); ;}
+ { if (PL_copline > (line_t)(yyvsp[-3].ival))
+ PL_copline = (line_t)(yyvsp[-3].ival);
+ (yyval.opval) = block_end((yyvsp[-2].ival), (yyvsp[-1].opval)); ;}
break;
case 7:
#line 125 "perly.y"
- { yyval.ival = block_start(FALSE); ;}
+ { (yyval.ival) = block_start(FALSE); ;}
break;
case 8:
#line 129 "perly.y"
- { yyval.ival = PL_savestack_ix; ;}
+ { (yyval.ival) = PL_savestack_ix; ;}
break;
case 9:
#line 133 "perly.y"
- { yyval.opval = Nullop; ;}
+ { (yyval.opval) = Nullop; ;}
break;
case 10:
#line 135 "perly.y"
- { yyval.opval = yyvsp[-1].opval; ;}
+ { (yyval.opval) = (yyvsp[-1].opval); ;}
break;
case 11:
#line 137 "perly.y"
- { LEAVE_SCOPE(yyvsp[-1].ival);
- yyval.opval = append_list(OP_LINESEQ,
- (LISTOP*)yyvsp[-2].opval, (LISTOP*)yyvsp[0].opval);
+ { LEAVE_SCOPE((yyvsp[-1].ival));
+ (yyval.opval) = append_list(OP_LINESEQ,
+ (LISTOP*)(yyvsp[-2].opval), (LISTOP*)(yyvsp[0].opval));
PL_pad_reset_pending = TRUE;
- if (yyvsp[-2].opval && yyvsp[0].opval) PL_hints |= HINT_BLOCK_SCOPE; ;}
+ if ((yyvsp[-2].opval) && (yyvsp[0].opval)) PL_hints |= HINT_BLOCK_SCOPE; ;}
break;
case 12:
#line 146 "perly.y"
- { yyval.opval = newSTATEOP(0, yyvsp[-1].pval, yyvsp[0].opval); ;}
+ { (yyval.opval) = newSTATEOP(0, (yyvsp[-1].pval), (yyvsp[0].opval)); ;}
break;
case 14:
#line 149 "perly.y"
- { if (yyvsp[-1].pval != Nullch) {
- yyval.opval = newSTATEOP(0, yyvsp[-1].pval, newOP(OP_NULL, 0));
+ { if ((yyvsp[-1].pval) != Nullch) {
+ (yyval.opval) = newSTATEOP(0, (yyvsp[-1].pval), newOP(OP_NULL, 0));
}
else {
- yyval.opval = Nullop;
+ (yyval.opval) = Nullop;
PL_copline = NOLINE;
}
PL_expect = XSTATE; ;}
@@ -77,306 +77,306 @@ case 2:
case 15:
#line 158 "perly.y"
- { yyval.opval = newSTATEOP(0, yyvsp[-2].pval, yyvsp[-1].opval);
+ { (yyval.opval) = newSTATEOP(0, (yyvsp[-2].pval), (yyvsp[-1].opval));
PL_expect = XSTATE; ;}
break;
case 16:
#line 164 "perly.y"
- { yyval.opval = Nullop; ;}
+ { (yyval.opval) = Nullop; ;}
break;
case 17:
#line 166 "perly.y"
- { yyval.opval = yyvsp[0].opval; ;}
+ { (yyval.opval) = (yyvsp[0].opval); ;}
break;
case 18:
#line 168 "perly.y"
- { yyval.opval = newLOGOP(OP_AND, 0, yyvsp[0].opval, yyvsp[-2].opval); ;}
+ { (yyval.opval) = newLOGOP(OP_AND, 0, (yyvsp[0].opval), (yyvsp[-2].opval)); ;}
break;
case 19:
#line 170 "perly.y"
- { yyval.opval = newLOGOP(OP_OR, 0, yyvsp[0].opval, yyvsp[-2].opval); ;}
+ { (yyval.opval) = newLOGOP(OP_OR, 0, (yyvsp[0].opval), (yyvsp[-2].opval)); ;}
break;
case 20:
#line 172 "perly.y"
- { yyval.opval = newLOOPOP(OPf_PARENS, 1, scalar(yyvsp[0].opval), yyvsp[-2].opval); ;}
+ { (yyval.opval) = newLOOPOP(OPf_PARENS, 1, scalar((yyvsp[0].opval)), (yyvsp[-2].opval)); ;}
break;
case 21:
#line 174 "perly.y"
- { yyval.opval = newLOOPOP(OPf_PARENS, 1, yyvsp[0].opval, yyvsp[-2].opval);;}
+ { (yyval.opval) = newLOOPOP(OPf_PARENS, 1, (yyvsp[0].opval), (yyvsp[-2].opval));;}
break;
case 22:
#line 176 "perly.y"
- { yyval.opval = newFOROP(0, Nullch, (line_t)yyvsp[-1].ival,
- Nullop, yyvsp[0].opval, yyvsp[-2].opval, Nullop); ;}
+ { (yyval.opval) = newFOROP(0, Nullch, (line_t)(yyvsp[-1].ival),
+ Nullop, (yyvsp[0].opval), (yyvsp[-2].opval), Nullop); ;}
break;
case 23:
#line 182 "perly.y"
- { yyval.opval = Nullop; ;}
+ { (yyval.opval) = Nullop; ;}
break;
case 24:
#line 184 "perly.y"
- { (yyvsp[0].opval)->op_flags |= OPf_PARENS; yyval.opval = scope(yyvsp[0].opval); ;}
+ { ((yyvsp[0].opval))->op_flags |= OPf_PARENS; (yyval.opval) = scope((yyvsp[0].opval)); ;}
break;
case 25:
#line 186 "perly.y"
- { PL_copline = (line_t)yyvsp[-5].ival;
- yyval.opval = newCONDOP(0, yyvsp[-3].opval, scope(yyvsp[-1].opval), yyvsp[0].opval);
+ { PL_copline = (line_t)(yyvsp[-5].ival);
+ (yyval.opval) = newCONDOP(0, (yyvsp[-3].opval), scope((yyvsp[-1].opval)), (yyvsp[0].opval));
PL_hints |= HINT_BLOCK_SCOPE; ;}
break;
case 26:
#line 193 "perly.y"
- { PL_copline = (line_t)yyvsp[-6].ival;
- yyval.opval = block_end(yyvsp[-4].ival,
- newCONDOP(0, yyvsp[-3].opval, scope(yyvsp[-1].opval), yyvsp[0].opval)); ;}
+ { PL_copline = (line_t)(yyvsp[-6].ival);
+ (yyval.opval) = block_end((yyvsp[-4].ival),
+ newCONDOP(0, (yyvsp[-3].opval), scope((yyvsp[-1].opval)), (yyvsp[0].opval))); ;}
break;
case 27:
#line 197 "perly.y"
- { PL_copline = (line_t)yyvsp[-6].ival;
- yyval.opval = block_end(yyvsp[-4].ival,
- newCONDOP(0, yyvsp[-3].opval, scope(yyvsp[-1].opval), yyvsp[0].opval)); ;}
+ { PL_copline = (line_t)(yyvsp[-6].ival);
+ (yyval.opval) = block_end((yyvsp[-4].ival),
+ newCONDOP(0, (yyvsp[-3].opval), scope((yyvsp[-1].opval)), (yyvsp[0].opval))); ;}
break;
case 28:
#line 204 "perly.y"
- { yyval.opval = Nullop; ;}
+ { (yyval.opval) = Nullop; ;}
break;
case 29:
#line 206 "perly.y"
- { yyval.opval = scope(yyvsp[0].opval); ;}
+ { (yyval.opval) = scope((yyvsp[0].opval)); ;}
break;
case 30:
#line 211 "perly.y"
- { PL_copline = (line_t)yyvsp[-6].ival;
- yyval.opval = block_end(yyvsp[-4].ival,
- newSTATEOP(0, yyvsp[-7].pval,
+ { PL_copline = (line_t)(yyvsp[-6].ival);
+ (yyval.opval) = block_end((yyvsp[-4].ival),
+ newSTATEOP(0, (yyvsp[-7].pval),
newWHILEOP(0, 1, (LOOP*)Nullop,
- yyvsp[-6].ival, yyvsp[-3].opval, yyvsp[-1].opval, yyvsp[0].opval))); ;}
+ (yyvsp[-6].ival), (yyvsp[-3].opval), (yyvsp[-1].opval), (yyvsp[0].opval)))); ;}
break;
case 31:
#line 217 "perly.y"
- { PL_copline = (line_t)yyvsp[-6].ival;
- yyval.opval = block_end(yyvsp[-4].ival,
- newSTATEOP(0, yyvsp[-7].pval,
+ { PL_copline = (line_t)(yyvsp[-6].ival);
+ (yyval.opval) = block_end((yyvsp[-4].ival),
+ newSTATEOP(0, (yyvsp[-7].pval),
newWHILEOP(0, 1, (LOOP*)Nullop,
- yyvsp[-6].ival, yyvsp[-3].opval, yyvsp[-1].opval, yyvsp[0].opval))); ;}
+ (yyvsp[-6].ival), (yyvsp[-3].opval), (yyvsp[-1].opval), (yyvsp[0].opval)))); ;}
break;
case 32:
#line 223 "perly.y"
- { yyval.opval = block_end(yyvsp[-6].ival,
- newFOROP(0, yyvsp[-9].pval, (line_t)yyvsp[-8].ival, yyvsp[-5].opval, yyvsp[-3].opval, yyvsp[-1].opval, yyvsp[0].opval)); ;}
+ { (yyval.opval) = block_end((yyvsp[-6].ival),
+ newFOROP(0, (yyvsp[-9].pval), (line_t)(yyvsp[-8].ival), (yyvsp[-5].opval), (yyvsp[-3].opval), (yyvsp[-1].opval), (yyvsp[0].opval))); ;}
break;
case 33:
#line 226 "perly.y"
- { yyval.opval = block_end(yyvsp[-4].ival,
- newFOROP(0, yyvsp[-8].pval, (line_t)yyvsp[-7].ival, mod(yyvsp[-6].opval, OP_ENTERLOOP),
- yyvsp[-3].opval, yyvsp[-1].opval, yyvsp[0].opval)); ;}
+ { (yyval.opval) = block_end((yyvsp[-4].ival),
+ newFOROP(0, (yyvsp[-8].pval), (line_t)(yyvsp[-7].ival), mod((yyvsp[-6].opval), OP_ENTERLOOP),
+ (yyvsp[-3].opval), (yyvsp[-1].opval), (yyvsp[0].opval))); ;}
break;
case 34:
#line 230 "perly.y"
- { yyval.opval = block_end(yyvsp[-4].ival,
- newFOROP(0, yyvsp[-7].pval, (line_t)yyvsp[-6].ival, Nullop, yyvsp[-3].opval, yyvsp[-1].opval, yyvsp[0].opval)); ;}
+ { (yyval.opval) = block_end((yyvsp[-4].ival),
+ newFOROP(0, (yyvsp[-7].pval), (line_t)(yyvsp[-6].ival), Nullop, (yyvsp[-3].opval), (yyvsp[-1].opval), (yyvsp[0].opval))); ;}
break;
case 35:
#line 234 "perly.y"
{ OP *forop;
- PL_copline = (line_t)yyvsp[-9].ival;
- forop = newSTATEOP(0, yyvsp[-10].pval,
+ PL_copline = (line_t)(yyvsp[-9].ival);
+ forop = newSTATEOP(0, (yyvsp[-10].pval),
newWHILEOP(0, 1, (LOOP*)Nullop,
- yyvsp[-9].ival, scalar(yyvsp[-4].opval),
- yyvsp[0].opval, yyvsp[-2].opval));
- if (yyvsp[-6].opval) {
+ (yyvsp[-9].ival), scalar((yyvsp[-4].opval)),
+ (yyvsp[0].opval), (yyvsp[-2].opval)));
+ if ((yyvsp[-6].opval)) {
forop = append_elem(OP_LINESEQ,
- newSTATEOP(0, (yyvsp[-10].pval?savepv(yyvsp[-10].pval):Nullch),
- yyvsp[-6].opval),
+ newSTATEOP(0, ((yyvsp[-10].pval)?savepv((yyvsp[-10].pval)):Nullch),
+ (yyvsp[-6].opval)),
forop);
}
- yyval.opval = block_end(yyvsp[-7].ival, forop); ;}
+ (yyval.opval) = block_end((yyvsp[-7].ival), forop); ;}
break;
case 36:
#line 249 "perly.y"
- { yyval.opval = newSTATEOP(0, yyvsp[-2].pval,
+ { (yyval.opval) = newSTATEOP(0, (yyvsp[-2].pval),
newWHILEOP(0, 1, (LOOP*)Nullop,
- NOLINE, Nullop, yyvsp[-1].opval, yyvsp[0].opval)); ;}
+ NOLINE, Nullop, (yyvsp[-1].opval), (yyvsp[0].opval))); ;}
break;
case 37:
#line 256 "perly.y"
- { yyval.opval = Nullop; ;}
+ { (yyval.opval) = Nullop; ;}
break;
case 39:
#line 262 "perly.y"
- { (void)scan_num("1", &yylval); yyval.opval = yylval.opval; ;}
+ { (void)scan_num("1", &yylval); (yyval.opval) = yylval.opval; ;}
break;
case 41:
#line 268 "perly.y"
- { yyval.opval = invert(scalar(yyvsp[0].opval)); ;}
+ { (yyval.opval) = invert(scalar((yyvsp[0].opval))); ;}
break;
case 42:
#line 273 "perly.y"
- { yyval.opval = yyvsp[0].opval; intro_my(); ;}
+ { (yyval.opval) = (yyvsp[0].opval); intro_my(); ;}
break;
case 43:
#line 277 "perly.y"
- { yyval.opval = yyvsp[0].opval; intro_my(); ;}
+ { (yyval.opval) = (yyvsp[0].opval); intro_my(); ;}
break;
case 44:
#line 281 "perly.y"
- { yyval.opval = yyvsp[0].opval; intro_my(); ;}
+ { (yyval.opval) = (yyvsp[0].opval); intro_my(); ;}
break;
case 45:
#line 285 "perly.y"
- { yyval.opval = yyvsp[0].opval; intro_my(); ;}
+ { (yyval.opval) = (yyvsp[0].opval); intro_my(); ;}
break;
case 46:
#line 290 "perly.y"
- { yyval.pval = Nullch; ;}
+ { (yyval.pval) = Nullch; ;}
break;
case 48:
#line 296 "perly.y"
- { yyval.ival = 0; ;}
+ { (yyval.ival) = 0; ;}
break;
case 49:
#line 298 "perly.y"
- { yyval.ival = 0; ;}
+ { (yyval.ival) = 0; ;}
break;
case 50:
#line 300 "perly.y"
- { yyval.ival = 0; ;}
+ { (yyval.ival) = 0; ;}
break;
case 51:
#line 302 "perly.y"
- { yyval.ival = 0; ;}
+ { (yyval.ival) = 0; ;}
break;
case 52:
#line 304 "perly.y"
- { yyval.ival = 0; ;}
+ { (yyval.ival) = 0; ;}
break;
case 53:
#line 308 "perly.y"
- { newFORM(yyvsp[-2].ival, yyvsp[-1].opval, yyvsp[0].opval); ;}
+ { newFORM((yyvsp[-2].ival), (yyvsp[-1].opval), (yyvsp[0].opval)); ;}
break;
case 54:
#line 311 "perly.y"
- { yyval.opval = yyvsp[0].opval; ;}
+ { (yyval.opval) = (yyvsp[0].opval); ;}
break;
case 55:
#line 312 "perly.y"
- { yyval.opval = Nullop; ;}
+ { (yyval.opval) = Nullop; ;}
break;
case 56:
#line 317 "perly.y"
- { newMYSUB(yyvsp[-4].ival, yyvsp[-3].opval, yyvsp[-2].opval, yyvsp[-1].opval, yyvsp[0].opval); ;}
+ { newMYSUB((yyvsp[-4].ival), (yyvsp[-3].opval), (yyvsp[-2].opval), (yyvsp[-1].opval), (yyvsp[0].opval)); ;}
break;
case 57:
#line 322 "perly.y"
- { newATTRSUB(yyvsp[-4].ival, yyvsp[-3].opval, yyvsp[-2].opval, yyvsp[-1].opval, yyvsp[0].opval); ;}
+ { newATTRSUB((yyvsp[-4].ival), (yyvsp[-3].opval), (yyvsp[-2].opval), (yyvsp[-1].opval), (yyvsp[0].opval)); ;}
break;
case 58:
#line 326 "perly.y"
- { yyval.ival = start_subparse(FALSE, 0); ;}
+ { (yyval.ival) = start_subparse(FALSE, 0); ;}
break;
case 59:
#line 330 "perly.y"
- { yyval.ival = start_subparse(FALSE, CVf_ANON); ;}
+ { (yyval.ival) = start_subparse(FALSE, CVf_ANON); ;}
break;
case 60:
#line 334 "perly.y"
- { yyval.ival = start_subparse(TRUE, 0); ;}
+ { (yyval.ival) = start_subparse(TRUE, 0); ;}
break;
case 61:
#line 338 "perly.y"
- { STRLEN n_a; char *name = SvPV(((SVOP*)yyvsp[0].opval)->op_sv,n_a);
+ { STRLEN n_a; char *name = SvPV(((SVOP*)(yyvsp[0].opval))->op_sv,n_a);
if (strEQ(name, "BEGIN") || strEQ(name, "END")
|| strEQ(name, "INIT") || strEQ(name, "CHECK"))
CvSPECIAL_on(PL_compcv);
- yyval.opval = yyvsp[0].opval; ;}
+ (yyval.opval) = (yyvsp[0].opval); ;}
break;
case 62:
#line 347 "perly.y"
- { yyval.opval = Nullop; ;}
+ { (yyval.opval) = Nullop; ;}
break;
case 64:
#line 353 "perly.y"
- { yyval.opval = Nullop; ;}
+ { (yyval.opval) = Nullop; ;}
break;
case 65:
#line 355 "perly.y"
- { yyval.opval = yyvsp[0].opval; ;}
+ { (yyval.opval) = (yyvsp[0].opval); ;}
break;
case 66:
#line 357 "perly.y"
- { yyval.opval = Nullop; ;}
+ { (yyval.opval) = Nullop; ;}
break;
case 67:
#line 362 "perly.y"
- { yyval.opval = yyvsp[0].opval; ;}
+ { (yyval.opval) = (yyvsp[0].opval); ;}
break;
case 68:
#line 364 "perly.y"
- { yyval.opval = Nullop; ;}
+ { (yyval.opval) = Nullop; ;}
break;
case 69:
#line 368 "perly.y"
- { yyval.opval = yyvsp[0].opval; ;}
+ { (yyval.opval) = (yyvsp[0].opval); ;}
break;
case 70:
#line 369 "perly.y"
- { yyval.opval = Nullop; PL_expect = XSTATE; ;}
+ { (yyval.opval) = Nullop; PL_expect = XSTATE; ;}
break;
case 71:
#line 373 "perly.y"
- { package(yyvsp[-1].opval); ;}
+ { package((yyvsp[-1].opval)); ;}
break;
case 72:
@@ -386,658 +386,659 @@ case 2:
case 73:
#line 379 "perly.y"
- { utilize(yyvsp[-6].ival, yyvsp[-5].ival, yyvsp[-3].opval, yyvsp[-2].opval, yyvsp[-1].opval); ;}
+ { utilize((yyvsp[-6].ival), (yyvsp[-5].ival), (yyvsp[-3].opval), (yyvsp[-2].opval), (yyvsp[-1].opval)); ;}
break;
case 74:
#line 384 "perly.y"
- { yyval.opval = newLOGOP(OP_AND, 0, yyvsp[-2].opval, yyvsp[0].opval); ;}
+ { (yyval.opval) = newLOGOP(OP_AND, 0, (yyvsp[-2].opval), (yyvsp[0].opval)); ;}
break;
case 75:
#line 386 "perly.y"
- { yyval.opval = newLOGOP(yyvsp[-1].ival, 0, yyvsp[-2].opval, yyvsp[0].opval); ;}
+ { (yyval.opval) = newLOGOP((yyvsp[-1].ival), 0, (yyvsp[-2].opval), (yyvsp[0].opval)); ;}
break;
case 76:
#line 388 "perly.y"
- { yyval.opval = newLOGOP(OP_DOR, 0, yyvsp[-2].opval, yyvsp[0].opval); ;}
+ { (yyval.opval) = newLOGOP(OP_DOR, 0, (yyvsp[-2].opval), (yyvsp[0].opval)); ;}
break;
case 78:
#line 394 "perly.y"
- { yyval.opval = yyvsp[-1].opval; ;}
+ { (yyval.opval) = (yyvsp[-1].opval); ;}
break;
case 79:
#line 396 "perly.y"
- { yyval.opval = append_elem(OP_LIST, yyvsp[-2].opval, yyvsp[0].opval); ;}
+ { (yyval.opval) = append_elem(OP_LIST, (yyvsp[-2].opval), (yyvsp[0].opval)); ;}
break;
case 81:
#line 402 "perly.y"
- { yyval.opval = convert(yyvsp[-2].ival, OPf_STACKED,
- prepend_elem(OP_LIST, newGVREF(yyvsp[-2].ival,yyvsp[-1].opval), yyvsp[0].opval) ); ;}
+ { (yyval.opval) = convert((yyvsp[-2].ival), OPf_STACKED,
+ prepend_elem(OP_LIST, newGVREF((yyvsp[-2].ival),(yyvsp[-1].opval)), (yyvsp[0].opval)) ); ;}
break;
case 82:
#line 405 "perly.y"
- { yyval.opval = convert(yyvsp[-4].ival, OPf_STACKED,
- prepend_elem(OP_LIST, newGVREF(yyvsp[-4].ival,yyvsp[-2].opval), yyvsp[-1].opval) ); ;}
+ { (yyval.opval) = convert((yyvsp[-4].ival), OPf_STACKED,
+ prepend_elem(OP_LIST, newGVREF((yyvsp[-4].ival),(yyvsp[-2].opval)), (yyvsp[-1].opval)) ); ;}
break;
case 83:
#line 408 "perly.y"
- { yyval.opval = convert(OP_ENTERSUB, OPf_STACKED,
+ { (yyval.opval) = convert(OP_ENTERSUB, OPf_STACKED,
append_elem(OP_LIST,
- prepend_elem(OP_LIST, scalar(yyvsp[-5].opval), yyvsp[-1].opval),
- newUNOP(OP_METHOD, 0, yyvsp[-3].opval))); ;}
+ prepend_elem(OP_LIST, scalar((yyvsp[-5].opval)), (yyvsp[-1].opval)),
+ newUNOP(OP_METHOD, 0, (yyvsp[-3].opval)))); ;}
break;
case 84:
#line 413 "perly.y"
- { yyval.opval = convert(OP_ENTERSUB, OPf_STACKED,
- append_elem(OP_LIST, scalar(yyvsp[-2].opval),
- newUNOP(OP_METHOD, 0, yyvsp[0].opval))); ;}
+ { (yyval.opval) = convert(OP_ENTERSUB, OPf_STACKED,
+ append_elem(OP_LIST, scalar((yyvsp[-2].opval)),
+ newUNOP(OP_METHOD, 0, (yyvsp[0].opval)))); ;}
break;
case 85:
#line 417 "perly.y"
- { yyval.opval = convert(OP_ENTERSUB, OPf_STACKED,
+ { (yyval.opval) = convert(OP_ENTERSUB, OPf_STACKED,
append_elem(OP_LIST,
- prepend_elem(OP_LIST, yyvsp[-1].opval, yyvsp[0].opval),
- newUNOP(OP_METHOD, 0, yyvsp[-2].opval))); ;}
+ prepend_elem(OP_LIST, (yyvsp[-1].opval), (yyvsp[0].opval)),
+ newUNOP(OP_METHOD, 0, (yyvsp[-2].opval)))); ;}
break;
case 86:
#line 422 "perly.y"
- { yyval.opval = convert(OP_ENTERSUB, OPf_STACKED,
+ { (yyval.opval) = convert(OP_ENTERSUB, OPf_STACKED,
append_elem(OP_LIST,
- prepend_elem(OP_LIST, yyvsp[-3].opval, yyvsp[-1].opval),
- newUNOP(OP_METHOD, 0, yyvsp[-4].opval))); ;}
+ prepend_elem(OP_LIST, (yyvsp[-3].opval), (yyvsp[-1].opval)),
+ newUNOP(OP_METHOD, 0, (yyvsp[-4].opval)))); ;}
break;
case 87:
#line 427 "perly.y"
- { yyval.opval = convert(yyvsp[-1].ival, 0, yyvsp[0].opval); ;}
+ { (yyval.opval) = convert((yyvsp[-1].ival), 0, (yyvsp[0].opval)); ;}
break;
case 88:
#line 429 "perly.y"
- { yyval.opval = convert(yyvsp[-3].ival, 0, yyvsp[-1].opval); ;}
+ { (yyval.opval) = convert((yyvsp[-3].ival), 0, (yyvsp[-1].opval)); ;}
break;
case 89:
#line 431 "perly.y"
- { yyvsp[0].opval = newANONATTRSUB(yyvsp[-1].ival, 0, Nullop, yyvsp[0].opval); ;}
+ { (yyvsp[0].opval) = newANONATTRSUB((yyvsp[-1].ival), 0, Nullop, (yyvsp[0].opval)); ;}
break;
case 90:
#line 433 "perly.y"
- { yyval.opval = newUNOP(OP_ENTERSUB, OPf_STACKED,
+ { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
append_elem(OP_LIST,
- prepend_elem(OP_LIST, yyvsp[-2].opval, yyvsp[0].opval), yyvsp[-4].opval)); ;}
+ prepend_elem(OP_LIST, (yyvsp[-2].opval), (yyvsp[0].opval)), (yyvsp[-4].opval))); ;}
break;
case 93:
#line 447 "perly.y"
- { yyval.opval = newBINOP(OP_GELEM, 0, yyvsp[-4].opval, scalar(yyvsp[-2].opval));
+ { (yyval.opval) = newBINOP(OP_GELEM, 0, (yyvsp[-4].opval), scalar((yyvsp[-2].opval)));
PL_expect = XOPERATOR; ;}
break;
case 94:
#line 450 "perly.y"
- { yyval.opval = newBINOP(OP_AELEM, 0, oopsAV(yyvsp[-3].opval), scalar(yyvsp[-1].opval)); ;}
+ { (yyval.opval) = newBINOP(OP_AELEM, 0, oopsAV((yyvsp[-3].opval)), scalar((yyvsp[-1].opval))); ;}
break;
case 95:
#line 452 "perly.y"
- { yyval.opval = newBINOP(OP_AELEM, 0,
- ref(newAVREF(yyvsp[-4].opval),OP_RV2AV),
- scalar(yyvsp[-1].opval));;}
+ { (yyval.opval) = newBINOP(OP_AELEM, 0,
+ ref(newAVREF((yyvsp[-4].opval)),OP_RV2AV),
+ scalar((yyvsp[-1].opval)));;}
break;
case 96:
#line 456 "perly.y"
- { yyval.opval = newBINOP(OP_AELEM, 0,
- ref(newAVREF(yyvsp[-3].opval),OP_RV2AV),
- scalar(yyvsp[-1].opval));;}
+ { (yyval.opval) = newBINOP(OP_AELEM, 0,
+ ref(newAVREF((yyvsp[-3].opval)),OP_RV2AV),
+ scalar((yyvsp[-1].opval)));;}
break;
case 97:
#line 460 "perly.y"
- { yyval.opval = newBINOP(OP_HELEM, 0, oopsHV(yyvsp[-4].opval), jmaybe(yyvsp[-2].opval));
+ { (yyval.opval) = newBINOP(OP_HELEM, 0, oopsHV((yyvsp[-4].opval)), jmaybe((yyvsp[-2].opval)));
PL_expect = XOPERATOR; ;}
break;
case 98:
#line 463 "perly.y"
- { yyval.opval = newBINOP(OP_HELEM, 0,
- ref(newHVREF(yyvsp[-5].opval),OP_RV2HV),
- jmaybe(yyvsp[-2].opval));
+ { (yyval.opval) = newBINOP(OP_HELEM, 0,
+ ref(newHVREF((yyvsp[-5].opval)),OP_RV2HV),
+ jmaybe((yyvsp[-2].opval)));
PL_expect = XOPERATOR; ;}
break;
case 99:
#line 468 "perly.y"
- { yyval.opval = newBINOP(OP_HELEM, 0,
- ref(newHVREF(yyvsp[-4].opval),OP_RV2HV),
- jmaybe(yyvsp[-2].opval));
+ { (yyval.opval) = newBINOP(OP_HELEM, 0,
+ ref(newHVREF((yyvsp[-4].opval)),OP_RV2HV),
+ jmaybe((yyvsp[-2].opval)));
PL_expect = XOPERATOR; ;}
break;
case 100:
#line 473 "perly.y"
- { yyval.opval = newUNOP(OP_ENTERSUB, OPf_STACKED,
- newCVREF(0, scalar(yyvsp[-3].opval))); ;}
+ { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
+ newCVREF(0, scalar((yyvsp[-3].opval)))); ;}
break;
case 101:
#line 476 "perly.y"
- { yyval.opval = newUNOP(OP_ENTERSUB, OPf_STACKED,
- append_elem(OP_LIST, yyvsp[-1].opval,
- newCVREF(0, scalar(yyvsp[-4].opval)))); ;}
+ { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
+ append_elem(OP_LIST, (yyvsp[-1].opval),
+ newCVREF(0, scalar((yyvsp[-4].opval))))); ;}
break;
case 102:
#line 481 "perly.y"
- { yyval.opval = newUNOP(OP_ENTERSUB, OPf_STACKED,
- append_elem(OP_LIST, yyvsp[-1].opval,
- newCVREF(0, scalar(yyvsp[-3].opval)))); ;}
+ { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
+ append_elem(OP_LIST, (yyvsp[-1].opval),
+ newCVREF(0, scalar((yyvsp[-3].opval))))); ;}
break;
case 103:
#line 485 "perly.y"
- { yyval.opval = newUNOP(OP_ENTERSUB, OPf_STACKED,
- newCVREF(0, scalar(yyvsp[-2].opval))); ;}
+ { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
+ newCVREF(0, scalar((yyvsp[-2].opval)))); ;}
break;
case 104:
#line 491 "perly.y"
- { yyval.opval = newASSIGNOP(OPf_STACKED, yyvsp[-2].opval, yyvsp[-1].ival, yyvsp[0].opval); ;}
+ { (yyval.opval) = newASSIGNOP(OPf_STACKED, (yyvsp[-2].opval), (yyvsp[-1].ival), (yyvsp[0].opval)); ;}
break;
case 105:
#line 493 "perly.y"
- { yyval.opval = newBINOP(yyvsp[-1].ival, 0, scalar(yyvsp[-2].opval), scalar(yyvsp[0].opval)); ;}
+ { (yyval.opval) = newBINOP((yyvsp[-1].ival), 0, scalar((yyvsp[-2].opval)), scalar((yyvsp[0].opval))); ;}
break;
case 106:
#line 495 "perly.y"
- { if (yyvsp[-1].ival != OP_REPEAT)
- scalar(yyvsp[-2].opval);
- yyval.opval = newBINOP(yyvsp[-1].ival, 0, yyvsp[-2].opval, scalar(yyvsp[0].opval)); ;}
+ { if ((yyvsp[-1].ival) != OP_REPEAT)
+ scalar((yyvsp[-2].opval));
+ (yyval.opval) = newBINOP((yyvsp[-1].ival), 0, (yyvsp[-2].opval), scalar((yyvsp[0].opval))); ;}
break;
case 107:
#line 499 "perly.y"
- { yyval.opval = newBINOP(yyvsp[-1].ival, 0, scalar(yyvsp[-2].opval), scalar(yyvsp[0].opval)); ;}
+ { (yyval.opval) = newBINOP((yyvsp[-1].ival), 0, scalar((yyvsp[-2].opval)), scalar((yyvsp[0].opval))); ;}
break;
case 108:
#line 501 "perly.y"
- { yyval.opval = newBINOP(yyvsp[-1].ival, 0, scalar(yyvsp[-2].opval), scalar(yyvsp[0].opval)); ;}
+ { (yyval.opval) = newBINOP((yyvsp[-1].ival), 0, scalar((yyvsp[-2].opval)), scalar((yyvsp[0].opval))); ;}
break;
case 109:
#line 503 "perly.y"
- { yyval.opval = newBINOP(yyvsp[-1].ival, 0, scalar(yyvsp[-2].opval), scalar(yyvsp[0].opval)); ;}
+ { (yyval.opval) = newBINOP((yyvsp[-1].ival), 0, scalar((yyvsp[-2].opval)), scalar((yyvsp[0].opval))); ;}
break;
case 110:
#line 505 "perly.y"
- { yyval.opval = newBINOP(yyvsp[-1].ival, 0, scalar(yyvsp[-2].opval), scalar(yyvsp[0].opval)); ;}
+ { (yyval.opval) = newBINOP((yyvsp[-1].ival), 0, scalar((yyvsp[-2].opval)), scalar((yyvsp[0].opval))); ;}
break;
case 111:
#line 507 "perly.y"
- { yyval.opval = newBINOP(yyvsp[-1].ival, 0, scalar(yyvsp[-2].opval), scalar(yyvsp[0].opval)); ;}
+ { (yyval.opval) = newBINOP((yyvsp[-1].ival), 0, scalar((yyvsp[-2].opval)), scalar((yyvsp[0].opval))); ;}
break;
case 112:
#line 509 "perly.y"
- { yyval.opval = newBINOP(yyvsp[-1].ival, 0, scalar(yyvsp[-2].opval), scalar(yyvsp[0].opval)); ;}
+ { (yyval.opval) = newBINOP((yyvsp[-1].ival), 0, scalar((yyvsp[-2].opval)), scalar((yyvsp[0].opval))); ;}
break;
case 113:
#line 511 "perly.y"
- { yyval.opval = newRANGE(yyvsp[-1].ival, scalar(yyvsp[-2].opval), scalar(yyvsp[0].opval));;}
+ { (yyval.opval) = newRANGE((yyvsp[-1].ival), scalar((yyvsp[-2].opval)), scalar((yyvsp[0].opval)));;}
break;
case 114:
#line 513 "perly.y"
- { yyval.opval = newLOGOP(OP_AND, 0, yyvsp[-2].opval, yyvsp[0].opval); ;}
+ { (yyval.opval) = newLOGOP(OP_AND, 0, (yyvsp[-2].opval), (yyvsp[0].opval)); ;}
break;
case 115:
#line 515 "perly.y"
- { yyval.opval = newLOGOP(OP_OR, 0, yyvsp[-2].opval, yyvsp[0].opval); ;}
+ { (yyval.opval) = newLOGOP(OP_OR, 0, (yyvsp[-2].opval), (yyvsp[0].opval)); ;}
break;
case 116:
#line 517 "perly.y"
- { yyval.opval = newLOGOP(OP_DOR, 0, yyvsp[-2].opval, yyvsp[0].opval); ;}
+ { (yyval.opval) = newLOGOP(OP_DOR, 0, (yyvsp[-2].opval), (yyvsp[0].opval)); ;}
break;
case 117:
#line 519 "perly.y"
- { yyval.opval = bind_match(yyvsp[-1].ival, yyvsp[-2].opval, yyvsp[0].opval); ;}
+ { (yyval.opval) = bind_match((yyvsp[-1].ival), (yyvsp[-2].opval), (yyvsp[0].opval)); ;}
break;
case 118:
#line 524 "perly.y"
- { yyval.opval = newUNOP(OP_NEGATE, 0, scalar(yyvsp[0].opval)); ;}
+ { (yyval.opval) = newUNOP(OP_NEGATE, 0, scalar((yyvsp[0].opval))); ;}
break;
case 119:
#line 526 "perly.y"
- { yyval.opval = yyvsp[0].opval; ;}
+ { (yyval.opval) = (yyvsp[0].opval); ;}
break;
case 120:
#line 528 "perly.y"
- { yyval.opval = newUNOP(OP_NOT, 0, scalar(yyvsp[0].opval)); ;}
+ { (yyval.opval) = newUNOP(OP_NOT, 0, scalar((yyvsp[0].opval))); ;}
break;
case 121:
#line 530 "perly.y"
- { yyval.opval = newUNOP(OP_COMPLEMENT, 0, scalar(yyvsp[0].opval));;}
+ { (yyval.opval) = newUNOP(OP_COMPLEMENT, 0, scalar((yyvsp[0].opval)));;}
break;
case 122:
#line 532 "perly.y"
- { yyval.opval = newUNOP(OP_POSTINC, 0,
- mod(scalar(yyvsp[-1].opval), OP_POSTINC)); ;}
+ { (yyval.opval) = newUNOP(OP_POSTINC, 0,
+ mod(scalar((yyvsp[-1].opval)), OP_POSTINC)); ;}
break;
case 123:
#line 535 "perly.y"
- { yyval.opval = newUNOP(OP_POSTDEC, 0,
- mod(scalar(yyvsp[-1].opval), OP_POSTDEC)); ;}
+ { (yyval.opval) = newUNOP(OP_POSTDEC, 0,
+ mod(scalar((yyvsp[-1].opval)), OP_POSTDEC)); ;}
break;
case 124:
#line 538 "perly.y"
- { yyval.opval = newUNOP(OP_PREINC, 0,
- mod(scalar(yyvsp[0].opval), OP_PREINC)); ;}
+ { (yyval.opval) = newUNOP(OP_PREINC, 0,
+ mod(scalar((yyvsp[0].opval)), OP_PREINC)); ;}
break;
case 125:
#line 541 "perly.y"
- { yyval.opval = newUNOP(OP_PREDEC, 0,
- mod(scalar(yyvsp[0].opval), OP_PREDEC)); ;}
+ { (yyval.opval) = newUNOP(OP_PREDEC, 0,
+ mod(scalar((yyvsp[0].opval)), OP_PREDEC)); ;}
break;
case 126:
#line 548 "perly.y"
- { yyval.opval = newANONLIST(yyvsp[-1].opval); ;}
+ { (yyval.opval) = newANONLIST((yyvsp[-1].opval)); ;}
break;
case 127:
#line 550 "perly.y"
- { yyval.opval = newANONLIST(Nullop); ;}
+ { (yyval.opval) = newANONLIST(Nullop); ;}
break;
case 128:
#line 552 "perly.y"
- { yyval.opval = newANONHASH(yyvsp[-2].opval); ;}
+ { (yyval.opval) = newANONHASH((yyvsp[-2].opval)); ;}
break;
case 129:
#line 554 "perly.y"
- { yyval.opval = newANONHASH(Nullop); ;}
+ { (yyval.opval) = newANONHASH(Nullop); ;}
break;
case 130:
#line 556 "perly.y"
- { yyval.opval = newANONATTRSUB(yyvsp[-3].ival, yyvsp[-2].opval, yyvsp[-1].opval, yyvsp[0].opval); ;}
+ { (yyval.opval) = newANONATTRSUB((yyvsp[-3].ival), (yyvsp[-2].opval), (yyvsp[-1].opval), (yyvsp[0].opval)); ;}
break;
case 131:
#line 562 "perly.y"
- { yyval.opval = dofile(yyvsp[0].opval); ;}
+ { (yyval.opval) = dofile((yyvsp[0].opval)); ;}
break;
case 132:
#line 564 "perly.y"
- { yyval.opval = newUNOP(OP_NULL, OPf_SPECIAL, scope(yyvsp[0].opval)); ;}
+ { (yyval.opval) = newUNOP(OP_NULL, OPf_SPECIAL, scope((yyvsp[0].opval))); ;}
break;
case 133:
#line 566 "perly.y"
- { yyval.opval = newUNOP(OP_ENTERSUB,
+ { (yyval.opval) = newUNOP(OP_ENTERSUB,
OPf_SPECIAL|OPf_STACKED,
prepend_elem(OP_LIST,
scalar(newCVREF(
(OPpENTERSUB_AMPER<<8),
- scalar(yyvsp[-2].opval)
+ scalar((yyvsp[-2].opval))
)),Nullop)); dep();;}
break;
case 134:
#line 574 "perly.y"
- { yyval.opval = newUNOP(OP_ENTERSUB,
+ { (yyval.opval) = newUNOP(OP_ENTERSUB,
OPf_SPECIAL|OPf_STACKED,
append_elem(OP_LIST,
- yyvsp[-1].opval,
+ (yyvsp[-1].opval),
scalar(newCVREF(
(OPpENTERSUB_AMPER<<8),
- scalar(yyvsp[-3].opval)
+ scalar((yyvsp[-3].opval))
)))); dep();;}
break;
case 135:
#line 583 "perly.y"
- { yyval.opval = newUNOP(OP_ENTERSUB, OPf_SPECIAL|OPf_STACKED,
+ { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_SPECIAL|OPf_STACKED,
prepend_elem(OP_LIST,
- scalar(newCVREF(0,scalar(yyvsp[-2].opval))), Nullop)); dep();;}
+ scalar(newCVREF(0,scalar((yyvsp[-2].opval)))), Nullop)); dep();;}
break;
case 136:
#line 587 "perly.y"
- { yyval.opval = newUNOP(OP_ENTERSUB, OPf_SPECIAL|OPf_STACKED,
+ { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_SPECIAL|OPf_STACKED,
prepend_elem(OP_LIST,
- yyvsp[-1].opval,
- scalar(newCVREF(0,scalar(yyvsp[-3].opval))))); dep();;}
+ (yyvsp[-1].opval),
+ scalar(newCVREF(0,scalar((yyvsp[-3].opval)))))); dep();;}
break;
case 141:
#line 599 "perly.y"
- { yyval.opval = newCONDOP(0, yyvsp[-4].opval, yyvsp[-2].opval, yyvsp[0].opval); ;}
+ { (yyval.opval) = newCONDOP(0, (yyvsp[-4].opval), (yyvsp[-2].opval), (yyvsp[0].opval)); ;}
break;
case 142:
#line 601 "perly.y"
- { yyval.opval = newUNOP(OP_REFGEN, 0, mod(yyvsp[0].opval,OP_REFGEN)); ;}
+ { (yyval.opval) = newUNOP(OP_REFGEN, 0, mod((yyvsp[0].opval),OP_REFGEN)); ;}
break;
case 143:
#line 603 "perly.y"
- { yyval.opval = yyvsp[0].opval; ;}
+ { (yyval.opval) = (yyvsp[0].opval); ;}
break;
case 144:
#line 605 "perly.y"
- { yyval.opval = localize(yyvsp[0].opval,yyvsp[-1].ival); ;}
+ { (yyval.opval) = localize((yyvsp[0].opval),(yyvsp[-1].ival)); ;}
break;
case 145:
#line 607 "perly.y"
- { yyval.opval = sawparens(yyvsp[-1].opval); ;}
+ { (yyval.opval) = sawparens((yyvsp[-1].opval)); ;}
break;
case 146:
#line 609 "perly.y"
- { yyval.opval = sawparens(newNULLLIST()); ;}
+ { (yyval.opval) = sawparens(newNULLLIST()); ;}
break;
case 147:
#line 611 "perly.y"
- { yyval.opval = yyvsp[0].opval; ;}
+ { (yyval.opval) = (yyvsp[0].opval); ;}
break;
case 148:
#line 613 "perly.y"
- { yyval.opval = yyvsp[0].opval; ;}
+ { (yyval.opval) = (yyvsp[0].opval); ;}
break;
case 149:
#line 615 "perly.y"
- { yyval.opval = yyvsp[0].opval; ;}
+ { (yyval.opval) = (yyvsp[0].opval); ;}
break;
case 150:
#line 617 "perly.y"
- { yyval.opval = yyvsp[0].opval; ;}
+ { (yyval.opval) = (yyvsp[0].opval); ;}
break;
case 151:
#line 619 "perly.y"
- { yyval.opval = newUNOP(OP_AV2ARYLEN, 0, ref(yyvsp[0].opval, OP_AV2ARYLEN));;}
+ { (yyval.opval) = newUNOP(OP_AV2ARYLEN, 0, ref((yyvsp[0].opval), OP_AV2ARYLEN));;}
break;
case 152:
#line 621 "perly.y"
- { yyval.opval = yyvsp[0].opval; ;}
+ { (yyval.opval) = (yyvsp[0].opval); ;}
break;
case 153:
#line 623 "perly.y"
- { yyval.opval = newSLICEOP(0, yyvsp[-1].opval, yyvsp[-4].opval); ;}
+ { (yyval.opval) = newSLICEOP(0, (yyvsp[-1].opval), (yyvsp[-4].opval)); ;}
break;
case 154:
#line 625 "perly.y"
- { yyval.opval = newSLICEOP(0, yyvsp[-1].opval, Nullop); ;}
+ { (yyval.opval) = newSLICEOP(0, (yyvsp[-1].opval), Nullop); ;}
break;
case 155:
#line 627 "perly.y"
- { yyval.opval = prepend_elem(OP_ASLICE,
+ { (yyval.opval) = prepend_elem(OP_ASLICE,
newOP(OP_PUSHMARK, 0),
newLISTOP(OP_ASLICE, 0,
- list(yyvsp[-1].opval),
- ref(yyvsp[-3].opval, OP_ASLICE))); ;}
+ list((yyvsp[-1].opval)),
+ ref((yyvsp[-3].opval), OP_ASLICE))); ;}
break;
case 156:
#line 633 "perly.y"
- { yyval.opval = prepend_elem(OP_HSLICE,
+ { (yyval.opval) = prepend_elem(OP_HSLICE,
newOP(OP_PUSHMARK, 0),
newLISTOP(OP_HSLICE, 0,
- list(yyvsp[-2].opval),
- ref(oopsHV(yyvsp[-4].opval), OP_HSLICE)));
+ list((yyvsp[-2].opval)),
+ ref(oopsHV((yyvsp[-4].opval)), OP_HSLICE)));
PL_expect = XOPERATOR; ;}
break;
case 157:
#line 640 "perly.y"
- { yyval.opval = yyvsp[0].opval; ;}
+ { (yyval.opval) = (yyvsp[0].opval); ;}
break;
case 158:
#line 642 "perly.y"
- { yyval.opval = newUNOP(OP_ENTERSUB, 0, scalar(yyvsp[0].opval)); ;}
+ { (yyval.opval) = newUNOP(OP_ENTERSUB, 0, scalar((yyvsp[0].opval))); ;}
break;
case 159:
#line 644 "perly.y"
- { yyval.opval = newUNOP(OP_ENTERSUB, OPf_STACKED, scalar(yyvsp[-2].opval)); ;}
+ { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, scalar((yyvsp[-2].opval))); ;}
break;
case 160:
#line 646 "perly.y"
- { yyval.opval = newUNOP(OP_ENTERSUB, OPf_STACKED,
- append_elem(OP_LIST, yyvsp[-1].opval, scalar(yyvsp[-3].opval))); ;}
+ { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
+ append_elem(OP_LIST, (yyvsp[-1].opval), scalar((yyvsp[-3].opval)))); ;}
break;
case 161:
#line 649 "perly.y"
- { yyval.opval = newUNOP(OP_ENTERSUB, OPf_STACKED,
- append_elem(OP_LIST, yyvsp[0].opval, scalar(yyvsp[-1].opval))); ;}
+ { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
+ append_elem(OP_LIST, (yyvsp[0].opval), scalar((yyvsp[-1].opval)))); ;}
break;
case 162:
#line 652 "perly.y"
- { yyval.opval = newOP(yyvsp[0].ival, OPf_SPECIAL);
+ { (yyval.opval) = newOP((yyvsp[0].ival), OPf_SPECIAL);
PL_hints |= HINT_BLOCK_SCOPE; ;}
break;
case 163:
#line 655 "perly.y"
- { yyval.opval = newLOOPEX(yyvsp[-1].ival,yyvsp[0].opval); ;}
+ { (yyval.opval) = newLOOPEX((yyvsp[-1].ival),(yyvsp[0].opval)); ;}
break;
case 164:
#line 657 "perly.y"
- { yyval.opval = newUNOP(OP_NOT, 0, scalar(yyvsp[0].opval)); ;}
+ { (yyval.opval) = newUNOP(OP_NOT, 0, scalar((yyvsp[0].opval))); ;}
break;
case 165:
#line 659 "perly.y"
- { yyval.opval = newOP(yyvsp[0].ival, 0); ;}
+ { (yyval.opval) = newOP((yyvsp[0].ival), 0); ;}
break;
case 166:
#line 661 "perly.y"
- { yyval.opval = newUNOP(yyvsp[-1].ival, 0, yyvsp[0].opval); ;}
+ { (yyval.opval) = newUNOP((yyvsp[-1].ival), 0, (yyvsp[0].opval)); ;}
break;
case 167:
#line 663 "perly.y"
- { yyval.opval = newUNOP(yyvsp[-1].ival, 0, yyvsp[0].opval); ;}
+ { (yyval.opval) = newUNOP((yyvsp[-1].ival), 0, (yyvsp[0].opval)); ;}
break;
case 168:
#line 665 "perly.y"
- { yyval.opval = newUNOP(OP_ENTERSUB, OPf_STACKED,
- append_elem(OP_LIST, yyvsp[0].opval, scalar(yyvsp[-1].opval))); ;}
+ { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
+ append_elem(OP_LIST, (yyvsp[0].opval), scalar((yyvsp[-1].opval)))); ;}
break;
case 169:
#line 668 "perly.y"
- { yyval.opval = newOP(yyvsp[0].ival, 0); ;}
+ { (yyval.opval) = newOP((yyvsp[0].ival), 0); ;}
break;
case 170:
#line 670 "perly.y"
- { yyval.opval = newOP(yyvsp[-2].ival, 0); ;}
+ { (yyval.opval) = newOP((yyvsp[-2].ival), 0); ;}
break;
case 171:
#line 672 "perly.y"
- { yyval.opval = newUNOP(OP_ENTERSUB, OPf_STACKED,
- scalar(yyvsp[0].opval)); ;}
+ { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
+ scalar((yyvsp[0].opval))); ;}
break;
case 172:
#line 675 "perly.y"
- { yyval.opval = newOP(yyvsp[-2].ival, OPf_SPECIAL); ;}
+ { (yyval.opval) = (yyvsp[-2].ival) == OP_NOT ? newUNOP((yyvsp[-2].ival), 0, newSVOP(OP_CONST, 0, newSViv(0)))
+ : newOP((yyvsp[-2].ival), OPf_SPECIAL); ;}
break;
case 173:
-#line 677 "perly.y"
- { yyval.opval = newUNOP(yyvsp[-3].ival, 0, yyvsp[-1].opval); ;}
+#line 678 "perly.y"
+ { (yyval.opval) = newUNOP((yyvsp[-3].ival), 0, (yyvsp[-1].opval)); ;}
break;
case 174:
-#line 679 "perly.y"
- { yyval.opval = pmruntime(yyvsp[-3].opval, yyvsp[-1].opval, 1); ;}
+#line 680 "perly.y"
+ { (yyval.opval) = pmruntime((yyvsp[-3].opval), (yyvsp[-1].opval), 1); ;}
break;
case 177:
-#line 686 "perly.y"
- { yyval.opval = my_attrs(yyvsp[-1].opval,yyvsp[0].opval); ;}
+#line 687 "perly.y"
+ { (yyval.opval) = my_attrs((yyvsp[-1].opval),(yyvsp[0].opval)); ;}
break;
case 178:
-#line 688 "perly.y"
- { yyval.opval = localize(yyvsp[0].opval,yyvsp[-1].ival); ;}
+#line 689 "perly.y"
+ { (yyval.opval) = localize((yyvsp[0].opval),(yyvsp[-1].ival)); ;}
break;
case 179:
-#line 693 "perly.y"
- { yyval.opval = sawparens(yyvsp[-1].opval); ;}
+#line 694 "perly.y"
+ { (yyval.opval) = sawparens((yyvsp[-1].opval)); ;}
break;
case 180:
-#line 695 "perly.y"
- { yyval.opval = sawparens(newNULLLIST()); ;}
+#line 696 "perly.y"
+ { (yyval.opval) = sawparens(newNULLLIST()); ;}
break;
case 181:
-#line 697 "perly.y"
- { yyval.opval = yyvsp[0].opval; ;}
+#line 698 "perly.y"
+ { (yyval.opval) = (yyvsp[0].opval); ;}
break;
case 182:
-#line 699 "perly.y"
- { yyval.opval = yyvsp[0].opval; ;}
+#line 700 "perly.y"
+ { (yyval.opval) = (yyvsp[0].opval); ;}
break;
case 183:
-#line 701 "perly.y"
- { yyval.opval = yyvsp[0].opval; ;}
+#line 702 "perly.y"
+ { (yyval.opval) = (yyvsp[0].opval); ;}
break;
case 184:
-#line 706 "perly.y"
- { yyval.opval = Nullop; ;}
+#line 707 "perly.y"
+ { (yyval.opval) = Nullop; ;}
break;
case 185:
-#line 708 "perly.y"
- { yyval.opval = yyvsp[0].opval; ;}
+#line 709 "perly.y"
+ { (yyval.opval) = (yyvsp[0].opval); ;}
break;
case 186:
-#line 712 "perly.y"
- { yyval.opval = Nullop; ;}
+#line 713 "perly.y"
+ { (yyval.opval) = Nullop; ;}
break;
case 187:
-#line 714 "perly.y"
- { yyval.opval = yyvsp[0].opval; ;}
+#line 715 "perly.y"
+ { (yyval.opval) = (yyvsp[0].opval); ;}
break;
case 188:
-#line 716 "perly.y"
- { yyval.opval = yyvsp[-1].opval; ;}
+#line 717 "perly.y"
+ { (yyval.opval) = (yyvsp[-1].opval); ;}
break;
case 189:
-#line 722 "perly.y"
- { PL_in_my = 0; yyval.opval = my(yyvsp[0].opval); ;}
+#line 723 "perly.y"
+ { PL_in_my = 0; (yyval.opval) = my((yyvsp[0].opval)); ;}
break;
case 190:
-#line 726 "perly.y"
- { yyval.opval = newCVREF(yyvsp[-1].ival,yyvsp[0].opval); ;}
+#line 727 "perly.y"
+ { (yyval.opval) = newCVREF((yyvsp[-1].ival),(yyvsp[0].opval)); ;}
break;
case 191:
-#line 730 "perly.y"
- { yyval.opval = newSVREF(yyvsp[0].opval); ;}
+#line 731 "perly.y"
+ { (yyval.opval) = newSVREF((yyvsp[0].opval)); ;}
break;
case 192:
-#line 734 "perly.y"
- { yyval.opval = newAVREF(yyvsp[0].opval); ;}
+#line 735 "perly.y"
+ { (yyval.opval) = newAVREF((yyvsp[0].opval)); ;}
break;
case 193:
-#line 738 "perly.y"
- { yyval.opval = newHVREF(yyvsp[0].opval); ;}
+#line 739 "perly.y"
+ { (yyval.opval) = newHVREF((yyvsp[0].opval)); ;}
break;
case 194:
-#line 742 "perly.y"
- { yyval.opval = newAVREF(yyvsp[0].opval); ;}
+#line 743 "perly.y"
+ { (yyval.opval) = newAVREF((yyvsp[0].opval)); ;}
break;
case 195:
-#line 746 "perly.y"
- { yyval.opval = newGVREF(0,yyvsp[0].opval); ;}
+#line 747 "perly.y"
+ { (yyval.opval) = newGVREF(0,(yyvsp[0].opval)); ;}
break;
case 196:
-#line 751 "perly.y"
- { yyval.opval = scalar(yyvsp[0].opval); ;}
+#line 752 "perly.y"
+ { (yyval.opval) = scalar((yyvsp[0].opval)); ;}
break;
case 197:
-#line 753 "perly.y"
- { yyval.opval = scalar(yyvsp[0].opval); ;}
+#line 754 "perly.y"
+ { (yyval.opval) = scalar((yyvsp[0].opval)); ;}
break;
case 198:
-#line 755 "perly.y"
- { yyval.opval = scope(yyvsp[0].opval); ;}
+#line 756 "perly.y"
+ { (yyval.opval) = scope((yyvsp[0].opval)); ;}
break;
case 199:
-#line 758 "perly.y"
- { yyval.opval = yyvsp[0].opval; ;}
+#line 759 "perly.y"
+ { (yyval.opval) = (yyvsp[0].opval); ;}
break;
diff --git a/perly.h b/perly.h
index e92ca95091..32c0f325c8 100644
--- a/perly.h
+++ b/perly.h
@@ -1,8 +1,8 @@
#ifdef PERL_CORE
-/* A Bison parser, made by GNU Bison 1.875. */
+/* A Bison parser, made by GNU Bison 2.0. */
/* Skeleton parser for Yacc-like parsing with Bison,
- Copyright (C) 1984, 1989, 1990, 2000, 2001, 2002 Free Software Foundation, Inc.
+ Copyright (C) 1984, 1989, 1990, 2000, 2001, 2002, 2003, 2004 Free Software Foundation, Inc.
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
@@ -171,8 +171,8 @@ typedef union YYSTYPE {
OP *opval;
GV *gvval;
} YYSTYPE;
-/* Line 1248 of yacc.c. */
-#line 173 "perly.h"
+/* Line 1318 of yacc.c. */
+#line 174 "perly.h"
# define yystype YYSTYPE /* obsolescent; will be withdrawn */
# define YYSTYPE_IS_DECLARED 1
# define YYSTYPE_IS_TRIVIAL 1
diff --git a/perly.tab b/perly.tab
index 1b32b629f6..5e98358db6 100644
--- a/perly.tab
+++ b/perly.tab
@@ -59,7 +59,7 @@ static const unsigned char yytranslate[] =
#if YYDEBUG
/* YYPRHS[YYN] -- Index of the first RHS symbol of rule number YYN in
YYRHS. */
-static const unsigned short yyprhs[] =
+static const unsigned short int yyprhs[] =
{
0, 0, 3, 6, 11, 12, 13, 18, 19, 20,
21, 24, 28, 31, 33, 36, 40, 42, 44, 48,
@@ -84,7 +84,7 @@ static const unsigned short yyprhs[] =
};
/* YYRHS -- A `-1'-separated list of the rules' RHS. */
-static const short yyrhs[] =
+static const short int yyrhs[] =
{
86, 0, -1, 89, 93, -1, 3, 88, 93, 76,
-1, -1, -1, 3, 91, 93, 76, -1, -1, -1,
@@ -159,7 +159,7 @@ static const short yyrhs[] =
};
/* YYRLINE[YYN] -- source line where rule number YYN was defined. */
-static const unsigned short yyrline[] =
+static const unsigned short int yyrline[] =
{
0, 95, 95, 101, 108, 112, 118, 125, 129, 133,
134, 136, 145, 147, 148, 157, 163, 165, 167, 169,
@@ -178,9 +178,9 @@ static const unsigned short yyrline[] =
597, 598, 600, 602, 604, 606, 608, 610, 612, 614,
616, 618, 620, 622, 624, 626, 632, 639, 641, 643,
645, 648, 651, 654, 656, 658, 660, 662, 664, 667,
- 669, 671, 674, 676, 678, 680, 681, 685, 687, 692,
- 694, 696, 698, 700, 705, 707, 712, 713, 715, 721,
- 725, 729, 733, 737, 741, 745, 750, 752, 754, 757
+ 669, 671, 674, 677, 679, 681, 682, 686, 688, 693,
+ 695, 697, 699, 701, 706, 708, 713, 714, 716, 722,
+ 726, 730, 734, 738, 742, 746, 751, 753, 755, 758
};
#endif
@@ -189,26 +189,26 @@ static const unsigned short yyrline[] =
First, the terminals, then, starting at YYNTOKENS, nonterminals. */
static const char *const yytname[] =
{
- "$end", "error", "$undefined", "'{'", "WORD", "METHOD", "FUNCMETH",
- "THING", "PMFUNC", "PRIVATEREF", "FUNC0SUB", "UNIOPSUB", "LSTOPSUB",
- "LABEL", "FORMAT", "SUB", "ANONSUB", "PACKAGE", "USE", "WHILE", "UNTIL",
- "IF", "UNLESS", "ELSE", "ELSIF", "CONTINUE", "FOR", "LOOPEX", "DOTDOT",
- "FUNC0", "FUNC1", "FUNC", "UNIOP", "LSTOP", "RELOP", "EQOP", "MULOP",
- "ADDOP", "DOLSHARP", "DO", "HASHBRACK", "NOAMP", "LOCAL", "MY", "MYSUB",
- "COLONATTR", "'&'", "PREC_LOW", "DOROP", "OROP", "ANDOP", "NOTOP",
- "','", "ASSIGNOP", "'?'", "':'", "DORDOR", "OROR", "ANDAND", "BITOROP",
- "BITANDOP", "SHIFTOP", "MATCHOP", "'!'", "'~'", "REFGEN", "UMINUS",
- "POWOP", "POSTDEC", "POSTINC", "PREDEC", "PREINC", "ARROW", "')'",
- "'('", "'['", "'}'", "';'", "']'", "'-'", "'+'", "'$'", "'@'", "'%'",
- "'*'", "$accept", "prog", "block", "remember", "progstart", "mblock",
- "mremember", "savescope", "lineseq", "line", "sideff", "else", "cond",
- "cont", "loop", "nexpr", "texpr", "iexpr", "mexpr", "mnexpr", "mtexpr",
- "miexpr", "label", "decl", "format", "formname", "mysubrout", "subrout",
- "startsub", "startanonsub", "startformsub", "subname", "proto",
- "subattrlist", "myattrlist", "subbody", "package", "use", "@1", "expr",
- "argexpr", "listop", "@2", "method", "subscripted", "termbinop",
- "termunop", "anonymous", "termdo", "term", "myattrterm", "myterm",
- "listexpr", "listexprcom", "my_scalar", "amper", "scalar", "ary", "hsh",
+ "$end", "error", "$undefined", "'{'", "WORD", "METHOD", "FUNCMETH",
+ "THING", "PMFUNC", "PRIVATEREF", "FUNC0SUB", "UNIOPSUB", "LSTOPSUB",
+ "LABEL", "FORMAT", "SUB", "ANONSUB", "PACKAGE", "USE", "WHILE", "UNTIL",
+ "IF", "UNLESS", "ELSE", "ELSIF", "CONTINUE", "FOR", "LOOPEX", "DOTDOT",
+ "FUNC0", "FUNC1", "FUNC", "UNIOP", "LSTOP", "RELOP", "EQOP", "MULOP",
+ "ADDOP", "DOLSHARP", "DO", "HASHBRACK", "NOAMP", "LOCAL", "MY", "MYSUB",
+ "COLONATTR", "'&'", "PREC_LOW", "DOROP", "OROP", "ANDOP", "NOTOP", "','",
+ "ASSIGNOP", "'?'", "':'", "DORDOR", "OROR", "ANDAND", "BITOROP",
+ "BITANDOP", "SHIFTOP", "MATCHOP", "'!'", "'~'", "REFGEN", "UMINUS",
+ "POWOP", "POSTDEC", "POSTINC", "PREDEC", "PREINC", "ARROW", "')'", "'('",
+ "'['", "'}'", "';'", "']'", "'-'", "'+'", "'$'", "'@'", "'%'", "'*'",
+ "$accept", "prog", "block", "remember", "progstart", "mblock",
+ "mremember", "savescope", "lineseq", "line", "sideff", "else", "cond",
+ "cont", "loop", "nexpr", "texpr", "iexpr", "mexpr", "mnexpr", "mtexpr",
+ "miexpr", "label", "decl", "format", "formname", "mysubrout", "subrout",
+ "startsub", "startanonsub", "startformsub", "subname", "proto",
+ "subattrlist", "myattrlist", "subbody", "package", "use", "@1", "expr",
+ "argexpr", "listop", "@2", "method", "subscripted", "termbinop",
+ "termunop", "anonymous", "termdo", "term", "myattrterm", "myterm",
+ "listexpr", "listexprcom", "my_scalar", "amper", "scalar", "ary", "hsh",
"arylen", "star", "indirob", 0
};
#endif
@@ -216,7 +216,7 @@ static const char *const yytname[] =
# ifdef YYPRINT
/* YYTOKNUM[YYLEX-NUM] -- Internal token number corresponding to
token YYLEX-NUM. */
-static const unsigned short yytoknum[] =
+static const unsigned short int yytoknum[] =
{
0, 256, 257, 123, 258, 259, 260, 261, 262, 263,
264, 265, 266, 267, 268, 269, 270, 271, 272, 273,
@@ -328,7 +328,7 @@ static const unsigned char yydefact[] =
};
/* YYDEFGOTO[NTERM-NUM]. */
-static const short yydefgoto[] =
+static const short int yydefgoto[] =
{
-1, 1, 104, 101, 2, 361, 372, 10, 4, 23,
300, 377, 79, 162, 24, 301, 290, 293, 295, 303,
@@ -342,7 +342,7 @@ static const short yydefgoto[] =
/* YYPACT[STATE-NUM] -- Index in YYTABLE of the portion describing
STATE-NUM. */
#define YYPACT_NINF -343
-static const short yypact[] =
+static const short int yypact[] =
{
-343, 9, -343, -343, 147, -343, -343, 8, -343, -343,
7, -343, -343, -343, -343, -343, -343, 19, 52, -8,
@@ -387,7 +387,7 @@ static const short yypact[] =
};
/* YYPGOTO[NTERM-NUM]. */
-static const short yypgoto[] =
+static const short int yypgoto[] =
{
-343, -343, -23, -98, -343, 22, -343, -343, -100, -343,
305, -342, -343, -112, -343, -343, -343, 194, -210, -36,
@@ -403,7 +403,7 @@ static const short yypgoto[] =
number is the opposite. If zero, do what YYDEFACT says.
If YYTABLE_NINF, syntax error. */
#define YYTABLE_NINF -176
-static const short yytable[] =
+static const short int yytable[] =
{
80, 204, 77, 126, 96, 302, 286, 205, 203, 3,
100, 145, 19, 195, 210, 211, 212, 213, 214, 215,
@@ -602,7 +602,7 @@ static const short yytable[] =
0, 0, 0, 190, 191, 192, 0, 0, 193
};
-static const short yycheck[] =
+static const short int yycheck[] =
{
25, 101, 25, 54, 27, 215, 206, 106, 100, 0,
32, 62, 4, 3, 112, 113, 114, 115, 116, 117,
diff --git a/perly.y b/perly.y
index 73e36ab29d..2d989b3a30 100644
--- a/perly.y
+++ b/perly.y
@@ -672,7 +672,8 @@ term : termbinop
{ $$ = newUNOP(OP_ENTERSUB, OPf_STACKED,
scalar($1)); }
| FUNC1 '(' ')' /* not () */
- { $$ = newOP($1, OPf_SPECIAL); }
+ { $$ = $1 == OP_NOT ? newUNOP($1, 0, newSVOP(OP_CONST, 0, newSViv(0)))
+ : newOP($1, OPf_SPECIAL); }
| FUNC1 '(' expr ')' /* not($foo) */
{ $$ = newUNOP($1, 0, $3); }
| PMFUNC '(' argexpr ')' /* m//, s///, tr/// */
diff --git a/t/op/not.t b/t/op/not.t
new file mode 100644
index 0000000000..5ff65beaa1
--- /dev/null
+++ b/t/op/not.t
@@ -0,0 +1,13 @@
+#!./perl -w
+
+BEGIN {
+ chdir 't' if -d 't';
+ @INC = '../lib';
+ require './test.pl';
+}
+
+plan tests => 3;
+
+pass() if not();
+is(not(), 1);
+is(not(), not(0));