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

ruby-changes:3610

From: ko1@a...
Date: Fri, 18 Jan 2008 09:23:49 +0900 (JST)
Subject: [ruby-changes:3610] matz - Ruby:r15099 (trunk): * parse.y (parser_initialize): explicitly call rb_ascii8bit_encoding().

matz	2008-01-18 09:23:18 +0900 (Fri, 18 Jan 2008)

  New Revision: 15099

  Modified files:
    trunk/ChangeLog
    trunk/encoding.c
    trunk/parse.y

  Log:
    * parse.y (parser_initialize): explicitly call rb_ascii8bit_encoding().
    
    * parse.y (parser_prepare): lex_input may not be have encoding (e.g. IO).
    
    * parse.y (rb_parser_compile_string): set encoding from input string. 
    
    * encoding.c (rb_enc_find_index): use ASCII-8BIT if loading known
      encoding failed.

  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/parse.y?r1=15099&r2=15098&diff_format=u
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ChangeLog?r1=15099&r2=15098&diff_format=u
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/encoding.c?r1=15099&r2=15098&diff_format=u

Index: encoding.c
===================================================================
--- encoding.c	(revision 15098)
+++ encoding.c	(revision 15099)
@@ -498,6 +498,12 @@
 	}
 	else {
 	    i = load_encoding(name);
+	    enc = rb_enc_from_index(i);
+	    if (!enc->precise_mbc_enc_len) {
+		rb_warn("failed to load encoding (%s); use ASCII-8BIT instead",
+			name);
+		return 0;
+	    }
 	}
     }
     return i;
Index: ChangeLog
===================================================================
--- ChangeLog	(revision 15098)
+++ ChangeLog	(revision 15099)
@@ -1,3 +1,14 @@
+Fri Jan 18 09:22:07 2008  Yukihiro Matsumoto  <matz@r...>
+
+	* parse.y (parser_initialize): explicitly call rb_ascii8bit_encoding().
+
+	* parse.y (parser_prepare): lex_input may not be have encoding (e.g. IO).
+
+	* parse.y (rb_parser_compile_string): set encoding from input string. 
+
+	* encoding.c (rb_enc_find_index): use ASCII-8BIT if loading known
+	  encoding failed.
+
 Fri Jan 18 07:06:25 2008  Yukihiro Matsumoto  <matz@r...>
 
 	* io.c (Init_IO): stdin/stdout may not be duplex.
Index: parse.y
===================================================================
--- parse.y	(revision 15098)
+++ parse.y	(revision 15099)
@@ -4764,6 +4764,7 @@
     lex_gets = lex_get_str;
     lex_gets_ptr = 0;
     lex_input = s;
+    parser->enc = rb_enc_get(s);
     lex_pbeg = lex_p = lex_pend = 0;
     compile_for_eval = rb_parse_in_eval();
 
@@ -5956,7 +5957,6 @@
 	return;
     }
     pushback(c);
-    parser->enc = rb_enc_get(lex_input);
 }
 
 #define IS_ARG() (lex_state == EXPR_ARG || lex_state == EXPR_CMDARG)
@@ -9192,7 +9192,7 @@
 #ifdef YYMALLOC
     parser->heap = NULL;
 #endif
-    parser->enc = rb_enc_from_index(0);
+    parser->enc = rb_ascii8bit_encoding();
 }
 
 extern void rb_mark_source_filename(char *);

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

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