X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=MOP.xs;h=ae34df5d730bb9b30828c69dfa92c52fc31a067b;hb=b20287a17e10d06650885ca42500f9b63631ef70;hp=942b3785ba471fb55bd1d6e9c8e9c4ed4f06fbf4;hpb=da88f307a9f54e4fef38bf1d7354cdb4d137c451;p=gitmo%2FClass-MOP.git diff --git a/MOP.xs b/MOP.xs index 942b378..ae34df5 100644 --- a/MOP.xs +++ b/MOP.xs @@ -85,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; @@ -95,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 ) { @@ -169,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; @@ -182,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;