aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authormatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-12-30 16:07:14 +0000
committermatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-12-30 16:07:14 +0000
commitce0cd6ad1f486040676c30034f43700096afae41 (patch)
tree1e09ddf25a7bf3943e16bfcdaca5106024f4f42b
parenta413e50c415b456cc4b35ede5e3a2521d1bb48d2 (diff)
downloadruby-ce0cd6ad1f486040676c30034f43700096afae41.tar.gz
* object.c (rb_to_float): prohibit conversion from nil to float.
[ruby-dev:37663] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@21204 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog5
-rw-r--r--object.c3
2 files changed, 8 insertions, 0 deletions
diff --git a/ChangeLog b/ChangeLog
index cc5b5d1874..01275b9f36 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Wed Dec 31 00:27:54 2008 Yukihiro Matsumoto <matz@ruby-lang.org>
+
+ * object.c (rb_to_float): prohibit conversion from nil to float.
+ [ruby-dev:37663]
+
Tue Dec 30 21:17:00 2008 Tanaka Akira <akr@fsij.org>
* ext/socket/mkconstants.rb: use sock_define_uconst for INADDR_*
diff --git a/object.c b/object.c
index 889a0c6d21..61aa80a014 100644
--- a/object.c
+++ b/object.c
@@ -2273,6 +2273,9 @@ rb_to_float(VALUE val)
VALUE v;
if (TYPE(val) == T_FLOAT) return val;
+ if (NIL_P(val)) {
+ rb_raise(rb_eTypeError, "can't convert nil into Float");
+ }
v = convert_type(val, "Float", "to_f", Qtrue);
if (TYPE(v) != T_FLOAT) {
const char *cname = rb_obj_classname(val);