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

ruby-changes:5333

From: nobu <ko1@a...>
Date: Thu, 5 Jun 2008 14:04:05 +0900 (JST)
Subject: [ruby-changes:5333] Ruby:r16834 (trunk): * ext/iconv/iconv.c (iconv_create): find encoding without options.

nobu	2008-06-05 14:03:46 +0900 (Thu, 05 Jun 2008)

  New Revision: 16834

  Modified files:
    trunk/ChangeLog
    trunk/ext/iconv/iconv.c

  Log:
    * ext/iconv/iconv.c (iconv_create): find encoding without options.


  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ext/iconv/iconv.c?r1=16834&r2=16833&diff_format=u
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ChangeLog?r1=16834&r2=16833&diff_format=u

Index: ChangeLog
===================================================================
--- ChangeLog	(revision 16833)
+++ ChangeLog	(revision 16834)
@@ -1,3 +1,7 @@
+Thu Jun  5 14:03:44 2008  Nobuyoshi Nakada  <nobu@r...>
+
+	* ext/iconv/iconv.c (iconv_create): find encoding without options.
+
 Thu Jun  5 07:48:32 2008  Koichi Sasada  <ko1@a...>
 
 	* string.c (hash): should be "static".
Index: ext/iconv/iconv.c
===================================================================
--- ext/iconv/iconv.c	(revision 16833)
+++ ext/iconv/iconv.c	(revision 16834)
@@ -158,7 +158,13 @@
     const char* fromcode = map_charset(&from);
     iconv_t cd;
 
-    *idx = rb_enc_find_index(tocode);
+    if ((*idx = rb_enc_find_index(tocode)) < 0) {
+	const char *slash = strchr(tocode, '/');
+	if (slash && slash[1] == '/') {
+	    VALUE tmp = rb_str_new(tocode, slash - tocode);
+	    *idx = rb_enc_find_index(RSTRING_PTR(tmp));
+	}
+    }
 
     cd = iconv_open(tocode, fromcode);
     if (cd == (iconv_t)-1) {

--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml/

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