Commit baba1522 authored by yangguo's avatar yangguo Committed by Commit bot

[debugger] fix stepping out of across throwing.

R=jgruber@chromium.org
BUG=v8:5559

Review-Url: https://codereview.chromium.org/2445233004
Cr-Commit-Position: refs/heads/master@{#40549}
parent 26a5f212
...@@ -936,7 +936,7 @@ void Debug::PrepareStepOnThrow() { ...@@ -936,7 +936,7 @@ void Debug::PrepareStepOnThrow() {
it.Advance(); it.Advance();
} }
if (last_step_action() == StepNext) { if (last_step_action() == StepNext || last_step_action() == StepOut) {
while (!it.done()) { while (!it.done()) {
Address current_fp = it.frame()->UnpaddedFP(); Address current_fp = it.frame()->UnpaddedFP();
if (current_fp >= thread_local_.target_fp_) break; if (current_fp >= thread_local_.target_fp_) break;
......
// Copyright 2016 the V8 project authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
// Flags: --expose-debug-as debug
Debug = debug.Debug
var exception = null;
var break_count = 0;
function listener(event, exec_state, event_data, data) {
if (event != Debug.DebugEvent.Break) return;
try {
print(event_data.sourceLineText());
assertTrue(
event_data.sourceLineText().indexOf(`Break ${break_count++}.`) > 0);
exec_state.prepareStep(Debug.StepAction.StepOut);
} catch (e) {
exception = e;
}
};
function thrower() {
try {
debugger; // Break 0.
throw 'error';
} catch (err) {
}
}
Debug.setListener(listener);
thrower();
Debug.setListener(null); // Break 1.
assertNull(exception);
assertEquals(2, break_count);
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment