From 545ebecb30dce3fbb63c319a553c78cfb44a20a1 Mon Sep 17 00:00:00 2001 From: shyouhei Date: Thu, 5 Jun 2008 03:22:03 +0000 Subject: merge revision(s) 13587: * gc.c (id2ref): valid id should not refer T_VALUE nor T_ICLASS. [ruby-dev:31911] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8_5@16825 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 5 +++++ gc.c | 4 +++- version.h | 8 ++++---- 3 files changed, 12 insertions(+), 5 deletions(-) diff --git a/ChangeLog b/ChangeLog index bf1de06a1f..2b7dcfae6f 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +Thu Jun 5 12:21:06 2008 Yukihiro Matsumoto + + * gc.c (id2ref): valid id should not refer T_VALUE nor T_ICLASS. + [ruby-dev:31911] + Wed Jun 4 16:39:56 2008 Nobuyoshi Nakada * Makefile.in (ext/extinit.o): use $(OUTFLAG) as well as other diff --git a/gc.c b/gc.c index ef3044c1a3..2e171bd9d7 100644 --- a/gc.c +++ b/gc.c @@ -1878,6 +1878,7 @@ id2ref(obj, objid) VALUE obj, objid; { unsigned long ptr, p0; + int type; rb_secure(4); p0 = ptr = NUM2ULONG(objid); @@ -1894,7 +1895,8 @@ id2ref(obj, objid) return ID2SYM(symid); } - if (!is_pointer_to_heap((void *)ptr)|| BUILTIN_TYPE(ptr) >= T_BLKTAG) { + if (!is_pointer_to_heap((void *)ptr)|| + (type = BUILTIN_TYPE(ptr)) >= T_BLKTAG || type == T_ICLASS) { rb_raise(rb_eRangeError, "0x%lx is not id value", p0); } if (BUILTIN_TYPE(ptr) == 0 || RBASIC(ptr)->klass == 0) { diff --git a/version.h b/version.h index 46aa14a237..d9f6a703fe 100644 --- a/version.h +++ b/version.h @@ -1,15 +1,15 @@ #define RUBY_VERSION "1.8.5" -#define RUBY_RELEASE_DATE "2008-06-04" +#define RUBY_RELEASE_DATE "2008-06-05" #define RUBY_VERSION_CODE 185 -#define RUBY_RELEASE_CODE 20080604 -#define RUBY_PATCHLEVEL 126 +#define RUBY_RELEASE_CODE 20080605 +#define RUBY_PATCHLEVEL 127 #define RUBY_VERSION_MAJOR 1 #define RUBY_VERSION_MINOR 8 #define RUBY_VERSION_TEENY 5 #define RUBY_RELEASE_YEAR 2008 #define RUBY_RELEASE_MONTH 6 -#define RUBY_RELEASE_DAY 4 +#define RUBY_RELEASE_DAY 5 #ifdef RUBY_EXTERN RUBY_EXTERN const char ruby_version[]; -- cgit v1.2.3