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 | b525710be4dbfe8f725410787d977e97b103393e (patch) | |
tree | 3e6ea625deb823481c2ec16ed969ff9d02bfe945 | |
parent | f58c42d35776b2818474b59cbe109d180705b56d (diff) |
* sprintf.c (rb_str_format): fix a GC problem.
[ruby-dev:28001]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8@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:54:56 2005 GOTOU Yuuzou <gotoyuzo@notwork.org> * test/openssl/test_ssl.rb (test_parallel): call GC.start to close @@ -454,6 +454,7 @@ rb_f_sprintf(argc, argv) int base, bignum = 0; int len, pos; VALUE tmp; + volatile VALUE tmp1; switch (*p) { case 'd': @@ -602,7 +603,7 @@ rb_f_sprintf(argc, argv) 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) { |