ruby-changes:1957
From: ko1@a...
Date: 15 Sep 2007 17:32:23 +0900
Subject: [ruby-changes:1957] nobu - Ruby:r13448 (trunk): * parse.y (parser_initialize): set default encoding.
nobu 2007-09-15 17:32:12 +0900 (Sat, 15 Sep 2007)
New Revision: 13448
Modified files:
trunk/ChangeLog
trunk/parse.y
trunk/ruby.c
Log:
* parse.y (parser_initialize): set default encoding. [ruby-dev:31787]
* ruby.c (load_file): make new parse instance after processing shebang
line options.
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ruby.c?r1=13448&r2=13447
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/parse.y?r1=13448&r2=13447
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ChangeLog?r1=13448&r2=13447
Index: ChangeLog
===================================================================
--- ChangeLog (revision 13447)
+++ ChangeLog (revision 13448)
@@ -1,3 +1,10 @@
+Sat Sep 15 17:32:10 2007 Nobuyoshi Nakada <nobu@r...>
+
+ * parse.y (parser_initialize): set default encoding. [ruby-dev:31787]
+
+ * ruby.c (load_file): make new parse instance after processing shebang
+ line options.
+
Sat Sep 15 17:04:08 2007 Nobuyoshi Nakada <nobu@r...>
* encoding.c (rb_enc_associate_index, rb_enc_get_index): check if
Index: parse.y
===================================================================
--- parse.y (revision 13447)
+++ parse.y (revision 13448)
@@ -8686,7 +8686,7 @@
#ifdef YYMALLOC
parser->heap = NULL;
#endif
- parser->enc = rb_enc_from_index(0);
+ parser->enc = onigenc_get_default_encoding();
}
extern void rb_mark_source_filename(char *);
Index: ruby.c
===================================================================
--- ruby.c (revision 13447)
+++ ruby.c (revision 13448)
@@ -64,7 +64,7 @@
char *ruby_inplace_mode = 0;
-static NODE *load_file(VALUE, const char *, int);
+static NODE *load_file(VALUE *, const char *, int);
static void forbid_setid(const char *);
static VALUE do_loop = Qfalse, do_print = Qfalse;
@@ -880,16 +880,16 @@
process_sflag();
ruby_init_loadpath();
- parser = rb_parser_new();
if (e_script) {
require_libraries();
+ parser = rb_parser_new();
tree = rb_parser_compile_string(parser, script, e_script, 1);
}
else {
if (script[0] == '-' && !script[1]) {
forbid_setid("program input from stdin");
}
- tree = load_file(parser, script, 1);
+ tree = load_file(&parser, script, 1);
}
process_sflag();
@@ -911,7 +911,7 @@
}
static NODE *
-load_file(VALUE parser, const char *fname, int script)
+load_file(VALUE *parser, const char *fname, int script)
{
extern VALUE rb_stdin;
VALUE f;
@@ -1027,8 +1027,9 @@
}
require_libraries(); /* Why here? unnatural */
}
- tree = (NODE *)rb_parser_compile_file(parser, fname, f, line_start);
- if (script && rb_parser_end_seen_p(parser)) {
+ *parser = rb_parser_new();
+ tree = (NODE *)rb_parser_compile_file(*parser, fname, f, line_start);
+ if (script && rb_parser_end_seen_p(*parser)) {
rb_define_global_const("DATA", f);
}
else if (f != rb_stdin) {
@@ -1040,7 +1041,9 @@
void *
rb_load_file(const char *fname)
{
- return load_file(rb_parser_new(), fname, 0);
+ VALUE parser;
+
+ return load_file(&parser, fname, 0);
}
VALUE rb_progname;
--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml