[前][次][番号順一覧][スレッド一覧]

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/

[前][次][番号順一覧][スレッド一覧]