/*
* Copyright 2010 Pablo Arrighi, Alex Concha, Miguel Lezama for version 1.
* Copyright 2013 Pablo Arrighi, Miguel Lezama, Kevin Mazet for version 2.
*
* This file is part of GOOL.
*
* GOOL is free software: you can redistribute it and/or modify it under the terms of the GNU
* General Public License as published by the Free Software Foundation, version 3.
*
* GOOL is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without
* even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the GNU General Public License version 3 for more details.
*
* You should have received a copy of the GNU General Public License along with GOOL,
* in the file COPYING.txt. If not, see <http://www.gnu.org/licenses/>.
*/
package gool.ast.core;
import gool.generator.GoolGeneratorController;
import java.util.ArrayList;
import java.util.List;
/**
* This class represents a list of statements with its optional 'return'
* expression.
*/
public class Block extends Statement {
/**
* The list of statements.
*/
private List<Statement> statements = new ArrayList<Statement>();
/**
* Creates a new block with the specified expression.
*
* @param expr
* the expression to be returned by the {@link Block}.
*/
public Block(Statement statement) {
statements.add(statement);
}
/**
* The empty constructor of new block.
*/
public Block() {
}
/**
* Appends a statement to the end of the statements' list.
*
* @param statement
* statement to be appended.
*/
public void addStatement(Statement statement) {
statements.add(statement);
}
/**
* Appends a statement to the end of the statements' list.
*
* @param statement
* statement to be appended
* @param position
* the position of the statement.
*/
public void addStatement(Statement statement, int position) {
statements.add(position, statement);
}
@Override
public String callGetCode() {
return GoolGeneratorController.generator().getCode(this);
}
/**
* Returns the list of statements.
*
* @return the list of statements.
*/
public List<Statement> getStatements() {
return statements;
}
/**
* Appends a list of statements to the end of the statements' list.
*
* @param statements
* statements to be appended.
*/
public void addStatements(List<Statement> statements) {
this.statements.addAll(statements);
}
}