import org.eclipse.swt.layout.GridLayout;
import org.eclipse.swt.widgets.Button;
import org.eclipse.swt.widgets.Composite;
+import org.eclipse.swt.widgets.Display;
import org.eclipse.swt.widgets.Label;
import org.eclipse.swt.widgets.Slider;
import org.eclipse.ui.PlatformUI;
import org.eclipse.ui.part.ViewPart;
import net.haspamelodica.swt.helper.zoomablecanvas.helper.ZoomableCanvasUserInput;
+import net.mograsim.logic.core.LogicObserver;
+import net.mograsim.logic.core.components.CoreClock;
import net.mograsim.logic.model.LogicExecuter;
import net.mograsim.logic.model.LogicUICanvas;
import net.mograsim.machine.Machine;
import net.mograsim.plugin.EclipsePreferences;
import net.mograsim.plugin.MachineContext;
import net.mograsim.plugin.MograsimActivator;
+ import net.mograsim.plugin.nature.MachineContextSwtTools;
+ import net.mograsim.plugin.nature.MachineContextSwtTools.MachineCombo;
+ import net.mograsim.plugin.nature.MachineContextSwtTools.MograsimProjectCombo;
import net.mograsim.plugin.tables.DisplaySettings;
import net.mograsim.plugin.tables.mi.ActiveInstructionPreviewContentProvider;
import net.mograsim.plugin.tables.mi.InstructionTable;
private LogicExecuter exec;
private LogicUICanvas ui;
+ private Machine m;
@Override
public void dispose()
{
if (exec != null)
exec.stopLiveExecution();
+ super.dispose();
}
@Override
Preferences.setPreferences(new EclipsePreferences(PlatformUI.getWorkbench().getThemeManager().getCurrentTheme(),
MograsimActivator.instance().getPreferenceStore()));
- Machine m = MachineContext.getInstance().getMachine();
+ m = MachineContext.getInstance().getMachine();
// initialize UI
GridLayout layout = new GridLayout(1, true);
private void addSimulationControlWidgets(Composite parent)
{
Composite c = new Composite(parent, SWT.NONE);
- c.setLayout(new GridLayout(5, false));
- c.setLayout(new GridLayout(6, false));
++ c.setLayout(new GridLayout(7, false));
+
+ MograsimProjectCombo projectCombo = MachineContextSwtTools.createMograsimProjectSelector(c, SWT.NONE);
+ MachineCombo machineCombo = MachineContextSwtTools.createMachineSelector(c, SWT.NONE);
+
+ Button sbseButton = new Button(c, SWT.CHECK);
Button pauseButton = new Button(c, SWT.TOGGLE);
+
+ LogicObserver clockObserver = o ->
+ {
+ if (((CoreClock) o).isOn())
+ {
+ exec.pauseLiveExecution();
+ Display.getDefault().asyncExec(() ->
+ {
+ pauseButton.setSelection(false);
+ setPauseText(pauseButton, false);
+ });
+ }
+ };
+
+ sbseButton.addListener(SWT.Selection, e ->
+ {
+ String statusString = "disabled";
+ CoreClock cl = m.getClock();
+ if (sbseButton.getSelection())
+ {
+ cl.registerObserver(clockObserver);
+ statusString = "enabled";
+ } else
+ cl.deregisterObserver(clockObserver);
+ sbseButton.setToolTipText(String.format("Step by step execution: %s", statusString));
+ });
+ sbseButton.setSelection(false);
+
pauseButton.setSelection(true);
setPauseText(pauseButton, false);
pauseButton.addListener(SWT.Selection, e ->
{
- setPauseText(pauseButton, false);
if (pauseButton.getSelection())
{
exec.unpauseLiveExecution();
exec.pauseLiveExecution();
}
});
+
pauseButton.addMouseTrackListener(new MouseTrackListener()
{
@Override
c.setVisible(true);
}
- private void setPauseText(Button pauseButton, boolean hovered)
+ private static void setPauseText(Button pauseButton, boolean hovered)
{
if (hovered)
{