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

[debugger] correctly find source position of implicit return statement.

The parser reads one character beyond EOF to have an additional source
position that the rewriter can use to insert the implicit return
statement at the end of a script. If we break at that return statement,
we need to be able to translate the source position to line and
column number.

R=jkummerow@chromium.org
BUG=chromium:569514
LOG=N

Committed: https://crrev.com/0b1076a68e1eadba260cec8afc5acec618561c28
Cr-Commit-Position: refs/heads/master@{#32825}

Review URL: https://codereview.chromium.org/1521953003

Cr-Commit-Position: refs/heads/master@{#32835}
parent 5483cfea
...@@ -11355,8 +11355,10 @@ static void CalculateLineEndsImpl(Isolate* isolate, ...@@ -11355,8 +11355,10 @@ static void CalculateLineEndsImpl(Isolate* isolate,
if (src_len > 0 && cache->IsLineTerminatorSequence(src[src_len - 1], 0)) { if (src_len > 0 && cache->IsLineTerminatorSequence(src[src_len - 1], 0)) {
line_ends->Add(src_len - 1); line_ends->Add(src_len - 1);
} else if (include_ending_line) { }
// Even if the last line misses a line end, it is counted. if (include_ending_line) {
// Include one character beyond the end of script. The rewriter uses that
// position for the implicit return statement.
line_ends->Add(src_len); line_ends->Add(src_len);
} }
} }
......
...@@ -63,9 +63,9 @@ var comment_lines = 28; ...@@ -63,9 +63,9 @@ var comment_lines = 28;
// This is the last position in the entire file (note: this equals // This is the last position in the entire file (note: this equals
// file size of <debug-sourceinfo.js> - 1, since starting at 0). // file size of <debug-sourceinfo.js> - 1, since starting at 0).
var last_position = 11337; var last_position = 11519;
// This is the last line of entire file (note: starting at 0). // This is the last line of entire file (note: starting at 0).
var last_line = 265; var last_line = 269;
// This is the last column of last line (note: starting at 0 and +1, due // This is the last column of last line (note: starting at 0 and +1, due
// to trailing <LF>). // to trailing <LF>).
var last_column = 1; var last_column = 1;
...@@ -244,18 +244,22 @@ assertEquals(70 + start_c, Debug.findFunctionSourceLocation(c, 6, 0).position); ...@@ -244,18 +244,22 @@ assertEquals(70 + start_c, Debug.findFunctionSourceLocation(c, 6, 0).position);
assertEquals(0 + start_d, Debug.findFunctionSourceLocation(d, 0, 0).position); assertEquals(0 + start_d, Debug.findFunctionSourceLocation(d, 0, 0).position);
assertEquals(6 + start_d, Debug.findFunctionSourceLocation(d, 1, 0).position); assertEquals(6 + start_d, Debug.findFunctionSourceLocation(d, 1, 0).position);
for (i = 1; i <= num_lines_d; i++) { for (i = 1; i <= num_lines_d; i++) {
assertEquals(6 + (i * line_length_d) + start_d, Debug.findFunctionSourceLocation(d, (i + 1), 0).position); assertEquals(6 + (i * line_length_d) + start_d,
Debug.findFunctionSourceLocation(d, (i + 1), 0).position);
} }
assertEquals(158 + start_d, Debug.findFunctionSourceLocation(d, 17, 0).position); assertEquals(158 + start_d, Debug.findFunctionSourceLocation(d, 17, 0).position);
// Make sure invalid inputs work properly. // Make sure invalid inputs work properly.
assertEquals(0, script.locationFromPosition(-1).line); assertEquals(0, script.locationFromPosition(-1).line);
assertEquals(null, script.locationFromPosition(last_position + 1)); assertEquals(null, script.locationFromPosition(last_position + 2));
// Test last position. // Test last position.
assertEquals(last_position, script.locationFromPosition(last_position).position); assertEquals(last_position, script.locationFromPosition(last_position).position);
assertEquals(last_line, script.locationFromPosition(last_position).line); assertEquals(last_line, script.locationFromPosition(last_position).line);
assertEquals(last_column, script.locationFromPosition(last_position).column); assertEquals(last_column, script.locationFromPosition(last_position).column);
assertEquals(last_line + 1,
script.locationFromPosition(last_position + 1).line);
assertEquals(0, script.locationFromPosition(last_position + 1).column);
// Test that script.sourceLine(line) works. // Test that script.sourceLine(line) works.
var location; var location;
......
// Copyright 2015 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 --allow-natives-syntax
var Debug = debug.Debug;
var expected = ["debugger;", "", "debugger;"];
function listener(event, exec_state, event_data, data) {
if (event != Debug.DebugEvent.Break) return;
try {
assertEquals(expected.shift(), exec_state.frame(0).sourceLineText());
exec_state.prepareStep(Debug.StepAction.StepNext, 1);
} catch (e) {
%AbortJS(e + "\n" + e.stack);
}
}
Debug.setListener(listener);
debugger;
...@@ -83,7 +83,7 @@ function testScriptMirror(f, file_name, file_lines, type, compilation_type, ...@@ -83,7 +83,7 @@ function testScriptMirror(f, file_name, file_lines, type, compilation_type,
// Test the script mirror for different functions. // Test the script mirror for different functions.
testScriptMirror(function(){}, 'mirror-script.js', 98, 2, 0); testScriptMirror(function(){}, 'mirror-script.js', 99, 2, 0);
testScriptMirror(Math.round, 'native math.js', -1, 0, 0); testScriptMirror(Math.round, 'native math.js', -1, 0, 0);
testScriptMirror(eval('(function(){})'), null, 1, 2, 1, '(function(){})', 87); testScriptMirror(eval('(function(){})'), null, 1, 2, 1, '(function(){})', 87);
testScriptMirror(eval('(function(){\n })'), null, 2, 2, 1, '(function(){\n })', 88); testScriptMirror(eval('(function(){\n })'), null, 2, 2, 1, '(function(){\n })', 88);
......
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