diff options
author | ko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2007-07-03 19:11:49 +0000 |
---|---|---|
committer | ko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2007-07-03 19:11:49 +0000 |
commit | 43bbe2841daf838111aa3f2687c23506191e76e7 (patch) | |
tree | 4afa1ee916597c6a307dc3bc90322792c077ec83 /compile.c | |
parent | 590609f255378694c085b5ee20a6a083d4eab0c3 (diff) |
* compile.c (compile_array): ignore NODE_ZARRAY.
[ruby-dev:31110]
* bootstraptest/test_method.rb: add a test for above.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@12686 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'compile.c')
-rw-r--r-- | compile.c | 22 |
1 files changed, 12 insertions, 10 deletions
@@ -1831,18 +1831,20 @@ compile_array(rb_iseq_t *iseq, int len = node->nd_alen, line = nd_line(node), i=0; DECL_ANCHOR(anchor); - while (node) { - if (nd_type(node) != NODE_ARRAY) { - rb_bug("compile_array: This node is not NODE_ARRAY, but %s", - ruby_node_name(nd_type(node))); - } + if (nd_type(node) != NODE_ZARRAY) { + while (node) { + if (nd_type(node) != NODE_ARRAY) { + rb_bug("compile_array: This node is not NODE_ARRAY, but %s", + ruby_node_name(nd_type(node))); + } - i++; - if (opt_p && nd_type(node->nd_head) != NODE_LIT) { - opt_p = Qfalse; + i++; + if (opt_p && nd_type(node->nd_head) != NODE_LIT) { + opt_p = Qfalse; + } + COMPILE(anchor, "array element", node->nd_head); + node = node->nd_next; } - COMPILE(anchor, "array element", node->nd_head); - node = node->nd_next; } if (len != i) { |