X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=Magic.xs;h=c2d8f6542f5c4af09941fd04f4aea404502d5728;hb=135abb4d38a3a9eab3a7e6d6cde33aafd62488c2;hp=858c80fcb3c831bebe0d1f0c70b9241f7b45a771;hpb=bf4c4354fb3bdfdd4d33501318ba3bdd382469c8;p=perl%2Fmodules%2FVariable-Magic.git diff --git a/Magic.xs b/Magic.xs index 858c80f..c2d8f65 100644 --- a/Magic.xs +++ b/Magic.xs @@ -812,6 +812,9 @@ STATIC int vmg_svt_clear(pTHX_ SV *sv, MAGIC *mg) { STATIC int vmg_svt_free(pTHX_ SV *sv, MAGIC *mg) { const MGWIZ *w; +#if VMG_HAS_PERL(5, 10, 0) + PERL_CONTEXT saved_cx; +#endif unsigned int had_err, has_err, flags = G_SCALAR | G_EVAL; int ret = 0; @@ -849,8 +852,21 @@ STATIC int vmg_svt_free(pTHX_ SV *sv, MAGIC *mg) { if (had_err) flags |= G_KEEPERR; +#if VMG_HAS_PERL(5, 10, 0) + /* This context should not be used anymore, but since we croak in places the + * core doesn't even dare to, some pointers to it may remain in the upper call + * stack. Make sure call_sv() doesn't clobber it. */ + if (cxstack_ix >= cxstack_max) + Perl_cxinc(aTHX); + saved_cx = cxstack[cxstack_ix + 1]; +#endif + call_sv(w->cb_free, flags); +#if VMG_HAS_PERL(5, 10, 0) + cxstack[cxstack_ix + 1] = saved_cx; +#endif + has_err = SvTRUE(ERRSV); if (IN_PERL_COMPILETIME && !had_err && has_err) ++PL_error_count; @@ -863,7 +879,10 @@ STATIC int vmg_svt_free(pTHX_ SV *sv, MAGIC *mg) { if (has_err) { /* Get the eval context that was pushed by call_sv, and fake an entry for the * namesv, as die_where will need it to be non NULL later */ - PERL_CONTEXT *cx = cxstack + cxstack_ix + 1; + PERL_CONTEXT *cx; + if (cxstack_ix >= cxstack_max) + Perl_cxinc(aTHX); + cx = cxstack + cxstack_ix + 1; if (!cx->blk_eval.old_namesv) cx->blk_eval.old_namesv = sv_2mortal(newSVpvn_share("Variable/Magic/DUMMY.pm", 23, 0));