From e446378ad044b7f7464d040eb5cc8f3784732c44 Mon Sep 17 00:00:00 2001 From: usa Date: Wed, 19 Dec 2012 14:54:50 +0000 Subject: * ruby.c (load_file_internal): use original C string as the filename for parser. reported by whiteleaf at [ruby-list:49085] [ruby-dev:46738] [Bug #7562] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@38474 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ruby.c | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) (limited to 'ruby.c') diff --git a/ruby.c b/ruby.c index adc1340f83..7a0310cb17 100644 --- a/ruby.c +++ b/ruby.c @@ -1569,6 +1569,7 @@ load_file_internal(VALUE arg) VALUE parser = argp->parser; VALUE fname_v = rb_str_encode_ospath(argp->fname); const char *fname = StringValueCStr(fname_v); + const char *orig_fname = StringValueCStr(argp->fname); int script = argp->script; struct cmdline_options *opt = argp->opt; VALUE f; @@ -1702,10 +1703,10 @@ load_file_internal(VALUE arg) if (NIL_P(f)) { f = rb_str_new(0, 0); rb_enc_associate(f, enc); - return (VALUE)rb_parser_compile_string(parser, fname, f, line_start); + return (VALUE)rb_parser_compile_string(parser, orig_fname, f, line_start); } rb_funcall(f, set_encoding, 2, rb_enc_from_encoding(enc), rb_str_new_cstr("-")); - tree = rb_parser_compile_file(parser, fname, f, line_start); + tree = rb_parser_compile_file(parser, orig_fname, f, line_start); rb_funcall(f, set_encoding, 1, rb_parser_encoding(parser)); if (script && tree && rb_parser_end_seen_p(parser)) { /* -- cgit v1.2.3