08f68102f8
Declare Variables with a name and position, rather than by passing through a VariableProxy. This allows us to not create dummy proxies for things like function declarations, and allows us to consider those declarations unused. As a side-effect, we also have to check if a variable is unused in the bytecode generator (as it will no longer be allocated), and we end up skip generating code/SFIs for dead variables/functions. Change-Id: I4c2c872473f23e124f9456b4b92f87159658f8e0 Reviewed-on: https://chromium-review.googlesource.com/c/1414916 Commit-Queue: Leszek Swirski <leszeks@chromium.org> Reviewed-by: Yang Guo <yangguo@chromium.org> Reviewed-by: Toon Verwaest <verwaest@chromium.org> Reviewed-by: Ross McIlroy <rmcilroy@chromium.org> Cr-Commit-Position: refs/heads/master@{#59088}
55 lines
1.4 KiB
JavaScript
55 lines
1.4 KiB
JavaScript
// Copyright 2014 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: --noalways-opt
|
|
|
|
Debug = debug.Debug
|
|
|
|
var debug_step = 0;
|
|
var failure = null;
|
|
|
|
function listener(event, exec_state, event_data, data) {
|
|
if (event != Debug.DebugEvent.Break) return;
|
|
try {
|
|
if (debug_step == 0) {
|
|
assertEquals(1, exec_state.frame(0).evaluate('a').value());
|
|
assertEquals(3, exec_state.frame(0).evaluate('b').value());
|
|
exec_state.frame(0).evaluate("a = 4").value();
|
|
debug_step++;
|
|
} else {
|
|
assertEquals(4, exec_state.frame(0).evaluate('a').value());
|
|
assertEquals(3, exec_state.frame(0).evaluate('b').value());
|
|
exec_state.frame(0).evaluate("set_a_to_5()");
|
|
exec_state.frame(0).evaluate("b = 5").value();
|
|
}
|
|
} catch (e) {
|
|
failure = e;
|
|
}
|
|
}
|
|
|
|
Debug.setListener(listener);
|
|
|
|
function* generator(a, b) {
|
|
function set_a_to_5() { a = 5 }
|
|
// Make sure set_a_to_5 is 'used' so that it is visible to the debugger.
|
|
set_a_to_5;
|
|
var b = 3; // Shadows a parameter.
|
|
debugger;
|
|
yield a;
|
|
yield b;
|
|
debugger;
|
|
yield a;
|
|
return b;
|
|
}
|
|
|
|
var foo = generator(1, 2);
|
|
|
|
assertEquals(4, foo.next().value);
|
|
assertEquals(3, foo.next().value);
|
|
assertEquals(5, foo.next().value);
|
|
assertEquals(5, foo.next().value);
|
|
assertNull(failure);
|
|
|
|
Debug.setListener(null);
|