From 056f219ecaa8daa50a77d28bed49fb5a4bf75928 Mon Sep 17 00:00:00 2001 From: matz Date: Fri, 13 Mar 1998 09:04:32 +0000 Subject: [PATCH] 1.1b9_02 git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/v1_1r@122 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 7 +++++++ env.h | 1 + eval.c | 8 +++++--- gc.c | 6 +++++- io.c | 4 ++-- lib/weakref.rb | 29 ++++++++++++++++------------- object.c | 1 + range.c | 6 +----- 8 files changed, 38 insertions(+), 24 deletions(-) diff --git a/ChangeLog b/ChangeLog index 047c3354ab..8543292541 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,10 @@ +Fri Mar 13 13:49:24 1998 Yukihiro Matsumoto + + * object.c (mod_clone): need to dups constants and instance + variables. + + * eval.c (rb_eval): forgot to initialize body for NODE_DEFS. + Thu Mar 12 15:33:57 1998 Yukihiro Matsumoto * experimental release 1.1b9_01. diff --git a/env.h b/env.h index ebcfcc5d31..b254ddef1c 100644 --- a/env.h +++ b/env.h @@ -12,6 +12,7 @@ #define ENV_H extern struct FRAME { + VALUE self; int argc; VALUE *argv; ID last_func; diff --git a/eval.c b/eval.c index 4c070729e7..a0efea26dc 100644 --- a/eval.c +++ b/eval.c @@ -1879,8 +1879,9 @@ rb_eval(self, node) } PUSH_ITER(the_iter->iter?ITER_PRE:ITER_NOT); - result = rb_call(RCLASS(the_frame->last_class)->super, self, - the_frame->last_func, argc, argv, 3); + result = rb_call(RCLASS(the_frame->last_class)->super, + the_frame->self, the_frame->last_func, + argc, argv, 3); POP_ITER(); } break; @@ -2234,7 +2235,7 @@ rb_eval(self, node) if (node->nd_defn) { VALUE recv = rb_eval(self, node->nd_recv); VALUE klass; - NODE *body; + NODE *body = 0; if (FIXNUM_P(recv)) { TypeError("Can't define method \"%s\" for Fixnum", @@ -3169,6 +3170,7 @@ rb_call0(klass, recv, id, argc, argv, body, nosuper) PUSH_FRAME(); the_frame->last_func = id; the_frame->last_class = nosuper?0:klass; + the_frame->self = recv; the_frame->argc = argc; the_frame->argv = argv; diff --git a/gc.c b/gc.c index fe1e4942f8..edf06d313a 100644 --- a/gc.c +++ b/gc.c @@ -1016,6 +1016,10 @@ id2ref(obj, id) INT ptr = NUM2INT(id); if (FIXNUM_P(ptr)) return (VALUE)ptr; + if (ptr == TRUE) return TRUE; + if (ptr == FALSE) return FALSE; + if (ptr == Qnil) return Qnil; + if (!looks_pointerp(ptr)) { IndexError("0x%x is not the id value", ptr); } @@ -1045,7 +1049,7 @@ Init_GC() rb_define_module_function(mObSpace, "remove_finalizer", rm_final, 1); rb_define_module_function(mObSpace, "finalizers", finals, 0); rb_define_module_function(mObSpace, "call_finalizer", call_final, 1); - rb_define_module_function(mObSpace, "id2ref", id2ref, 1); + rb_define_module_function(mObSpace, "_id2ref", id2ref, 1); rb_global_variable(&finalizers); finalizers = ary_new(); diff --git a/io.c b/io.c index 751a5ef393..4e3f60c982 100644 --- a/io.c +++ b/io.c @@ -369,7 +369,7 @@ io_gets_method(argc, argv, io) VALUE rs; if (argc == 0) { - return io_gets(io); + rs = RS; } else { rb_scan_args(argc, argv, "1", &rs); @@ -394,7 +394,6 @@ io_gets_method(argc, argv, io) rsptr = 0; rslen = 0; } - newline = rslen ? rsptr[rslen - 1] : 0777; GetOpenFile(io, fptr); io_readable(fptr); @@ -413,6 +412,7 @@ io_gets_method(argc, argv, io) } while (c != EOF); } + newline = rslen ? rsptr[rslen - 1] : 0777; { char buf[8192]; char *bp, *bpe = buf + sizeof buf - 3; diff --git a/lib/weakref.rb b/lib/weakref.rb index 18d3bbc9a3..6a6dcec5a1 100644 --- a/lib/weakref.rb +++ b/lib/weakref.rb @@ -31,26 +31,27 @@ class WeakRefsuper = RCLASS(module)->super; clone->iv_tbl = 0; clone->m_tbl = 0; /* avoid GC crashing */ + clone->iv_tbl = st_copy(RCLASS(module)->iv_tbl); clone->m_tbl = st_copy(RCLASS(module)->m_tbl); return (VALUE)clone; diff --git a/range.c b/range.c index a3f8865dc4..74ac972668 100644 --- a/range.c +++ b/range.c @@ -21,11 +21,7 @@ static VALUE range_check(args) VALUE *args; { - VALUE v = rb_funcall(args[0], rb_intern("<="), 1, args[1]); - - if (!RTEST(v)) { - Fail(""); /* no ascending values */ - } + rb_funcall(args[0], rb_intern("<=>"), 1, args[1]); return Qnil; }