ruby-changes:9253
From: yugui <ko1@a...>
Date: Tue, 16 Dec 2008 19:32:07 +0900 (JST)
Subject: [ruby-changes:9253] Ruby:r20790 (ruby_1_9_1): merges r20723 and r20724 from trunk into ruby_1_9_1.
yugui 2008-12-16 19:25:58 +0900 (Tue, 16 Dec 2008) New Revision: 20790 http://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=rev&revision=20790 Log: merges r20723 and r20724 from trunk into ruby_1_9_1. * string.c (sym_inspect): quote if symbol contains non-printable characters. [ruby-dev:37398] Modified files: branches/ruby_1_9_1/ChangeLog branches/ruby_1_9_1/string.c Index: ruby_1_9_1/ChangeLog =================================================================== --- ruby_1_9_1/ChangeLog (revision 20789) +++ ruby_1_9_1/ChangeLog (revision 20790) @@ -1,3 +1,7 @@ +Sat Dec 13 18:34:43 2008 Yukihiro Matsumoto <matz@r...> + + * string.c (sym_printable): wrong condition for string iteration. + Sat Dec 13 15:52:27 2008 Yukihiro Matsumoto <matz@r...> * string.c (sym_equal): remove documentation error "Otherwise, @@ -53,6 +57,9 @@ loading a locale encoding on some locale. fixed by Nobuyuki Nakada. + * string.c (sym_inspect): quote if symbol contains non-printable + characters. [ruby-dev:37398] + Sat Dec 13 14:24:38 2008 Yuki Sonoda (Yugui) <yugui@y...> * test/ruby/enc/test_utf16.rb: feature changed in r20626. Index: ruby_1_9_1/string.c =================================================================== --- ruby_1_9_1/string.c (revision 20789) +++ ruby_1_9_1/string.c (revision 20790) @@ -6826,6 +6826,18 @@ } +static int +sym_printable(const char *s, const char *send, rb_encoding *enc) +{ + while (s < send) { + int c = rb_enc_codepoint(s, send, enc); + int n = rb_enc_codelen(c, enc); + if (!rb_enc_isprint(c, enc)) return Qfalse; + s += n; + } + return Qtrue; +} + /* * call-seq: * sym.inspect => string @@ -6848,7 +6860,8 @@ RSTRING_PTR(str)[0] = ':'; memcpy(RSTRING_PTR(str)+1, RSTRING_PTR(sym), RSTRING_LEN(sym)); if (RSTRING_LEN(sym) != strlen(RSTRING_PTR(sym)) || - !rb_enc_symname_p(RSTRING_PTR(sym), enc)) { + !rb_enc_symname_p(RSTRING_PTR(sym), enc) || + !sym_printable(RSTRING_PTR(sym), RSTRING_END(sym), enc)) { str = rb_str_inspect(str); strncpy(RSTRING_PTR(str), ":\"", 2); } -- ML: ruby-changes@q... Info: http://www.atdot.net/~ko1/quickml/