diff options
author | Jari Vetoniemi <jari.vetoniemi@indooratlas.com> | 2020-03-16 18:49:26 +0900 |
---|---|---|
committer | Jari Vetoniemi <jari.vetoniemi@indooratlas.com> | 2020-03-30 00:39:06 +0900 |
commit | fcbf63e62c627deae76c1b8cb8c0876c536ed811 (patch) | |
tree | 64cb17de3f41a2b6fef2368028fbd00349946994 /jni/ruby/ext/-test-/marshal/usr/usrmarshal.c |
Fresh start
Diffstat (limited to 'jni/ruby/ext/-test-/marshal/usr/usrmarshal.c')
-rw-r--r-- | jni/ruby/ext/-test-/marshal/usr/usrmarshal.c | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/jni/ruby/ext/-test-/marshal/usr/usrmarshal.c b/jni/ruby/ext/-test-/marshal/usr/usrmarshal.c new file mode 100644 index 0000000..0c9e079 --- /dev/null +++ b/jni/ruby/ext/-test-/marshal/usr/usrmarshal.c @@ -0,0 +1,50 @@ +#include <ruby.h> + +static size_t +usr_size(const void *ptr) +{ + return sizeof(int); +} + +static const rb_data_type_t usrmarshal_type = { + "UsrMarshal", + {0, RUBY_DEFAULT_FREE, usr_size,}, + 0, 0, + RUBY_TYPED_FREE_IMMEDIATELY|RUBY_TYPED_WB_PROTECTED, +}; + +static VALUE +usr_alloc(VALUE klass) +{ + int *p; + return TypedData_Make_Struct(klass, int, &usrmarshal_type, p); +} + +static VALUE +usr_init(VALUE self, VALUE val) +{ + int *ptr = Check_TypedStruct(self, &usrmarshal_type); + *ptr = NUM2INT(val); + return self; +} + +static VALUE +usr_value(VALUE self) +{ + int *ptr = Check_TypedStruct(self, &usrmarshal_type); + int val = *ptr; + return INT2NUM(val); +} + +void +Init_usr(void) +{ + VALUE mMarshal = rb_define_module_under(rb_define_module("Bug"), "Marshal"); + VALUE newclass = rb_define_class_under(mMarshal, "UsrMarshal", rb_cObject); + + rb_define_alloc_func(newclass, usr_alloc); + rb_define_method(newclass, "initialize", usr_init, 1); + rb_define_method(newclass, "value", usr_value, 0); + rb_define_method(newclass, "marshal_load", usr_init, 1); + rb_define_method(newclass, "marshal_dump", usr_value, 0); +} |