summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorFather Chrysostomos <sprout@cpan.org>2011-06-16 14:51:33 -0700
committerFather Chrysostomos <sprout@cpan.org>2011-06-16 20:17:20 -0700
commit16eb5365105fd7ab1815c325059d04765892205f (patch)
treedce37d999210eb8d946f0d46491b791451815226
parent4263b84253eeb432b36ff8248a4d601c34af5736 (diff)
downloadperl-16eb5365105fd7ab1815c325059d04765892205f.tar.gz
Revert "pos in lvalue context now returns a PVMG instead of a PVLV."
This reverts commit 571f0e8653a532c34edde36e797ecba446978b1c. I’m afraid I have to revert this, as it does not modify sv_reftype accordingly, and doing so would add *more* complexity (the opposite of what that commit was trying to achieve) and slow down ref() at run time, by making it search for pos magic.
-rw-r--r--mg.c6
-rw-r--r--pod/perldelta.pod5
-rw-r--r--pp.c6
3 files changed, 8 insertions, 9 deletions
diff --git a/mg.c b/mg.c
index 64c7d2085f..1bdf5c4cda 100644
--- a/mg.c
+++ b/mg.c
@@ -2064,9 +2064,10 @@ int
Perl_magic_getpos(pTHX_ SV *sv, MAGIC *mg)
{
dVAR;
- SV *const lsv = mg->mg_obj;
+ SV* const lsv = LvTARG(sv);
PERL_ARGS_ASSERT_MAGIC_GETPOS;
+ PERL_UNUSED_ARG(mg);
if (SvTYPE(lsv) >= SVt_PVMG && SvMAGIC(lsv)) {
MAGIC * const found = mg_find(lsv, PERL_MAGIC_regex_global);
@@ -2086,13 +2087,14 @@ int
Perl_magic_setpos(pTHX_ SV *sv, MAGIC *mg)
{
dVAR;
- SV *const lsv = mg->mg_obj;
+ SV* const lsv = LvTARG(sv);
SSize_t pos;
STRLEN len;
STRLEN ulen = 0;
MAGIC* found;
PERL_ARGS_ASSERT_MAGIC_SETPOS;
+ PERL_UNUSED_ARG(mg);
if (SvTYPE(lsv) >= SVt_PVMG && SvMAGIC(lsv))
found = mg_find(lsv, PERL_MAGIC_regex_global);
diff --git a/pod/perldelta.pod b/pod/perldelta.pod
index a70e6a6cee..cbb1bfc7b3 100644
--- a/pod/perldelta.pod
+++ b/pod/perldelta.pod
@@ -867,11 +867,6 @@ last place where the core stores data beyond SvLEN().
=item *
-C<pos> in lvalue context now returns a PVMG instead of a PVLV, storing the
-target SV in C<mg_obj>, instead of C<LvTARG()>.
-
-=item *
-
Simplified logic in C<Perl_sv_magic()> introduces a small change of
behaviour for error cases involving unknown magic types. Previously, if
C<Perl_sv_magic()> was passed a magic type unknown to it, it would
diff --git a/pp.c b/pp.c
index f87e0dd3a4..385f1beef1 100644
--- a/pp.c
+++ b/pp.c
@@ -361,8 +361,10 @@ PP(pp_pos)
dVAR; dSP; dPOPss;
if (PL_op->op_flags & OPf_MOD || LVRET) {
- SV * const ret = sv_2mortal(newSV_type(SVt_PVMG)); /* Not TARG RT#67838 */
- sv_magic(ret, sv, PERL_MAGIC_pos, NULL, 0);
+ SV * const ret = sv_2mortal(newSV_type(SVt_PVLV)); /* Not TARG RT#67838 */
+ sv_magic(ret, NULL, PERL_MAGIC_pos, NULL, 0);
+ LvTYPE(ret) = '.';
+ LvTARG(ret) = SvREFCNT_inc_simple(sv);
PUSHs(ret); /* no SvSETMAGIC */
RETURN;
}