summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog7
-rw-r--r--include/ruby/intern.h1
-rw-r--r--range.c26
-rw-r--r--struct.c35
4 files changed, 45 insertions, 24 deletions
diff --git a/ChangeLog b/ChangeLog
index e36ef903fe..6ffa20a774 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,10 @@
+Fri Nov 23 13:34:08 2007 Tanaka Akira <akr@fsij.org>
+
+ * struct.c (rb_struct_define_without_accessor): new function.
+
+ * range.c (range_alloc): removed.
+ (Init_Range): use rb_struct_define_without_accessor.
+
Fri Nov 23 11:01:54 2007 Yukihiro Matsumoto <matz@ruby-lang.org>
* re.c (match_begin): should return offset by character.
diff --git a/include/ruby/intern.h b/include/ruby/intern.h
index dbb9a9b07b..7af65d414f 100644
--- a/include/ruby/intern.h
+++ b/include/ruby/intern.h
@@ -542,6 +542,7 @@ VALUE rb_struct_getmember(VALUE, ID);
VALUE rb_struct_iv_get(VALUE, const char*);
VALUE rb_struct_s_members(VALUE);
VALUE rb_struct_members(VALUE);
+VALUE rb_struct_define_without_accessor(char *, VALUE, ...);
/* thread.c */
typedef void rb_unblock_function_t(void *);
typedef VALUE rb_blocking_function_t(void *);
diff --git a/range.c b/range.c
index c0e2176060..5855be5f91 100644
--- a/range.c
+++ b/range.c
@@ -23,22 +23,6 @@ static ID id_cmp, id_succ, id_beg, id_end, id_excl;
#define SET_EXCL(r,v) (RSTRUCT(r)->as.ary[2] = (v) ? Qtrue : Qfalse)
static VALUE
-range_alloc(VALUE klass)
-{
- long n;
- NEWOBJ(r, struct RStruct);
- OBJSETUP(r, klass, T_STRUCT);
-
- n = 3;
-
- RBASIC(r)->flags &= ~RSTRUCT_EMBED_LEN_MASK;
- RBASIC(r)->flags |= n << RSTRUCT_EMBED_LEN_SHIFT;
- rb_mem_clear(r->as.ary, n);
-
- return (VALUE)r;
-}
-
-static VALUE
range_failed(void)
{
rb_raise(rb_eArgError, "bad value for range");
@@ -895,15 +879,9 @@ Init_Range(void)
id_end = rb_intern("end");
id_excl = rb_intern("excl");
- rb_cRange = rb_define_class("Range", rb_cObject);
-
- /* compatibility for rb_struct_members, etc. */
- members = rb_ary_new3(3, ID2SYM(id_beg), ID2SYM(id_end), ID2SYM(id_excl));
- OBJ_FREEZE(members);
- rb_iv_set(rb_cRange, "__size__", INT2FIX(3));
- rb_iv_set(rb_cRange, "__members__", members);
+ rb_cRange = rb_struct_define_without_accessor("Range", rb_cObject,
+ "begin", "end", "excl", NULL);
- rb_define_alloc_func(rb_cRange, range_alloc);
rb_include_module(rb_cRange, rb_mEnumerable);
rb_marshal_define_compat(rb_cRange, rb_cObject, range_dumper, range_loader);
rb_define_method(rb_cRange, "initialize", range_initialize, -1);
diff --git a/struct.c b/struct.c
index e87a082c23..ad5f4619aa 100644
--- a/struct.c
+++ b/struct.c
@@ -218,6 +218,41 @@ make_struct(VALUE name, VALUE members, VALUE klass)
}
VALUE
+rb_struct_define_without_accessor(char *class_name, VALUE super, ...)
+{
+ VALUE klass;
+ va_list ar;
+ VALUE members;
+ long i;
+ char *name;
+
+ members = rb_ary_new2(0);
+ va_start(ar, super);
+ i = 0;
+ while ((name = va_arg(ar, char*)) != NULL) {
+ rb_ary_push(members, ID2SYM(rb_intern(name)));
+ }
+ va_end(ar);
+ OBJ_FREEZE(members);
+
+ if (class_name) {
+ klass = rb_define_class(class_name, super);
+ }
+ else {
+ klass = rb_class_new(super);
+ rb_make_metaclass(klass, RBASIC(super)->klass);
+ rb_class_inherited(super, klass);
+ }
+
+ rb_iv_set(klass, "__size__", LONG2NUM(RARRAY_LEN(members)));
+ rb_iv_set(klass, "__members__", members);
+
+ rb_define_alloc_func(klass, struct_alloc);
+
+ return klass;
+}
+
+VALUE
rb_struct_define(const char *name, ...)
{
va_list ar;