/******************************************************************************* * Copyright (c) 2010-2015 Henshin developers. All rights reserved. * This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html * * Contributors: * TU Berlin, University of Luxembourg, SES S.A. *******************************************************************************/ /** */ package source; import org.eclipse.emf.common.util.EList; import org.eclipse.emf.ecore.EObject; /** * <!-- begin-user-doc --> * A representation of the model object '<em><b>Class</b></em>'. * <!-- end-user-doc --> * * <p> * The following features are supported: * <ul> * <li>{@link source.Class#getName <em>Name</em>}</li> * <li>{@link source.Class#getParent <em>Parent</em>}</li> * <li>{@link source.Class#getAttrs <em>Attrs</em>}</li> * </ul> * </p> * * @see source.SourcePackage#getClass_() * @model * @generated */ public interface Class extends EObject { /** * Returns the value of the '<em><b>Name</b></em>' attribute. * <!-- begin-user-doc --> * <p> * If the meaning of the '<em>Name</em>' attribute isn't clear, * there really should be more of a description here... * </p> * <!-- end-user-doc --> * @return the value of the '<em>Name</em>' attribute. * @see #setName(String) * @see source.SourcePackage#getClass_Name() * @model * @generated */ String getName(); /** * Sets the value of the '{@link source.Class#getName <em>Name</em>}' attribute. * <!-- begin-user-doc --> * <!-- end-user-doc --> * @param value the new value of the '<em>Name</em>' attribute. * @see #getName() * @generated */ void setName(String value); /** * Returns the value of the '<em><b>Parent</b></em>' reference. * <!-- begin-user-doc --> * <p> * If the meaning of the '<em>Parent</em>' reference isn't clear, * there really should be more of a description here... * </p> * <!-- end-user-doc --> * @return the value of the '<em>Parent</em>' reference. * @see #setParent(Class) * @see source.SourcePackage#getClass_Parent() * @model * @generated */ Class getParent(); /** * Sets the value of the '{@link source.Class#getParent <em>Parent</em>}' reference. * <!-- begin-user-doc --> * <!-- end-user-doc --> * @param value the new value of the '<em>Parent</em>' reference. * @see #getParent() * @generated */ void setParent(Class value); /** * Returns the value of the '<em><b>Attrs</b></em>' containment reference list. * The list contents are of type {@link source.Attribute}. * <!-- begin-user-doc --> * <p> * If the meaning of the '<em>Attrs</em>' containment reference list isn't clear, * there really should be more of a description here... * </p> * <!-- end-user-doc --> * @return the value of the '<em>Attrs</em>' containment reference list. * @see source.SourcePackage#getClass_Attrs() * @model containment="true" required="true" * @generated */ EList<Attribute> getAttrs(); } // Class