summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-01-15 16:14:43 +0000
committerko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-01-15 16:14:43 +0000
commite17e71c37f8cf5fef8ff56d354c7f81357a6dce1 (patch)
treefb97ed29bb2bc99c6a23ddd9f7599ea410453190
parent4decaa2678de2ac9c0de10565f62fe6063d7cc57 (diff)
downloadruby-e17e71c37f8cf5fef8ff56d354c7f81357a6dce1.tar.gz
ruby-e17e71c37f8cf5fef8ff56d354c7f81357a6dce1.tar.xz
ruby-e17e71c37f8cf5fef8ff56d354c7f81357a6dce1.zip
* ruby.c (process_options): decrement parse_in_eval to recognize
parsing main or normal eval script. * compile.c (rb_parse_in_main): return 1 if parsing main script. (if parse_in_eval is negative value, it means main script) * parse.y (yycompile0): check rb_parse_in_main() to accumulate script text. Bug #848 [ruby-core:20450] git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@21571 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog11
-rw-r--r--compile.c6
-rw-r--r--parse.y3
-rw-r--r--ruby.c4
4 files changed, 21 insertions, 3 deletions
diff --git a/ChangeLog b/ChangeLog
index 84fa3c3cf..9f2b3818c 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,14 @@
+Fri Jan 16 01:09:37 2009 Koichi Sasada <ko1@atdot.net>
+
+ * ruby.c (process_options): decrement parse_in_eval to recognize
+ parsing main or normal eval script.
+
+ * compile.c (rb_parse_in_main): return 1 if parsing main script.
+ (if parse_in_eval is negative value, it means main script)
+
+ * parse.y (yycompile0): check rb_parse_in_main() to accumulate
+ script text. Bug #848 [ruby-core:20450]
+
Fri Jan 16 00:57:34 2009 Koichi Sasada <ko1@atdot.net>
* lib/debug.rb: as wanabe-san pointed out,
diff --git a/compile.c b/compile.c
index f459eb3cd..205ebafa5 100644
--- a/compile.c
+++ b/compile.c
@@ -5350,3 +5350,9 @@ rb_parse_in_eval(void)
{
return GET_THREAD()->parse_in_eval != 0;
}
+
+int
+rb_parse_in_main(void)
+{
+ return GET_THREAD()->parse_in_eval < 0;
+}
diff --git a/parse.y b/parse.y
index 511568427..049566cf9 100644
--- a/parse.y
+++ b/parse.y
@@ -437,6 +437,7 @@ static void fixup_nodes(NODE **);
extern int rb_dvar_defined(ID);
extern int rb_local_defined(ID);
extern int rb_parse_in_eval(void);
+extern int rb_prase_in_main(void);
static VALUE reg_compile_gen(struct parser_params*, VALUE, int);
#define reg_compile(str,options) reg_compile_gen(parser, str, options)
@@ -4983,7 +4984,7 @@ yycompile0(VALUE arg, int tracing)
NODE *tree;
struct parser_params *parser = (struct parser_params *)arg;
- if (!compile_for_eval && rb_safe_level() == 0) {
+ if ((!compile_for_eval || rb_parse_in_main()) && rb_safe_level() == 0) {
ruby_debug_lines = debug_lines(ruby_sourcefile);
if (ruby_debug_lines && ruby_sourceline > 0) {
VALUE str = STR_NEW0();
diff --git a/ruby.c b/ruby.c
index 461a4f2db..c64a7608e 100644
--- a/ruby.c
+++ b/ruby.c
@@ -1343,10 +1343,10 @@ process_options(VALUE arg)
}
#define PREPARE_PARSE_MAIN(expr) do { \
- th->parse_in_eval++; \
+ th->parse_in_eval--; \
th->base_block = &env->block; \
expr; \
- th->parse_in_eval--; \
+ th->parse_in_eval++; \
th->base_block = 0; \
} while (0)