diff options
Diffstat (limited to 'plugins/uml/diagram/org.eclipse.papyrus.uml.diagram.sequence/custom-src/org/eclipse/papyrus/uml/diagram/sequence/edit/policies/ExecutionSpecificationGraphicalNodeEditPolicy.java')
-rw-r--r-- | plugins/uml/diagram/org.eclipse.papyrus.uml.diagram.sequence/custom-src/org/eclipse/papyrus/uml/diagram/sequence/edit/policies/ExecutionSpecificationGraphicalNodeEditPolicy.java | 30 |
1 files changed, 28 insertions, 2 deletions
diff --git a/plugins/uml/diagram/org.eclipse.papyrus.uml.diagram.sequence/custom-src/org/eclipse/papyrus/uml/diagram/sequence/edit/policies/ExecutionSpecificationGraphicalNodeEditPolicy.java b/plugins/uml/diagram/org.eclipse.papyrus.uml.diagram.sequence/custom-src/org/eclipse/papyrus/uml/diagram/sequence/edit/policies/ExecutionSpecificationGraphicalNodeEditPolicy.java index 19b20d395d1..cf5c53a774b 100644 --- a/plugins/uml/diagram/org.eclipse.papyrus.uml.diagram.sequence/custom-src/org/eclipse/papyrus/uml/diagram/sequence/edit/policies/ExecutionSpecificationGraphicalNodeEditPolicy.java +++ b/plugins/uml/diagram/org.eclipse.papyrus.uml.diagram.sequence/custom-src/org/eclipse/papyrus/uml/diagram/sequence/edit/policies/ExecutionSpecificationGraphicalNodeEditPolicy.java @@ -12,12 +12,16 @@ *****************************************************************************/ package org.eclipse.papyrus.uml.diagram.sequence.edit.policies; +import java.util.Map; + import org.eclipse.draw2d.Connection; import org.eclipse.draw2d.PolylineConnection; import org.eclipse.gef.Request; import org.eclipse.gef.commands.Command; +import org.eclipse.gef.commands.UnexecutableCommand; import org.eclipse.gef.editpolicies.GraphicalNodeEditPolicy; import org.eclipse.gef.requests.CreateConnectionRequest; +import org.eclipse.gef.requests.ReconnectRequest; import org.eclipse.gmf.runtime.diagram.ui.requests.CreateConnectionViewAndElementRequest; import org.eclipse.gmf.runtime.emf.type.core.requests.CreateRelationshipRequest; import org.eclipse.gmf.runtime.notation.View; @@ -49,7 +53,9 @@ public class ExecutionSpecificationGraphicalNodeEditPolicy extends ElementCreati } else { sourceOccurrence = execSpec.getFinish(); } - request.getExtendedData().put(SequenceRequestConstant.SOURCE_OCCURRENCE, sourceOccurrence); + @SuppressWarnings("unchecked") + Map<Object, Object> extendedData = request.getExtendedData(); + extendedData.put(SequenceRequestConstant.SOURCE_OCCURRENCE, sourceOccurrence); createRequest.setParameter(SequenceRequestConstant.SOURCE_OCCURRENCE, sourceOccurrence); } } @@ -79,7 +85,9 @@ public class ExecutionSpecificationGraphicalNodeEditPolicy extends ElementCreati } else { targetOccurrence = execSpec.getFinish(); } - request.getExtendedData().put(SequenceRequestConstant.TARGET_OCCURRENCE, targetOccurrence); + @SuppressWarnings("unchecked") + Map<Object, Object> extendedData = request.getExtendedData(); + extendedData.put(SequenceRequestConstant.TARGET_OCCURRENCE, targetOccurrence); createRequest.setParameter(SequenceRequestConstant.TARGET_OCCURRENCE, targetOccurrence); } } @@ -88,6 +96,24 @@ public class ExecutionSpecificationGraphicalNodeEditPolicy extends ElementCreati } @Override + protected Command getReconnectSourceCommand(ReconnectRequest request) { + if (DurationLinkUtil.isDurationLink(request)) { + // Bug 536639: Forbid reconnect on Duration edit parts + return UnexecutableCommand.INSTANCE; + } + return super.getReconnectSourceCommand(request); + } + + @Override + protected Command getReconnectTargetCommand(ReconnectRequest request) { + if (DurationLinkUtil.isDurationLink(request)) { + // Bug 536639: Forbid reconnect on Duration edit parts + return UnexecutableCommand.INSTANCE; + } + return super.getReconnectTargetCommand(request); + } + + @Override protected Connection createDummyConnection(Request req) { if (req instanceof CreateConnectionRequest && DurationLinkUtil.isCreateDurationLink((CreateConnectionRequest) req)) { return new DurationLinkFigure(); |