summaryrefslogtreecommitdiff
path: root/eval.c
diff options
context:
space:
mode:
authormatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2002-03-20 09:43:15 +0000
committermatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2002-03-20 09:43:15 +0000
commit760878b4242ae20a7b10f7a8f49d3875e0201aad (patch)
tree8510da313d4481225d854afdd0e949148e3815f6 /eval.c
parentfaac53f7baec4a2919bb941c0b7c0fcb62985381 (diff)
* eval.c (is_defined): should check receiver only once.
* eval.c (is_defined): should handle NODE_NEWLINE. * file.c (rb_file_s_expand_path): memory leak fixed. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@2229 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'eval.c')
-rw-r--r--eval.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/eval.c b/eval.c
index 5e2131ebed..32f7972c39 100644
--- a/eval.c
+++ b/eval.c
@@ -1803,6 +1803,7 @@ is_defined(self, node, buf)
VALUE val; /* OK */
int state;
+ again:
if (!node) return "expression";
switch (nd_type(node)) {
case NODE_SUPER:
@@ -1824,7 +1825,6 @@ is_defined(self, node, buf)
goto check_bound;
case NODE_CALL:
- if (!is_defined(self, node->nd_recv, buf)) return 0;
PUSH_TAG(PROT_NONE);
if ((state = EXEC_TAG()) == 0) {
val = rb_eval(self, node->nd_recv);
@@ -1960,6 +1960,10 @@ is_defined(self, node, buf)
}
break;
+ case NODE_NEWLINE:
+ node = node->nd_next;
+ goto again;
+
default:
PUSH_TAG(PROT_NONE);
if ((state = EXEC_TAG()) == 0) {