diff options
author | akr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2005-12-12 15:09:50 +0000 |
---|---|---|
committer | akr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2005-12-12 15:09:50 +0000 |
commit | 2da40f048ede054fec9f172464effdd8eb3f0d91 (patch) | |
tree | 845dbcef4a2c5072944ecb5a828db47a4d106d02 | |
parent | 2a0604d7b8029bec1815bc871efa3c0109923458 (diff) | |
download | ruby-2da40f048ede054fec9f172464effdd8eb3f0d91.tar.gz |
* sprintf.c (rb_str_format): fix a GC problem.
[ruby-dev:28001]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@9681 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | sprintf.c | 3 |
2 files changed, 7 insertions, 1 deletions
@@ -1,3 +1,8 @@ +Tue Dec 13 00:08:09 2005 Tanaka Akira <akr@m17n.org> + + * sprintf.c (rb_str_format): fix a GC problem. + [ruby-dev:28001] + Mon Dec 12 15:51:22 2005 GOTOU Yuuzou <gotoyuzo@notwork.org> * test/openssl/test_ssl.rb (test_parallel): call GC.start to close @@ -604,11 +604,12 @@ rb_str_format(int argc, const VALUE *argv, VALUE fmt) } } else { + volatile VALUE tmp1; if (!RBIGNUM(val)->sign) { val = rb_big_clone(val); rb_big_2comp(val); } - tmp = rb_big2str(val, base); + tmp1 = tmp = rb_big2str(val, base); s = RSTRING(tmp)->ptr; if (*s == '-') { if (base == 10) { |