X-Git-Url: https://mograsim.net/gitweb/?a=blobdiff_plain;f=plugins%2Fnet.mograsim.plugin.core%2Fsrc%2Fnet%2Fmograsim%2Fplugin%2Flaunch%2FMachineDebugTarget.java;h=03fe7fdd5424671571eda8ae51ecc108ab065081;hb=d031a0434011f1e8577de35ba1a5c0b6649beef4;hp=5270c767195b8cc024e17fc30338a0fbb34673ec;hpb=a873ef940ba160f284ba6fa3fee1b9704bf68858;p=Mograsim.git diff --git a/plugins/net.mograsim.plugin.core/src/net/mograsim/plugin/launch/MachineDebugTarget.java b/plugins/net.mograsim.plugin.core/src/net/mograsim/plugin/launch/MachineDebugTarget.java index 5270c767..03fe7fdd 100644 --- a/plugins/net.mograsim.plugin.core/src/net/mograsim/plugin/launch/MachineDebugTarget.java +++ b/plugins/net.mograsim.plugin.core/src/net/mograsim/plugin/launch/MachineDebugTarget.java @@ -1,6 +1,8 @@ package net.mograsim.plugin.launch; -import java.util.Arrays; +import java.util.ArrayList; +import java.util.List; +import java.util.function.Consumer; import org.eclipse.core.resources.IMarkerDelta; import org.eclipse.core.runtime.IStatus; @@ -15,38 +17,41 @@ import org.eclipse.debug.core.model.IBreakpoint; import org.eclipse.debug.core.model.IDebugElement; import org.eclipse.debug.core.model.IDebugTarget; import org.eclipse.debug.core.model.IMemoryBlock; +import org.eclipse.debug.core.model.IMemoryBlockExtension; +import org.eclipse.debug.core.model.IMemoryBlockRetrievalExtension; import org.eclipse.debug.core.model.IProcess; import org.eclipse.debug.core.model.IStepFilters; import org.eclipse.debug.core.model.IThread; +import net.mograsim.logic.model.LogicExecuter; import net.mograsim.machine.Machine; +import net.mograsim.machine.MachineDefinition; import net.mograsim.plugin.MograsimActivator; +import net.mograsim.plugin.launch.MachineLaunchConfigType.MachineLaunchParams; -public class MachineDebugTarget extends PlatformObject implements IDebugTarget +public class MachineDebugTarget extends PlatformObject implements IDebugTarget, IMemoryBlockRetrievalExtension { - private final MachineProcess process; + private final ILaunch launch; + private final Machine machine; + private final LogicExecuter exec; - public MachineDebugTarget(MachineProcess process) + private boolean running; + + private final List> executionSpeedListeners; + + private final MachineLaunchParams launchParams; + + public MachineDebugTarget(ILaunch launch, MachineLaunchParams launchParams, MachineDefinition machineDefinition) { - this.process = process; + this.launch = launch; + this.machine = machineDefinition.createNew(); + this.exec = new LogicExecuter(machine.getTimeline()); - DebugPlugin.getDefault().addDebugEventListener(es -> Arrays.stream(es).filter(e -> e.getSource() == process).forEach(e -> - { - switch (e.getKind()) - { - case DebugEvent.RESUME: - fireResumeEvent(e.getDetail()); - break; - case DebugEvent.SUSPEND: - fireSuspendEvent(e.getDetail()); - break; - case DebugEvent.TERMINATE: - fireTerminateEvent(); - break; - default: - // ignore - } - })); + this.executionSpeedListeners = new ArrayList<>(); + this.launchParams = launchParams; + + exec.startLiveExecution(); + running = true; getLaunch().addDebugTarget(this); fireCreationEvent(); @@ -54,13 +59,13 @@ public class MachineDebugTarget extends PlatformObject implements IDebugTarget public Machine getMachine() { - return process.getMachine(); + return machine; } @Override public String getName() throws DebugException { - return process.getName(); + return "Mograsim machine \"" + machine.getDefinition().getId() + '"'; } @Override @@ -78,60 +83,91 @@ public class MachineDebugTarget extends PlatformObject implements IDebugTarget @Override public ILaunch getLaunch() { - return process.getLaunch(); + return launch; + } + + public MachineLaunchParams getLaunchParams() + { + return launchParams; + } + + public double getExecutionSpeed() + { + return exec.getSpeedFactor(); } public void setExecutionSpeed(double speed) { - process.setExecutionSpeed(speed); + if (getExecutionSpeed() != speed) + { + exec.setSpeedFactor(speed); + callExecutionSpeedListener(speed); + } } @Override public boolean isSuspended() { - return process.isSuspended(); + return exec.isPaused(); } @Override public boolean canSuspend() { - return process.canSuspend(); + return !isTerminated() && !isSuspended(); } @Override public void suspend() throws DebugException { - process.suspend(); + if (isTerminated()) + throwDebugException("Can't suspend a terminated MachineProcess"); + if (isSuspended()) + throwDebugException("Can't suspend a suspended MachineProcess"); + + exec.pauseLiveExecution(); + fireSuspendEvent(DebugEvent.CLIENT_REQUEST); } @Override public boolean canResume() { - return process.canResume(); + return !isTerminated() && isSuspended(); } @Override public void resume() throws DebugException { - process.resume(); + if (isTerminated()) + throwDebugException("Can't resume a terminated MachineProcess"); + if (!isSuspended()) + throwDebugException("Can't resume a non-suspended MachineProcess"); + + exec.unpauseLiveExecution(); + fireResumeEvent(DebugEvent.CLIENT_REQUEST); } @Override public boolean isTerminated() { - return process.isTerminated(); + return !running; } @Override public boolean canTerminate() { - return process.canTerminate(); + return !isTerminated(); } @Override public void terminate() throws DebugException { - process.terminate(); + if (isTerminated()) + return; + + exec.stopLiveExecution(); + running = false; + fireTerminateEvent(); } @Override @@ -183,6 +219,7 @@ public class MachineDebugTarget extends PlatformObject implements IDebugTarget return true; } + @SuppressWarnings("deprecation") // TODO can we throw a DebugException instead? @Override public IMemoryBlock getMemoryBlock(long startAddress, long length) throws DebugException { @@ -190,9 +227,15 @@ public class MachineDebugTarget extends PlatformObject implements IDebugTarget } @Override - public MachineProcess getProcess() + public IMemoryBlockExtension getExtendedMemoryBlock(String expression, Object context) throws DebugException + { + return new MainMemoryBlockExtension(this, expression, context); + } + + @Override + public IProcess getProcess() { - return process; + return null; } @Override @@ -207,6 +250,21 @@ public class MachineDebugTarget extends PlatformObject implements IDebugTarget return new IThread[0]; } + public void addExecutionSpeedListener(Consumer executionSpeedListener) + { + executionSpeedListeners.add(executionSpeedListener); + } + + public void removeExecutionSpeedListener(Consumer executionSpeedListener) + { + executionSpeedListeners.remove(executionSpeedListener); + } + + private void callExecutionSpeedListener(double executionSpeed) + { + executionSpeedListeners.forEach(l -> l.accept(executionSpeed)); + } + @SuppressWarnings("unchecked") @Override public T getAdapter(Class adapter) @@ -225,9 +283,6 @@ public class MachineDebugTarget extends PlatformObject implements IDebugTarget if (adapter == ILaunch.class) return (T) getLaunch(); - if (adapter == IProcess.class) - return (T) getProcess(); - // CONTEXTLAUNCHING if (adapter == ILaunchConfiguration.class) return (T) getLaunch().getLaunchConfiguration(); @@ -280,4 +335,10 @@ public class MachineDebugTarget extends PlatformObject implements IDebugTarget { DebugPlugin.getDefault().fireDebugEventSet(new DebugEvent[] { event }); } + + private static void throwDebugException(String message) throws DebugException + { + throw new DebugException( + new Status(IStatus.ERROR, MograsimActivator.PLUGIN_ID, DebugException.TARGET_REQUEST_FAILED, message, null)); + } } \ No newline at end of file