summaryrefslogtreecommitdiff
path: root/object.c
diff options
context:
space:
mode:
authormatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2002-06-28 14:42:46 +0000
committermatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2002-06-28 14:42:46 +0000
commitf0221db4626bb589f230bf239a7f9df83d7e444f (patch)
tree0bd6a2a6dde695b2ac3cf1193419676a78f914b9 /object.c
parentee852ed46d1a2a0f894e20e939b079c31e1cdb4b (diff)
downloadruby-f0221db4626bb589f230bf239a7f9df83d7e444f.tar.gz
* re.c (rb_reg_expr_str): need to process backslashes properly.
* object.c (rb_any_to_a): declare Object#to_a to be obsolete. * object.c (rb_Array): do not convert nil into [] automagically. * object.c (rb_Integer): use "to_int" instead of "to_i". [experimental] * object.c (nil_to_f): new method. * object.c (rb_Integer): Symbols and nil should cause error. * object.c (rb_Float): nil should cause error. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@2608 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'object.c')
-rw-r--r--object.c36
1 files changed, 32 insertions, 4 deletions
diff --git a/object.c b/object.c
index 1b4b2c4d31..1f72b2a777 100644
--- a/object.c
+++ b/object.c
@@ -18,6 +18,7 @@
#include <stdio.h>
#include <errno.h>
#include <ctype.h>
+#include <math.h>
VALUE rb_mKernel;
VALUE rb_cObject;
@@ -134,6 +135,7 @@ static VALUE
rb_any_to_a(obj)
VALUE obj;
{
+ rb_warn("default `to_a' will be obsolete");
return rb_ary_new3(1, obj);
}
@@ -338,6 +340,13 @@ nil_to_i(obj)
}
static VALUE
+nil_to_f(obj)
+ VALUE obj;
+{
+ return rb_float_new(0.0);
+}
+
+static VALUE
nil_to_s(obj)
VALUE obj;
{
@@ -917,6 +926,7 @@ rb_check_convert_type(val, type, tname, method)
return v;
}
+
static VALUE
rb_to_integer(val, method)
VALUE val;
@@ -941,6 +951,8 @@ VALUE
rb_Integer(val)
VALUE val;
{
+ VALUE v;
+
switch (TYPE(val)) {
case T_FLOAT:
if (RFLOAT(val)->value <= (double)FIXNUM_MAX
@@ -961,7 +973,13 @@ rb_Integer(val)
default:
break;
}
- return rb_to_integer(val, "to_i");
+
+ if (rb_respond_to(val, rb_intern("to_int"))) {
+ return rb_to_integer(val, "to_int");
+ }
+ else {
+ return rb_to_integer(val, "to_i");
+ }
}
static VALUE
@@ -1073,10 +1091,17 @@ rb_Float(val)
return rb_float_new(rb_str_to_dbl(val, Qtrue));
case T_NIL:
- return rb_float_new(0.0);
+ rb_raise(rb_eTypeError, "cannot convert nil into Float");
+ break;
default:
- return rb_convert_type(val, T_FLOAT, "Float", "to_f");
+ {
+ VALUE f = rb_convert_type(val, T_FLOAT, "Float", "to_f");
+ if (isnan(RFLOAT(f)->value)) {
+ rb_raise(rb_eArgError, "invalid value for Float()");
+ }
+ return f;
+ }
}
}
@@ -1143,6 +1168,9 @@ rb_Array(val)
{
ID to_ary;
+ if (NIL_P(val)) {
+ rb_raise(rb_eTypeError, "cannot convert nil into Array");
+ }
if (TYPE(val) == T_ARRAY) return val;
to_ary = rb_intern("to_ary");
if (rb_respond_to(val, to_ary)) {
@@ -1251,7 +1279,7 @@ Init_Object()
rb_define_method(rb_mKernel, "freeze", rb_obj_freeze, 0);
rb_define_method(rb_mKernel, "frozen?", rb_obj_frozen_p, 0);
- rb_define_method(rb_mKernel, "to_a", rb_any_to_a, 0);
+ rb_define_method(rb_mKernel, "to_a", rb_any_to_a, 0); /* to be removed */
rb_define_method(rb_mKernel, "to_s", rb_any_to_s, 0);
rb_define_method(rb_mKernel, "inspect", rb_obj_inspect, 0);
rb_define_method(rb_mKernel, "methods", rb_obj_methods, 0);