diff options
| author | usa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-03-06 06:44:41 +0000 |
|---|---|---|
| committer | usa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-03-06 06:44:41 +0000 |
| commit | 312de647e72b9bbfb7ef744aaf44b775bd236606 (patch) | |
| tree | 26fccea37e0ce2d8ceb8625bd67a0db29b6bb295 /sprintf.c | |
| parent | 2e8927da99167e25e71c8b65eb710f2d0a986edd (diff) | |
| download | ruby-312de647e72b9bbfb7ef744aaf44b775bd236606.tar.gz ruby-312de647e72b9bbfb7ef744aaf44b775bd236606.tar.xz ruby-312de647e72b9bbfb7ef744aaf44b775bd236606.zip | |
* sprintf.c (rb_str_format): casting double to long is undefined
if the interger part of double is out of the range of long.
(fix previous commit).
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@15716 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'sprintf.c')
| -rw-r--r-- | sprintf.c | 3 |
1 files changed, 1 insertions, 2 deletions
@@ -540,8 +540,7 @@ rb_str_format(int argc, const VALUE *argv, VALUE fmt) bin_retry: switch (TYPE(val)) { case T_FLOAT: - if (RFLOAT_VALUE(val) <= LONG_MAX && - RFLOAT_VALUE(val) >= LONG_MIN) { + if (FIXABLE(RFLOAT_VALUE(val))) { val = LONG2FIX((long)RFLOAT_VALUE(val)); goto bin_retry; } |
