From 8020c2e6761ce25021f15d0c22eca10f8b90079a Mon Sep 17 00:00:00 2001 From: nobu Date: Fri, 25 Jan 2008 07:11:18 +0000 Subject: [PATCH] * ruby.c (process_options, load_file, rb_load_file): propagates script encoding by -K to libraries. [ruby-dev:33156] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@15231 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 5 +++++ ruby.c | 7 ++++++- 2 files changed, 11 insertions(+), 1 deletion(-) diff --git a/ChangeLog b/ChangeLog index d63ec41a46..ad8e9e5663 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +Fri Jan 25 16:11:16 2008 Nobuyoshi Nakada + + * ruby.c (process_options, load_file, rb_load_file): propagates script + encoding by -K to libraries. [ruby-dev:33156] + Fri Jan 25 15:56:48 2008 Nobuyoshi Nakada * ruby.c (cmdline_arguments): split argc and argv from cmdline_options. diff --git a/ruby.c b/ruby.c index 0573595234..739d78f44b 100644 --- a/ruby.c +++ b/ruby.c @@ -881,6 +881,8 @@ opt_enc_index(VALUE enc_name) return i; } +static int src_encoding_index = -1; /* TODO: VM private */ + static VALUE process_options(VALUE arg) { @@ -1000,6 +1002,7 @@ process_options(VALUE arg) } if (opt->src.enc.name != 0) { opt->src.enc.index = opt_enc_index(opt->src.enc.name); + src_encoding_index = opt->src.enc.index; } if (opt->ext.enc.index >= 0) { enc = rb_enc_from_index(opt->ext.enc.index); @@ -1181,6 +1184,7 @@ load_file(VALUE parser, const char *fname, int script, struct cmdline_options *o rb_io_ungetc(f, INT2FIX('#')); if (no_src_enc && opt->src.enc.name) { opt->src.enc.index = opt_enc_index(opt->src.enc.name); + src_encoding_index = opt->src.enc.index; } if (no_ext_enc && opt->ext.enc.name) { opt->ext.enc.index = opt_enc_index(opt->ext.enc.name); @@ -1224,6 +1228,7 @@ rb_load_file(const char *fname) struct cmdline_options opt; MEMZERO(&opt, opt, 1); + opt.src.enc.index = src_encoding_index; return load_file(rb_parser_new(), fname, 0, &opt); } @@ -1455,7 +1460,7 @@ ruby_process_options(int argc, char **argv) args.argc = argc; args.argv = argv; args.opt = &opt; - opt.src.enc.index = -1; + opt.src.enc.index = src_encoding_index; opt.ext.enc.index = -1; tree = (NODE *)rb_vm_call_cfunc(rb_vm_top_self(), process_options, (VALUE)&args,