X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=mouse.h;h=9447037a156a6d87415d453dc9169e18fe89e591;hb=a5df48e596d4b685f53bf59ef581d6999ab14eb6;hp=0ebe38cb90ca6cc70bcac92bbae31e3c67cbc744;hpb=7d96ae4dfb9f6806432c90c33bb2d3a5bf63a9a7;p=gitmo%2FMouse.git diff --git a/mouse.h b/mouse.h index 0ebe38c..9447037 100644 --- a/mouse.h +++ b/mouse.h @@ -6,16 +6,25 @@ #include #include +#define NEED_newSVpvn_flags #include "ppport.h" +/* for portability */ #ifndef newSVpvs_share #define newSVpvs_share(s) Perl_newSVpvn_share(aTHX_ s, sizeof(s)-1, 0U) #endif +#ifndef GvNAME_get +#define GvNAME_get GvNAME +#endif +#ifndef GvNAMELEN_get +#define GvNAMELEN_get GvNAMELEN +#endif + #ifndef mro_get_linear_isa #define no_mro_get_linear_isa #define mro_get_linear_isa(stash) mouse_mro_get_linear_isa(aTHX_ stash) -AV* mouse_mro_get_linear_isa(pTHX_ HV* const stash) +AV* mouse_mro_get_linear_isa(pTHX_ HV* const stash); #endif /* !mro_get_linear_isa */ #ifndef mro_get_pkg_gen @@ -26,7 +35,7 @@ AV* mouse_mro_get_linear_isa(pTHX_ HV* const stash) #endif /* !no_mro_get_linear_isa */ #endif /* mro_get_package_gen */ -#define MOUSE_CALL_BOOT(name) STMT_START { \ +#define MOUSE_CALL_BOOT(name) STMT_START { \ EXTERN_C XS(CAT2(boot_, name)); \ PUSHMARK(SP); \ CALL_FPTR(CAT2(boot_, name))(aTHX_ cv); \ @@ -34,6 +43,16 @@ AV* mouse_mro_get_linear_isa(pTHX_ HV* const stash) extern SV* mouse_package; extern SV* mouse_namespace; +extern SV* mouse_methods; +extern SV* mouse_name; + +void +mouse_throw_error(SV* const metaobject, SV* const data /* not used */, const char* const fmt, ...) +#ifdef __attribute__format__ + __attribute__format__(__printf__, 3, 4); +#else + ; +#endif #define is_class_loaded(sv) mouse_is_class_loaded(aTHX_ sv) bool mouse_is_class_loaded(pTHX_ SV*); @@ -54,7 +73,25 @@ SV* mouse_call1(pTHX_ SV *const self, SV *const method, SV* const arg1); #define MOUSEf_DIE_ON_FAIL 0x01 MAGIC* mouse_mg_find(pTHX_ SV* const sv, const MGVTBL* const vtbl, I32 const flags); -#define dMOUSE_self SV* const self = mouse_accessor_get_self(aTHX_ ax, items, cv) +/* MOUSE_av_at(av, ix) is the safer version of AvARRAY(av)[ix] if perl is compiled with -DDEBUGGING */ +#ifdef DEBUGGING +#define MOUSE_av_at(av, ix) *mouse_av_at_safe(aTHX_ (av) , (ix)) +SV** mouse_av_at_safe(pTHX_ AV* const mi, I32 const ix); +#else +#define MOUSE_av_at(av, ix) AvARRAY(av)[ix] +#endif + +#define dMOUSE_self SV* const self = mouse_accessor_get_self(aTHX_ ax, items, cv) +SV* mouse_accessor_get_self(pTHX_ I32 const ax, I32 const items, CV* const cv); + +#define MOUSE_mg_obj(mg) ((mg)->mg_obj) +#define MOUSE_mg_ptr(mg) ((mg)->mg_ptr) +#define MOUSE_mg_flags(mg) ((mg)->mg_private) +#define MOUSE_mg_virtual(mg) ((mg)->mg_virtual) + +#define MOUSE_mg_slot(mg) MOUSE_mg_obj(mg) +#define MOUSE_mg_xa(mg) ((AV*)MOUSE_mg_ptr(mg)) + /* mouse_instance.xs stuff */ SV* mouse_instance_create (pTHX_ HV* const stash); @@ -80,8 +117,15 @@ CV* mouse_install_simple_accessor(pTHX_ const char* const fq_name, const char* c XS(mouse_xs_simple_reader); XS(mouse_xs_simple_writer); +XS(mouse_xs_simple_clearer); XS(mouse_xs_simple_predicate); +CV* mouse_instantiate_xs_accessor(pTHX_ SV* const attr, XSUBADDR_t const accessor_impl); + +XS(mouse_xs_accessor); +XS(mouse_xs_reader); +XS(mouse_xs_writer); + typedef enum mouse_tc{ MOUSE_TC_ANY, MOUSE_TC_ITEM, @@ -109,7 +153,8 @@ typedef enum mouse_tc{ /* type constraints */ -int mouse_tc_check(pTHX_ mouse_tc const tc, SV* sv); +int mouse_tc_check(pTHX_ SV* const tc, SV* const sv); +int mouse_builtin_tc_check(pTHX_ mouse_tc const tc, SV* const sv); int mouse_tc_Any (pTHX_ SV* const sv); int mouse_tc_Bool (pTHX_ SV* const sv);