diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2010-10-12 14:09:27 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2010-10-12 14:09:27 +0000 |
commit | 3c24bea4b5bfa33b3dddde688638cc2892f9512c (patch) | |
tree | 5b61cda1b0259745a7113f1d4acc99e665afa218 | |
parent | 0172f3181ff592f3ce20b5a04c1eff603f48f557 (diff) |
* gc.c (obj_free, rb_objspace_call_finalizer): fix truncating
cast.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@29460 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | gc.c | 4 |
2 files changed, 6 insertions, 3 deletions
@@ -1,4 +1,7 @@ -Tue Oct 12 23:03:20 2010 Nobuyoshi Nakada <nobu@ruby-lang.org> +Tue Oct 12 23:09:24 2010 Nobuyoshi Nakada <nobu@ruby-lang.org> + + * gc.c (obj_free, rb_objspace_call_finalizer): fix truncating + cast. * gc.c (mark_current_machine_context): suppress warnings. @@ -2190,7 +2190,7 @@ obj_free(rb_objspace_t *objspace, VALUE obj) if (RTYPEDDATA_P(obj)) { RDATA(obj)->dfree = RANY(obj)->as.typeddata.type->function.dfree; } - if ((long)RANY(obj)->as.data.dfree == -1) { + if (RANY(obj)->as.data.dfree == (RUBY_DATA_FUNC)-1) { xfree(DATA_PTR(obj)); } else if (RANY(obj)->as.data.dfree) { @@ -2908,7 +2908,7 @@ rb_objspace_call_finalizer(rb_objspace_t *objspace) if (RTYPEDDATA_P(p)) { RDATA(p)->dfree = RANY(p)->as.typeddata.type->function.dfree; } - if ((long)RANY(p)->as.data.dfree == -1) { + if (RANY(p)->as.data.dfree == (RUBY_DATA_FUNC)-1) { xfree(DATA_PTR(p)); } else if (RANY(p)->as.data.dfree) { |