summaryrefslogtreecommitdiffhomepage
path: root/mrbgems/mruby-inline-struct/test/inline.c
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2021-10-02 20:11:32 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2021-10-02 20:11:32 +0900
commitd64d8ca8e4515a2e03165401470ef109a6097e5d (patch)
treeb5739f569da7eb1c6cfd40f683b5138d0f4e59e3 /mrbgems/mruby-inline-struct/test/inline.c
parent4e504eaca13ec6b24de0e10068afc43f0bee39d5 (diff)
parent31e3dbc5a8b8311f4a507c9dc1c997d166c9c8a9 (diff)
downloadmruby-d64d8ca8e4515a2e03165401470ef109a6097e5d.tar.gz
mruby-d64d8ca8e4515a2e03165401470ef109a6097e5d.zip
Merge branch 'dearblue-inline-struct-gem'
Diffstat (limited to 'mrbgems/mruby-inline-struct/test/inline.c')
-rw-r--r--mrbgems/mruby-inline-struct/test/inline.c85
1 files changed, 0 insertions, 85 deletions
diff --git a/mrbgems/mruby-inline-struct/test/inline.c b/mrbgems/mruby-inline-struct/test/inline.c
deleted file mode 100644
index 16d16fa4d..000000000
--- a/mrbgems/mruby-inline-struct/test/inline.c
+++ /dev/null
@@ -1,85 +0,0 @@
-#include <mruby.h>
-#include <mruby/class.h>
-#include <mruby/string.h>
-#include <mruby/istruct.h>
-
-static mrb_value
-istruct_test_initialize(mrb_state *mrb, mrb_value self)
-{
- char *string = (char*)mrb_istruct_ptr(self);
- mrb_int size = mrb_istruct_size();
- mrb_value object = mrb_get_arg1(mrb);
-
- if (mrb_integer_p(object)) {
- strncpy(string, "fixnum", size-1);
- }
-#ifndef MRB_NO_FLOAT
- else if (mrb_float_p(object)) {
- strncpy(string, "float", size-1);
- }
-#endif
- else if (mrb_string_p(object)) {
- strncpy(string, "string", size-1);
- }
- else {
- strncpy(string, "anything", size-1);
- }
-
- string[size - 1] = 0; // force NULL at the end
- return self;
-}
-
-static mrb_value
-istruct_test_to_s(mrb_state *mrb, mrb_value self)
-{
- return mrb_str_new_cstr(mrb, (const char*)mrb_istruct_ptr(self));
-}
-
-static mrb_value
-istruct_test_length(mrb_state *mrb, mrb_value self)
-{
- return mrb_fixnum_value(mrb_istruct_size());
-}
-
-static mrb_value
-istruct_test_test_receive(mrb_state *mrb, mrb_value self)
-{
- mrb_value object = mrb_get_arg1(mrb);
-
- if (mrb_obj_class(mrb, object) != mrb_class_get(mrb, "InlineStructTest"))
- {
- mrb_raise(mrb, E_TYPE_ERROR, "Expected InlineStructTest");
- }
- return mrb_bool_value(((char*)mrb_istruct_ptr(object))[0] == 's');
-}
-
-static mrb_value
-istruct_test_test_receive_direct(mrb_state *mrb, mrb_value self)
-{
- char *ptr;
- struct RClass *klass = mrb_class_get(mrb, "InlineStructTest");
- mrb_get_args(mrb, "I", &ptr, klass);
- return mrb_bool_value(ptr[0] == 's');
-}
-
-static mrb_value
-istruct_test_mutate(mrb_state *mrb, mrb_value self)
-{
- char *ptr = (char*)mrb_istruct_ptr(self);
- memcpy(ptr, "mutate", 6);
- return mrb_nil_value();
-}
-
-void mrb_mruby_inline_struct_gem_test(mrb_state *mrb)
-{
- struct RClass *cls;
-
- cls = mrb_define_class(mrb, "InlineStructTest", mrb->object_class);
- MRB_SET_INSTANCE_TT(cls, MRB_TT_ISTRUCT);
- mrb_define_method(mrb, cls, "initialize", istruct_test_initialize, MRB_ARGS_REQ(1));
- mrb_define_method(mrb, cls, "to_s", istruct_test_to_s, MRB_ARGS_NONE());
- mrb_define_method(mrb, cls, "mutate", istruct_test_mutate, MRB_ARGS_NONE());
- mrb_define_class_method(mrb, cls, "length", istruct_test_length, MRB_ARGS_NONE());
- mrb_define_class_method(mrb, cls, "test_receive", istruct_test_test_receive, MRB_ARGS_REQ(1));
- mrb_define_class_method(mrb, cls, "test_receive_direct", istruct_test_test_receive_direct, MRB_ARGS_REQ(1));
-}