IterNode.java

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

  33. import java.util.List;

  34. import org.jruby.ast.visitor.NodeVisitor;
  35. import org.jruby.lexer.yacc.ISourcePosition;
  36. import org.jruby.parser.StaticScope;
  37. import org.jruby.runtime.BlockBody;

  38. /**
  39.  * Represents a block.  
  40.  */
  41. public class IterNode extends Node {
  42.     private final Node varNode;
  43.     private final Node bodyNode;
  44.    
  45.     // What static scoping relationship exists when it comes into being.
  46.     private StaticScope scope;

  47.     /**
  48.      *  Used by Truffle 'for' and by ForNode only.
  49.      * This is to support 1.8-style assignments which only 'for' expressions use.
  50.      */
  51.     public IterNode(ISourcePosition position, Node args, StaticScope scope, Node body) {
  52.         super(position);

  53.         this.varNode = args;
  54.         this.scope = scope;
  55.         this.bodyNode = body;
  56.     }

  57.     /**
  58.      * Used for all non-for types of blocks.
  59.      */
  60.     public IterNode(ISourcePosition position, ArgsNode args, Node body, StaticScope scope) {
  61.         super(position);

  62.         this.varNode = args;
  63.         this.bodyNode = body;
  64.         this.scope = scope;
  65.     }

  66.     public int getArgumentType() {
  67.         return BlockBody.asArgumentType(varNode.getNodeType());
  68.     }

  69.     public NodeType getNodeType() {
  70.         return NodeType.ITERNODE;
  71.     }

  72.     /**
  73.      * Accept for the visitor pattern.
  74.      * @param iVisitor the visitor
  75.      **/
  76.     public <T> T accept(NodeVisitor<T> iVisitor) {
  77.         return iVisitor.visitIterNode(this);
  78.     }

  79.     public StaticScope getScope() {
  80.         return scope;
  81.     }

  82.     /**
  83.      * Gets the bodyNode.
  84.      * @return Returns a Node
  85.      */
  86.     public Node getBodyNode() {
  87.         return bodyNode;
  88.     }

  89.     /**
  90.      * Gets the varNode.
  91.      * @return Returns a Node
  92.      */
  93.     public Node getVarNode() {
  94.         return varNode;
  95.     }
  96.    
  97.     public List<Node> childNodes() {
  98.         return Node.createList(varNode, bodyNode);
  99.     }
  100. }