/** * Optimus, framework for Model Transformation * * Copyright (C) 2013 Worldline or third-party contributors as * indicated by the @author tags or express copyright attribution * statements applied by the authors. * * This library 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 2.1 of the License. * * 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 library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA */ package net.atos.optimus.m2m.javaxmi.operation.classes; import org.eclipse.emf.common.util.EList; import org.eclipse.gmt.modisco.java.ClassDeclaration; import org.eclipse.gmt.modisco.java.CompilationUnit; import org.eclipse.gmt.modisco.java.Modifier; import org.eclipse.gmt.modisco.java.Package; import org.eclipse.gmt.modisco.java.TypeAccess; import org.eclipse.gmt.modisco.java.TypeDeclaration; import org.eclipse.gmt.modisco.java.emf.JavaFactory; /** * A builder dedicated to create class declaration of modisco model * * @author tnachtergaele <nachtergaele.thomas@gmail.com> * * */ public class ClassDeclarationBuilder { /** The build class declaration */ private ClassDeclaration buildClassDeclaration; /** * Give a new class declaration builder * * @return a new class declaration builder. */ public static ClassDeclarationBuilder builder() { return new ClassDeclarationBuilder(); } /** * Private constructor * */ private ClassDeclarationBuilder() { this.buildClassDeclaration = JavaFactory.eINSTANCE.createClassDeclaration(); } /** * Build a class declaration of modisco model * * @return a new class declaration of modisco model. */ public ClassDeclaration build() { return this.buildClassDeclaration; } /** * Set the name of the class declaration under construction * * @param name * the name of the class declaration under construction. * @return the builder. */ public ClassDeclarationBuilder setName(String name) { this.buildClassDeclaration.setName(name); return this; } /** * Set the package of the class declaration under construction * * @param javaPackage * the parent package of the class declaration under * construction. * @return the builder. */ public ClassDeclarationBuilder setPackage(Package javaPackage) { this.buildClassDeclaration.setPackage(javaPackage); return this; } /** * Set the proxy state of the class declaration under construction * * @param isProxy * the proxy state of the class declaration under construction. * @return the builder. */ public ClassDeclarationBuilder setProxy(boolean isProxy) { this.buildClassDeclaration.setProxy(isProxy); return this; } /** * Set the modifier of the class declaration under construction * * @param modifier * the modifier of the class declaration under construction. * @return the builder. */ public ClassDeclarationBuilder setModifier(Modifier modifier) { this.buildClassDeclaration.setModifier(modifier); return this; } /** * Set the compilation unit of the class declaration under construction * * @param compilationUnit * the compilation unit of the class declaration under * construction. * @return the builder. */ public ClassDeclarationBuilder setCompilationUnit(CompilationUnit compilationUnit) { this.buildClassDeclaration.setOriginalCompilationUnit(compilationUnit); return this; } /** * Set the abstract type of the class declaration under construction * * @param typeDeclaration * the abstract type of the class declaration under construction. * @return the builder. */ public ClassDeclarationBuilder setAbstractTypeDeclaration(TypeDeclaration typeDeclaration) { this.buildClassDeclaration.setAbstractTypeDeclaration(typeDeclaration); return this; } /** * Set the super type class of the class declaration under construction * * @param superType * the super type class of the class declaration under * construction. * @return the builder. */ public ClassDeclarationBuilder setSuperClass(TypeAccess superType) { this.buildClassDeclaration.setSuperClass(superType); return this; } /** * Add interfaces list to the class declaration under construction * * @param interfaces * the interfaces list to add to the class declaration under * construction. * @return the builder. */ public ClassDeclarationBuilder addInterfaces(TypeAccess... interfaces) { EList<TypeAccess> interfacesList = this.buildClassDeclaration.getSuperInterfaces(); for (TypeAccess javaInterface : interfaces) { interfacesList.add(javaInterface); } return this; } }