lib/polyfill/v2_4/integer.rb in polyfill-1.0.1 vs lib/polyfill/v2_4/integer.rb in polyfill-1.1.0
- old
+ new
@@ -1,19 +1,19 @@
module Polyfill
module V2_4
module Integer
def ceil(ndigits = 0)
- ndigits = ndigits.to_int
+ ndigits = InternalUtils.to_int(ndigits)
return super() if ndigits == 0
return to_f if ndigits > 0
place = 10**-ndigits
(to_f / place).ceil * place
end
def digits(base = 10)
- base = base.to_int
+ base = InternalUtils.to_int(base)
raise Math::DomainError, 'out of domain' if self < 0
raise ArgumentError, 'negative radix' if base < 0
raise ArgumentError, "invalid radix #{base}" if base < 2
acc = []
@@ -24,11 +24,11 @@
end
acc
end
def floor(ndigits = 0)
- ndigits = ndigits.to_int
+ ndigits = InternalUtils.to_int(ndigits)
return super() if ndigits == 0
return to_f if ndigits > 0
place = 10**-ndigits
(to_f / place).floor * place
@@ -36,19 +36,19 @@
def round(ndigits = 0, half: nil)
unless [nil, :down, :even, :up, 'down', 'even', 'up'].include?(half)
raise ArgumentError, "invalid rounding mode: #{half}"
end
- ndigits = ndigits.to_int
+ ndigits = InternalUtils.to_int(ndigits)
return super() if ndigits == 0
return to_f if ndigits > 0
place = 10**-ndigits
(to_f / place).round * place
end
def truncate(ndigits = 0)
- ndigits = ndigits.to_int
+ ndigits = InternalUtils.to_int(ndigits)
return super() if ndigits == 0
return to_f if ndigits > 0
place = 10**-ndigits
(to_f / place).truncate * place