Skip to content

Commit

Permalink
Revert "Fixed number_with_precision rounding error [#6182 state:resol…
Browse files Browse the repository at this point in the history
…ved]"

This reverts commit 006ec77.
  • Loading branch information
drogus committed Dec 17, 2010
1 parent f7e3362 commit 07567ae
Show file tree
Hide file tree
Showing 2 changed files with 2 additions and 8 deletions.
5 changes: 2 additions & 3 deletions actionpack/lib/action_view/helpers/number_helper.rb
Expand Up @@ -270,13 +270,12 @@ def number_with_precision(number, options = {})
digits, rounded_number = 1, 0
else
digits = (Math.log10(number.abs) + 1).floor
rounded_number = (BigDecimal.new(number.to_s) / 10 ** (digits - precision)).round.to_f * 10 ** (digits - precision)
digits = (Math.log10(rounded_number.abs) + 1).floor # After rounding, the number of digits may have changed
rounded_number = BigDecimal.new((number / 10 ** (digits - precision)).to_s).round.to_f * 10 ** (digits - precision)
end
precision -= digits
precision = precision > 0 ? precision : 0 #don't let it be negative
else
rounded_number = BigDecimal.new(number.to_s).round(precision).to_f
rounded_number = BigDecimal.new((number * (10 ** precision)).to_s).round.to_f / 10 ** precision
end
formatted_number = number_with_delimiter("%01.#{precision}f" % rounded_number, options)
if strip_insignificant_zeros
Expand Down
5 changes: 0 additions & 5 deletions actionpack/test/template/number_helper_test.rb
Expand Up @@ -100,11 +100,6 @@ def test_number_with_precision
assert_equal("0", number_with_precision(0, :precision => 0))
assert_equal("0.00100", number_with_precision(0.001, :precision => 5))
assert_equal("0.001", number_with_precision(0.00111, :precision => 3))
assert_equal("10.00", number_with_precision(9.995, :precision => 2))
assert_equal("11.00", number_with_precision(10.995, :precision => 2))
assert_equal("10.0", number_with_precision(9.995, :precision => 3, :significant => true))
assert_equal("9.99", number_with_precision(9.994, :precision => 3, :significant => true))
assert_equal("11.0", number_with_precision(10.995, :precision => 3, :significant => true))
end

def test_number_with_precision_with_custom_delimiter_and_separator
Expand Down

0 comments on commit 07567ae

Please sign in to comment.