diff options
| author | ksss <[email protected]> | 2014-03-16 23:39:58 +0900 |
|---|---|---|
| committer | ksss <[email protected]> | 2014-03-16 23:39:58 +0900 |
| commit | 0fab9d557e62a364b0d2d7563c502e07ed53c227 (patch) | |
| tree | 3a09a19d2359fdffb39415d77eb321a35cb1da61 | |
| parent | 18bebd3acdea1124b3d192ffc171eb6807d391cf (diff) | |
| download | mruby-0fab9d557e62a364b0d2d7563c502e07ed53c227.tar.gz mruby-0fab9d557e62a364b0d2d7563c502e07ed53c227.zip | |
float + nil should be raise TypeError
| -rw-r--r-- | src/numeric.c | 11 | ||||
| -rw-r--r-- | test/t/float.rb | 3 |
2 files changed, 8 insertions, 6 deletions
diff --git a/src/numeric.c b/src/numeric.c index 38a05ae92..e2af14b97 100644 --- a/src/numeric.c +++ b/src/numeric.c @@ -1306,15 +1306,14 @@ num_cmp(mrb_state *mrb, mrb_value self) * and <code>other</code>. */ static mrb_value -flo_plus(mrb_state *mrb, mrb_value self) +flo_plus(mrb_state *mrb, mrb_value x) { - mrb_float x, y; - - x = mrb_float(self); - mrb_get_args(mrb, "f", &y); + mrb_value y; - return mrb_float_value(mrb, x + y); + mrb_get_args(mrb, "o", &y); + return mrb_float_value(mrb, mrb_float(x) + mrb_to_flo(mrb, y)); } + /* ------------------------------------------------------------------------*/ void mrb_init_numeric(mrb_state *mrb) diff --git a/test/t/float.rb b/test/t/float.rb index b50b1e175..c817e01da 100644 --- a/test/t/float.rb +++ b/test/t/float.rb @@ -15,6 +15,9 @@ assert('Float#+', '15.2.9.3.1') do assert_float(3.123456789, a) assert_float(4.123456789, b) + + assert_raise(TypeError){ 0.0+nil } + assert_raise(TypeError){ 1.0+nil } end assert('Float#-', '15.2.9.3.2') do |
