Sha256: bc3cef44340cd08bae52a58ee5dbd0df6eca57b8eaf6d1df10bd01e155e4ccbf
Contents?: true
Size: 1.67 KB
Versions: 1
Compression:
Stored size: 1.67 KB
Contents
#include <ruby.h> #include <xlsxwriter.h> #include "xlsxwriter_ext.h" #include "shared_strings.h" struct sst { lxw_sst *sst; }; VALUE cSharedStringsTable; size_t sst_size(const void *data) { return sizeof(struct sst); } const rb_data_type_t sst_type = { .wrap_struct_name = "lxw_rich_string_tuple", .function = { .dmark = NULL, .dfree = ruby_xfree, .dsize = sst_size, }, .data = NULL, .flags = RUBY_TYPED_FREE_IMMEDIATELY, }; /* :nodoc: */ VALUE sst_alloc(VALUE klass) { VALUE obj; struct sst *sst_ptr; obj = TypedData_Make_Struct(klass, struct sst, &sst_type, sst_ptr); sst_ptr->sst = NULL; return obj; } VALUE alloc_shared_strings_table_by_ref(struct lxw_sst *sst) { if (!sst) return Qnil; VALUE object = rb_obj_alloc(cSharedStringsTable); struct sst *sst_ptr; TypedData_Get_Struct(object, struct sst, &sst_type, sst_ptr); sst_ptr->sst = sst; return object; } VALUE sst_string_count_get_(VALUE self) { struct sst *sst_ptr; TypedData_Get_Struct(self, struct sst, &sst_type, sst_ptr); return INT2NUM(sst_ptr->sst->string_count); } VALUE sst_string_count_set_(VALUE self, VALUE val) { struct sst *sst_ptr; TypedData_Get_Struct(self, struct sst, &sst_type, sst_ptr); sst_ptr->sst->string_count = NUM2INT(val); return val; } void init_xlsxwriter_shared_strings_table() { cSharedStringsTable = rb_define_class_under(mXlsxWriter, "SharedStringsTable", rb_cObject); rb_define_alloc_func(cSharedStringsTable, sst_alloc); rb_define_method(cSharedStringsTable, "string_count", sst_string_count_get_, 0); rb_define_method(cSharedStringsTable, "string_count=", sst_string_count_set_, 1); }
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
xlsxwriter-0.2.3.pre.1 | ext/xlsxwriter/shared_strings.c |