mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
merge revision(s) 38548:
* gc.c (obj_id_to_ref): add a macro to treat Bignum object id. This follows the change r38493. * gc.c (id2ref): fix for working fine with Bignum object id on x64 Windows. * gc.c (wmap_finalize): ditto. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_9_3@38588 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
29ff037211
commit
2a9ac6af7c
3 changed files with 16 additions and 4 deletions
|
@ -1,3 +1,12 @@
|
|||
Tue Dec 25 09:54:31 2012 Hiroshi Shirosaki <h.shirosaki@gmail.com>
|
||||
|
||||
* gc.c (obj_id_to_ref): add a macro to treat Bignum object id.
|
||||
This follows the change r38493.
|
||||
|
||||
* gc.c (id2ref): fix for working fine with Bignum object id on x64
|
||||
Windows.
|
||||
* gc.c (wmap_finalize): ditto.
|
||||
|
||||
Sat Dec 22 00:33:28 2012 NAKAMURA Usaku <usa@ruby-lang.org>
|
||||
|
||||
* object.c (rb_obj_hash): shouldn't assume object_id can be long.
|
||||
|
|
5
gc.c
5
gc.c
|
@ -101,8 +101,11 @@ ruby_gc_params_t initial_params = {
|
|||
|
||||
#if SIZEOF_LONG == SIZEOF_VOIDP
|
||||
# define nonspecial_obj_id(obj) (VALUE)((SIGNED_VALUE)(obj)|FIXNUM_FLAG)
|
||||
# define obj_id_to_ref(objid) ((objid) ^ FIXNUM_FLAG) /* unset FIXNUM_FLAG */
|
||||
#elif SIZEOF_LONG_LONG == SIZEOF_VOIDP
|
||||
# define nonspecial_obj_id(obj) LL2NUM((SIGNED_VALUE)(obj) / 2)
|
||||
# define obj_id_to_ref(objid) (FIXNUM_P(objid) ? \
|
||||
((objid) ^ FIXNUM_FLAG) : (NUM2PTR(objid) << 1))
|
||||
#else
|
||||
# error not supported
|
||||
#endif
|
||||
|
@ -3208,7 +3211,7 @@ id2ref(VALUE obj, VALUE objid)
|
|||
if (ptr == Qfalse) return Qfalse;
|
||||
if (ptr == Qnil) return Qnil;
|
||||
if (FIXNUM_P(ptr)) return (VALUE)ptr;
|
||||
ptr = objid ^ FIXNUM_FLAG; /* unset FIXNUM_FLAG */
|
||||
ptr = obj_id_to_ref(objid);
|
||||
|
||||
if ((ptr % sizeof(RVALUE)) == (4 << 2)) {
|
||||
ID symid = ptr / sizeof(RVALUE);
|
||||
|
|
|
@ -1,10 +1,10 @@
|
|||
#define RUBY_VERSION "1.9.3"
|
||||
#define RUBY_PATCHLEVEL 358
|
||||
#define RUBY_PATCHLEVEL 359
|
||||
|
||||
#define RUBY_RELEASE_DATE "2012-12-22"
|
||||
#define RUBY_RELEASE_DATE "2012-12-25"
|
||||
#define RUBY_RELEASE_YEAR 2012
|
||||
#define RUBY_RELEASE_MONTH 12
|
||||
#define RUBY_RELEASE_DAY 22
|
||||
#define RUBY_RELEASE_DAY 25
|
||||
|
||||
#include "ruby/version.h"
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue