summaryrefslogtreecommitdiff
path: root/ruby.c
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-01-25 07:11:18 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-01-25 07:11:18 +0000
commit8020c2e6761ce25021f15d0c22eca10f8b90079a (patch)
tree82b105b2b020646e0d4259ee2d65c3ac29d42378 /ruby.c
parent5776f23d692fc92fc81696d1e49767ed1ef88508 (diff)
* 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
Diffstat (limited to 'ruby.c')
-rw-r--r--ruby.c7
1 files changed, 6 insertions, 1 deletions
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,