ruby-changes:8471
From: naruse <ko1@a...>
Date: Tue, 28 Oct 2008 23:30:36 +0900 (JST)
Subject: [ruby-changes:8471] Ruby:r20004 (trunk): * ext/nkf/nkf-utf8/nkf.c (kanji_convert): output unicode chars.
naruse 2008-10-28 23:30:17 +0900 (Tue, 28 Oct 2008) New Revision: 20004 http://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=rev&revision=20004 Log: * ext/nkf/nkf-utf8/nkf.c (kanji_convert): output unicode chars. [ruby-dev:36957] * ext/nkf/nkf-utf8/nkf.c (numchar_getc): increase buffer size. reported and patched at [ruby-dev:36957] by mame. Modified files: trunk/ChangeLog trunk/ext/nkf/nkf-utf8/nkf.c Index: ChangeLog =================================================================== --- ChangeLog (revision 20003) +++ ChangeLog (revision 20004) @@ -1,3 +1,11 @@ +Tue Oct 28 23:29:06 2008 NARUSE, Yui <naruse@r...> + + * ext/nkf/nkf-utf8/nkf.c (kanji_convert): output unicode chars. + [ruby-dev:36957] + + * ext/nkf/nkf-utf8/nkf.c (numchar_getc): increase buffer size. + reported and patched at [ruby-dev:36957] by mame. + Tue Oct 28 23:03:46 2008 Yuki Sonoda (Yugui) <yugui@y...> * test/ruby/test_proc.rb: filled all patterns for testing Index: ext/nkf/nkf-utf8/nkf.c =================================================================== --- ext/nkf/nkf-utf8/nkf.c (revision 20003) +++ ext/nkf/nkf-utf8/nkf.c (revision 20004) @@ -33,7 +33,7 @@ ***********************************************************************/ #define NKF_IDENT "$Id$" #define NKF_VERSION "2.0.8" -#define NKF_RELEASE_DATE "2008-02-08" +#define NKF_RELEASE_DATE "2008-10-28" #define COPY_RIGHT \ "Copyright (C) 1987, FUJITSU LTD. (I.Ichikawa),2000 S. Kono, COW\n" \ "Copyright (C) 2002-2008 Kono, Furukawa, Naruse, mastodon" @@ -41,6 +41,10 @@ #include "config.h" #include "nkf.h" #include "utf8tbl.h" +#ifdef __WIN32__ +#include <windows.h> +#include <locale.h> +#endif /* state of output_mode and input_mode @@ -718,7 +722,16 @@ #ifdef HAVE_LANGINFO_H return nl_langinfo(CODESET); #elif defined(__WIN32__) - return sprintf("CP%d", GetACP()); + char buf[16]; + char *str; + int len = sprintf(buf, "CP%d", GetACP()); + if (len > 0) { + str = malloc(len + 1); + strcpy(str, buf); + str[len] = '\0'; + return str; + } + else return NULL; #else return NULL; #endif @@ -4100,7 +4113,7 @@ nkf_char (*g)(FILE *) = i_ngetc; nkf_char (*u)(nkf_char c ,FILE *f) = i_nungetc; int i = 0, j; - nkf_char buf[8]; + nkf_char buf[12]; long c = -1; buf[i] = (*g)(f); @@ -5328,6 +5341,10 @@ SEND; } } + else if (nkf_char_unicode_p(c1)) { + (*oconv)(0, c1); + NEXT; + } else { /* first byte */ if (input_mode == JIS_X_0208 && DEL <= c1 && c1 < 0x92) { -- ML: ruby-changes@q... Info: http://www.atdot.net/~ko1/quickml/