summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog6
-rw-r--r--eval.c13
2 files changed, 16 insertions, 3 deletions
diff --git a/ChangeLog b/ChangeLog
index cf26c43aa3..4ecdef1e31 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,8 +1,12 @@
-Thu May 12 01:21:13 2005 Nobuyoshi Nakada <nobu@ruby-lang.org>
+Thu May 12 01:23:55 2005 Nobuyoshi Nakada <nobu@ruby-lang.org>
* eval.c (rb_eval), parse.y (arg): reduce fixnum range literal at
parser. fixed: [ruby-dev:26113]
+ * eval.c (unknown_node): ignore broken NODE to get rid of accessing
+ possibly inaccessible address. fixed: [ruby-dev:26122]
+ should emit more useful information like [ruby-dev:26126], though.
+
Wed May 11 16:20:01 2005 GOTOU Yuuzou <gotoyuzo@notwork.org>
* lib/webrick/cgi.rb: new methods WEBrick::CGI#[], WEBrick::CGI#logger
diff --git a/eval.c b/eval.c
index 86a97c1b31..65329ff7b1 100644
--- a/eval.c
+++ b/eval.c
@@ -2754,6 +2754,15 @@ class_prefix(self, cpath)
NORETURN(static void return_jump _((VALUE)));
NORETURN(static void break_jump _((VALUE)));
+NORETURN(static void unknown_node _((NODE *)));
+
+static void
+unknown_node(node)
+ NODE *volatile node;
+{
+ ruby_current_node = 0;
+ rb_bug("unknown node type %d", nd_type(node));
+}
static VALUE
rb_eval(self, n)
@@ -3960,7 +3969,7 @@ rb_eval(self, n)
goto again;
default:
- rb_bug("unknown node type %d", nd_type(node));
+ unknown_node(node);
}
finish:
CHECK_INTS;
@@ -5758,7 +5767,7 @@ rb_call0(klass, recv, id, oid, argc, argv, body, nosuper)
break;
default:
- rb_bug("unknown node type %d", nd_type(body));
+ unknown_node(body);
break;
}
POP_FRAME();