summaryrefslogtreecommitdiff
path: root/op.h
diff options
context:
space:
mode:
authorNicholas Clark <nick@ccl4.org>2008-01-11 12:14:04 +0000
committerNicholas Clark <nick@ccl4.org>2008-01-11 12:14:04 +0000
commit14a49a2428492a7a120f0254ff8085e99252f641 (patch)
tree32e1575fa0e68d4c2eb45dc0c44f5e6e312c862a /op.h
parentccb2c8b8ab146edc148e377cd6b108da77d1320b (diff)
downloadperl-14a49a2428492a7a120f0254ff8085e99252f641.tar.gz
REGEXPs are now stored directly in PL_regex_padav, rather than
indirectly via RVs. This saves memory, and removes 1 level of pointer indirection. p4raw-id: //depot/perl@32950
Diffstat (limited to 'op.h')
-rw-r--r--op.h30
1 files changed, 11 insertions, 19 deletions
diff --git a/op.h b/op.h
index 2bb042bfa0..dc36c01806 100644
--- a/op.h
+++ b/op.h
@@ -329,29 +329,21 @@ struct pmop {
};
#ifdef USE_ITHREADS
-#define PM_GETRE(o) (SvROK(PL_regex_pad[(o)->op_pmoffset]) ? \
- (REGEXP*)SvRV(PL_regex_pad[(o)->op_pmoffset]) : NULL)
+#define PM_GETRE(o) (SvTYPE(PL_regex_pad[(o)->op_pmoffset]) == SVt_REGEXP \
+ ? (REGEXP*)(PL_regex_pad[(o)->op_pmoffset]) : NULL)
/* The assignment is just to enforce type safety (or at least get a warning).
*/
+/* With first class regexps not via a reference one needs to assign
+ &PL_sv_undef under ithreads. (This would probably work unthreaded, but NULL
+ is cheaper. I guess we could allow NULL, but the check above would get
+ more complex, and we'd have an AV with (SV*)NULL in it, which feels bad */
+/* BEWARE - something that calls this macro passes (r) which has a side
+ effect. */
#define PM_SETRE(o,r) STMT_START { \
- const REGEXP *const slosh = (r); \
- SV *const whap = PL_regex_pad[(o)->op_pmoffset]; \
- SvIOK_off(whap); \
- SvROK_on(whap); \
- SvRV_set(whap, (SV*)slosh); \
+ const REGEXP *const whap = (r); \
+ assert(whap); \
+ PL_regex_pad[(o)->op_pmoffset] = (SV*)whap; \
} STMT_END
-/* Actually you can assign any IV, not just an offset. And really should it be
- UV? */
-/* Need to turn the SvOK off as the regexp code is quite carefully manually
- reference counting the thing pointed to, so don't want sv_setiv also
- deciding to clear a reference count because it sees an SV. */
-#define PM_SETRE_OFFSET(o,iv) \
- STMT_START { \
- SV* const sv = PL_regex_pad[(o)->op_pmoffset]; \
- SvROK_off(sv); \
- sv_setiv(sv, (iv)); \
- } STMT_END
-
# ifndef PERL_CORE
/* No longer used anywhere in the core. Migrate to Devel::PPPort? */
#define PM_GETRE_SAFE(o) (PL_regex_pad ? PM_GETRE(o) : (REGEXP*)0)