Retract #11712 for now. The real fix would probably
Jarkko Hietaniemi [Sat, 18 Aug 2001 06:03:24 +0000 (06:03 +0000)]
be something like making PL_reg_sv a copy (PV + UTF8)
of the matched/substituted string (note: not just a SvPOK
string, for example the stringified form of a ROK would
be applicable)  Beware of leaks.

p4raw-id: //depot/perl@11714

pp_hot.c
t/op/pat.t

index c0c6fe8..0f4a693 100644 (file)
--- a/pp_hot.c
+++ b/pp_hot.c
@@ -1222,7 +1222,7 @@ PP(pp_match)
        TARG = DEFSV;
        EXTEND(SP,1);
     }
-    PL_reg_sv = SvREFCNT_inc(TARG);
+    PL_reg_sv = TARG;
     PUTBACK;                           /* EVAL blocks need stack_sp. */
     s = SvPV(TARG, len);
     strend = s + len;
@@ -1909,7 +1909,7 @@ PP(pp_subst)
        TARG = DEFSV;
        EXTEND(SP,1);
     }
-    PL_reg_sv = SvREFCNT_inc(TARG);
+    PL_reg_sv = TARG;
     do_utf8 = DO_UTF8(PL_reg_sv);
     if (SvFAKE(TARG) && SvREADONLY(TARG))
        sv_force_normal(TARG);
index 478e299..d2d3205 100755 (executable)
@@ -6,7 +6,7 @@
 
 $| = 1;
 
-print "1..686\n";
+print "1..684\n";
 
 BEGIN {
     chdir 't' if -d 't';
@@ -1987,22 +1987,3 @@ print "ok 683\n" if @a == 9 && "@a" eq "f o o \n $a $b b a r";
     $c = pos;
     print "$a $b $c" eq 'ba:ba ad:ae 10' ? "ok 684\n" : "not ok 684\t# $a $b $c\n";
 }
-
-{
-    package ID_20010407_006;
-
-    sub x {
-       "a\x{1234}";
-    }
-
-    my $x = x;
-    my $y;
-
-    $x =~ /(..)/; $y = $1;
-    print "not " unless length($y) == 2 && $y eq $x;
-    print "ok 685\n" if length($y) == 2;
-
-    x  =~ /(..)/; $y = $1;
-    print "not " unless length($y) == 2 && $y eq $x;
-    print "ok 686\n";
-}