summaryrefslogtreecommitdiff
path: root/eval.c
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2001-11-08 12:42:39 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2001-11-08 12:42:39 +0000
commit76204d7a5288fa8237c95674bd77d682e2fe284b (patch)
treeb29f1ff1cf80ffbd23bcb06e97e47807d5a20f22 /eval.c
parenta3d0d9953049bb149a2fdae7f85d3c4148ef0288 (diff)
* eval.c (rb_trap_eval): avoid annoying warning with signal.
[ruby-talk:23225] * eval.c (rb_call0): adjust caller source file/line while evaluating optional arguments. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@1819 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'eval.c')
-rw-r--r--eval.c8
1 files changed, 7 insertions, 1 deletions
diff --git a/eval.c b/eval.c
index 90f17e5be4..e91fa8a7a3 100644
--- a/eval.c
+++ b/eval.c
@@ -1394,9 +1394,11 @@ rb_trap_eval(cmd, sig)
VALUE val; /* OK */
PUSH_TAG(PROT_NONE);
+ PUSH_ITER(ITER_NOT);
if ((state = EXEC_TAG()) == 0) {
val = rb_eval_cmd(cmd, rb_ary_new3(1, INT2FIX(sig)));
}
+ POP_ITER();
POP_TAG();
if (state) {
rb_trap_immediate = 0;
@@ -4559,7 +4561,11 @@ rb_call0(klass, recv, id, argc, argv, body, nosuper)
argv++; argc--;
opt = opt->nd_next;
}
- rb_eval(recv, opt);
+ if (opt) {
+ ruby_sourcefile = opt->nd_file;
+ ruby_sourceline = nd_line(opt);
+ rb_eval(recv, opt);
+ }
}
local_vars = ruby_scope->local_vars;
if (node->nd_rest >= 0) {