From: David Mitchell Date: Wed, 20 Jul 2011 13:39:20 +0000 (+0100) Subject: make assign to $^A update FmLINES X-Git-Tag: accepted/trunk/20130322.191538~3249 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=64eff8b72e154607aa99f7713bd4d05c443be47f;p=platform%2Fupstream%2Fperl.git make assign to $^A update FmLINES Currently assigning to $^A updates the string in PL_bodytarget, but doesn't update FmLINES(PL_bodytarget). This can cause later writes to get confused about how many lines have been output, and was causing write.t to fail test 418 under miniperl. (Only under miniperl, because skipping some tests under miniperl affected how $^A's content and line count got messed up). Fix this by updating FmLINES(PL_bodytarget) when $^A is set. (Also fixes a TODO test which was failing due to 'local $^A' in earlier tests) --- diff --git a/mg.c b/mg.c index 036ac80..c07c78b 100644 --- a/mg.c +++ b/mg.c @@ -2483,6 +2483,14 @@ Perl_magic_set(pTHX_ SV *sv, MAGIC *mg) break; case '\001': /* ^A */ sv_setsv(PL_bodytarget, sv); + FmLINES(PL_bodytarget) = 0; + if (SvPOK(PL_bodytarget)) { + char *s = SvPVX(PL_bodytarget); + while ( ((s = strchr(s, '\n'))) ) { + FmLINES(PL_bodytarget)++; + s++; + } + } /* mg_set() has temporarily made sv non-magical */ if (PL_tainting) { if ((tmg = mg_find(sv,PERL_MAGIC_taint)) && tmg->mg_len & 1) diff --git a/t/op/write.t b/t/op/write.t index d30c9d7..8be0b41 100644 --- a/t/op/write.t +++ b/t/op/write.t @@ -61,7 +61,7 @@ for my $tref ( @NumTests ){ my $bas_tests = 20; # number of tests in section 3 -my $bug_tests = 4 + 3 * 3 * 5 * 2 * 3 + 2 + 66 + 4 + 2 + 1 + 1; +my $bug_tests = 4 + 3 * 3 * 5 * 2 * 3 + 2 + 66 + 4 + 2 + 3; # number of tests in section 4 my $hmb_tests = 35; @@ -593,7 +593,7 @@ $test . -# [ID 20020227.005] format bug with undefined _TOP +# RT #8698 format bug with undefined _TOP open STDOUT_DUP, ">&STDOUT"; my $oldfh = select STDOUT_DUP; @@ -602,10 +602,7 @@ $= = 10; local $~ = "Comment"; write; curr_test($test + 1); - { - local $::TODO = '[ID 20020227.005] format bug with undefined _TOP'; - is $-, 9; - } + is $-, 9; is $^, "STDOUT_DUP_TOP"; } select $oldfh; @@ -735,6 +732,33 @@ SKIP: { is $buf, "ok $test\n", "write to duplicated format"; } +format caret_A_test_TOP = +T +. + +format caret_A_test = +L1 +L2 +L3 +L4 +. + +SKIP: { + skip_if_miniperl('miniperl does not support scalario'); + my $buf = ""; + open my $fh, ">", \$buf; + my $old_fh = select $fh; + local $^ = "caret_A_test_TOP"; + local $~ = "caret_A_test"; + local $= = 3; + local $^A = "A1\nA2\nA3\nA4\n"; + write; + select $old_fh; + close $fh; + is $buf, "T\nA1\nA2\n\fT\nA3\nA4\n\fT\nL1\nL2\n\fT\nL3\nL4\n", + "assign to ^A sets FmLINES"; +} + fresh_perl_like(<<'EOP', qr/^Format STDOUT redefined at/, {stderr => 1}, '#64562 - Segmentation fault with redefined formats and warnings'); #!./perl