/* * ****************************************************************************** * MontiCore Language Workbench * Copyright (c) 2016, 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.codegen.symboltable; import static de.monticore.codegen.GeneratorHelper.getPackageName; import static de.monticore.codegen.GeneratorHelper.getSimpleTypeNameToGenerate; import static de.se_rwth.commons.Names.getSimpleName; import java.nio.file.Path; import java.nio.file.Paths; import de.monticore.codegen.mc2cd.TransformationHelper; import de.monticore.generating.GeneratorEngine; import de.monticore.grammar.symboltable.MCProdSymbol; import de.monticore.io.paths.IterablePath; import de.se_rwth.commons.Names; /** * @author Pedram Mir Seyed Nazari */ public class CommonScopeSpanningSymbolGenerator implements ScopeSpanningSymbolGenerator { public static final String EMPTY_SYMBOL_SUFFIX = "SymbolEMPTY"; public void generate(GeneratorEngine genEngine, SymbolTableGeneratorHelper genHelper, IterablePath handCodedPath, MCProdSymbol ruleSymbol) { final String className = getSimpleTypeNameToGenerate(getSimpleName(ruleSymbol.getName() + "Symbol"), genHelper.getTargetPackage(), handCodedPath); final Path filePath = Paths.get(Names.getPathFromPackage(genHelper.getTargetPackage()), className + ".java"); generateEmpty(genEngine, genHelper, handCodedPath, ruleSymbol); genEngine.generate("symboltable.ScopeSpanningSymbol", filePath, ruleSymbol.getAstNode().get(), className, getScopeClassName(ruleSymbol), ruleSymbol); generateScope(genEngine, genHelper, handCodedPath, ruleSymbol); } protected void generateEmpty(GeneratorEngine genEngine, SymbolTableGeneratorHelper genHelper, IterablePath handCodedPath, MCProdSymbol ruleSymbol) { final String className = getSimpleTypeNameToGenerate(getSimpleName(ruleSymbol.getName() + EMPTY_SYMBOL_SUFFIX), genHelper.getTargetPackage(), handCodedPath); final Path filePath = Paths.get(Names.getPathFromPackage(genHelper.getTargetPackage()), className + ".java"); if (ruleSymbol.getAstNode().isPresent()) { genEngine.generate("symboltable.EmptyScopeSpanningSymbol", filePath, ruleSymbol.getAstNode().get(), className, ruleSymbol); } } protected void generateScope(GeneratorEngine genEngine, SymbolTableGeneratorHelper genHelper, IterablePath handCodedPath, MCProdSymbol ruleSymbol) { final String className = getScopeClassName(ruleSymbol); final String qualifiedClassName = getPackageName(genHelper.getTargetPackage(), "") + className; if(TransformationHelper.existsHandwrittenClass(handCodedPath, qualifiedClassName)) { // Scope classes are very simple and small. Hence, skip their generation // if handwritten class exists. return; } final Path filePath = Paths.get(Names.getPathFromPackage(genHelper.getTargetPackage()), className + ".java"); if (ruleSymbol.getAstNode().isPresent()) { genEngine.generate("symboltable.Scope", filePath, ruleSymbol.getAstNode().get(), className); } } private String getScopeClassName(MCProdSymbol ruleSymbol) { return ruleSymbol.getName() + "Scope"; } }