diff --git a/ChangeLog b/ChangeLog index 0cb77acfde..97f11fa8e6 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,13 @@ +Fri Aug 16 07:57:26 2002 Nobuyoshi Nakada + +Fri Aug 16 07:56:16 2002 Nobuyoshi Nakada + + * eval.c (compile_error): must not clear ruby_sourcefile here. + (ruby-bugs:PR#364). + + * eval.c (rb_longjmp): set ruby_sourcefile before making + backtrace. + Thu Aug 15 20:38:58 2002 Nobuyoshi Nakada * eval.c (ruby_current_node) : added to set sourceline on demand. diff --git a/eval.c b/eval.c index ec44f509f0..ee19b03c2b 100644 --- a/eval.c +++ b/eval.c @@ -1282,7 +1282,6 @@ compile_error(at) { VALUE str; - ruby_sourcefile = 0; ruby_nerrs = 0; str = rb_str_buf_new2("compile error"); if (at) { @@ -3602,6 +3601,7 @@ rb_longjmp(tag, mesg) mesg = rb_exc_new(rb_eRuntimeError, 0, 0); } + ruby_set_current_source(); if (ruby_sourcefile && !NIL_P(mesg)) { at = get_backtrace(mesg); if (NIL_P(at)) { @@ -3618,7 +3618,6 @@ rb_longjmp(tag, mesg) VALUE e = ruby_errinfo; StringValue(e); - ruby_set_current_source(); fprintf(stderr, "Exception `%s' at %s:%d - %s\n", rb_class2name(CLASS_OF(ruby_errinfo)), ruby_sourcefile, ruby_sourceline, @@ -5036,7 +5035,6 @@ eval(self, src, scope, file, line) } if (file == 0) { ruby_set_current_source(); - ruby_current_node = 0; file = ruby_sourcefile; line = ruby_sourceline; }