From 971a57004e346d87c7f0f55d16f1abb66fe24451 Mon Sep 17 00:00:00 2001 From: mrkn Date: Sun, 19 Sep 2010 17:38:18 +0000 Subject: * ext/bigdecimal/bigdecimal.c (check_rounding_mode, BigDecimal_mode): raise ArgumentError instead of TypeError passing invalid modes. * test/bigdecimal/test_bigdecimal.rb (test_mode, test_round): change against the above modifications. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@29304 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ext/bigdecimal/bigdecimal.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) (limited to 'ext') diff --git a/ext/bigdecimal/bigdecimal.c b/ext/bigdecimal/bigdecimal.c index 64eebecad1..a251a8e9de 100644 --- a/ext/bigdecimal/bigdecimal.c +++ b/ext/bigdecimal/bigdecimal.c @@ -311,7 +311,7 @@ check_rounding_mode(VALUE const v) return VP_ROUND_CEIL; if (id == id_floor) return VP_ROUND_FLOOR; - break; + rb_raise(rb_eArgError, "invalid rounding mode"); default: break; @@ -320,7 +320,7 @@ check_rounding_mode(VALUE const v) Check_Type(v, T_FIXNUM); sw = (unsigned short)FIX2UINT(v); if (!VpIsRoundMode(sw)) { - rb_raise(rb_eTypeError, "invalid rounding mode"); + rb_raise(rb_eArgError, "invalid rounding mode"); } return sw; } @@ -380,7 +380,7 @@ BigDecimal_mode(int argc, VALUE *argv, VALUE self) fo = VpGetException(); if(val==Qnil) return INT2FIX(fo); if(val!=Qfalse && val!=Qtrue) { - rb_raise(rb_eTypeError, "second argument must be true or false"); + rb_raise(rb_eArgError, "second argument must be true or false"); return Qnil; /* Not reached */ } if(f&VP_EXCEPTION_INFINITY) { -- cgit v1.2.3