summaryrefslogtreecommitdiffstats
path: root/object.c
diff options
context:
space:
mode:
authormatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-12-29 13:40:33 +0000
committermatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-12-29 13:40:33 +0000
commit9ba8470dee98b8da2c813aed8ce2b420abd6548a (patch)
tree23ba13bfdfb9f68d7fdeefb9f774968ffa2b8e01 /object.c
parent37379378fa275baf099e0fda7240197ff6c03008 (diff)
downloadruby-9ba8470dee98b8da2c813aed8ce2b420abd6548a.tar.gz
ruby-9ba8470dee98b8da2c813aed8ce2b420abd6548a.tar.xz
ruby-9ba8470dee98b8da2c813aed8ce2b420abd6548a.zip
* pack.c (pack_pack): template f should not accept non float
values. [ruby-dev:37656] * object.c (rb_to_float): new function to type check floats. git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@21179 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'object.c')
-rw-r--r--object.c15
1 files changed, 15 insertions, 0 deletions
diff --git a/object.c b/object.c
index 4f2fcb6de..889a0c6d2 100644
--- a/object.c
+++ b/object.c
@@ -2267,6 +2267,21 @@ rb_f_float(VALUE obj, VALUE arg)
return rb_Float(arg);
}
+VALUE
+rb_to_float(VALUE val)
+{
+ VALUE v;
+
+ if (TYPE(val) == T_FLOAT) return val;
+ v = convert_type(val, "Float", "to_f", Qtrue);
+ if (TYPE(v) != T_FLOAT) {
+ const char *cname = rb_obj_classname(val);
+ rb_raise(rb_eTypeError, "can't convert %s to Float (%s#to_f gives %s)",
+ cname, cname, rb_obj_classname(v));
+ }
+ return v;
+}
+
double
rb_num2dbl(VALUE val)
{