Commit 396397bc authored by Yukihiro Matsumoto's avatar Yukihiro Matsumoto

move KHASH_DECLARE to header files

parent 8b8151a6
...@@ -216,12 +216,6 @@ static inline khint_t __ac_X31_hash_string(const char *s) ...@@ -216,12 +216,6 @@ static inline khint_t __ac_X31_hash_string(const char *s)
typedef const char *kh_cstr_t; typedef const char *kh_cstr_t;
/* declare common hash types. */
#include "mruby.h"
KHASH_DECLARE(mt, mrb_sym, struct RProc*, 1)
KHASH_DECLARE(iv, mrb_sym, mrb_value, 1)
#if defined(__cplusplus) #if defined(__cplusplus)
} /* extern "C" { */ } /* extern "C" { */
#endif #endif
......
...@@ -50,6 +50,9 @@ struct RProc *mrb_proc_new(mrb_state*, mrb_irep*); ...@@ -50,6 +50,9 @@ struct RProc *mrb_proc_new(mrb_state*, mrb_irep*);
struct RProc *mrb_proc_new_cfunc(mrb_state*, mrb_func_t); struct RProc *mrb_proc_new_cfunc(mrb_state*, mrb_func_t);
struct RProc *mrb_closure_new(mrb_state*, mrb_irep*); struct RProc *mrb_closure_new(mrb_state*, mrb_irep*);
#include "mruby/khash.h"
KHASH_DECLARE(mt, mrb_sym, struct RProc*, 1);
#if defined(__cplusplus) #if defined(__cplusplus)
} /* extern "C" { */ } /* extern "C" { */
#endif #endif
......
...@@ -20,6 +20,7 @@ typedef struct global_variable { ...@@ -20,6 +20,7 @@ typedef struct global_variable {
//int block_trace; //int block_trace;
//struct trace_var *trace; //struct trace_var *trace;
} global_variable; } global_variable;
struct global_entry { struct global_entry {
global_variable *var; global_variable *var;
mrb_sym id; mrb_sym id;
...@@ -41,7 +42,8 @@ mrb_value mrb_obj_iv_get(mrb_state*, struct RObject*, mrb_sym); ...@@ -41,7 +42,8 @@ mrb_value mrb_obj_iv_get(mrb_state*, struct RObject*, mrb_sym);
void mrb_obj_iv_set(mrb_state*, struct RObject*, mrb_sym, mrb_value); void mrb_obj_iv_set(mrb_state*, struct RObject*, mrb_sym, mrb_value);
const char * mrb_class2name(mrb_state *mrb, struct RClass* klass); const char * mrb_class2name(mrb_state *mrb, struct RClass* klass);
mrb_value mrb_iv_get(mrb_state *mrb, mrb_value obj, mrb_sym sym); mrb_value mrb_iv_get(mrb_state *mrb, mrb_value obj, mrb_sym sym);
void mrb_iv_set(mrb_state *mrb, mrb_value obj, mrb_sym sym, mrb_value v); /* mrb_iv_set */ void mrb_iv_set(mrb_state *mrb, mrb_value obj, mrb_sym sym, mrb_value v);
mrb_value mrb_iv_remove(mrb_state *mrb, mrb_value obj, mrb_sym sym);
void mrb_copy_generic_ivar(mrb_value clone, mrb_value obj); void mrb_copy_generic_ivar(mrb_value clone, mrb_value obj);
int mrb_const_defined_at(mrb_state *mrb, struct RClass *klass, mrb_sym id); int mrb_const_defined_at(mrb_state *mrb, struct RClass *klass, mrb_sym id);
mrb_value mrb_f_global_variables(mrb_state *mrb, mrb_value self); mrb_value mrb_f_global_variables(mrb_state *mrb, mrb_value self);
...@@ -55,6 +57,9 @@ void mrb_gc_mark_iv(mrb_state*, struct RObject*); ...@@ -55,6 +57,9 @@ void mrb_gc_mark_iv(mrb_state*, struct RObject*);
size_t mrb_gc_mark_iv_size(mrb_state*, struct RObject*); size_t mrb_gc_mark_iv_size(mrb_state*, struct RObject*);
void mrb_gc_free_iv(mrb_state*, struct RObject*); void mrb_gc_free_iv(mrb_state*, struct RObject*);
#include "mruby/khash.h"
KHASH_DECLARE(iv, mrb_sym, mrb_value, 1)
#if defined(__cplusplus) #if defined(__cplusplus)
} /* extern "C" { */ } /* extern "C" { */
#endif #endif
......
...@@ -15,7 +15,8 @@ ...@@ -15,7 +15,8 @@
#include "mruby/array.h" #include "mruby/array.h"
#include "error.h" #include "error.h"
#include "mruby/khash.h" KHASH_DEFINE(iv, mrb_sym, mrb_value, 1, kh_int_hash_func, kh_int_hash_equal);
KHASH_DEFINE(mt, mrb_sym, struct RProc*, 1, kh_int_hash_func, kh_int_hash_equal);
typedef struct fc_result { typedef struct fc_result {
mrb_sym name; mrb_sym name;
...@@ -25,9 +26,6 @@ typedef struct fc_result { ...@@ -25,9 +26,6 @@ typedef struct fc_result {
struct fc_result *prev; struct fc_result *prev;
} fcresult_t; } fcresult_t;
int kiv_lookup(khash_t(iv) *table, mrb_sym key, mrb_value *value);
extern struct kh_iv *mrb_class_tbl;
void void
mrb_gc_mark_mt(mrb_state *mrb, struct RClass *c) mrb_gc_mark_mt(mrb_state *mrb, struct RClass *c)
{ {
......
...@@ -10,14 +10,12 @@ ...@@ -10,14 +10,12 @@
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include "mruby/proc.h" #include "mruby/proc.h"
#include "mruby/range.h" #include "mruby/range.h"
#include "mruby/array.h" #include "mruby/array.h"
#include "mruby/hash.h" #include "mruby/hash.h"
#include "mruby/class.h" #include "mruby/class.h"
#include "mruby/struct.h" #include "mruby/struct.h"
#include "mruby/variable.h" #include "mruby/variable.h"
#include "mruby/khash.h"
#include "error.h" #include "error.h"
typedef enum { typedef enum {
...@@ -1057,39 +1055,14 @@ mrb_value ...@@ -1057,39 +1055,14 @@ mrb_value
mrb_obj_remove_instance_variable(mrb_state *mrb, mrb_value self) mrb_obj_remove_instance_variable(mrb_state *mrb, mrb_value self)
{ {
mrb_sym sym; mrb_sym sym;
mrb_value name;
khash_t(iv) *h;
khiter_t k;
mrb_value val; mrb_value val;
mrb_value Qundef = mrb_undef_value();
mrb_get_args(mrb, "o", &name); mrb_get_args(mrb, "n", &sym);
sym = mrb_to_id(mrb, name); val = mrb_iv_remove(mrb, self, sym);
//if (OBJ_FROZEN(obj)) mrb_error_frozen("object"); if (UNDEF_P(val)) {
//if (!mrb_is_instance_id(id)) {
// mrb_name_error(mrb, id, "`%s' is not allowed as an instance variable name", mrb_sym2name(mrb, id));
//}
switch (mrb_type(self)) {
case MRB_TT_OBJECT:
case MRB_TT_CLASS:
case MRB_TT_MODULE:
if (!mrb_obj_ptr(self)->iv) break;
h = mrb_obj_ptr(self)->iv;
if (!h) break;
k = kh_get(iv, h, sym);
if (k != kh_end(h)) {
val = kh_value(h, k);
if (!mrb_obj_equal(mrb, val, Qundef)) {
kh_value(h, k) = Qundef;
return val;
}
}
break;
default:
break;
}
mrb_name_error(mrb, sym, "instance variable %s not defined", mrb_sym2name(mrb, sym)); mrb_name_error(mrb, sym, "instance variable %s not defined", mrb_sym2name(mrb, sym));
return mrb_nil_value(); /* not reached */ }
return val;
} }
static inline int static inline int
......
...@@ -94,10 +94,28 @@ mrb_obj_iv_get(mrb_state *mrb, struct RObject *obj, mrb_sym sym) ...@@ -94,10 +94,28 @@ mrb_obj_iv_get(mrb_state *mrb, struct RObject *obj, mrb_sym sym)
return ivget(mrb, obj->iv, sym); return ivget(mrb, obj->iv, sym);
} }
static int
obj_iv_p(mrb_value obj)
{
switch (mrb_type(obj)) {
case MRB_TT_OBJECT:
case MRB_TT_CLASS:
case MRB_TT_MODULE:
case MRB_TT_HASH:
case MRB_TT_DATA:
return TRUE;
default:
return FALSE;
}
}
mrb_value mrb_value
mrb_iv_get(mrb_state *mrb, mrb_value obj, mrb_sym sym) mrb_iv_get(mrb_state *mrb, mrb_value obj, mrb_sym sym)
{ {
if (obj_iv_p(obj)) {
return mrb_obj_iv_get(mrb, mrb_obj_ptr(obj), sym); return mrb_obj_iv_get(mrb, mrb_obj_ptr(obj), sym);
}
return mrb_nil_value();
} }
static void static void
...@@ -127,7 +145,30 @@ mrb_obj_iv_set(mrb_state *mrb, struct RObject *obj, mrb_sym sym, mrb_value v) ...@@ -127,7 +145,30 @@ mrb_obj_iv_set(mrb_state *mrb, struct RObject *obj, mrb_sym sym, mrb_value v)
void void
mrb_iv_set(mrb_state *mrb, mrb_value obj, mrb_sym sym, mrb_value v) /* mrb_ivar_set */ mrb_iv_set(mrb_state *mrb, mrb_value obj, mrb_sym sym, mrb_value v) /* mrb_ivar_set */
{ {
if (obj_iv_p(obj)) {
mrb_obj_iv_set(mrb, mrb_obj_ptr(obj), sym, v); mrb_obj_iv_set(mrb, mrb_obj_ptr(obj), sym, v);
}
}
mrb_value
mrb_iv_remove(mrb_state *mrb, mrb_value obj, mrb_sym sym)
{
mrb_value val;
if (obj_iv_p(obj)) {
khash_t(iv) *h = mrb_obj_ptr(obj)->iv;
khiter_t k;
if (h) {
k = kh_get(iv, h, sym);
if (k != kh_end(h)) {
val = kh_value(h, k);
kh_del(iv, h, k);
return val;
}
}
}
return mrb_undef_value();
} }
mrb_value mrb_value
...@@ -366,7 +407,7 @@ mrb_st_lookup(struct kh_iv *table, mrb_sym id, khiter_t *value) ...@@ -366,7 +407,7 @@ mrb_st_lookup(struct kh_iv *table, mrb_sym id, khiter_t *value)
} }
} }
int static int
kiv_lookup(khash_t(iv)* table, mrb_sym key, mrb_value *value) kiv_lookup(khash_t(iv)* table, mrb_sym key, mrb_value *value)
{ {
khash_t(iv) *h=table; khash_t(iv) *h=table;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment