Skip to main content
summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
Diffstat (limited to 'org.eclipse.emf.refactor.comrel.diagram/src/comrel/diagram/edit/policies/ConditionalUnitItemSemanticEditPolicy.java')
-rw-r--r--org.eclipse.emf.refactor.comrel.diagram/src/comrel/diagram/edit/policies/ConditionalUnitItemSemanticEditPolicy.java337
1 files changed, 337 insertions, 0 deletions
diff --git a/org.eclipse.emf.refactor.comrel.diagram/src/comrel/diagram/edit/policies/ConditionalUnitItemSemanticEditPolicy.java b/org.eclipse.emf.refactor.comrel.diagram/src/comrel/diagram/edit/policies/ConditionalUnitItemSemanticEditPolicy.java
new file mode 100644
index 0000000..ef30e72
--- /dev/null
+++ b/org.eclipse.emf.refactor.comrel.diagram/src/comrel/diagram/edit/policies/ConditionalUnitItemSemanticEditPolicy.java
@@ -0,0 +1,337 @@
+/*
+ *
+ */
+package comrel.diagram.edit.policies;
+
+import java.util.Iterator;
+
+import org.eclipse.emf.ecore.EAnnotation;
+import org.eclipse.gef.commands.Command;
+import org.eclipse.gmf.runtime.common.core.command.ICompositeCommand;
+import org.eclipse.gmf.runtime.diagram.core.commands.DeleteCommand;
+import org.eclipse.gmf.runtime.emf.commands.core.command.CompositeTransactionalCommand;
+import org.eclipse.gmf.runtime.emf.type.core.commands.DestroyElementCommand;
+import org.eclipse.gmf.runtime.emf.type.core.requests.CreateElementRequest;
+import org.eclipse.gmf.runtime.emf.type.core.requests.DestroyElementRequest;
+import org.eclipse.gmf.runtime.notation.Edge;
+import org.eclipse.gmf.runtime.notation.Node;
+import org.eclipse.gmf.runtime.notation.View;
+
+import comrel.diagram.edit.commands.MultiInputPort9CreateCommand;
+import comrel.diagram.edit.commands.SingleInputPort8CreateCommand;
+import comrel.diagram.edit.parts.AtomicUnit6EditPart;
+import comrel.diagram.edit.parts.AtomicUnit7EditPart;
+import comrel.diagram.edit.parts.CartesianQueuedUnit6EditPart;
+import comrel.diagram.edit.parts.CartesianQueuedUnit7EditPart;
+import comrel.diagram.edit.parts.ConditionCheckEditPart;
+import comrel.diagram.edit.parts.ConditionalUnit6EditPart;
+import comrel.diagram.edit.parts.ConditionalUnit7EditPart;
+import comrel.diagram.edit.parts.ConditionalUnitConditionalUnitElseCompartment7EditPart;
+import comrel.diagram.edit.parts.ConditionalUnitConditionalUnitHelperUnitsCompartment7EditPart;
+import comrel.diagram.edit.parts.ConditionalUnitConditionalUnitIfCompartment7EditPart;
+import comrel.diagram.edit.parts.ConditionalUnitConditionalUnitThenCompartment7EditPart;
+import comrel.diagram.edit.parts.MultiFeatureUnit3EditPart;
+import comrel.diagram.edit.parts.MultiFilterUnit3EditPart;
+import comrel.diagram.edit.parts.MultiInputPort9EditPart;
+import comrel.diagram.edit.parts.MultiPortMappingEditPart;
+import comrel.diagram.edit.parts.MultiSinglePortMappingEditPart;
+import comrel.diagram.edit.parts.ParallelQueuedUnit3EditPart;
+import comrel.diagram.edit.parts.ParallelQueuedUnit7EditPart;
+import comrel.diagram.edit.parts.SequentialUnit5EditPart;
+import comrel.diagram.edit.parts.SequentialUnit7EditPart;
+import comrel.diagram.edit.parts.SingleFeatureUnit3EditPart;
+import comrel.diagram.edit.parts.SingleFilterUnit3EditPart;
+import comrel.diagram.edit.parts.SingleInputPort8EditPart;
+import comrel.diagram.edit.parts.SinglePortMappingEditPart;
+import comrel.diagram.edit.parts.SingleQueuedUnit4EditPart;
+import comrel.diagram.edit.parts.SingleQueuedUnit7EditPart;
+import comrel.diagram.part.ComrelVisualIDRegistry;
+import comrel.diagram.providers.ComrelElementTypes;
+
+/**
+ * @generated
+ */
+public class ConditionalUnitItemSemanticEditPolicy extends
+ ComrelBaseItemSemanticEditPolicy {
+
+ /**
+ * @generated
+ */
+ public ConditionalUnitItemSemanticEditPolicy() {
+ super(ComrelElementTypes.ConditionalUnit_2006);
+ }
+
+ /**
+ * @generated
+ */
+ protected Command getCreateCommand(CreateElementRequest req) {
+ if (ComrelElementTypes.SingleInputPort_3031 == req.getElementType()) {
+ return getGEFWrapper(new SingleInputPort8CreateCommand(req));
+ }
+ if (ComrelElementTypes.MultiInputPort_3032 == req.getElementType()) {
+ return getGEFWrapper(new MultiInputPort9CreateCommand(req));
+ }
+ return super.getCreateCommand(req);
+ }
+
+ /**
+ * @generated
+ */
+ protected Command getDestroyElementCommand(DestroyElementRequest req) {
+ View view = (View) getHost().getModel();
+ CompositeTransactionalCommand cmd = new CompositeTransactionalCommand(
+ getEditingDomain(), null);
+ cmd.setTransactionNestingEnabled(false);
+ EAnnotation annotation = view.getEAnnotation("Shortcut"); //$NON-NLS-1$
+ if (annotation == null) {
+ // there are indirectly referenced children, need extra commands: false
+ addDestroyChildNodesCommand(cmd);
+ addDestroyShortcutsCommand(cmd, view);
+ // delete host element
+ cmd.add(new DestroyElementCommand(req));
+ } else {
+ cmd.add(new DeleteCommand(getEditingDomain(), view));
+ }
+ return getGEFWrapper(cmd.reduce());
+ }
+
+ /**
+ * @generated
+ */
+ private void addDestroyChildNodesCommand(ICompositeCommand cmd) {
+ View view = (View) getHost().getModel();
+ for (Iterator<?> nit = view.getChildren().iterator(); nit.hasNext();) {
+ Node node = (Node) nit.next();
+ switch (ComrelVisualIDRegistry.getVisualID(node)) {
+ case SingleInputPort8EditPart.VISUAL_ID:
+ for (Iterator<?> it = node.getTargetEdges().iterator(); it
+ .hasNext();) {
+ Edge incomingLink = (Edge) it.next();
+ if (ComrelVisualIDRegistry.getVisualID(incomingLink) == SinglePortMappingEditPart.VISUAL_ID) {
+ DestroyElementRequest r = new DestroyElementRequest(
+ incomingLink.getElement(), false);
+ cmd.add(new DestroyElementCommand(r));
+ cmd.add(new DeleteCommand(getEditingDomain(),
+ incomingLink));
+ continue;
+ }
+ if (ComrelVisualIDRegistry.getVisualID(incomingLink) == MultiSinglePortMappingEditPart.VISUAL_ID) {
+ DestroyElementRequest r = new DestroyElementRequest(
+ incomingLink.getElement(), false);
+ cmd.add(new DestroyElementCommand(r));
+ cmd.add(new DeleteCommand(getEditingDomain(),
+ incomingLink));
+ continue;
+ }
+ }
+ for (Iterator<?> it = node.getSourceEdges().iterator(); it
+ .hasNext();) {
+ Edge outgoingLink = (Edge) it.next();
+ if (ComrelVisualIDRegistry.getVisualID(outgoingLink) == SinglePortMappingEditPart.VISUAL_ID) {
+ DestroyElementRequest r = new DestroyElementRequest(
+ outgoingLink.getElement(), false);
+ cmd.add(new DestroyElementCommand(r));
+ cmd.add(new DeleteCommand(getEditingDomain(),
+ outgoingLink));
+ continue;
+ }
+ }
+ cmd.add(new DestroyElementCommand(new DestroyElementRequest(
+ getEditingDomain(), node.getElement(), false))); // directlyOwned: true
+ // don't need explicit deletion of node as parent's view deletion would clean child views as well
+ // cmd.add(new org.eclipse.gmf.runtime.diagram.core.commands.DeleteCommand(getEditingDomain(), node));
+ break;
+ case MultiInputPort9EditPart.VISUAL_ID:
+ for (Iterator<?> it = node.getTargetEdges().iterator(); it
+ .hasNext();) {
+ Edge incomingLink = (Edge) it.next();
+ if (ComrelVisualIDRegistry.getVisualID(incomingLink) == MultiPortMappingEditPart.VISUAL_ID) {
+ DestroyElementRequest r = new DestroyElementRequest(
+ incomingLink.getElement(), false);
+ cmd.add(new DestroyElementCommand(r));
+ cmd.add(new DeleteCommand(getEditingDomain(),
+ incomingLink));
+ continue;
+ }
+ }
+ for (Iterator<?> it = node.getSourceEdges().iterator(); it
+ .hasNext();) {
+ Edge outgoingLink = (Edge) it.next();
+ if (ComrelVisualIDRegistry.getVisualID(outgoingLink) == MultiPortMappingEditPart.VISUAL_ID) {
+ DestroyElementRequest r = new DestroyElementRequest(
+ outgoingLink.getElement(), false);
+ cmd.add(new DestroyElementCommand(r));
+ cmd.add(new DeleteCommand(getEditingDomain(),
+ outgoingLink));
+ continue;
+ }
+ if (ComrelVisualIDRegistry.getVisualID(outgoingLink) == MultiSinglePortMappingEditPart.VISUAL_ID) {
+ DestroyElementRequest r = new DestroyElementRequest(
+ outgoingLink.getElement(), false);
+ cmd.add(new DestroyElementCommand(r));
+ cmd.add(new DeleteCommand(getEditingDomain(),
+ outgoingLink));
+ continue;
+ }
+ }
+ cmd.add(new DestroyElementCommand(new DestroyElementRequest(
+ getEditingDomain(), node.getElement(), false))); // directlyOwned: true
+ // don't need explicit deletion of node as parent's view deletion would clean child views as well
+ // cmd.add(new org.eclipse.gmf.runtime.diagram.core.commands.DeleteCommand(getEditingDomain(), node));
+ break;
+ case ConditionalUnitConditionalUnitIfCompartment7EditPart.VISUAL_ID:
+ for (Iterator<?> cit = node.getChildren().iterator(); cit
+ .hasNext();) {
+ Node cnode = (Node) cit.next();
+ switch (ComrelVisualIDRegistry.getVisualID(cnode)) {
+ case ConditionCheckEditPart.VISUAL_ID:
+ cmd.add(new DestroyElementCommand(
+ new DestroyElementRequest(getEditingDomain(),
+ cnode.getElement(), false))); // directlyOwned: true
+ // don't need explicit deletion of cnode as parent's view deletion would clean child views as well
+ // cmd.add(new org.eclipse.gmf.runtime.diagram.core.commands.DeleteCommand(getEditingDomain(), cnode));
+ break;
+ }
+ }
+ break;
+ case ConditionalUnitConditionalUnitHelperUnitsCompartment7EditPart.VISUAL_ID:
+ for (Iterator<?> cit = node.getChildren().iterator(); cit
+ .hasNext();) {
+ Node cnode = (Node) cit.next();
+ switch (ComrelVisualIDRegistry.getVisualID(cnode)) {
+ case SingleFeatureUnit3EditPart.VISUAL_ID:
+ cmd.add(new DestroyElementCommand(
+ new DestroyElementRequest(getEditingDomain(),
+ cnode.getElement(), false))); // directlyOwned: true
+ // don't need explicit deletion of cnode as parent's view deletion would clean child views as well
+ // cmd.add(new org.eclipse.gmf.runtime.diagram.core.commands.DeleteCommand(getEditingDomain(), cnode));
+ break;
+ case MultiFeatureUnit3EditPart.VISUAL_ID:
+ cmd.add(new DestroyElementCommand(
+ new DestroyElementRequest(getEditingDomain(),
+ cnode.getElement(), false))); // directlyOwned: true
+ // don't need explicit deletion of cnode as parent's view deletion would clean child views as well
+ // cmd.add(new org.eclipse.gmf.runtime.diagram.core.commands.DeleteCommand(getEditingDomain(), cnode));
+ break;
+ case SingleFilterUnit3EditPart.VISUAL_ID:
+ cmd.add(new DestroyElementCommand(
+ new DestroyElementRequest(getEditingDomain(),
+ cnode.getElement(), false))); // directlyOwned: true
+ // don't need explicit deletion of cnode as parent's view deletion would clean child views as well
+ // cmd.add(new org.eclipse.gmf.runtime.diagram.core.commands.DeleteCommand(getEditingDomain(), cnode));
+ break;
+ case MultiFilterUnit3EditPart.VISUAL_ID:
+ cmd.add(new DestroyElementCommand(
+ new DestroyElementRequest(getEditingDomain(),
+ cnode.getElement(), false))); // directlyOwned: true
+ // don't need explicit deletion of cnode as parent's view deletion would clean child views as well
+ // cmd.add(new org.eclipse.gmf.runtime.diagram.core.commands.DeleteCommand(getEditingDomain(), cnode));
+ break;
+ }
+ }
+ break;
+ case ConditionalUnitConditionalUnitThenCompartment7EditPart.VISUAL_ID:
+ for (Iterator<?> cit = node.getChildren().iterator(); cit
+ .hasNext();) {
+ Node cnode = (Node) cit.next();
+ switch (ComrelVisualIDRegistry.getVisualID(cnode)) {
+ case CartesianQueuedUnit6EditPart.VISUAL_ID:
+ cmd.add(new DestroyElementCommand(
+ new DestroyElementRequest(getEditingDomain(),
+ cnode.getElement(), false))); // directlyOwned: true
+ // don't need explicit deletion of cnode as parent's view deletion would clean child views as well
+ // cmd.add(new org.eclipse.gmf.runtime.diagram.core.commands.DeleteCommand(getEditingDomain(), cnode));
+ break;
+ case ParallelQueuedUnit3EditPart.VISUAL_ID:
+ cmd.add(new DestroyElementCommand(
+ new DestroyElementRequest(getEditingDomain(),
+ cnode.getElement(), false))); // directlyOwned: true
+ // don't need explicit deletion of cnode as parent's view deletion would clean child views as well
+ // cmd.add(new org.eclipse.gmf.runtime.diagram.core.commands.DeleteCommand(getEditingDomain(), cnode));
+ break;
+ case SingleQueuedUnit4EditPart.VISUAL_ID:
+ cmd.add(new DestroyElementCommand(
+ new DestroyElementRequest(getEditingDomain(),
+ cnode.getElement(), false))); // directlyOwned: true
+ // don't need explicit deletion of cnode as parent's view deletion would clean child views as well
+ // cmd.add(new org.eclipse.gmf.runtime.diagram.core.commands.DeleteCommand(getEditingDomain(), cnode));
+ break;
+ case SequentialUnit5EditPart.VISUAL_ID:
+ cmd.add(new DestroyElementCommand(
+ new DestroyElementRequest(getEditingDomain(),
+ cnode.getElement(), false))); // directlyOwned: true
+ // don't need explicit deletion of cnode as parent's view deletion would clean child views as well
+ // cmd.add(new org.eclipse.gmf.runtime.diagram.core.commands.DeleteCommand(getEditingDomain(), cnode));
+ break;
+ case ConditionalUnit6EditPart.VISUAL_ID:
+ cmd.add(new DestroyElementCommand(
+ new DestroyElementRequest(getEditingDomain(),
+ cnode.getElement(), false))); // directlyOwned: true
+ // don't need explicit deletion of cnode as parent's view deletion would clean child views as well
+ // cmd.add(new org.eclipse.gmf.runtime.diagram.core.commands.DeleteCommand(getEditingDomain(), cnode));
+ break;
+ case AtomicUnit6EditPart.VISUAL_ID:
+ cmd.add(new DestroyElementCommand(
+ new DestroyElementRequest(getEditingDomain(),
+ cnode.getElement(), false))); // directlyOwned: true
+ // don't need explicit deletion of cnode as parent's view deletion would clean child views as well
+ // cmd.add(new org.eclipse.gmf.runtime.diagram.core.commands.DeleteCommand(getEditingDomain(), cnode));
+ break;
+ }
+ }
+ break;
+ case ConditionalUnitConditionalUnitElseCompartment7EditPart.VISUAL_ID:
+ for (Iterator<?> cit = node.getChildren().iterator(); cit
+ .hasNext();) {
+ Node cnode = (Node) cit.next();
+ switch (ComrelVisualIDRegistry.getVisualID(cnode)) {
+ case CartesianQueuedUnit7EditPart.VISUAL_ID:
+ cmd.add(new DestroyElementCommand(
+ new DestroyElementRequest(getEditingDomain(),
+ cnode.getElement(), false))); // directlyOwned: true
+ // don't need explicit deletion of cnode as parent's view deletion would clean child views as well
+ // cmd.add(new org.eclipse.gmf.runtime.diagram.core.commands.DeleteCommand(getEditingDomain(), cnode));
+ break;
+ case ParallelQueuedUnit7EditPart.VISUAL_ID:
+ cmd.add(new DestroyElementCommand(
+ new DestroyElementRequest(getEditingDomain(),
+ cnode.getElement(), false))); // directlyOwned: true
+ // don't need explicit deletion of cnode as parent's view deletion would clean child views as well
+ // cmd.add(new org.eclipse.gmf.runtime.diagram.core.commands.DeleteCommand(getEditingDomain(), cnode));
+ break;
+ case SingleQueuedUnit7EditPart.VISUAL_ID:
+ cmd.add(new DestroyElementCommand(
+ new DestroyElementRequest(getEditingDomain(),
+ cnode.getElement(), false))); // directlyOwned: true
+ // don't need explicit deletion of cnode as parent's view deletion would clean child views as well
+ // cmd.add(new org.eclipse.gmf.runtime.diagram.core.commands.DeleteCommand(getEditingDomain(), cnode));
+ break;
+ case SequentialUnit7EditPart.VISUAL_ID:
+ cmd.add(new DestroyElementCommand(
+ new DestroyElementRequest(getEditingDomain(),
+ cnode.getElement(), false))); // directlyOwned: true
+ // don't need explicit deletion of cnode as parent's view deletion would clean child views as well
+ // cmd.add(new org.eclipse.gmf.runtime.diagram.core.commands.DeleteCommand(getEditingDomain(), cnode));
+ break;
+ case ConditionalUnit7EditPart.VISUAL_ID:
+ cmd.add(new DestroyElementCommand(
+ new DestroyElementRequest(getEditingDomain(),
+ cnode.getElement(), false))); // directlyOwned: true
+ // don't need explicit deletion of cnode as parent's view deletion would clean child views as well
+ // cmd.add(new org.eclipse.gmf.runtime.diagram.core.commands.DeleteCommand(getEditingDomain(), cnode));
+ break;
+ case AtomicUnit7EditPart.VISUAL_ID:
+ cmd.add(new DestroyElementCommand(
+ new DestroyElementRequest(getEditingDomain(),
+ cnode.getElement(), false))); // directlyOwned: true
+ // don't need explicit deletion of cnode as parent's view deletion would clean child views as well
+ // cmd.add(new org.eclipse.gmf.runtime.diagram.core.commands.DeleteCommand(getEditingDomain(), cnode));
+ break;
+ }
+ }
+ break;
+ }
+ }
+ }
+
+}

Back to the top