diff options
Diffstat (limited to 'plugins/uml/diagram/org.eclipse.papyrus.uml.diagram.clazz/src/org/eclipse/papyrus/uml/diagram/clazz/edit/policies/ComponentItemSemanticEditPolicyCN.java')
-rw-r--r-- | plugins/uml/diagram/org.eclipse.papyrus.uml.diagram.clazz/src/org/eclipse/papyrus/uml/diagram/clazz/edit/policies/ComponentItemSemanticEditPolicyCN.java | 996 |
1 files changed, 479 insertions, 517 deletions
diff --git a/plugins/uml/diagram/org.eclipse.papyrus.uml.diagram.clazz/src/org/eclipse/papyrus/uml/diagram/clazz/edit/policies/ComponentItemSemanticEditPolicyCN.java b/plugins/uml/diagram/org.eclipse.papyrus.uml.diagram.clazz/src/org/eclipse/papyrus/uml/diagram/clazz/edit/policies/ComponentItemSemanticEditPolicyCN.java index 43e0bda8a71..f87b74f8018 100644 --- a/plugins/uml/diagram/org.eclipse.papyrus.uml.diagram.clazz/src/org/eclipse/papyrus/uml/diagram/clazz/edit/policies/ComponentItemSemanticEditPolicyCN.java +++ b/plugins/uml/diagram/org.eclipse.papyrus.uml.diagram.clazz/src/org/eclipse/papyrus/uml/diagram/clazz/edit/policies/ComponentItemSemanticEditPolicyCN.java @@ -1,517 +1,479 @@ -/** - * Copyright (c) 2014 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 at - * http://www.eclipse.org/legal/epl-v10.html - * - * Contributors: - * CEA LIST - Initial API and implementation - */ -package org.eclipse.papyrus.uml.diagram.clazz.edit.policies; - -import org.eclipse.emf.ecore.EObject; -import org.eclipse.gef.commands.Command; -import org.eclipse.gef.commands.UnexecutableCommand; -import org.eclipse.gmf.runtime.common.core.command.ICommand; -import org.eclipse.gmf.runtime.diagram.ui.commands.ICommandProxy; -import org.eclipse.gmf.runtime.emf.type.core.IElementType; -import org.eclipse.gmf.runtime.emf.type.core.requests.CreateElementRequest; -import org.eclipse.gmf.runtime.emf.type.core.requests.CreateRelationshipRequest; -import org.eclipse.gmf.runtime.emf.type.core.requests.DestroyElementRequest; -import org.eclipse.gmf.runtime.emf.type.core.requests.ReorientReferenceRelationshipRequest; -import org.eclipse.gmf.runtime.emf.type.core.requests.ReorientRelationshipRequest; -import org.eclipse.papyrus.infra.extendedtypes.types.IExtendedHintedElementType; -import org.eclipse.papyrus.infra.extendedtypes.util.ElementTypeUtils; -import org.eclipse.papyrus.infra.gmfdiag.common.utils.DiagramUtils; -import org.eclipse.papyrus.infra.services.edit.service.ElementEditServiceUtils; -import org.eclipse.papyrus.infra.services.edit.service.IElementEditService; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.AbstractionCreateCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.AbstractionReorientCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.AssociationBranchCreateCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.AssociationBranchReorientCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.AssociationClassLinkCreateCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.AssociationClassLinkReorientCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.AssociationCreateCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.AssociationReorientCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.CommentAnnotatedElementCreateCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.CommentAnnotatedElementReorientCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.ConnectorDurationObservationCreateCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.ConnectorDurationObservationReorientCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.ConnectorTimeObservationCreateCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.ConnectorTimeObservationReorientCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.ConstraintConstrainedElementCreateCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.ConstraintConstrainedElementReorientCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.ContextLinkCreateCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.ContextLinkReorientCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.Dependency2ReorientCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.Dependency3CreateCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.DependencyCreateCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.DependencyReorientCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.ElementImportCreateCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.ElementImportReorientCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.GeneralizationCreateCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.InformationFlowCreateCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.InformationFlowReorientCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.InterfaceRealizationCreateCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.InterfaceRealizationReorientCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.PackageImportCreateCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.PackageImportReorientCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.RealizationCreateCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.RealizationReorientCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.RedefinableTemplateSignatureCreateCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.SubstitutionCreateCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.SubstitutionReorientCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.TemplateBindingCreateCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.TemplateBindingReorientCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.UsageCreateCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.UsageReorientCommand; -import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.AbstractionEditPart; -import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.AssociationBranchEditPart; -import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.AssociationClassLinkEditPart; -import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.AssociationEditPart; -import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.CommentAnnotatedElementEditPart; -import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.ConnectorDurationObservationEditPart; -import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.ConnectorTimeObservationEditPart; -import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.ConstraintConstrainedElementEditPart; -import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.ContextLinkEditPart; -import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.DependencyBranchEditPart; -import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.DependencyEditPart; -import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.ElementImportEditPart; -import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.GeneralizationEditPart; -import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.InformationFlowEditPart; -import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.InterfaceRealizationEditPart; -import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.PackageImportEditPart; -import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.RealizationEditPart; -import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.SubstitutionEditPart; -import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.TemplateBindingEditPart; -import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.UsageEditPart; -import org.eclipse.papyrus.uml.diagram.clazz.providers.UMLElementTypes; - -/** - * @generated - */ -public class ComponentItemSemanticEditPolicyCN extends UMLBaseItemSemanticEditPolicy { - /** - * @generated - */ - public ComponentItemSemanticEditPolicyCN() { - super(UMLElementTypes.Component_3021); - } - - /** - * @generated - */ - protected Command getCreateCommand(CreateElementRequest req) { - IElementType requestElementType = req.getElementType(); - if (requestElementType == null) { - return super.getCreateCommand(req); - } - if (UMLElementTypes.RedefinableTemplateSignature_3015 == requestElementType) { - return getGEFWrapper(new RedefinableTemplateSignatureCreateCommand(req, DiagramUtils.getDiagramFrom(getHost()))); - } - return super.getCreateCommand(req); - } - - /** - * @generated - */ - protected Command getDestroyElementCommand(DestroyElementRequest req) { - EObject selectedEObject = req.getElementToDestroy(); - IElementEditService provider = ElementEditServiceUtils.getCommandProvider(selectedEObject); - if (provider != null) { - // Retrieve delete command from the Element Edit service - ICommand deleteCommand = provider.getEditCommand(req); - if (deleteCommand != null) { - return new ICommandProxy(deleteCommand); - } - } - return UnexecutableCommand.INSTANCE; - } - - /** - * @generated - */ - protected Command getCreateRelationshipCommand( - CreateRelationshipRequest req) { - Command command = req.getTarget() == null ? - getStartCreateRelationshipCommand(req) : getCompleteCreateRelationshipCommand(req); - return command != null ? command : super.getCreateRelationshipCommand(req); - } - - /** - * @generated - */ - protected Command getStartCreateRelationshipCommand( - CreateRelationshipRequest req) { - IElementType requestElementType = req.getElementType(); - if (requestElementType == null) { - return null; - } - IElementType baseElementType = requestElementType; - boolean isExtendedType = false; - if (requestElementType instanceof IExtendedHintedElementType) { - baseElementType = ElementTypeUtils.getClosestDiagramType(requestElementType); - if (baseElementType != null) { - isExtendedType = true; - } else { - // no reference element type ID. using the closest super element type to give more opportunities, but can lead to bugs. - baseElementType = ElementTypeUtils.findClosestNonExtendedElementType((IExtendedHintedElementType) requestElementType); - isExtendedType = true; - } - } - if (UMLElementTypes.AssociationClass_4017 == baseElementType) { - if (isExtendedType) { - return getExtendedStartCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new AssociationClassLinkCreateCommand(req, - req.getSource(), req.getTarget())); - } - if (UMLElementTypes.Association_4001 == baseElementType) { - if (isExtendedType) { - return getExtendedStartCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new AssociationCreateCommand(req, - req.getSource(), req.getTarget())); - } - if (UMLElementTypes.Association_4019 == baseElementType) { - if (isExtendedType) { - return getExtendedStartCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new AssociationBranchCreateCommand(req, - req.getSource(), req.getTarget())); - } - if (UMLElementTypes.Generalization_4002 == baseElementType) { - if (isExtendedType) { - return getExtendedStartCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new GeneralizationCreateCommand(req, - req.getSource(), req.getTarget())); - } - if (UMLElementTypes.InterfaceRealization_4003 == baseElementType) { - if (isExtendedType) { - return getExtendedStartCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new InterfaceRealizationCreateCommand(req, - req.getSource(), req.getTarget())); - } - if (UMLElementTypes.Substitution_4004 == baseElementType) { - if (isExtendedType) { - return getExtendedStartCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new SubstitutionCreateCommand(req, - req.getSource(), req.getTarget())); - } - if (UMLElementTypes.Realization_4005 == baseElementType) { - if (isExtendedType) { - return getExtendedStartCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new RealizationCreateCommand(req, - req.getSource(), req.getTarget())); - } - if (UMLElementTypes.Abstraction_4006 == baseElementType) { - if (isExtendedType) { - return getExtendedStartCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new AbstractionCreateCommand(req, - req.getSource(), req.getTarget())); - } - if (UMLElementTypes.Usage_4007 == baseElementType) { - if (isExtendedType) { - return getExtendedStartCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new UsageCreateCommand(req, - req.getSource(), req.getTarget())); - } - if (UMLElementTypes.Dependency_4008 == baseElementType) { - if (isExtendedType) { - return getExtendedStartCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new DependencyCreateCommand(req, - req.getSource(), req.getTarget())); - } - if (UMLElementTypes.Dependency_4018 == baseElementType) { - if (isExtendedType) { - return getExtendedStartCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new Dependency3CreateCommand(req, - req.getSource(), req.getTarget())); - } - if (UMLElementTypes.ElementImport_4009 == baseElementType) { - if (isExtendedType) { - return getExtendedStartCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new ElementImportCreateCommand(req, - req.getSource(), req.getTarget())); - } - if (UMLElementTypes.PackageImport_4010 == baseElementType) { - if (isExtendedType) { - return getExtendedStartCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new PackageImportCreateCommand(req, - req.getSource(), req.getTarget())); - } - if (UMLElementTypes.CommentAnnotatedElement_4013 == baseElementType) { - return null; - } - if (UMLElementTypes.ConstraintConstrainedElement_4014 == baseElementType) { - return null; - } - if (UMLElementTypes.TemplateBinding_4015 == baseElementType) { - if (isExtendedType) { - return getExtendedStartCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new TemplateBindingCreateCommand(req, - req.getSource(), req.getTarget())); - } - if (UMLElementTypes.TimeObservationEvent_4024 == baseElementType) { - return null; - } - if (UMLElementTypes.DurationObservationEvent_4025 == baseElementType) { - return null; - } - if (UMLElementTypes.InformationFlow_4026 == baseElementType) { - if (isExtendedType) { - return getExtendedStartCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new InformationFlowCreateCommand(req, - req.getSource(), req.getTarget())); - } - if (UMLElementTypes.ConstraintContext_8500 == baseElementType) { - return null; - } - return null; - } - - /** - * @generated - */ - protected Command getCompleteCreateRelationshipCommand( - CreateRelationshipRequest req) { - IElementType requestElementType = req.getElementType(); - if (requestElementType == null) { - return null; - } - IElementType baseElementType = requestElementType; - boolean isExtendedType = false; - if (requestElementType instanceof IExtendedHintedElementType) { - baseElementType = ElementTypeUtils.getClosestDiagramType(requestElementType); - if (baseElementType != null) { - isExtendedType = true; - } else { - // no reference element type ID. using the closest super element type to give more opportunities, but can lead to bugs. - baseElementType = ElementTypeUtils.findClosestNonExtendedElementType((IExtendedHintedElementType) requestElementType); - isExtendedType = true; - } - } - if (UMLElementTypes.AssociationClass_4017 == baseElementType) { - if (isExtendedType) { - return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new AssociationClassLinkCreateCommand(req, - req.getSource(), req.getTarget())); - } - if (UMLElementTypes.Association_4001 == baseElementType) { - if (isExtendedType) { - return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new AssociationCreateCommand(req, - req.getSource(), req.getTarget())); - } - if (UMLElementTypes.Association_4019 == baseElementType) { - if (isExtendedType) { - return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new AssociationBranchCreateCommand(req, - req.getSource(), req.getTarget())); - } - if (UMLElementTypes.Generalization_4002 == baseElementType) { - if (isExtendedType) { - return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new GeneralizationCreateCommand(req, - req.getSource(), req.getTarget())); - } - if (UMLElementTypes.InterfaceRealization_4003 == baseElementType) { - return null; - } - if (UMLElementTypes.Substitution_4004 == baseElementType) { - if (isExtendedType) { - return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new SubstitutionCreateCommand(req, - req.getSource(), req.getTarget())); - } - if (UMLElementTypes.Realization_4005 == baseElementType) { - if (isExtendedType) { - return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new RealizationCreateCommand(req, - req.getSource(), req.getTarget())); - } - if (UMLElementTypes.Abstraction_4006 == baseElementType) { - if (isExtendedType) { - return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new AbstractionCreateCommand(req, - req.getSource(), req.getTarget())); - } - if (UMLElementTypes.Usage_4007 == baseElementType) { - if (isExtendedType) { - return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new UsageCreateCommand(req, - req.getSource(), req.getTarget())); - } - if (UMLElementTypes.Dependency_4008 == baseElementType) { - if (isExtendedType) { - return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new DependencyCreateCommand(req, - req.getSource(), req.getTarget())); - } - if (UMLElementTypes.Dependency_4018 == baseElementType) { - if (isExtendedType) { - return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new Dependency3CreateCommand(req, - req.getSource(), req.getTarget())); - } - if (UMLElementTypes.ElementImport_4009 == baseElementType) { - if (isExtendedType) { - return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new ElementImportCreateCommand(req, - req.getSource(), req.getTarget())); - } - if (UMLElementTypes.PackageImport_4010 == baseElementType) { - return null; - } - if (UMLElementTypes.CommentAnnotatedElement_4013 == baseElementType) { - if (isExtendedType) { - return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new CommentAnnotatedElementCreateCommand(req, - req.getSource(), req.getTarget())); - } - if (UMLElementTypes.ConstraintConstrainedElement_4014 == baseElementType) { - if (isExtendedType) { - return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new ConstraintConstrainedElementCreateCommand(req, - req.getSource(), req.getTarget())); - } - if (UMLElementTypes.TemplateBinding_4015 == baseElementType) { - if (isExtendedType) { - return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new TemplateBindingCreateCommand(req, - req.getSource(), req.getTarget())); - } - if (UMLElementTypes.TimeObservationEvent_4024 == baseElementType) { - if (isExtendedType) { - return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new ConnectorTimeObservationCreateCommand(req, - req.getSource(), req.getTarget())); - } - if (UMLElementTypes.DurationObservationEvent_4025 == baseElementType) { - if (isExtendedType) { - return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new ConnectorDurationObservationCreateCommand(req, - req.getSource(), req.getTarget())); - } - if (UMLElementTypes.InformationFlow_4026 == baseElementType) { - if (isExtendedType) { - return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new InformationFlowCreateCommand(req, - req.getSource(), req.getTarget())); - } - if (UMLElementTypes.ConstraintContext_8500 == baseElementType) { - if (isExtendedType) { - return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType) requestElementType); - } - return getGEFWrapper(new ContextLinkCreateCommand(req, - req.getSource(), req.getTarget())); - } - return null; - } - - /** - * Returns command to reorient EClass based link. New link target or source - * should be the domain model element associated with this node. - * - * @generated - */ - protected Command getReorientRelationshipCommand( - ReorientRelationshipRequest req) { - switch (getVisualID(req)) { - case GeneralizationEditPart.VISUAL_ID: - IElementEditService provider = ElementEditServiceUtils.getCommandProvider(req.getRelationship()); - if (provider == null) { - return UnexecutableCommand.INSTANCE; - } - // Retrieve re-orient command from the Element Edit service - ICommand reorientCommand = provider.getEditCommand(req); - if (reorientCommand == null) { - return UnexecutableCommand.INSTANCE; - } - return getGEFWrapper(reorientCommand.reduce()); - case AssociationClassLinkEditPart.VISUAL_ID: - return getGEFWrapper(new AssociationClassLinkReorientCommand(req)); - case AssociationEditPart.VISUAL_ID: - return getGEFWrapper(new AssociationReorientCommand(req)); - case AssociationBranchEditPart.VISUAL_ID: - return getGEFWrapper(new AssociationBranchReorientCommand(req)); - case InterfaceRealizationEditPart.VISUAL_ID: - return getGEFWrapper(new InterfaceRealizationReorientCommand(req)); - case SubstitutionEditPart.VISUAL_ID: - return getGEFWrapper(new SubstitutionReorientCommand(req)); - case RealizationEditPart.VISUAL_ID: - return getGEFWrapper(new RealizationReorientCommand(req)); - case AbstractionEditPart.VISUAL_ID: - return getGEFWrapper(new AbstractionReorientCommand(req)); - case UsageEditPart.VISUAL_ID: - return getGEFWrapper(new UsageReorientCommand(req)); - case DependencyEditPart.VISUAL_ID: - return getGEFWrapper(new DependencyReorientCommand(req)); - case DependencyBranchEditPart.VISUAL_ID: - return getGEFWrapper(new Dependency2ReorientCommand(req)); - case ElementImportEditPart.VISUAL_ID: - return getGEFWrapper(new ElementImportReorientCommand(req)); - case PackageImportEditPart.VISUAL_ID: - return getGEFWrapper(new PackageImportReorientCommand(req)); - case TemplateBindingEditPart.VISUAL_ID: - return getGEFWrapper(new TemplateBindingReorientCommand(req)); - case InformationFlowEditPart.VISUAL_ID: - return getGEFWrapper(new InformationFlowReorientCommand(req)); - } - return super.getReorientRelationshipCommand(req); - } - - /** - * Returns command to reorient EReference based link. New link target or source - * should be the domain model element associated with this node. - * - * @generated - */ - protected Command getReorientReferenceRelationshipCommand( - ReorientReferenceRelationshipRequest req) { - switch (getVisualID(req)) { - case CommentAnnotatedElementEditPart.VISUAL_ID: - return getGEFWrapper(new CommentAnnotatedElementReorientCommand(req)); - case ConstraintConstrainedElementEditPart.VISUAL_ID: - return getGEFWrapper(new ConstraintConstrainedElementReorientCommand(req)); - case ConnectorTimeObservationEditPart.VISUAL_ID: - return getGEFWrapper(new ConnectorTimeObservationReorientCommand(req)); - case ConnectorDurationObservationEditPart.VISUAL_ID: - return getGEFWrapper(new ConnectorDurationObservationReorientCommand(req)); - case ContextLinkEditPart.VISUAL_ID: - return getGEFWrapper(new ContextLinkReorientCommand(req)); - } - return super.getReorientReferenceRelationshipCommand(req); - } -} +/**
+ * Copyright (c) 2014 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 at
+ * http://www.eclipse.org/legal/epl-v10.html
+ *
+ * Contributors:
+ * CEA LIST - Initial API and implementation
+ */
+package org.eclipse.papyrus.uml.diagram.clazz.edit.policies;
+
+import org.eclipse.emf.ecore.EObject;
+import org.eclipse.gef.commands.Command;
+import org.eclipse.gef.commands.UnexecutableCommand;
+import org.eclipse.gmf.runtime.common.core.command.ICommand;
+import org.eclipse.gmf.runtime.diagram.ui.commands.ICommandProxy;
+import org.eclipse.gmf.runtime.emf.type.core.IElementType;
+import org.eclipse.gmf.runtime.emf.type.core.requests.CreateElementRequest;
+import org.eclipse.gmf.runtime.emf.type.core.requests.CreateRelationshipRequest;
+import org.eclipse.gmf.runtime.emf.type.core.requests.DestroyElementRequest;
+import org.eclipse.gmf.runtime.emf.type.core.requests.ReorientReferenceRelationshipRequest;
+import org.eclipse.gmf.runtime.emf.type.core.requests.ReorientRelationshipRequest;
+import org.eclipse.papyrus.infra.extendedtypes.types.IExtendedHintedElementType;
+import org.eclipse.papyrus.infra.extendedtypes.util.ElementTypeUtils;
+import org.eclipse.papyrus.infra.gmfdiag.common.utils.DiagramUtils;
+import org.eclipse.papyrus.infra.services.edit.service.ElementEditServiceUtils;
+import org.eclipse.papyrus.infra.services.edit.service.IElementEditService;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.AbstractionCreateCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.AbstractionReorientCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.AssociationBranchCreateCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.AssociationBranchReorientCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.AssociationClassLinkCreateCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.AssociationClassLinkReorientCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.AssociationCreateCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.AssociationReorientCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.CommentAnnotatedElementCreateCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.CommentAnnotatedElementReorientCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.ConnectorDurationObservationCreateCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.ConnectorDurationObservationReorientCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.ConnectorTimeObservationCreateCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.ConnectorTimeObservationReorientCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.ConstraintConstrainedElementCreateCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.ConstraintConstrainedElementReorientCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.ContextLinkCreateCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.ContextLinkReorientCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.Dependency2ReorientCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.Dependency3CreateCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.DependencyCreateCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.DependencyReorientCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.ElementImportCreateCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.ElementImportReorientCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.GeneralizationCreateCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.InformationFlowCreateCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.InformationFlowReorientCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.InterfaceRealizationCreateCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.InterfaceRealizationReorientCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.PackageImportCreateCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.PackageImportReorientCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.RealizationCreateCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.RealizationReorientCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.RedefinableTemplateSignatureCreateCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.SubstitutionCreateCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.SubstitutionReorientCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.TemplateBindingCreateCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.TemplateBindingReorientCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.UsageCreateCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.commands.UsageReorientCommand;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.AbstractionEditPart;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.AssociationBranchEditPart;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.AssociationClassLinkEditPart;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.AssociationEditPart;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.CommentAnnotatedElementEditPart;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.ConnectorDurationObservationEditPart;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.ConnectorTimeObservationEditPart;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.ConstraintConstrainedElementEditPart;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.ContextLinkEditPart;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.DependencyBranchEditPart;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.DependencyEditPart;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.ElementImportEditPart;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.GeneralizationEditPart;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.InformationFlowEditPart;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.InterfaceRealizationEditPart;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.PackageImportEditPart;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.RealizationEditPart;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.SubstitutionEditPart;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.TemplateBindingEditPart;
+import org.eclipse.papyrus.uml.diagram.clazz.edit.parts.UsageEditPart;
+import org.eclipse.papyrus.uml.diagram.clazz.providers.UMLElementTypes;
+
+/**
+ * @generated
+ */
+public class ComponentItemSemanticEditPolicyCN extends UMLBaseItemSemanticEditPolicy {
+
+ /**
+ * @generated
+ */
+ public ComponentItemSemanticEditPolicyCN() {
+ super(UMLElementTypes.Component_3021);
+ }
+
+ /**
+ * @generated
+ */
+ protected Command getCreateCommand(CreateElementRequest req) {
+ IElementType requestElementType = req.getElementType();
+ if(requestElementType == null) {
+ return super.getCreateCommand(req);
+ }
+ if(UMLElementTypes.RedefinableTemplateSignature_3015 == requestElementType) {
+ return getGEFWrapper(new RedefinableTemplateSignatureCreateCommand(req, DiagramUtils.getDiagramFrom(getHost())));
+ }
+ return super.getCreateCommand(req);
+ }
+
+ /**
+ * @generated
+ */
+ protected Command getDestroyElementCommand(DestroyElementRequest req) {
+ EObject selectedEObject = req.getElementToDestroy();
+ IElementEditService provider = ElementEditServiceUtils.getCommandProvider(selectedEObject);
+ if(provider != null) {
+ // Retrieve delete command from the Element Edit service
+ ICommand deleteCommand = provider.getEditCommand(req);
+ if(deleteCommand != null) {
+ return new ICommandProxy(deleteCommand);
+ }
+ }
+ return UnexecutableCommand.INSTANCE;
+ }
+
+ /**
+ * @generated
+ */
+ protected Command getCreateRelationshipCommand(CreateRelationshipRequest req) {
+ Command command = req.getTarget() == null ? getStartCreateRelationshipCommand(req) : getCompleteCreateRelationshipCommand(req);
+ return command != null ? command : super.getCreateRelationshipCommand(req);
+ }
+
+ /**
+ * @generated
+ */
+ protected Command getStartCreateRelationshipCommand(CreateRelationshipRequest req) {
+ IElementType requestElementType = req.getElementType();
+ if(requestElementType == null) {
+ return null;
+ }
+ IElementType baseElementType = requestElementType;
+ boolean isExtendedType = false;
+ if(requestElementType instanceof IExtendedHintedElementType) {
+ baseElementType = ElementTypeUtils.getClosestDiagramType(requestElementType);
+ if(baseElementType != null) {
+ isExtendedType = true;
+ } else {
+ // no reference element type ID. using the closest super element type to give more opportunities, but can lead to bugs.
+ baseElementType = ElementTypeUtils.findClosestNonExtendedElementType((IExtendedHintedElementType)requestElementType);
+ isExtendedType = true;
+ }
+ }
+ if(UMLElementTypes.AssociationClass_4017 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedStartCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new AssociationClassLinkCreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ if(UMLElementTypes.Association_4001 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedStartCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new AssociationCreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ if(UMLElementTypes.Association_4019 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedStartCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new AssociationBranchCreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ if(UMLElementTypes.Generalization_4002 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedStartCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new GeneralizationCreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ if(UMLElementTypes.InterfaceRealization_4003 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedStartCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new InterfaceRealizationCreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ if(UMLElementTypes.Substitution_4004 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedStartCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new SubstitutionCreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ if(UMLElementTypes.Realization_4005 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedStartCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new RealizationCreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ if(UMLElementTypes.Abstraction_4006 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedStartCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new AbstractionCreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ if(UMLElementTypes.Usage_4007 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedStartCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new UsageCreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ if(UMLElementTypes.Dependency_4008 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedStartCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new DependencyCreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ if(UMLElementTypes.Dependency_4018 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedStartCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new Dependency3CreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ if(UMLElementTypes.ElementImport_4009 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedStartCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new ElementImportCreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ if(UMLElementTypes.PackageImport_4010 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedStartCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new PackageImportCreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ if(UMLElementTypes.CommentAnnotatedElement_4013 == baseElementType) {
+ return null;
+ }
+ if(UMLElementTypes.ConstraintConstrainedElement_4014 == baseElementType) {
+ return null;
+ }
+ if(UMLElementTypes.TemplateBinding_4015 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedStartCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new TemplateBindingCreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ if(UMLElementTypes.TimeObservationEvent_4024 == baseElementType) {
+ return null;
+ }
+ if(UMLElementTypes.DurationObservationEvent_4025 == baseElementType) {
+ return null;
+ }
+ if(UMLElementTypes.InformationFlow_4026 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedStartCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new InformationFlowCreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ if(UMLElementTypes.ConstraintContext_8500 == baseElementType) {
+ return null;
+ }
+ return null;
+ }
+
+ /**
+ * @generated
+ */
+ protected Command getCompleteCreateRelationshipCommand(CreateRelationshipRequest req) {
+ IElementType requestElementType = req.getElementType();
+ if(requestElementType == null) {
+ return null;
+ }
+ IElementType baseElementType = requestElementType;
+ boolean isExtendedType = false;
+ if(requestElementType instanceof IExtendedHintedElementType) {
+ baseElementType = ElementTypeUtils.getClosestDiagramType(requestElementType);
+ if(baseElementType != null) {
+ isExtendedType = true;
+ } else {
+ // no reference element type ID. using the closest super element type to give more opportunities, but can lead to bugs.
+ baseElementType = ElementTypeUtils.findClosestNonExtendedElementType((IExtendedHintedElementType)requestElementType);
+ isExtendedType = true;
+ }
+ }
+ if(UMLElementTypes.AssociationClass_4017 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new AssociationClassLinkCreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ if(UMLElementTypes.Association_4001 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new AssociationCreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ if(UMLElementTypes.Association_4019 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new AssociationBranchCreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ if(UMLElementTypes.Generalization_4002 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new GeneralizationCreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ if(UMLElementTypes.InterfaceRealization_4003 == baseElementType) {
+ return null;
+ }
+ if(UMLElementTypes.Substitution_4004 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new SubstitutionCreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ if(UMLElementTypes.Realization_4005 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new RealizationCreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ if(UMLElementTypes.Abstraction_4006 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new AbstractionCreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ if(UMLElementTypes.Usage_4007 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new UsageCreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ if(UMLElementTypes.Dependency_4008 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new DependencyCreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ if(UMLElementTypes.Dependency_4018 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new Dependency3CreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ if(UMLElementTypes.ElementImport_4009 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new ElementImportCreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ if(UMLElementTypes.PackageImport_4010 == baseElementType) {
+ return null;
+ }
+ if(UMLElementTypes.CommentAnnotatedElement_4013 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new CommentAnnotatedElementCreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ if(UMLElementTypes.ConstraintConstrainedElement_4014 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new ConstraintConstrainedElementCreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ if(UMLElementTypes.TemplateBinding_4015 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new TemplateBindingCreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ if(UMLElementTypes.TimeObservationEvent_4024 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new ConnectorTimeObservationCreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ if(UMLElementTypes.DurationObservationEvent_4025 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new ConnectorDurationObservationCreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ if(UMLElementTypes.InformationFlow_4026 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new InformationFlowCreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ if(UMLElementTypes.ConstraintContext_8500 == baseElementType) {
+ if(isExtendedType) {
+ return getExtendedCompleteCreateRelationshipCommand(req, (IExtendedHintedElementType)requestElementType);
+ }
+ return getGEFWrapper(new ContextLinkCreateCommand(req, req.getSource(), req.getTarget()));
+ }
+ return null;
+ }
+
+ /**
+ * Returns command to reorient EClass based link. New link target or source
+ * should be the domain model element associated with this node.
+ *
+ * @generated
+ */
+ protected Command getReorientRelationshipCommand(ReorientRelationshipRequest req) {
+ switch(getVisualID(req)) {
+ case GeneralizationEditPart.VISUAL_ID:
+ IElementEditService provider = ElementEditServiceUtils.getCommandProvider(req.getRelationship());
+ if(provider == null) {
+ return UnexecutableCommand.INSTANCE;
+ }
+ // Retrieve re-orient command from the Element Edit service
+ ICommand reorientCommand = provider.getEditCommand(req);
+ if(reorientCommand == null) {
+ return UnexecutableCommand.INSTANCE;
+ }
+ return getGEFWrapper(reorientCommand.reduce());
+ case AssociationClassLinkEditPart.VISUAL_ID:
+ return getGEFWrapper(new AssociationClassLinkReorientCommand(req));
+ case AssociationEditPart.VISUAL_ID:
+ return getGEFWrapper(new AssociationReorientCommand(req));
+ case AssociationBranchEditPart.VISUAL_ID:
+ return getGEFWrapper(new AssociationBranchReorientCommand(req));
+ case InterfaceRealizationEditPart.VISUAL_ID:
+ return getGEFWrapper(new InterfaceRealizationReorientCommand(req));
+ case SubstitutionEditPart.VISUAL_ID:
+ return getGEFWrapper(new SubstitutionReorientCommand(req));
+ case RealizationEditPart.VISUAL_ID:
+ return getGEFWrapper(new RealizationReorientCommand(req));
+ case AbstractionEditPart.VISUAL_ID:
+ return getGEFWrapper(new AbstractionReorientCommand(req));
+ case UsageEditPart.VISUAL_ID:
+ return getGEFWrapper(new UsageReorientCommand(req));
+ case DependencyEditPart.VISUAL_ID:
+ return getGEFWrapper(new DependencyReorientCommand(req));
+ case DependencyBranchEditPart.VISUAL_ID:
+ return getGEFWrapper(new Dependency2ReorientCommand(req));
+ case ElementImportEditPart.VISUAL_ID:
+ return getGEFWrapper(new ElementImportReorientCommand(req));
+ case PackageImportEditPart.VISUAL_ID:
+ return getGEFWrapper(new PackageImportReorientCommand(req));
+ case TemplateBindingEditPart.VISUAL_ID:
+ return getGEFWrapper(new TemplateBindingReorientCommand(req));
+ case InformationFlowEditPart.VISUAL_ID:
+ return getGEFWrapper(new InformationFlowReorientCommand(req));
+ }
+ return super.getReorientRelationshipCommand(req);
+ }
+
+ /**
+ * Returns command to reorient EReference based link. New link target or source
+ * should be the domain model element associated with this node.
+ *
+ * @generated
+ */
+ protected Command getReorientReferenceRelationshipCommand(ReorientReferenceRelationshipRequest req) {
+ switch(getVisualID(req)) {
+ case CommentAnnotatedElementEditPart.VISUAL_ID:
+ return getGEFWrapper(new CommentAnnotatedElementReorientCommand(req));
+ case ConstraintConstrainedElementEditPart.VISUAL_ID:
+ return getGEFWrapper(new ConstraintConstrainedElementReorientCommand(req));
+ case ConnectorTimeObservationEditPart.VISUAL_ID:
+ return getGEFWrapper(new ConnectorTimeObservationReorientCommand(req));
+ case ConnectorDurationObservationEditPart.VISUAL_ID:
+ return getGEFWrapper(new ConnectorDurationObservationReorientCommand(req));
+ case ContextLinkEditPart.VISUAL_ID:
+ return getGEFWrapper(new ContextLinkReorientCommand(req));
+ }
+ return super.getReorientReferenceRelationshipCommand(req);
+ }
+}
|