ruby-changes:4000
From: ko1@a...
Date: Sat, 16 Feb 2008 00:22:40 +0900 (JST)
Subject: [ruby-changes:4000] nobu - Ruby:r15490 (trunk): * range.c (rb_range_beg_len): check if responds to "begin" and "end"
nobu 2008-02-16 00:21:51 +0900 (Sat, 16 Feb 2008)
New Revision: 15490
Modified files:
trunk/ChangeLog
trunk/range.c
trunk/version.h
Log:
* range.c (rb_range_beg_len): check if responds to "begin" and "end"
methods for non-Range object.
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/version.h?r1=15490&r2=15489&diff_format=u
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ChangeLog?r1=15490&r2=15489&diff_format=u
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/range.c?r1=15490&r2=15489&diff_format=u
Index: ChangeLog
===================================================================
--- ChangeLog (revision 15489)
+++ ChangeLog (revision 15490)
@@ -1,3 +1,8 @@
+Sat Feb 16 00:21:49 2008 Nobuyoshi Nakada <nobu@r...>
+
+ * range.c (rb_range_beg_len): check if responds to "begin" and "end"
+ methods for non-Range object.
+
Fri Feb 15 20:29:42 2008 Masaki Suketa <masaki.suketa@n...>
* ext/win32ole/win32ole.c (ole_init_cp): initialize WIN32OLE.codepage
Index: range.c
===================================================================
--- range.c (revision 15489)
+++ range.c (revision 15490)
@@ -597,12 +597,10 @@
excl = EXCL(range);
}
else {
- b = rb_check_to_integer(range, "begin");
- if (NIL_P(b))
- return Qfalse;
- e = rb_check_to_integer(range, "end");
- if (NIL_P(e))
- return Qfalse;
+ if (!rb_respond_to(range, id_beg)) return Qfalse;
+ if (!rb_respond_to(range, id_end)) return Qfalse;
+ b = rb_funcall(range, id_beg, 0);
+ e = rb_funcall(range, id_end, 0);
excl = RTEST(rb_funcall(range, rb_intern("exclude_end?"), 0));
}
beg = NUM2LONG(b);
@@ -751,8 +749,6 @@
}
else if (TYPE(beg) == T_STRING && TYPE(end) == T_STRING &&
RSTRING_LEN(beg) == 1 && RSTRING_LEN(end) == 1) {
- rb_encoding *enc = rb_enc_check(beg, end);
-
if (NIL_P(val)) return Qfalse;
if (TYPE(val) == T_STRING) {
if (RSTRING_LEN(val) == 0 || RSTRING_LEN(val) > 1)
Index: version.h
===================================================================
--- version.h (revision 15489)
+++ version.h (revision 15490)
@@ -1,7 +1,7 @@
#define RUBY_VERSION "1.9.0"
-#define RUBY_RELEASE_DATE "2008-02-15"
+#define RUBY_RELEASE_DATE "2008-02-16"
#define RUBY_VERSION_CODE 190
-#define RUBY_RELEASE_CODE 20080215
+#define RUBY_RELEASE_CODE 20080216
#define RUBY_PATCHLEVEL 0
#define RUBY_VERSION_MAJOR 1
@@ -9,7 +9,7 @@
#define RUBY_VERSION_TEENY 0
#define RUBY_RELEASE_YEAR 2008
#define RUBY_RELEASE_MONTH 2
-#define RUBY_RELEASE_DAY 15
+#define RUBY_RELEASE_DAY 16
#ifdef RUBY_EXTERN
RUBY_EXTERN const char ruby_version[];
--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml/