Sha256: 7cc9962d4edc567d353a568090236dbf607b3873d3a41f35e6621d1561dc1fec
Contents?: true
Size: 1.48 KB
Versions: 6
Compression:
Stored size: 1.48 KB
Contents
module Polyfill module V2_4 module Integer def ceil(ndigits = 0) ndigits = ndigits.to_int 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 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 = [] remainder = self while remainder > 0 remainder, value = remainder.divmod(base) acc.push(value) end acc end def floor(ndigits = 0) ndigits = ndigits.to_int return super() if ndigits == 0 return to_f if ndigits > 0 place = 10**-ndigits (to_f / place).floor * place end 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 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 return super() if ndigits == 0 return to_f if ndigits > 0 place = 10**-ndigits (to_f / place).truncate * place end end end end
Version data entries
6 entries across 6 versions & 1 rubygems