KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > org > jruby > ast > ForNode


1 /***** BEGIN LICENSE BLOCK *****
2  * Version: CPL 1.0/GPL 2.0/LGPL 2.1
3  *
4  * The contents of this file are subject to the Common Public
5  * License Version 1.0 (the "License"); you may not use this file
6  * except in compliance with the License. You may obtain a copy of
7  * the License at http://www.eclipse.org/legal/cpl-v10.html
8  *
9  * Software distributed under the License is distributed on an "AS
10  * IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
11  * implied. See the License for the specific language governing
12  * rights and limitations under the License.
13  *
14  * Copyright (C) 2001-2002 Jan Arne Petersen <jpetersen@uni-bonn.de>
15  * Copyright (C) 2001-2002 Benoit Cerrina <b.cerrina@wanadoo.fr>
16  * Copyright (C) 2002 Anders Bengtsson <ndrsbngtssn@yahoo.se>
17  * Copyright (C) 2004-2006 Thomas E Enebo <enebo@acm.org>
18  *
19  * Alternatively, the contents of this file may be used under the terms of
20  * either of the GNU General Public License Version 2 or later (the "GPL"),
21  * or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
22  * in which case the provisions of the GPL or the LGPL are applicable instead
23  * of those above. If you wish to allow use of your version of this file only
24  * under the terms of either the GPL or the LGPL, and not to allow others to
25  * use your version of this file under the terms of the CPL, indicate your
26  * decision by deleting the provisions above and replace them with the notice
27  * and other provisions required by the GPL or the LGPL. If you do not delete
28  * the provisions above, a recipient may use your version of this file under
29  * the terms of any one of the CPL, the GPL or the LGPL.
30  ***** END LICENSE BLOCK *****/

31 package org.jruby.ast;
32
33 import org.jruby.ast.visitor.NodeVisitor;
34 import org.jruby.evaluator.Instruction;
35 import org.jruby.lexer.yacc.ISourcePosition;
36
37 /**
38  * A 'for' statement. This is implemented using iter and that is how MRI does things,
39  * but 'for's do not have their own stack, so doing this way is mildly painful.
40  *
41  * @see IterNode
42  */

43 public class ForNode extends IterNode {
44     static final long serialVersionUID = -8319863477790150586L;
45     private Node iterNode;
46
47     public ForNode(ISourcePosition position, Node varNode, Node bodyNode, Node iterNode) {
48         // For nodes do not have their own scope so we pass null to indicate this.
49
// 'For's are implemented as blocks in evaluation, but they have no scope so we
50
// just deal with this lack of scope throughout its lifespan. We should probably
51
// change the way this works to get rid of multiple null checks.
52
super(position, varNode, null, bodyNode, NodeTypes.FORNODE);
53         
54         this.iterNode = iterNode;
55     }
56     
57     public Node getIterNode() {
58         return iterNode;
59     }
60
61     /**
62      * Accept for the visitor pattern.
63      * @param iVisitor the visitor
64      **/

65     public Instruction accept(NodeVisitor iVisitor) {
66         return iVisitor.visitForNode(this);
67     }
68 }
69
Popular Tags