Optimize can_xs()
[gitmo/Class-MOP.git] / mop.h
1 #ifndef __MOP_H__
2 #define __MOP_H__
3
4 #define PERL_NO_GET_CONTEXT
5 #include "EXTERN.h"
6 #include "perl.h"
7 #include "XSUB.h"
8
9 #include "ppport.h"
10
11 #define MOP_CALL_BOOT(name)  mop_call_xs(aTHX_ name, cv, mark);
12
13 #ifndef XSPROTO
14 #define XSPROTO(name) XS(name)
15 #endif
16
17 void mop_call_xs (pTHX_ XSPROTO(subaddr), CV *cv, SV **mark);
18
19
20 #define MAKE_KEYSV(name) newSVpvn_share(#name, sizeof(#name)-1, 0U)
21
22 XS(mop_xs_simple_accessor);
23 XS(mop_xs_simple_reader);
24 XS(mop_xs_simple_writer);
25 XS(mop_xs_simple_predicate);
26 XS(mop_xs_simple_predicate_for_metaclass);
27 XS(mop_xs_simple_clearer);
28
29 extern SV *mop_method_metaclass;
30 extern SV *mop_associated_metaclass;
31 extern SV *mop_associated_attribute;
32 extern SV *mop_wrap;
33 extern SV *mop_methods;
34 extern SV *mop_name;
35 extern SV *mop_body;
36 extern SV *mop_package;
37 extern SV *mop_package_name;
38 extern SV *mop_package_cache_flag;
39 extern SV *mop_VERSION;
40 extern SV *mop_ISA;
41
42 UV mop_check_package_cache_flag(pTHX_ HV *stash);
43 int mop_get_code_info (SV *coderef, char **pkg, char **name);
44 SV *mop_call0(pTHX_ SV *const self, SV *const method);
45 SV *mop_call1(pTHX_ SV *const self, SV *const method, SV *const arg1);
46
47 #define mop_call0_pvs(o, m)    mop_call0(aTHX_ o, newSVpvs_flags(m, SVs_TEMP))
48 #define mop_call1_pvs(o, m, a) mop_call1(aTHX_ o, newSVpvs_flags(m, SVs_TEMP), a)
49
50
51 typedef enum {
52     TYPE_FILTER_NONE,
53     TYPE_FILTER_CODE,
54     TYPE_FILTER_ARRAY,
55     TYPE_FILTER_IO,
56     TYPE_FILTER_HASH,
57     TYPE_FILTER_SCALAR,
58 } type_filter_t;
59
60 typedef bool (*get_package_symbols_cb_t) (const char *, STRLEN, SV *, void *);
61
62 void mop_get_package_symbols(HV *stash, type_filter_t filter, get_package_symbols_cb_t cb, void *ud);
63 HV  *mop_get_all_package_symbols (HV *stash, type_filter_t filter);
64
65
66 /* Class::MOP::Instance stuff */
67
68 typedef struct {
69     SV*  (*create_instance)(pTHX);
70     bool (*has_slot)       (pTHX_ SV* const instance, SV* const slot_name);
71     SV*  (*get_slot)       (pTHX_ SV* const instance, SV* const slot_name);
72     SV*  (*set_slot)       (pTHX_ SV* const instance, SV* const slot_name, SV* const value);
73     SV*  (*delete_slot)    (pTHX_ SV* const instance, SV* const slot_name);
74     void (*weaken_slot)    (pTHX_ SV* const instance, SV* const slot_name);
75 } mop_instance_vtbl;
76
77 const mop_instance_vtbl* mop_get_default_instance_vtbl(pTHX);
78
79 #define MOP_mg_meta(mg) ((AV*)(mg)->mg_obj)
80 #ifdef DEBUGGING
81 #define MOP_mg_key(mg)  (*av_fetch( MOP_mg_meta(mg) , 0, TRUE))
82 #else
83 #define MOP_mg_key(mg)  (AvARRAY( MOP_mg_meta(mg))[0])
84 #endif
85 #define MOP_mg_vtbl(mg) ((const mop_instance_vtbl*)(mg)->mg_ptr)
86
87 /* Class::MOP::Method::Accessor stuff */
88
89 #define dMOP_METHOD_COMMON                                            \
90     SV* const self      = mop_accessor_get_self(aTHX_ ax, items, cv); \
91     MAGIC* const mg     = mop_accessor_get_mg(aTHX_ cv)               \
92
93
94 SV*    mop_accessor_get_self(pTHX_ I32 const ax, I32 const items, CV* const cv);
95 MAGIC* mop_accessor_get_mg(pTHX_ CV* const cv);
96
97 CV*    mop_install_accessor(pTHX_ const char* const fq_name, const char* const key, I32 const keylen, XSPROTO(accessor_impl), const mop_instance_vtbl* vtbl);
98
99 #define INSTALL_SIMPLE_READER(klass, name)                  INSTALL_SIMPLE_READER_WITH_KEY(klass, name, name)
100 #define INSTALL_SIMPLE_READER_WITH_KEY(klass, name, key)    (void)mop_install_accessor(aTHX_ "Class::MOP::" #klass "::" #name, #key, sizeof(#key)-1, mop_xs_simple_reader, NULL)
101
102 #define INSTALL_SIMPLE_WRITER(klass, name)                  INSTALL_SIMPLE_WRITER_WITH_KEY(klass, name, name)
103 #define INSTALL_SIMPLE_WRITER_WITH_KEY(klass, name, key)    (void)mop_install_accessor(aTHX_ "Class::MOP::" #klass "::" #name, #key, sizeof(#key)-1, mop_xs_simple_writer, NULL)
104
105 #define INSTALL_SIMPLE_PREDICATE(klass, name)                INSTALL_SIMPLE_PREDICATE_WITH_KEY(klass, name, name)
106 #define INSTALL_SIMPLE_PREDICATE_WITH_KEY(klass, name, key) (void)mop_install_accessor(aTHX_ "Class::MOP::" #klass "::has_" #name, #key, sizeof(#key)-1, mop_xs_simple_predicate_for_metaclass, NULL)
107
108 #define MOPf_DIE_ON_FAIL 0x01
109 MAGIC* mop_mg_find(pTHX_ SV* const sv, const MGVTBL* const vtbl, I32 const flags);
110
111 #endif