Skip to main content
aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
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.java30
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();

Back to the top