summaryrefslogtreecommitdiff
path: root/cop.h
diff options
context:
space:
mode:
authorDavid Mitchell <davem@iabyn.com>2015-12-26 11:52:33 +0000
committerDavid Mitchell <davem@iabyn.com>2016-02-03 09:19:18 +0000
commit40ba680a17dc8d6a78964c98884ac1cb18695d8a (patch)
tree10e8255c9cc84dae2fabf155921bffe061bd7c79 /cop.h
parentfd9b7244731b18bb1794c4ff6540e4040e51879b (diff)
downloadperl-40ba680a17dc8d6a78964c98884ac1cb18695d8a.tar.gz
PUSHSUB: don't use implicit args
Make cv and hasargs explicit parameters of PUSHSUB(), rather than just assuming that there are such vars in scope.
Diffstat (limited to 'cop.h')
-rw-r--r--cop.h14
1 files changed, 7 insertions, 7 deletions
diff --git a/cop.h b/cop.h
index 1fa485eb73..e2d85c1a60 100644
--- a/cop.h
+++ b/cop.h
@@ -595,7 +595,7 @@ struct block_format {
* The context frame holds a reference to the CV so that it can't be
* freed while we're executing it */
-#define PUSHSUB_BASE(cx) \
+#define PUSHSUB_BASE(cx, cv, hasargs) \
ENTRY_PROBE(CvNAMED(cv) \
? HEK_KEY(CvNAME_HEK(cv)) \
: GvENAME(CvGV(cv)), \
@@ -620,17 +620,17 @@ struct block_format {
? 0 : (U8)func(aTHX) \
)
-#define PUSHSUB(cx) \
+#define PUSHSUB(cx, cv, hasargs) \
{ \
U8 phlags = PUSHSUB_GET_LVALUE_MASK(Perl_was_lvalue_sub); \
- PUSHSUB_BASE(cx) \
+ PUSHSUB_BASE(cx, cv, hasargs) \
cx->blk_u16 = PL_op->op_private & \
(phlags|OPpDEREF); \
}
/* variant for use by OP_DBSTATE, where op_private holds hint bits */
-#define PUSHSUB_DB(cx) \
- PUSHSUB_BASE(cx) \
+#define PUSHSUB_DB(cx, cv, hasargs) \
+ PUSHSUB_BASE(cx, cv, hasargs) \
cx->blk_u16 = 0;
@@ -1345,7 +1345,7 @@ See L<perlcall/LIGHTWEIGHT CALLBACKS>.
PUSHSTACKi(PERLSI_MULTICALL); \
PUSHBLOCK(cx, (CXt_SUB|CXp_MULTICALL|flags), gimme, \
PL_stack_sp, PL_savestack_ix); \
- PUSHSUB(cx); \
+ PUSHSUB(cx, cv, hasargs); \
SAVEOP(); \
saveix_floor = PL_savestack_ix; \
if (!(flags & CXp_SUB_RE_FAKE)) \
@@ -1394,7 +1394,7 @@ See L<perlcall/LIGHTWEIGHT CALLBACKS>.
assert(CxMULTICALL(cx)); \
CX_POPSUB_COMMON(cx); \
cx->cx_type = (CXt_SUB|CXp_MULTICALL|flags); \
- PUSHSUB(cx); \
+ PUSHSUB(cx, cv, hasargs); \
if (!(flags & CXp_SUB_RE_FAKE)) \
CvDEPTH(cv)++; \
if (CvDEPTH(cv) >= 2) \