summaryrefslogtreecommitdiff
path: root/toke.c
diff options
context:
space:
mode:
authorNicholas Clark <nick@ccl4.org>2007-04-06 21:53:46 +0000
committerNicholas Clark <nick@ccl4.org>2007-04-06 21:53:46 +0000
commitad639bfb68f3fce4864d833950ed2ff9dd1cb28d (patch)
tree0f94b8b59215fe8d987ae34bd2793fcc3961cadd /toke.c
parentbfd0ff222f043bea86c0b0e7700eeab47f675d46 (diff)
downloadperl-ad639bfb68f3fce4864d833950ed2ff9dd1cb28d.tar.gz
Only append ?? match ops to the list used by reset. This saves memory
and time. p4raw-id: //depot/perl@30857
Diffstat (limited to 'toke.c')
-rw-r--r--toke.c22
1 files changed, 21 insertions, 1 deletions
diff --git a/toke.c b/toke.c
index 5a79dcd91e..0485df18f9 100644
--- a/toke.c
+++ b/toke.c
@@ -10841,8 +10841,28 @@ S_scan_pat(pTHX_ char *start, I32 type)
}
pm = (PMOP*)newPMOP(type, 0);
- if (PL_multi_open == '?')
+ if (PL_multi_open == '?') {
+ /* This is the only point in the code that sets PMf_ONCE: */
pm->op_pmflags |= PMf_ONCE;
+
+ /* Hence it's safe to do this bit of PMOP book-keeping here, which
+ allows us to restrict the list needed by reset to just the ??
+ matches. */
+ assert(type != OP_TRANS);
+ if (PL_curstash) {
+ MAGIC *mg = mg_find((SV*)PL_curstash, PERL_MAGIC_symtab);
+ U32 elements;
+ if (!mg) {
+ mg = sv_magicext((SV*)PL_curstash, 0, PERL_MAGIC_symtab, 0, 0,
+ 0);
+ }
+ elements = mg->mg_len / sizeof(PMOP**);
+ Renewc(mg->mg_ptr, elements + 1, PMOP*, char);
+ ((PMOP**)mg->mg_ptr) [elements++] = pm;
+ mg->mg_len = elements * sizeof(PMOP**);
+ PmopSTASH_set(pm,PL_curstash);
+ }
+ }
#ifdef PERL_MAD
modstart = s;
#endif