[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}
This commit is contained in:
parent
26a5f2128b
commit
baba15223c
@ -936,7 +936,7 @@ void Debug::PrepareStepOnThrow() {
|
||||
it.Advance();
|
||||
}
|
||||
|
||||
if (last_step_action() == StepNext) {
|
||||
if (last_step_action() == StepNext || last_step_action() == StepOut) {
|
||||
while (!it.done()) {
|
||||
Address current_fp = it.frame()->UnpaddedFP();
|
||||
if (current_fp >= thread_local_.target_fp_) break;
|
||||
|
38
test/mjsunit/regress/regress-5559.js
Normal file
38
test/mjsunit/regress/regress-5559.js
Normal file
@ -0,0 +1,38 @@
|
||||
// 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);
|
Loading…
Reference in New Issue
Block a user