PUTBACK;
- if (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 ) {
case SVt_RV:
/* BAH! constants are horrible */
+ if (!SvROK (gv)) {
+ continue;
+ }
+
/* we don't really care about the length,
but that's the API */
key = HePV(he, keylen);
}
-SV *
+void
name(self)
SV *self
PREINIT:
die("Cannot call name as a class method");
}
- if (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)))
XPUSHs(HeVAL(he));
else
ST(0) = &PL_sv_undef;
MODULE = Class::MOP PACKAGE = Class::MOP::Attribute
-SV *
+void
name(self)
SV *self
PREINIT:
die("Cannot call name as a class method");
}
- if (he = hv_fetch_ent((HV *)SvRV(self), key_name, 0, hash_name))
+ if ((he = hv_fetch_ent((HV *)SvRV(self), key_name, 0, hash_name)))
XPUSHs(HeVAL(he));
else
ST(0) = &PL_sv_undef;
MODULE = Class::MOP PACKAGE = Class::MOP::Method
-SV *
+void
name(self)
SV *self
PREINIT:
die("Cannot call name as a class method");
}
- if (he = hv_fetch_ent((HV *)SvRV(self), key_name, 0, hash_name))
+ if ((he = hv_fetch_ent((HV *)SvRV(self), key_name, 0, hash_name)))
XPUSHs(HeVAL(he));
else
ST(0) = &PL_sv_undef;
-SV *
+void
package_name(self)
SV *self
PREINIT:
die("Cannot call package_name as a class method");
}
- if (he = hv_fetch_ent((HV *)SvRV(self), key_package_name, 0, hash_package_name))
+ 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 *
+void
body(self)
SV *self
PREINIT:
die("Cannot call body as a class method");
}
- if (he = hv_fetch_ent((HV *)SvRV(self), key_body, 0, hash_body))
+ if ((he = hv_fetch_ent((HV *)SvRV(self), key_body, 0, hash_body)))
XPUSHs(HeVAL(he));
else
ST(0) = &PL_sv_undef;