| /** |
| * Copyright (c) 2017 CEA LIST. 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 a; http://www.eclipse.org/legal/epl-v10.html Contributors: - Initial API and implementation Yupanqui Munoz Julho (CEA LIST) - Initial API and implementation |
| */ |
| package org.eclipse.papyrus.requirements.sysml.papyrusre.papyrusre.Glossary.impl; |
| |
| import org.eclipse.emf.ecore.EAttribute; |
| import org.eclipse.emf.ecore.EClass; |
| import org.eclipse.emf.ecore.EPackage; |
| import org.eclipse.emf.ecore.EReference; |
| import org.eclipse.emf.ecore.EcorePackage; |
| |
| import org.eclipse.emf.ecore.impl.EPackageImpl; |
| |
| import org.eclipse.papyrus.requirements.sysml.papyrusre.papyrusre.BasicRequirement.BasicRequirementPackage; |
| |
| import org.eclipse.papyrus.requirements.sysml.papyrusre.papyrusre.BasicRequirement.impl.BasicRequirementPackageImpl; |
| |
| import org.eclipse.papyrus.requirements.sysml.papyrusre.papyrusre.Glossary.Glossary; |
| import org.eclipse.papyrus.requirements.sysml.papyrusre.papyrusre.Glossary.GlossaryFactory; |
| import org.eclipse.papyrus.requirements.sysml.papyrusre.papyrusre.Glossary.GlossaryPackage; |
| import org.eclipse.papyrus.requirements.sysml.papyrusre.papyrusre.Glossary.Term; |
| |
| import org.eclipse.papyrus.requirements.sysml.papyrusre.papyrusre.PapyrusREPackage; |
| import org.eclipse.papyrus.requirements.sysml.papyrusre.papyrusre.RequirementClassification.RequirementClassificationPackage; |
| |
| import org.eclipse.papyrus.requirements.sysml.papyrusre.papyrusre.RequirementClassification.impl.RequirementClassificationPackageImpl; |
| |
| import org.eclipse.papyrus.requirements.sysml.papyrusre.papyrusre.RequirementKind.RequirementKindPackage; |
| |
| import org.eclipse.papyrus.requirements.sysml.papyrusre.papyrusre.RequirementKind.impl.RequirementKindPackageImpl; |
| |
| import org.eclipse.papyrus.requirements.sysml.papyrusre.papyrusre.Stakeholder.StakeholderPackage; |
| |
| import org.eclipse.papyrus.requirements.sysml.papyrusre.papyrusre.Stakeholder.impl.StakeholderPackageImpl; |
| |
| import org.eclipse.papyrus.requirements.sysml.papyrusre.papyrusre.impl.PapyrusREPackageImpl; |
| import org.eclipse.papyrus.sysml16.sysml.SysMLPackage; |
| |
| import org.eclipse.uml2.types.TypesPackage; |
| |
| import org.eclipse.uml2.uml.UMLPackage; |
| |
| import org.eclipse.uml2.uml.profile.standard.StandardPackage; |
| |
| /** |
| * <!-- begin-user-doc --> |
| * An implementation of the model <b>Package</b>. |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| public class GlossaryPackageImpl extends EPackageImpl implements GlossaryPackage { |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| private EClass glossaryEClass = null; |
| |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| private EClass termEClass = null; |
| |
| /** |
| * Creates an instance of the model <b>Package</b>, registered with |
| * {@link org.eclipse.emf.ecore.EPackage.Registry EPackage.Registry} by the package |
| * package URI value. |
| * <p>Note: the correct way to create the package is via the static |
| * factory method {@link #init init()}, which also performs |
| * initialization of the package, or returns the registered package, |
| * if one already exists. |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @see org.eclipse.emf.ecore.EPackage.Registry |
| * @see org.eclipse.papyrus.requirements.sysml.papyrusre.papyrusre.Glossary.GlossaryPackage#eNS_URI |
| * @see #init() |
| * @generated |
| */ |
| private GlossaryPackageImpl() { |
| super(eNS_URI, GlossaryFactory.eINSTANCE); |
| } |
| |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| private static boolean isInited = false; |
| |
| /** |
| * Creates, registers, and initializes the <b>Package</b> for this model, and for any others upon which it depends. |
| * |
| * <p>This method is used to initialize {@link GlossaryPackage#eINSTANCE} when that field is accessed. |
| * Clients should not invoke it directly. Instead, they should simply access that field to obtain the package. |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @see #eNS_URI |
| * @see #createPackageContents() |
| * @see #initializePackageContents() |
| * @generated |
| */ |
| public static GlossaryPackage init() { |
| if (isInited) return (GlossaryPackage)EPackage.Registry.INSTANCE.getEPackage(GlossaryPackage.eNS_URI); |
| |
| // Obtain or create and register package |
| Object registeredGlossaryPackage = EPackage.Registry.INSTANCE.get(eNS_URI); |
| GlossaryPackageImpl theGlossaryPackage = registeredGlossaryPackage instanceof GlossaryPackageImpl ? (GlossaryPackageImpl)registeredGlossaryPackage : new GlossaryPackageImpl(); |
| |
| isInited = true; |
| |
| // Initialize simple dependencies |
| EcorePackage.eINSTANCE.eClass(); |
| StandardPackage.eINSTANCE.eClass(); |
| SysMLPackage.eINSTANCE.eClass(); |
| TypesPackage.eINSTANCE.eClass(); |
| UMLPackage.eINSTANCE.eClass(); |
| |
| // Obtain or create and register interdependencies |
| Object registeredPackage = EPackage.Registry.INSTANCE.getEPackage(PapyrusREPackage.eNS_URI); |
| PapyrusREPackageImpl thePapyrusREPackage = (PapyrusREPackageImpl)(registeredPackage instanceof PapyrusREPackageImpl ? registeredPackage : PapyrusREPackage.eINSTANCE); |
| registeredPackage = EPackage.Registry.INSTANCE.getEPackage(BasicRequirementPackage.eNS_URI); |
| BasicRequirementPackageImpl theBasicRequirementPackage = (BasicRequirementPackageImpl)(registeredPackage instanceof BasicRequirementPackageImpl ? registeredPackage : BasicRequirementPackage.eINSTANCE); |
| registeredPackage = EPackage.Registry.INSTANCE.getEPackage(StakeholderPackage.eNS_URI); |
| StakeholderPackageImpl theStakeholderPackage = (StakeholderPackageImpl)(registeredPackage instanceof StakeholderPackageImpl ? registeredPackage : StakeholderPackage.eINSTANCE); |
| registeredPackage = EPackage.Registry.INSTANCE.getEPackage(RequirementKindPackage.eNS_URI); |
| RequirementKindPackageImpl theRequirementKindPackage = (RequirementKindPackageImpl)(registeredPackage instanceof RequirementKindPackageImpl ? registeredPackage : RequirementKindPackage.eINSTANCE); |
| registeredPackage = EPackage.Registry.INSTANCE.getEPackage(RequirementClassificationPackage.eNS_URI); |
| RequirementClassificationPackageImpl theRequirementClassificationPackage = (RequirementClassificationPackageImpl)(registeredPackage instanceof RequirementClassificationPackageImpl ? registeredPackage : RequirementClassificationPackage.eINSTANCE); |
| |
| // Create package meta-data objects |
| theGlossaryPackage.createPackageContents(); |
| thePapyrusREPackage.createPackageContents(); |
| theBasicRequirementPackage.createPackageContents(); |
| theStakeholderPackage.createPackageContents(); |
| theRequirementKindPackage.createPackageContents(); |
| theRequirementClassificationPackage.createPackageContents(); |
| |
| // Initialize created meta-data |
| theGlossaryPackage.initializePackageContents(); |
| thePapyrusREPackage.initializePackageContents(); |
| theBasicRequirementPackage.initializePackageContents(); |
| theStakeholderPackage.initializePackageContents(); |
| theRequirementKindPackage.initializePackageContents(); |
| theRequirementClassificationPackage.initializePackageContents(); |
| |
| // Mark meta-data to indicate it can't be changed |
| theGlossaryPackage.freeze(); |
| |
| // Update the registry and return the package |
| EPackage.Registry.INSTANCE.put(GlossaryPackage.eNS_URI, theGlossaryPackage); |
| return theGlossaryPackage; |
| } |
| |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| @Override |
| public EClass getGlossary() { |
| return glossaryEClass; |
| } |
| |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| @Override |
| public EReference getGlossary_Base_Package() { |
| return (EReference)glossaryEClass.getEStructuralFeatures().get(0); |
| } |
| |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| @Override |
| public EClass getTerm() { |
| return termEClass; |
| } |
| |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| @Override |
| public EAttribute getTerm_Definition() { |
| return (EAttribute)termEClass.getEStructuralFeatures().get(0); |
| } |
| |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| @Override |
| public EReference getTerm_Base_PrimitiveType() { |
| return (EReference)termEClass.getEStructuralFeatures().get(1); |
| } |
| |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| @Override |
| public GlossaryFactory getGlossaryFactory() { |
| return (GlossaryFactory)getEFactoryInstance(); |
| } |
| |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| private boolean isCreated = false; |
| |
| /** |
| * Creates the meta-model objects for the package. This method is |
| * guarded to have no affect on any invocation but its first. |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| public void createPackageContents() { |
| if (isCreated) return; |
| isCreated = true; |
| |
| // Create classes and their features |
| glossaryEClass = createEClass(GLOSSARY); |
| createEReference(glossaryEClass, GLOSSARY__BASE_PACKAGE); |
| |
| termEClass = createEClass(TERM); |
| createEAttribute(termEClass, TERM__DEFINITION); |
| createEReference(termEClass, TERM__BASE_PRIMITIVE_TYPE); |
| } |
| |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| private boolean isInitialized = false; |
| |
| /** |
| * Complete the initialization of the package and its meta-model. This |
| * method is guarded to have no affect on any invocation but its first. |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| public void initializePackageContents() { |
| if (isInitialized) return; |
| isInitialized = true; |
| |
| // Initialize package |
| setName(eNAME); |
| setNsPrefix(eNS_PREFIX); |
| setNsURI(eNS_URI); |
| |
| // Obtain other dependent packages |
| UMLPackage theUMLPackage = (UMLPackage)EPackage.Registry.INSTANCE.getEPackage(UMLPackage.eNS_URI); |
| TypesPackage theTypesPackage = (TypesPackage)EPackage.Registry.INSTANCE.getEPackage(TypesPackage.eNS_URI); |
| |
| // Create type parameters |
| |
| // Set bounds for type parameters |
| |
| // Add supertypes to classes |
| |
| // Initialize classes, features, and operations; add parameters |
| initEClass(glossaryEClass, Glossary.class, "Glossary", !IS_ABSTRACT, !IS_INTERFACE, IS_GENERATED_INSTANCE_CLASS); //$NON-NLS-1$ |
| initEReference(getGlossary_Base_Package(), theUMLPackage.getPackage(), null, "base_Package", null, 0, 1, Glossary.class, !IS_TRANSIENT, !IS_VOLATILE, IS_CHANGEABLE, !IS_COMPOSITE, IS_RESOLVE_PROXIES, !IS_UNSETTABLE, IS_UNIQUE, !IS_DERIVED, !IS_ORDERED); //$NON-NLS-1$ |
| |
| initEClass(termEClass, Term.class, "Term", !IS_ABSTRACT, !IS_INTERFACE, IS_GENERATED_INSTANCE_CLASS); //$NON-NLS-1$ |
| initEAttribute(getTerm_Definition(), theTypesPackage.getString(), "definition", " ", 0, 1, Term.class, !IS_TRANSIENT, !IS_VOLATILE, IS_CHANGEABLE, !IS_UNSETTABLE, !IS_ID, IS_UNIQUE, !IS_DERIVED, !IS_ORDERED); //$NON-NLS-1$ //$NON-NLS-2$ |
| initEReference(getTerm_Base_PrimitiveType(), theUMLPackage.getPrimitiveType(), null, "base_PrimitiveType", null, 0, 1, Term.class, !IS_TRANSIENT, !IS_VOLATILE, IS_CHANGEABLE, !IS_COMPOSITE, IS_RESOLVE_PROXIES, !IS_UNSETTABLE, IS_UNIQUE, !IS_DERIVED, !IS_ORDERED); //$NON-NLS-1$ |
| } |
| |
| } //GlossaryPackageImpl |