diff options
author | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-01-18 00:23:18 +0000 |
---|---|---|
committer | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-01-18 00:23:18 +0000 |
commit | bf4b9ba49e350a38dac7199cadc54f2fda94d98b (patch) | |
tree | 8cc811e869dcb8f7b175640816d0f433f114b98c | |
parent | a5598ceb26cac304656200e41b12fb66f584587d (diff) | |
download | ruby-bf4b9ba49e350a38dac7199cadc54f2fda94d98b.tar.gz ruby-bf4b9ba49e350a38dac7199cadc54f2fda94d98b.tar.xz ruby-bf4b9ba49e350a38dac7199cadc54f2fda94d98b.zip |
* 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.
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@15099 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 11 | ||||
-rw-r--r-- | encoding.c | 6 | ||||
-rw-r--r-- | parse.y | 4 |
3 files changed, 19 insertions, 2 deletions
@@ -1,3 +1,14 @@ +Fri Jan 18 09:22:07 2008 Yukihiro Matsumoto <matz@ruby-lang.org> + + * 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@ruby-lang.org> * io.c (Init_IO): stdin/stdout may not be duplex. diff --git a/encoding.c b/encoding.c index 1453b267b..38d2cf2c9 100644 --- a/encoding.c +++ b/encoding.c @@ -498,6 +498,12 @@ rb_enc_find_index(const char *name) } 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; @@ -4764,6 +4764,7 @@ rb_parser_compile_string(volatile VALUE vparser, const char *f, VALUE s, int lin 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 @@ parser_prepare(struct parser_params *parser) 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 @@ parser_initialize(struct parser_params *parser) #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 *); |