diff options
author | Henrik Rentz-Reichert | 2014-08-26 08:33:19 +0000 |
---|---|---|
committer | Henrik Rentz-Reichert | 2014-08-26 08:33:19 +0000 |
commit | d2c0327d3d7184f4d3f59567b815c1555ca0ec45 (patch) | |
tree | 6a865c11f3d816fb60726b6cbdf49cfb0e1a7f66 | |
parent | adfb9b0630290a66855b464a50ee80c6f8dca55b (diff) | |
download | org.eclipse.etrice-d2c0327d3d7184f4d3f59567b815c1555ca0ec45.tar.gz org.eclipse.etrice-d2c0327d3d7184f4d3f59567b815c1555ca0ec45.tar.xz org.eclipse.etrice-d2c0327d3d7184f4d3f59567b815c1555ca0ec45.zip |
[ui.behavior, ui.behavior.fsm, ui.commands] moved ExportDiagramsHandler to FSM part
Change-Id: I547a278a55aede52143f9ac76b4ea1182f014fc9
-rw-r--r-- | plugins/org.eclipse.etrice.ui.behavior.fsm/src/org/eclipse/etrice/ui/behavior/fsm/editor/AbstractFSMEditor.java | 164 | ||||
-rw-r--r-- | plugins/org.eclipse.etrice.ui.behavior.fsm/src/org/eclipse/etrice/ui/behavior/fsm/editor/BehaviorExporter.java (renamed from plugins/org.eclipse.etrice.ui.behavior/src/org/eclipse/etrice/ui/behavior/editor/BehaviorExporter.java) | 18 | ||||
-rw-r--r-- | plugins/org.eclipse.etrice.ui.behavior/src/org/eclipse/etrice/ui/behavior/editor/BehaviorEditor.java | 168 | ||||
-rw-r--r-- | plugins/org.eclipse.etrice.ui.commands/src/org/eclipse/etrice/ui/commands/handlers/ExportDiagramsHandler.java | 5 |
4 files changed, 178 insertions, 177 deletions
diff --git a/plugins/org.eclipse.etrice.ui.behavior.fsm/src/org/eclipse/etrice/ui/behavior/fsm/editor/AbstractFSMEditor.java b/plugins/org.eclipse.etrice.ui.behavior.fsm/src/org/eclipse/etrice/ui/behavior/fsm/editor/AbstractFSMEditor.java index 14e14628e..6d55067b8 100644 --- a/plugins/org.eclipse.etrice.ui.behavior.fsm/src/org/eclipse/etrice/ui/behavior/fsm/editor/AbstractFSMEditor.java +++ b/plugins/org.eclipse.etrice.ui.behavior.fsm/src/org/eclipse/etrice/ui/behavior/fsm/editor/AbstractFSMEditor.java @@ -12,10 +12,33 @@ package org.eclipse.etrice.ui.behavior.fsm.editor; +import java.util.ArrayList; +import java.util.Map; + +import org.eclipse.core.runtime.IProgressMonitor; import org.eclipse.emf.common.command.Command; +import org.eclipse.emf.common.util.URI; +import org.eclipse.emf.ecore.EObject; +import org.eclipse.emf.ecore.util.EcoreUtil; import org.eclipse.emf.transaction.RecordingCommand; +import org.eclipse.etrice.core.fsm.fSM.FSMFactory; +import org.eclipse.etrice.core.fsm.fSM.ModelComponent; +import org.eclipse.etrice.core.fsm.fSM.RefinedState; +import org.eclipse.etrice.core.fsm.fSM.State; +import org.eclipse.etrice.core.fsm.fSM.StateGraph; +import org.eclipse.etrice.core.fsm.util.FSMHelpers; import org.eclipse.etrice.ui.behavior.fsm.support.ContextSwitcher; +import org.eclipse.etrice.ui.behavior.fsm.support.FSMSupportUtil; import org.eclipse.etrice.ui.common.base.editor.DiagramEditorBase; +import org.eclipse.graphiti.dt.IDiagramTypeProvider; +import org.eclipse.graphiti.features.IFeatureProvider; +import org.eclipse.graphiti.features.context.IUpdateContext; +import org.eclipse.graphiti.features.context.impl.UpdateContext; +import org.eclipse.graphiti.mm.pictograms.Diagram; +import org.eclipse.graphiti.mm.pictograms.Shape; +import org.eclipse.graphiti.services.Graphiti; + +import com.google.common.base.Function; /** * @author Henrik Rentz-Reichert @@ -53,4 +76,145 @@ public abstract class AbstractFSMEditor extends DiagramEditorBase { getEditingDomain().getCommandStack().execute(cmd); getEditingDomain().getCommandStack().flush(); } + + public boolean showStateGraph(StateGraph sg) { + URI boUri = EcoreUtil.getURI(sg); + final StateGraph mySG = (StateGraph) getEditingDomain().getResourceSet().getEObject(boUri, true); + if (mySG==null) + return false; + + Command cmd = new RecordingCommand(getEditingDomain()) { + @Override + protected void doExecute() { + ContextSwitcher.switchTo(getDiagramTypeProvider().getDiagram(), mySG); + } + }; + getEditingDomain().getCommandStack().execute(cmd); + getEditingDomain().getCommandStack().flush(); + + return true; + } + + @Override + public void dispose() { + // Stop observing the Room Model + diagnosingModelObserver.removeObserver(); + super.dispose(); + } + + @Override + public void doSave(IProgressMonitor monitor) { + getEditingDomain().getCommandStack().execute(new RecordingCommand(getEditingDomain()) { + protected void doExecute() { + removeEmptySubgraphs(); + rebaseRefinedStates(); + removeUnusedRefinedStates(); + } + }); + + super.doSave(monitor); + } + + /** + * + */ + protected void removeUnusedRefinedStates() { + Diagram diagram = getDiagramTypeProvider().getDiagram(); + ModelComponent ac = FSMSupportUtil.getInstance().getModelComponent(diagram); + + if (ac.getStateMachine()!=null) { + ArrayList<RefinedState> toBeRemoved = new ArrayList<RefinedState>(); + for (State s : ac.getStateMachine().getStates()) { + if (s instanceof RefinedState) { + if (isUnused((RefinedState)s)) + toBeRemoved.add((RefinedState) s); + } + } + + ac.getStateMachine().getStates().removeAll(toBeRemoved); + } + } + + /** + * @param s + * @return + */ + private boolean isUnused(RefinedState s) { + FSMHelpers fsmHelpers = FSMSupportUtil.getInstance().getFSMHelpers(); + if (fsmHelpers.hasDirectSubStructure(s)) + return false; + if (fsmHelpers.hasDetailCode(s.getEntryCode())) + return false; + if (fsmHelpers.hasDetailCode(s.getExitCode())) + return false; + + return true; + } + + protected void removeEmptySubgraphs() { + Diagram diagram = getDiagramTypeProvider().getDiagram(); + FSMHelpers fsmHelpers = FSMSupportUtil.getInstance().getFSMHelpers(); + + // if our current context is an empty state graph we go one level up + StateGraph current = ContextSwitcher.getCurrentStateGraph(diagram); + if (current!=null && current.eContainer() instanceof State) { + State s = (State) current.eContainer(); + if (!fsmHelpers.hasDirectSubStructure(s)) { + ContextSwitcher.goUp(diagram, current); + } + } + + ArrayList<Shape> toBeRemoved = new ArrayList<Shape>(); + for (Shape ctxShape : diagram.getChildren()) { + EObject bo = Graphiti.getLinkService().getBusinessObjectForLinkedPictogramElement(ctxShape); + if (bo.eIsProxy()) { + toBeRemoved.add(ctxShape); + continue; + } + + assert(bo instanceof StateGraph): "expected state graph"; + + StateGraph sg = (StateGraph) bo; + if (sg.eContainer() instanceof State) { + State s = (State) sg.eContainer(); + if (!fsmHelpers.hasDirectSubStructure(s)) { + EcoreUtil.delete(sg); + toBeRemoved.add(ctxShape); + } + } + } + + // need to recursively delete the shapes to avoid dangling HREFs + for (Shape shape : toBeRemoved) { + EcoreUtil.delete(shape, true); + } + } + + protected void rebaseRefinedStates() { + ModelComponent ac = getModelComponent(); + + if (ac.getStateMachine()==null) + return; + + Function<RefinedState, String> nameProvider = FSMSupportUtil.getInstance().getFSMNameProvider().getRefinedStateNameProvider(); + Map<RefinedState, RefinedState> rs2parent = FSMSupportUtil.getInstance().getFSMHelpers().getRefinedStatesToRelocate(ac, nameProvider); + + // move all to the new context + for (RefinedState rs : rs2parent.keySet()) { + RefinedState parent = rs2parent.get(rs); + if (parent.getSubgraph()==null) + parent.setSubgraph(FSMFactory.eINSTANCE.createStateGraph()); + parent.getSubgraph().getStates().add(rs); + } + } + + @Override + protected void superClassChanged() { + IDiagramTypeProvider diagramTypeProvider = getDiagramTypeProvider(); + Diagram diagram = diagramTypeProvider.getDiagram(); + IFeatureProvider featureProvider = diagramTypeProvider.getFeatureProvider(); + IUpdateContext updateCtx = new UpdateContext(diagram); + featureProvider.updateIfPossible(updateCtx); + diagramTypeProvider.getDiagramBehavior().refresh(); + } } diff --git a/plugins/org.eclipse.etrice.ui.behavior/src/org/eclipse/etrice/ui/behavior/editor/BehaviorExporter.java b/plugins/org.eclipse.etrice.ui.behavior.fsm/src/org/eclipse/etrice/ui/behavior/fsm/editor/BehaviorExporter.java index 135abdd1f..ce6af1b7a 100644 --- a/plugins/org.eclipse.etrice.ui.behavior/src/org/eclipse/etrice/ui/behavior/editor/BehaviorExporter.java +++ b/plugins/org.eclipse.etrice.ui.behavior.fsm/src/org/eclipse/etrice/ui/behavior/fsm/editor/BehaviorExporter.java @@ -10,31 +10,35 @@ * *******************************************************************************/ -package org.eclipse.etrice.ui.behavior.editor; +package org.eclipse.etrice.ui.behavior.fsm.editor; import java.io.File; import org.eclipse.etrice.core.fsm.fSM.ModelComponent; import org.eclipse.etrice.core.fsm.fSM.State; import org.eclipse.etrice.core.fsm.fSM.StateGraph; -import org.eclipse.etrice.ui.behavior.DiagramAccess; import org.eclipse.etrice.ui.behavior.fsm.support.FSMSupportUtil; import org.eclipse.etrice.ui.common.base.editor.DiagramExporter; +import org.eclipse.etrice.ui.common.base.support.DiagramAccessBase; import org.eclipse.ui.PlatformUI; +import com.google.inject.Inject; + public class BehaviorExporter { private static final String SUFFIX = "_behavior"; + + @Inject + private DiagramAccessBase da; - public static void export(ModelComponent ac, String folder) { - DiagramAccess da = new DiagramAccess(); + public void export(ModelComponent ac, String folder) { boolean wasOpen = false; - BehaviorEditor editor = (BehaviorEditor) da.findDiagramEditor(ac); + AbstractFSMEditor editor = (AbstractFSMEditor) da.findDiagramEditor(ac); if (editor!=null) wasOpen = true; else - editor = (BehaviorEditor) da.openDiagramEditor(ac); + editor = (AbstractFSMEditor) da.openDiagramEditor(ac); if (editor!=null) { String filename = folder+File.separatorChar+ac.getComponentName()+SUFFIX; @@ -47,7 +51,7 @@ public class BehaviorExporter { } } - private static void exportSubGraphsRecursively(StateGraph sg, BehaviorEditor editor, String basename) { + private void exportSubGraphsRecursively(StateGraph sg, AbstractFSMEditor editor, String basename) { if (sg==null) return; diff --git a/plugins/org.eclipse.etrice.ui.behavior/src/org/eclipse/etrice/ui/behavior/editor/BehaviorEditor.java b/plugins/org.eclipse.etrice.ui.behavior/src/org/eclipse/etrice/ui/behavior/editor/BehaviorEditor.java index 7f00da588..ebe0cd987 100644 --- a/plugins/org.eclipse.etrice.ui.behavior/src/org/eclipse/etrice/ui/behavior/editor/BehaviorEditor.java +++ b/plugins/org.eclipse.etrice.ui.behavior/src/org/eclipse/etrice/ui/behavior/editor/BehaviorEditor.java @@ -9,42 +9,18 @@ package org.eclipse.etrice.ui.behavior.editor; -import java.util.ArrayList; -import java.util.Map; - -import org.eclipse.core.runtime.IProgressMonitor; -import org.eclipse.emf.common.command.Command; -import org.eclipse.emf.common.util.URI; import org.eclipse.emf.ecore.EObject; -import org.eclipse.emf.ecore.util.EcoreUtil; -import org.eclipse.emf.transaction.RecordingCommand; -import org.eclipse.etrice.core.fsm.fSM.FSMFactory; -import org.eclipse.etrice.core.fsm.fSM.ModelComponent; -import org.eclipse.etrice.core.fsm.fSM.RefinedState; -import org.eclipse.etrice.core.fsm.fSM.State; -import org.eclipse.etrice.core.fsm.fSM.StateGraph; -import org.eclipse.etrice.core.fsm.util.FSMHelpers; import org.eclipse.etrice.core.room.ActorClass; import org.eclipse.etrice.core.room.StructureClass; import org.eclipse.etrice.core.ui.editor.RoomEditor; import org.eclipse.etrice.ui.behavior.Activator; import org.eclipse.etrice.ui.behavior.fsm.editor.AbstractFSMEditor; -import org.eclipse.etrice.ui.behavior.fsm.support.ContextSwitcher; -import org.eclipse.etrice.ui.behavior.fsm.support.FSMSupportUtil; -import org.eclipse.etrice.ui.behavior.support.SupportUtil; import org.eclipse.etrice.ui.common.commands.ChangeDiagramInputJob; -import org.eclipse.graphiti.dt.IDiagramTypeProvider; -import org.eclipse.graphiti.features.IFeatureProvider; -import org.eclipse.graphiti.features.context.IUpdateContext; -import org.eclipse.graphiti.features.context.impl.UpdateContext; import org.eclipse.graphiti.mm.pictograms.Diagram; -import org.eclipse.graphiti.mm.pictograms.Shape; import org.eclipse.graphiti.services.Graphiti; import org.eclipse.jface.dialogs.MessageDialog; import org.eclipse.swt.graphics.Image; -import com.google.common.base.Function; - public class BehaviorEditor extends AbstractFSMEditor { @@ -60,31 +36,6 @@ public class BehaviorEditor extends AbstractFSMEditor { return Activator.getImage("icons/Behavior.gif"); } - @Override - public void dispose() { - // Stop observing the Room Model - diagnosingModelObserver.removeObserver(); - super.dispose(); - } - - public boolean showStateGraph(StateGraph sg) { - URI boUri = EcoreUtil.getURI(sg); - final StateGraph mySG = (StateGraph) getEditingDomain().getResourceSet().getEObject(boUri, true); - if (mySG==null) - return false; - - Command cmd = new RecordingCommand(getEditingDomain()) { - @Override - protected void doExecute() { - ContextSwitcher.switchTo(getDiagramTypeProvider().getDiagram(), mySG); - } - }; - getEditingDomain().getCommandStack().execute(cmd); - getEditingDomain().getCommandStack().flush(); - - return true; - } - /** * @return the actor class of this editor */ @@ -97,125 +48,6 @@ public class BehaviorEditor extends AbstractFSMEditor { return null; } - /* (non-Javadoc) - * @see org.eclipse.graphiti.ui.internal.editor.DiagramEditorInternal#doSave(org.eclipse.core.runtime.IProgressMonitor) - */ - @Override - public void doSave(IProgressMonitor monitor) { - getEditingDomain().getCommandStack().execute(new RecordingCommand(getEditingDomain()) { - protected void doExecute() { - removeEmptySubgraphs(); - rebaseRefinedStates(); - removeUnusedRefinedStates(); - } - }); - - super.doSave(monitor); - } - - /** - * - */ - protected void removeUnusedRefinedStates() { - Diagram diagram = getDiagramTypeProvider().getDiagram(); - ModelComponent ac = FSMSupportUtil.getInstance().getModelComponent(diagram); - - if (ac.getStateMachine()!=null) { - ArrayList<RefinedState> toBeRemoved = new ArrayList<RefinedState>(); - for (State s : ac.getStateMachine().getStates()) { - if (s instanceof RefinedState) { - if (isUnused((RefinedState)s)) - toBeRemoved.add((RefinedState) s); - } - } - - ac.getStateMachine().getStates().removeAll(toBeRemoved); - } - } - - /** - * @param s - * @return - */ - private boolean isUnused(RefinedState s) { - FSMHelpers fsmHelpers = SupportUtil.getInstance().getFSMHelpers(); - if (fsmHelpers.hasDirectSubStructure(s)) - return false; - if (fsmHelpers.hasDetailCode(s.getEntryCode())) - return false; - if (fsmHelpers.hasDetailCode(s.getExitCode())) - return false; - - return true; - } - - protected void removeEmptySubgraphs() { - Diagram diagram = getDiagramTypeProvider().getDiagram(); - FSMHelpers fsmHelpers = SupportUtil.getInstance().getFSMHelpers(); - - // if our current context is an empty state graph we go one level up - StateGraph current = ContextSwitcher.getCurrentStateGraph(diagram); - if (current!=null && current.eContainer() instanceof State) { - State s = (State) current.eContainer(); - if (!fsmHelpers.hasDirectSubStructure(s)) { - ContextSwitcher.goUp(diagram, current); - } - } - - ArrayList<Shape> toBeRemoved = new ArrayList<Shape>(); - for (Shape ctxShape : diagram.getChildren()) { - EObject bo = Graphiti.getLinkService().getBusinessObjectForLinkedPictogramElement(ctxShape); - if (bo.eIsProxy()) { - toBeRemoved.add(ctxShape); - continue; - } - - assert(bo instanceof StateGraph): "expected state graph"; - - StateGraph sg = (StateGraph) bo; - if (sg.eContainer() instanceof State) { - State s = (State) sg.eContainer(); - if (!fsmHelpers.hasDirectSubStructure(s)) { - EcoreUtil.delete(sg); - toBeRemoved.add(ctxShape); - } - } - } - - // need to recursively delete the shapes to avoid dangling HREFs - for (Shape shape : toBeRemoved) { - EcoreUtil.delete(shape, true); - } - } - - protected void rebaseRefinedStates() { - ModelComponent ac = getModelComponent(); - - if (ac.getStateMachine()==null) - return; - - Function<RefinedState, String> nameProvider = SupportUtil.getInstance().getFSMNameProvider().getRefinedStateNameProvider(); - Map<RefinedState, RefinedState> rs2parent = SupportUtil.getInstance().getFSMHelpers().getRefinedStatesToRelocate(ac, nameProvider); - - // move all to the new context - for (RefinedState rs : rs2parent.keySet()) { - RefinedState parent = rs2parent.get(rs); - if (parent.getSubgraph()==null) - parent.setSubgraph(FSMFactory.eINSTANCE.createStateGraph()); - parent.getSubgraph().getStates().add(rs); - } - } - - @Override - protected void superClassChanged() { - IDiagramTypeProvider diagramTypeProvider = getDiagramTypeProvider(); - Diagram diagram = diagramTypeProvider.getDiagram(); - IFeatureProvider featureProvider = diagramTypeProvider.getFeatureProvider(); - IUpdateContext updateCtx = new UpdateContext(diagram); - featureProvider.updateIfPossible(updateCtx); - diagramTypeProvider.getDiagramBehavior().refresh(); - } - protected StructureClass getStructureClass() { return (StructureClass) getModelComponent(); } diff --git a/plugins/org.eclipse.etrice.ui.commands/src/org/eclipse/etrice/ui/commands/handlers/ExportDiagramsHandler.java b/plugins/org.eclipse.etrice.ui.commands/src/org/eclipse/etrice/ui/commands/handlers/ExportDiagramsHandler.java index 8ca831837..ea0ee2350 100644 --- a/plugins/org.eclipse.etrice.ui.commands/src/org/eclipse/etrice/ui/commands/handlers/ExportDiagramsHandler.java +++ b/plugins/org.eclipse.etrice.ui.commands/src/org/eclipse/etrice/ui/commands/handlers/ExportDiagramsHandler.java @@ -34,7 +34,7 @@ import org.eclipse.etrice.core.room.ActorClass; import org.eclipse.etrice.core.room.RoomModel; import org.eclipse.etrice.core.room.SubSystemClass; import org.eclipse.etrice.core.ui.RoomUiModule; -import org.eclipse.etrice.ui.behavior.editor.BehaviorExporter; +import org.eclipse.etrice.ui.behavior.fsm.editor.BehaviorExporter; import org.eclipse.etrice.ui.common.base.UIBaseActivator; import org.eclipse.etrice.ui.common.base.preferences.UIBasePreferenceConstants; import org.eclipse.etrice.ui.structure.editor.StructureExporter; @@ -143,9 +143,10 @@ public class ExportDiagramsHandler extends AbstractHandler { if (folder.exists()) { String folderPath = folder.getLocation().toOSString(); + BehaviorExporter exporter = org.eclipse.etrice.ui.behavior.Activator.getDefault().getInjector().getInstance(BehaviorExporter.class); for (ActorClass ac : model.getActorClasses()) { if (ac.getStateMachine()!=null) - BehaviorExporter.export(ac, folderPath); + exporter.export(ac, folderPath); StructureExporter.export(ac, folderPath); } |