remove struct RStruct, use RArray instead

parent d9dc492f
...@@ -13,22 +13,11 @@ ...@@ -13,22 +13,11 @@
#include "mruby/data.h" #include "mruby/data.h"
#include "mruby/variable.h" #include "mruby/variable.h"
struct RStruct { static struct mrb_data_type mrb_struct_type = { "mrb_struct", NULL };
struct RBasic basic;
mrb_value values;
};
static void
rstruct_free(mrb_state *mrb, void *ptr)
{
mrb_free(mrb, ptr);
}
static struct mrb_data_type mrb_struct_type = { "mrb_struct", rstruct_free };
#define RSTRUCT(st) ((struct RStruct*)(DATA_PTR(st))) #define RSTRUCT_ARY(st) ((struct RArray*)DATA_PTR(st))
#define RSTRUCT_LEN(st) ((int)(RARRAY_LEN(RSTRUCT(st)->values))) #define RSTRUCT_LEN(st) RSTRUCT_ARY(st)->len
#define RSTRUCT_PTR(st) (RARRAY_PTR(RSTRUCT(st)->values)) #define RSTRUCT_PTR(st) RSTRUCT_ARY(st)->ptr
static struct RClass * static struct RClass *
struct_class(mrb_state *mrb) struct_class(mrb_state *mrb)
...@@ -420,23 +409,23 @@ mrb_struct_initialize_withArg(mrb_state *mrb, int argc, mrb_value *argv, mrb_val ...@@ -420,23 +409,23 @@ mrb_struct_initialize_withArg(mrb_state *mrb, int argc, mrb_value *argv, mrb_val
{ {
struct RClass *klass = mrb_obj_class(mrb, self); struct RClass *klass = mrb_obj_class(mrb, self);
int i, n; int i, n;
struct RStruct *st; mrb_value values;
n = num_members(mrb, klass); n = num_members(mrb, klass);
if (n < argc) { if (n < argc) {
mrb_raise(mrb, E_ARGUMENT_ERROR, "struct size differs"); mrb_raise(mrb, E_ARGUMENT_ERROR, "struct size differs");
} }
st = (struct RStruct *) mrb_malloc(mrb, sizeof(struct RStruct));
DATA_PTR(self) = st; values = mrb_ary_new_capa(mrb, n);
DATA_PTR(self) = mrb_ary_ptr(values);
DATA_TYPE(self) = &mrb_struct_type; DATA_TYPE(self) = &mrb_struct_type;
st->values = mrb_ary_new_capa(mrb, n);
for (i = 0; i < argc; i++) { for (i = 0; i < argc; i++) {
mrb_ary_set(mrb, st->values, i, argv[i]); mrb_ary_set(mrb, values, i, argv[i]);
} }
for (i = argc; i < n; i++) { for (i = argc; i < n; i++) {
mrb_ary_set(mrb, st->values, i, mrb_nil_value()); mrb_ary_set(mrb, values, i, mrb_nil_value());
} }
mrb_iv_set(mrb, self, mrb_intern(mrb, "__values__"), st->values); mrb_iv_set(mrb, self, mrb_intern(mrb, "__values__"), values);
return self; return self;
} }
...@@ -524,7 +513,7 @@ mrb_struct_inspect(mrb_state *mrb, mrb_value s) ...@@ -524,7 +513,7 @@ mrb_struct_inspect(mrb_state *mrb, mrb_value s)
mrb_value mrb_value
mrb_struct_init_copy(mrb_state *mrb, mrb_value copy) mrb_struct_init_copy(mrb_state *mrb, mrb_value copy)
{ {
mrb_value s; mrb_value s, a;
int i, len; int i, len;
mrb_get_args(mrb, "o", &s); mrb_get_args(mrb, "o", &s);
...@@ -537,8 +526,9 @@ mrb_struct_init_copy(mrb_state *mrb, mrb_value copy) ...@@ -537,8 +526,9 @@ mrb_struct_init_copy(mrb_state *mrb, mrb_value copy)
mrb_raise(mrb, E_TYPE_ERROR, "struct size mismatch"); mrb_raise(mrb, E_TYPE_ERROR, "struct size mismatch");
} }
len = RSTRUCT_LEN(copy); len = RSTRUCT_LEN(copy);
a = mrb_obj_value(RSTRUCT_ARY(copy));
for (i = 0; i < len; i++) { for (i = 0; i < len; i++) {
mrb_ary_set(mrb, RSTRUCT(copy)->values, i, RSTRUCT_PTR(s)[i]); mrb_ary_set(mrb, a, i, RSTRUCT_PTR(s)[i]);
} }
return copy; return copy;
} }
......
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