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

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/

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