Actions
Bug #19335
closedInteger#remainder and Numeric#remainder should respect #coerce
Bug #19335: Integer#remainder and Numeric#remainder should respect #coerce
Description
Thinking of the result of the following, Integer#remainder and Numeric#remainder should respect #coerce.
(BigDecimal#remainder seems to respect #coerce.)
c = Object.new def c.coerce(other) [other, 10] end p 1234 / c # => 123 p 1234.div(c) # => 123 p 1234.quo(c) # => (617/5) p 1234.fdiv(c) # => 123.4 p 1234 % c # => 4 p 1234.modulo(c) # => 4 p 1234.divmod(c) # => [123, 4] p 1234.remainder(c) # => in `remainder': comparison of Object with 0 failed (ArgumentError) p 1234.0 / c # => 123.4 p 1234.0.div(c) # => 123 p 1234.0.quo(c) # => 123.4 p 1234.0.fdiv(c) # => 123.4 p 1234.0 % c # => 4.0 p 1234.0.modulo(c) # => 4.0 p 1234.0.divmod(c) # => [123, 4.0] p 1234.0.remainder(c) # => in `remainder': comparison of Object with 0 failed (ArgumentError) require 'bigdecimal' p BigDecimal('1234.0').remainder(c) # => 0.4e1
Updated by nobu (Nobuyoshi Nakada) almost 3 years ago
- Assignee set to mrkn (Kenta Murata)
Sounds reasonable.
Updated by kyanagi (Kouhei Yanagita) almost 3 years ago
- Description updated (diff)
Updated by nobu (Nobuyoshi Nakada) almost 3 years ago
- Status changed from Open to Closed
Applied in changeset git|71ce7e1825c5b8fe08dd96cd77c6a379afd34256.
[Bug #19335] Integer#remainder should respect #coerce (#7120)
Also Numeric#remainder should.
Actions