diff options
| author | mimaki <[email protected]> | 2012-04-20 09:39:03 +0900 |
|---|---|---|
| committer | mimaki <[email protected]> | 2012-04-20 09:39:03 +0900 |
| commit | e0d6430f63c4cbe0c71ce82ee23284671389a818 (patch) | |
| tree | 41abad7f12eced98d9ac14d141cea62464c3332f /src/method.h | |
| parent | 54ad561098ed353ada70205c39b2c42a2a2eb9e5 (diff) | |
| download | mruby-e0d6430f63c4cbe0c71ce82ee23284671389a818.tar.gz mruby-e0d6430f63c4cbe0c71ce82ee23284671389a818.zip | |
add mruby sources
Diffstat (limited to 'src/method.h')
| -rw-r--r-- | src/method.h | 103 |
1 files changed, 103 insertions, 0 deletions
diff --git a/src/method.h b/src/method.h new file mode 100644 index 000000000..3591917a2 --- /dev/null +++ b/src/method.h @@ -0,0 +1,103 @@ +/********************************************************************** + + method.h - + + $Author: ko1 $ + created at: Wed Jul 15 20:02:33 2009 + + Copyright (C) 2009 Koichi Sasada + +**********************************************************************/ +#ifndef METHOD_H +#define METHOD_H + +typedef enum { + NOEX_PUBLIC = 0x00, + NOEX_NOSUPER = 0x01, + NOEX_PRIVATE = 0x02, + NOEX_PROTECTED = 0x04, + NOEX_MASK = 0x06, + NOEX_BASIC = 0x08, + NOEX_UNDEF = NOEX_NOSUPER, + NOEX_MODFUNC = 0x12, + NOEX_SUPER = 0x20, + NOEX_VCALL = 0x40, + NOEX_RESPONDS = 0x80 +} mrb_method_flag_t; + +#define NOEX_SAFE(n) ((int)((n) >> 8) & 0x0F) +#define NOEX_WITH(n, s) ((s << 8) | (n) | (ruby_running ? 0 : NOEX_BASIC)) +#define NOEX_WITH_SAFE(n) NOEX_WITH(n, mrb_safe_level()) + +/* method data type */ + +typedef enum { + VM_METHOD_TYPE_ISEQ, + VM_METHOD_TYPE_CFUNC, + VM_METHOD_TYPE_ATTRSET, + VM_METHOD_TYPE_IVAR, + VM_METHOD_TYPE_BMETHOD, + VM_METHOD_TYPE_ZSUPER, + VM_METHOD_TYPE_UNDEF, + VM_METHOD_TYPE_NOTIMPLEMENTED, + VM_METHOD_TYPE_OPTIMIZED, /* Kernel#send, Proc#call, etc */ + VM_METHOD_TYPE_MISSING /* wrapper for method_missing(id) */ +} mrb_method_type_t; + +typedef struct mrb_method_cfunc_struct { + mrb_value (*func)(ANYARGS); + int argc; +} mrb_method_cfunc_t; + +typedef struct mrb_method_attr_struct { + mrb_sym id; + mrb_value location; +} mrb_method_attr_t; + +typedef struct mrb_iseq_struct mrb_iseq_t; + +typedef struct mrb_method_definition_struct { + mrb_method_type_t type; /* method type */ + mrb_sym original_id; + union { + mrb_iseq_t *iseq; /* should be mark */ + mrb_method_cfunc_t cfunc; + mrb_method_attr_t attr; + mrb_value proc; /* should be mark */ + enum method_optimized_type { + OPTIMIZED_METHOD_TYPE_SEND, + OPTIMIZED_METHOD_TYPE_CALL + } optimize_type; + } body; + int alias_count; +} mrb_method_definition_t; + +typedef struct mrb_method_entry_struct { + mrb_method_flag_t flag; + char mark; + mrb_method_definition_t *def; + mrb_sym called_id; + mrb_value klass; /* should be mark */ +} mrb_method_entry_t; + +struct unlinked_method_entry_list_entry { + struct unlinked_method_entry_list_entry *next; + mrb_method_entry_t *me; +}; + +#define UNDEFINED_METHOD_ENTRY_P(me) (!(me) || !(me)->def || (me)->def->type == VM_METHOD_TYPE_UNDEF) + +void mrb_add_method_cfunc(mrb_value klass, mrb_sym mid, mrb_value (*func)(ANYARGS), int argc, mrb_method_flag_t noex); +mrb_method_entry_t *mrb_add_method(mrb_value klass, mrb_sym mid, mrb_method_type_t type, void *option, mrb_method_flag_t noex); +mrb_method_entry_t *mrb_method_entry(mrb_state *mrb, mrb_value klass, mrb_sym id); + +mrb_method_entry_t *mrb_method_entry_get_without_cache(mrb_value klass, mrb_sym id); +mrb_method_entry_t *mrb_method_entry_set(mrb_value klass, mrb_sym mid, const mrb_method_entry_t *, mrb_method_flag_t noex); + +int mrb_method_entry_arity(const mrb_method_entry_t *me); + +void mrb_mark_method_entry(const mrb_method_entry_t *me); +void mrb_free_method_entry(mrb_method_entry_t *me); +void mrb_sweep_method_entry(void *vm); + +#endif /* METHOD_H */ |
