/* * ****************************************************************************** * MontiCore Language Workbench * Copyright (c) 2015, MontiCore, All rights reserved. * * This project is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 3.0 of the License, or (at your option) any later version. * This library 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this project. If not, see <http://www.gnu.org/licenses/>. * ****************************************************************************** */ package de.monticore.symboltable.mocks.languages.entity; import de.monticore.symboltable.Symbol; import de.monticore.symboltable.SymbolPredicate; /** * TODO: Write me! * * @author (last commit) $Author$ * @version $Revision$, * $Date$ * */ public class PropertyPredicate implements SymbolPredicate { private final PropertySymbol propertySymbol; public PropertyPredicate(PropertySymbol propertySymbol) { this.propertySymbol = propertySymbol; } @Override public boolean test(Symbol symbol) { // TODO PN eigentlich ist nur der Variable Kind relevant. Aber um auf alle // Methoden von VariabelSymbol zugreifen zu können ist der Cast notwendig // zu klären ist: wie stehen Symbol-Klasse und -Kind zueinander? // Kann bzw. darf es passieren, dass eine Unterklasse von PropertySymbol // nicht mit dem Kind kompatibel ist? if ((symbol == null) || !(symbol instanceof PropertySymbol)) { return false; } PropertySymbol casted = (PropertySymbol)symbol; return casted.isKindOf(propertySymbol.getKind()) && casted.getName().equals(propertySymbol.getName()) && casted.getType().getName().equals(propertySymbol.getType().getName()); } }