diff options
author | Nicholas Clark <nick@ccl4.org> | 2011-03-08 17:33:39 +0000 |
---|---|---|
committer | Nicholas Clark <nick@ccl4.org> | 2011-03-08 17:33:39 +0000 |
commit | 4b5ae309d8932eb959b5fc621604614358181bc9 (patch) | |
tree | e7642f4b976009cdcc21a5f4a6c1d19052406d38 | |
parent | f8088870d3cebbc655e7ab8ab4e3f997db4e0fbe (diff) | |
download | perl-4b5ae309d8932eb959b5fc621604614358181bc9.tar.gz |
In Tie::Hash::NamedCapture move the tie of %+ and %- from perl to XS.
-rw-r--r-- | ext/Tie-Hash-NamedCapture/NamedCapture.pm | 9 | ||||
-rw-r--r-- | ext/Tie-Hash-NamedCapture/NamedCapture.xs | 18 |
2 files changed, 19 insertions, 8 deletions
diff --git a/ext/Tie-Hash-NamedCapture/NamedCapture.pm b/ext/Tie-Hash-NamedCapture/NamedCapture.pm index db86908a49..932e4404d1 100644 --- a/ext/Tie-Hash-NamedCapture/NamedCapture.pm +++ b/ext/Tie-Hash-NamedCapture/NamedCapture.pm @@ -3,15 +3,8 @@ package Tie::Hash::NamedCapture; our $VERSION = "0.08"; -sub TIEHASH; - require XSLoader; -XSLoader::load(); - -tie %+, __PACKAGE__; -tie %-, __PACKAGE__, all => 1; - -1; +XSLoader::load(); # This returns true, which makes require happy. __END__ diff --git a/ext/Tie-Hash-NamedCapture/NamedCapture.xs b/ext/Tie-Hash-NamedCapture/NamedCapture.xs index 73deacdc1b..459a9984f8 100644 --- a/ext/Tie-Hash-NamedCapture/NamedCapture.xs +++ b/ext/Tie-Hash-NamedCapture/NamedCapture.xs @@ -15,9 +15,27 @@ #define EXISTS_ALIAS (RXapif_EXISTS | (2 << EXPECT_SHIFT)) #define SCALAR_ALIAS (RXapif_SCALAR | (1 << EXPECT_SHIFT)) +static +tie_it(pTHX_ const char name, UV flag) +{ + GV *const gv = gv_fetchpvn(&name, 1, GV_ADDMULTI|GV_NOTQUAL, SVt_PVHV); + HV *const hv = GvHV(gv); + SV *rv = newSV_type(SVt_RV); + + sv_setuv(newSVrv(rv, "Tie::Hash::NamedCapture"), flag); + + sv_unmagic((SV *)hv, PERL_MAGIC_tied); + sv_magic((SV *)hv, rv, PERL_MAGIC_tied, NULL, 0); + SvREFCNT_dec(rv); /* As sv_magic increased it by one. */ +} + MODULE = Tie::Hash::NamedCapture PACKAGE = Tie::Hash::NamedCapture PROTOTYPES: DISABLE +BOOT: + tie_it(aTHX_ '-', RXapif_ALL); + tie_it(aTHX_ '+', RXapif_ONE); + SV * TIEHASH(package, ...) const char *package; |