X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=MOP.xs;h=ae34df5d730bb9b30828c69dfa92c52fc31a067b;hb=3ecd1b253d51e4159c5dd0387cfe84bde55a3f43;hp=6230e45577f3f73b7f3b202579a7b4a5c57f0e77;hpb=dcbfe027c090a3cc999d7274e81198e7ab221710;p=gitmo%2FClass-MOP.git diff --git a/MOP.xs b/MOP.xs index 6230e45..ae34df5 100644 --- a/MOP.xs +++ b/MOP.xs @@ -13,6 +13,9 @@ U32 hash_name; SV *key_package; U32 hash_package; +SV *key_package_name; +U32 hash_package_name; + SV *key_body; U32 hash_body; @@ -29,10 +32,12 @@ BOOT: key_name = newSVpvs("name"); key_body = newSVpvs("body"); key_package = newSVpvs("package"); + key_package_name = newSVpvs("package_name"); PERL_HASH(hash_name, "name", 4); PERL_HASH(hash_body, "body", 4); PERL_HASH(hash_package, "package", 7); + PERL_HASH(hash_package_name, "package_name", 12); PROTOTYPES: ENABLE @@ -80,6 +85,9 @@ get_all_package_symbols(self, ...) SV *type_filter = NULL; register HE *he; PPCODE: + if (! SvROK(self)) { + die("Cannot call get_all_package_symbols as a class method"); + } switch ( GIMME_V ) { case G_VOID: return; break; @@ -90,7 +98,7 @@ get_all_package_symbols(self, ...) PUTBACK; - if (SvROK(self) && (he = hv_fetch_ent((HV *)SvRV(self), key_package, 0, hash_package))) + if (he = hv_fetch_ent((HV *)SvRV(self), key_package, 0, hash_package)) stash = gv_stashsv(HeVAL(he),0); if ( stash ) { @@ -164,7 +172,11 @@ name(self) PREINIT: register HE *he; PPCODE: - if (SvROK(self) && (he = hv_fetch_ent((HV *)SvRV(self), key_package, 0, hash_package))) + if (! SvROK(self)) { + die("Cannot call name as a class method"); + } + + if (he = hv_fetch_ent((HV *)SvRV(self), key_package, 0, hash_package)) XPUSHs(HeVAL(he)); else ST(0) = &PL_sv_undef; @@ -177,7 +189,11 @@ name(self) PREINIT: register HE *he; PPCODE: - if (SvROK(self) && (he = hv_fetch_ent((HV *)SvRV(self), key_name, 0, hash_name))) + if (! SvROK(self)) { + die("Cannot call name as a class method"); + } + + if (he = hv_fetch_ent((HV *)SvRV(self), key_name, 0, hash_name)) XPUSHs(HeVAL(he)); else ST(0) = &PL_sv_undef; @@ -185,12 +201,46 @@ name(self) MODULE = Class::MOP PACKAGE = Class::MOP::Method SV * +name(self) + SV *self + PREINIT: + register HE *he; + PPCODE: + if (! SvROK(self)) { + die("Cannot call name as a class method"); + } + + if (he = hv_fetch_ent((HV *)SvRV(self), key_name, 0, hash_name)) + XPUSHs(HeVAL(he)); + else + ST(0) = &PL_sv_undef; + +SV * +package_name(self) + SV *self + PREINIT: + register HE *he; + PPCODE: + if (! SvROK(self)) { + die("Cannot call package_name as a class method"); + } + + if (he = hv_fetch_ent((HV *)SvRV(self), key_package_name, 0, hash_package_name)) + XPUSHs(HeVAL(he)); + else + ST(0) = &PL_sv_undef; + +SV * body(self) SV *self PREINIT: register HE *he; PPCODE: - if (SvROK(self) && (he = hv_fetch_ent((HV *)SvRV(self), key_body, 0, hash_body))) + if (! SvROK(self)) { + die("Cannot call body as a class method"); + } + + if (he = hv_fetch_ent((HV *)SvRV(self), key_body, 0, hash_body)) XPUSHs(HeVAL(he)); else ST(0) = &PL_sv_undef;