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

ruby-changes:2894

From: ko1@a...
Date: 21 Dec 2007 12:24:43 +0900
Subject: [ruby-changes:2894] akr - Ruby:r14380 (trunk): * encoding.c: include locale.h

akr	2007-12-21 11:52:23 +0900 (Fri, 21 Dec 2007)

  New Revision: 14380

  Modified files:
    trunk/ChangeLog
    trunk/encoding.c
    trunk/include/ruby/encoding.h
    trunk/main.c
    trunk/ruby.c

  Log:
    * encoding.c: include locale.h
      (rb_locale_charmap): new method Encoding.locale_charmap for
      nl_langinfo(CODESET).
    
    * include/ruby/encoding.h (rb_locale_charmap): declared.
    
    * main.c (main): call setlocale with LC_CTYPE.
    
    * ruby.c (locale_encoding): use rb_locale_charmap.


  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ruby.c?r1=14380&r2=14379
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ChangeLog?r1=14380&r2=14379
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/include/ruby/encoding.h?r1=14380&r2=14379
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/encoding.c?r1=14380&r2=14379
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/main.c?r1=14380&r2=14379

Index: encoding.c
===================================================================
--- encoding.c	(revision 14379)
+++ encoding.c	(revision 14380)
@@ -14,6 +14,7 @@
 #include "ruby/encoding.h"
 #include "regenc.h"
 #include <ctype.h>
+#include <langinfo.h>
 
 static ID id_encoding, id_based_encoding;
 static VALUE rb_cEncoding;
@@ -703,6 +704,14 @@
     default_external_index = rb_enc_to_index(rb_to_encoding(encoding));
 }
 
+VALUE
+rb_locale_charmap(VALUE klass)
+{
+    char *codeset;
+    codeset = nl_langinfo(CODESET);
+    return rb_str_new2(codeset);
+}
+
 static void
 set_encoding_const(const char *name, rb_encoding *enc)
 {
@@ -772,6 +781,7 @@
     rb_define_singleton_method(rb_cEncoding, "_load", enc_load, 1);
 
     rb_define_singleton_method(rb_cEncoding, "default_external", get_default_external, 0);
+    rb_define_singleton_method(rb_cEncoding, "locale_charmap", rb_locale_charmap, 0);
 
     /* dummy for unsupported, statefull encoding */
     rb_enc_replicate("ISO-2022-JP", rb_enc_find(rb_enc_name(ONIG_ENCODING_ASCII)));
Index: include/ruby/encoding.h
===================================================================
--- include/ruby/encoding.h	(revision 14379)
+++ include/ruby/encoding.h	(revision 14380)
@@ -117,5 +117,6 @@
 rb_encoding *rb_default_external_encoding(void);
 VALUE rb_enc_default_external(void);
 void rb_enc_set_default_external(VALUE encoding);
+VALUE rb_locale_charmap(VALUE klass);
 
 #endif /* RUBY_ENCODING_H */
Index: ChangeLog
===================================================================
--- ChangeLog	(revision 14379)
+++ ChangeLog	(revision 14380)
@@ -1,3 +1,15 @@
+Fri Dec 21 11:47:56 2007  Tanaka Akira  <akr@f...>
+
+	* encoding.c: include locale.h
+	  (rb_locale_charmap): new method Encoding.locale_charmap for
+	  nl_langinfo(CODESET).
+
+	* include/ruby/encoding.h (rb_locale_charmap): declared.
+
+	* main.c (main): call setlocale with LC_CTYPE.
+
+	* ruby.c (locale_encoding): use rb_locale_charmap.
+
 Fri Dec 21 11:35:10 2007  Koichi Sasada  <ko1@a...>
 
 	* vm.c, vm_dump.c: fix typo.  Reported by Yuki Mitsui.
Index: main.c
===================================================================
--- main.c	(revision 14379)
+++ main.c	(revision 14380)
@@ -12,6 +12,7 @@
 
 #undef RUBY_EXPORT
 #include "ruby/ruby.h"
+#include <locale.h>
 
 RUBY_GLOBAL_SETUP
 
@@ -22,6 +23,7 @@
     extern void ruby_set_debug_option(const char *);
     ruby_set_debug_option(getenv("RUBY_DEBUG"));
 #endif
+    setlocale(LC_CTYPE, "");
 
     ruby_sysinit(&argc, &argv);
     {
Index: ruby.c
===================================================================
--- ruby.c	(revision 14379)
+++ ruby.c	(revision 14380)
@@ -138,32 +138,14 @@
 static rb_encoding *
 locale_encoding(void)
 {
-    static const char *const langs[] = {"LC_ALL", "LC_CTYPE", "LANG",};
-    const char *lang, *at;
-    int i, len, idx = 0;
-    char buf[32];
-    rb_encoding *enc;
+    VALUE codeset = rb_locale_charmap(Qnil);
+    char *name = StringValueCStr(codeset);
+    int idx;
 
-    for (i = 0; i < sizeof(langs) / sizeof(langs[0]); ++i) {
-	if (!(lang = getenv(langs[i]))) continue;
-	if (!(lang = strchr(lang, '.'))) continue;
-	at = strchr(++lang, '@');
-	if ((len = (at ? at - lang : strlen(lang))) >= sizeof(buf) - 1) continue;
-	MEMCPY(buf, lang, char, len);
-	buf[len] = 0;
-	idx = rb_enc_find_index(buf);
-	if (idx < 0 && len > 3 &&
-	    (strncasecmp(buf, "euc", 3) == 0 ||
-	     strncasecmp(buf, "utf", 3) == 0) &&
-	    buf[3]) {
-	    MEMMOVE(buf + 4, buf + 3, char, len - 2);
-	    buf[3] = '-';
-	    idx = rb_enc_find_index(buf);
-	}
-	enc = rb_enc_from_index(idx);
-	if (enc) return enc;
-    }
-    return rb_default_encoding();
+    idx = rb_enc_find_index(name);
+    if (idx < 0)
+        return rb_default_encoding();
+    return rb_enc_from_index(idx);
 }
 
 extern VALUE rb_load_path;

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

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