mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* numeric.c (int_round): should not just truncate.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@12437 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
3c17590061
commit
931614a341
2 changed files with 30 additions and 17 deletions
|
@ -18,7 +18,7 @@ Tue Jun 5 13:17:11 2007 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||||
pack.c, re.c, thread.c, thread_win32.ci, vm.c, vm_dump.c: fixed
|
pack.c, re.c, thread.c, thread_win32.ci, vm.c, vm_dump.c: fixed
|
||||||
indentation.
|
indentation.
|
||||||
|
|
||||||
Mon Jun 04 21:15:45 2007 NARUSE, Yui <naruse@ruby-lang.org>
|
Mon Jun 4 21:15:45 2007 NARUSE, Yui <naruse@ruby-lang.org>
|
||||||
|
|
||||||
* lib/json.rb, lib/json, ext/json, test/json:
|
* lib/json.rb, lib/json, ext/json, test/json:
|
||||||
import JSON library.
|
import JSON library.
|
||||||
|
@ -26,6 +26,10 @@ Mon Jun 04 21:15:45 2007 NARUSE, Yui <naruse@ruby-lang.org>
|
||||||
* ext/nkf: import nkf.c rev:1.124
|
* ext/nkf: import nkf.c rev:1.124
|
||||||
Support CP10001.
|
Support CP10001.
|
||||||
|
|
||||||
|
Mon Jun 4 20:52:58 2007 Yukihiro Matsumoto <matz@ruby-lang.org>
|
||||||
|
|
||||||
|
* numeric.c (int_round): should not just truncate.
|
||||||
|
|
||||||
Sat Jun 2 16:48:55 2007 Koichi Sasada <ko1@atdot.net>
|
Sat Jun 2 16:48:55 2007 Koichi Sasada <ko1@atdot.net>
|
||||||
|
|
||||||
* cont.c (Fiber#pass): rename to Fiber#yield. Block parameter
|
* cont.c (Fiber#pass): rename to Fiber#yield. Block parameter
|
||||||
|
|
41
numeric.c
41
numeric.c
|
@ -2308,22 +2308,6 @@ int_pow(long x, unsigned long y)
|
||||||
return LONG2NUM(z);
|
return LONG2NUM(z);
|
||||||
}
|
}
|
||||||
|
|
||||||
static VALUE
|
|
||||||
int_round(int argc, VALUE* argv, VALUE num)
|
|
||||||
{
|
|
||||||
VALUE nd;
|
|
||||||
int ndigits;
|
|
||||||
|
|
||||||
if (argc == 0) return num;
|
|
||||||
rb_scan_args(argc, argv, "1", &nd);
|
|
||||||
ndigits = NUM2INT(nd);
|
|
||||||
if (ndigits > 0) {
|
|
||||||
return rb_Float(num);
|
|
||||||
}
|
|
||||||
ndigits = -ndigits;
|
|
||||||
return rb_funcall(num, '-', 1, rb_funcall(num, '%', 1, int_pow(10, ndigits)));
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* call-seq:
|
* call-seq:
|
||||||
* fix ** other => Numeric
|
* fix ** other => Numeric
|
||||||
|
@ -2911,6 +2895,31 @@ int_dotimes(VALUE num)
|
||||||
return num;
|
return num;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static VALUE
|
||||||
|
int_round(int argc, VALUE* argv, VALUE num)
|
||||||
|
{
|
||||||
|
VALUE n, f, h, r;
|
||||||
|
int ndigits;
|
||||||
|
|
||||||
|
if (argc == 0) return num;
|
||||||
|
if (FIXNUM_P(num)) return num_round(argc, argv, num);
|
||||||
|
|
||||||
|
rb_scan_args(argc, argv, "1", &n);
|
||||||
|
ndigits = NUM2INT(n);
|
||||||
|
if (ndigits > 0) {
|
||||||
|
return rb_Float(num);
|
||||||
|
}
|
||||||
|
ndigits = -ndigits;
|
||||||
|
f = int_pow(10, ndigits);
|
||||||
|
h = rb_funcall(f, '/', 1, INT2FIX(2));
|
||||||
|
r = rb_funcall(num, '%', 1, f);
|
||||||
|
n = rb_funcall(num, '-', 1, r);
|
||||||
|
if (!RTEST(rb_funcall(r, '<', 1, h))) {
|
||||||
|
n = rb_funcall(n, '+', 1, f);
|
||||||
|
}
|
||||||
|
return n;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* call-seq:
|
* call-seq:
|
||||||
* fix.zero? => true or false
|
* fix.zero? => true or false
|
||||||
|
|
Loading…
Reference in a new issue