summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPeter Martini <PeterCMartini@GMail.com>2013-03-03 00:09:58 +0000
committerDavid Mitchell <davem@iabyn.com>2013-03-03 00:25:13 +0000
commit89e006ae4e39db68ad35c878eb6e6de83ebd8ec9 (patch)
tree0b1dd9aff102daa5cbff60b5fad1d8a0ab848bdd
parenta429ddf7a2c14de7caaf9248c6a79212167468f9 (diff)
downloadperl-89e006ae4e39db68ad35c878eb6e6de83ebd8ec9.tar.gz
Stop SEGV on 'our sub { syntax error }'
Fix for RT #116981. If a sub is declared with our, the name is added to the stash early, and left with a NULL ptr if there's a syntax error while compiling it. Since the only time it becomes an issue is when that same name is used in the same scope after a syntax error, what happens in the pad is not particularly important. The simple fix is to simply fall back to treating it like a bareword, and pretending it was never added to the pad in the first place.
-rw-r--r--t/cmd/lexsub.t15
-rw-r--r--toke.c5
2 files changed, 19 insertions, 1 deletions
diff --git a/t/cmd/lexsub.t b/t/cmd/lexsub.t
index 86c7e26a14..46bab038fd 100644
--- a/t/cmd/lexsub.t
+++ b/t/cmd/lexsub.t
@@ -8,7 +8,7 @@ BEGIN {
*bar::like = *like;
}
no warnings 'deprecated';
-plan 128;
+BEGIN{plan 133;}
# -------------------- Errors with feature disabled -------------------- #
@@ -95,6 +95,19 @@ sub bar::c { 43 }
my $y = if if if;
is $y, 42, 'our subs from other packages override all keywords';
}
+# Make sure errors don't pollute the stash (see RT 116981)
+{
+ eval "our sub ln99{!} ln99(1)";
+ eval "ln99(1)";
+ like $@, "Undefined subroutine &main::ln99 called", "Bad definitions do not pollute the stash";
+ isnt $::{ln99}, -1, "No placeholder was entered";
+ our sub ln103;
+ is $::{ln103}, -1, "Placeholder was entered";
+ eval "our sub ln103{!} ln103(1)";
+ eval "ln103(1)";
+ like $@, "Undefined subroutine &main::ln103 called", "Bad definitions do not pollute the stash";
+ isnt $::{ln103}, -1, "Placeholder was removed";
+}
# -------------------- state -------------------- #
diff --git a/toke.c b/toke.c
index aace60b720..006f885288 100644
--- a/toke.c
+++ b/toke.c
@@ -6900,6 +6900,11 @@ Perl_yylex(pTHX)
gv = gv_fetchsv(sv, GV_NOADD_NOINIT | SvUTF8(sv),
SVt_PVCV);
off = 0;
+ if (!gv) {
+ sv_free(sv);
+ sv = NULL;
+ goto just_a_word;
+ }
}
else {
rv2cv_op = newOP(OP_PADANY, 0);