From: shyouhei@...
Date: 2018-07-11T01:55:44+00:00
Subject: [ruby-core:87898] [Ruby trunk Bug#12548] Rounding modes inconsistency between round versus sprintf

Issue #12548 has been updated by shyouhei (Shyouhei Urabe).


The current status is:

- We once have fixed this bug.
- That caused rails breakage.
- Everybody complained.
- So we reverted.

I personally believe this issue is a real bug but it seems I am a minority here.  The consensus, if any, is that it should be kept as it is.

See also: https://bugs.ruby-lang.org/issues/12958

----------------------------------------
Bug #12548: Rounding modes inconsistency between round versus sprintf
https://bugs.ruby-lang.org/issues/12548#change-72909

* Author: unclekiki (Kieran McCusker)
* Status: Open
* Priority: Normal
* Assignee: 
* Target version: 
* ruby -v: 2.4.0
* Backport: 2.1: UNKNOWN, 2.2: UNKNOWN, 2.3: UNKNOWN
----------------------------------------
Hi

I've found this possible bug with `sprintf` in our production code, but it
seems very odd that no one has reported it so I'm doubting myself.

I've tested a few versions (CRuby 2.3.1 and 2.1.9) and it was present in
both.

To reproduce in irb:

```ruby
sprintf('%1.0f', 12.5)
```

Expected result 13 actual 12

In fact if you look at the number sequence 0.5 -> 99.5 you find the even
half will all round down and the odd half round up. 12.5.round produces the correct result (13)

If you do the same in jruby 2.2.1 you get the expected result of 13.

Many thanks

Kieran


---Files--------------------------------
round_even.patch (4.43 KB)


-- 
https://bugs.ruby-lang.org/

Unsubscribe: <mailto:ruby-core-request@ruby-lang.org?subject=unsubscribe>
<http://lists.ruby-lang.org/cgi-bin/mailman/options/ruby-core>