diff --git a/core/src/main/java/org/teavm/backend/wasm/debug/info/FunctionControlFlowIterator.java b/core/src/main/java/org/teavm/backend/wasm/debug/info/FunctionControlFlowIterator.java index d0fa2949d..fabff1cd0 100644 --- a/core/src/main/java/org/teavm/backend/wasm/debug/info/FunctionControlFlowIterator.java +++ b/core/src/main/java/org/teavm/backend/wasm/debug/info/FunctionControlFlowIterator.java @@ -26,7 +26,7 @@ public class FunctionControlFlowIterator { FunctionControlFlowIterator(FunctionControlFlow controlFlow, int index) { this.controlFlow = controlFlow; - this.index = 0; + this.index = index; } public boolean hasNext() { @@ -39,7 +39,10 @@ public class FunctionControlFlowIterator { } public void rewind(int index) { - this.index = index; + if (this.index != index) { + this.index = index; + fill(); + } } private void fill() { diff --git a/core/src/main/java/org/teavm/backend/wasm/debug/info/StepLocationsFinder.java b/core/src/main/java/org/teavm/backend/wasm/debug/info/StepLocationsFinder.java index 6b0b9719c..61f8f2c63 100644 --- a/core/src/main/java/org/teavm/backend/wasm/debug/info/StepLocationsFinder.java +++ b/core/src/main/java/org/teavm/backend/wasm/debug/info/StepLocationsFinder.java @@ -176,7 +176,7 @@ public class StepLocationsFinder { breakpointAddresses.add(point.address + debugInfo.offset()); return; } - if (enterMethod) { + if (enterMethod && point.isCall) { breakpointAddresses.add(point.address + debugInfo.offset()); callAddresses.add(point.address + debugInfo.offset()); } diff --git a/core/src/main/java/org/teavm/backend/wasm/render/WasmBinaryRenderingVisitor.java b/core/src/main/java/org/teavm/backend/wasm/render/WasmBinaryRenderingVisitor.java index d3293aa94..52a81b38b 100644 --- a/core/src/main/java/org/teavm/backend/wasm/render/WasmBinaryRenderingVisitor.java +++ b/core/src/main/java/org/teavm/backend/wasm/render/WasmBinaryRenderingVisitor.java @@ -967,6 +967,7 @@ class WasmBinaryRenderingVisitor implements WasmExpressionVisitor { emitLocation(null); flushLocation(); if (debugLines != null) { + debugLines.advance(writer.getPosition() + addressOffset); debugLines.end(); } }