Compare commits

..

2 Commits

Author SHA1 Message Date
3a05416510 bump 2024-03-30 10:30:26 +02:00
c291328cc3 fix: detach debugger after close 2024-03-30 10:22:12 +02:00
3 changed files with 12 additions and 4 deletions

View File

@@ -1,4 +1,4 @@
project_group = me.topchetoeu
project_name = jscript
project_version = 0.9.12-beta
project_version = 0.9.23-beta
main_class = me.topchetoeu.jscript.utils.JScriptRepl

View File

@@ -36,6 +36,10 @@ public class DebugContext {
this.debugger = debugger;
return true;
}
public boolean detachDebugger(DebugHandler debugger) {
if (this.debugger != debugger) return false;
return detachDebugger();
}
public boolean detachDebugger() {
this.debugger = null;
return true;

View File

@@ -205,6 +205,7 @@ public class SimpleDebugger implements Debugger {
private ObjectValue emptyObject = new ObjectValue();
private WeakHashMap<DebugContext, DebugContext> contexts = new WeakHashMap<>();
private WeakHashMap<FunctionBody, FunctionMap> mappings = new WeakHashMap<>();
private WeakHashMap<FunctionBody, HashMap<Location, Breakpoint>> bpLocs = new WeakHashMap<>();
@@ -642,11 +643,10 @@ public class SimpleDebugger implements Debugger {
execptionType = CatchType.NONE;
state = State.RESUMED;
// idToBptCand.clear();
mappings.clear();
bpLocs.clear();
idToBreakpoint.clear();
// locToBreakpoint.clear();
// tmpBreakpts.clear();
filenameToId.clear();
idToSource.clear();
@@ -664,6 +664,9 @@ public class SimpleDebugger implements Debugger {
stepOutFrame = currFrame = null;
stepOutPtr = 0;
for (var ctx : contexts.keySet()) ctx.detachDebugger(this);
contexts.clear();
updateNotifier.next();
}
@@ -1041,6 +1044,7 @@ public class SimpleDebugger implements Debugger {
public SimpleDebugger attach(DebugContext ctx) {
ctx.attachDebugger(this);
contexts.put(ctx, ctx);
return this;
}