/* * 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.ast.type.IType; import gool.generator.GoolGeneratorController; /** * This class captures a variable declaration in the intermediate language. * Hence it is a Dec. But because declarations are usually OK statements in OO * Languages it is also a Statement * * @param T * is the type of the declared variable, if known at compile time, * otherwise put IType. That way java generics grant us some level of * type checking of the generated code at compiler design time. * Sometimes we will not be able to use this though, because we will * not know T at compiler design time. */ public final class Identifier extends Expression { /** * The name of the identifier. */ private String name; /** * The constructor of an identifier. * @param type * : The type of the identifier. * @param name * : The name of the identifier. */ public Identifier(IType type, String name) { super(type); this.name = name; } @Override public String callGetCode() { return GoolGeneratorController.generator().getCode(this); } /** * Gets the name of the identifier. * @return * The name of the identifier. */ public String getName() { return name; } }