ed18aa65ea
Now that ES2015 const has shipped, in Chrome 49, legacy const declarations are no more. This lets us remove a bunch of code from many parts of the codebase. In this patch, I remove parser support for generating legacy const variables from const declarations. This also removes the special "illegal declaration" bit from Scope, which has ripples into all compiler backends. Also gone are any tests which relied on legacy const declarations. Note that we do still generate a Variable in mode CONST_LEGACY in one case: function name bindings in sloppy mode. The likely fix there is to add a new Variable::Kind for this case and handle it appropriately for stores in each backend, but I leave that for a later patch to make this one completely subtractive. Review URL: https://codereview.chromium.org/1819123002 Cr-Commit-Position: refs/heads/master@{#35002}
81 lines
1.6 KiB
JavaScript
81 lines
1.6 KiB
JavaScript
// 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: --harmony-sloppy-function
|
|
|
|
// In sloppy mode we allow function redeclarations within blocks for webcompat.
|
|
(function() {
|
|
assertEquals(undefined, f); // Annex B
|
|
if (true) {
|
|
assertEquals(2, f());
|
|
function f() { return 1 }
|
|
assertEquals(2, f());
|
|
function f() { return 2 }
|
|
assertEquals(2, f());
|
|
}
|
|
assertEquals(2, f()); // Annex B
|
|
})();
|
|
|
|
// Should still fail in strict mode
|
|
assertThrows(`
|
|
(function() {
|
|
"use strict";
|
|
if (true) {
|
|
function f() { return 1 }
|
|
function f() { return 2 }
|
|
}
|
|
})();
|
|
`, SyntaxError);
|
|
|
|
// Conflicts between let and function still throw
|
|
assertThrows(`
|
|
(function() {
|
|
if (true) {
|
|
let f;
|
|
function f() { return 2 }
|
|
}
|
|
})();
|
|
`, SyntaxError);
|
|
|
|
assertThrows(`
|
|
(function() {
|
|
if (true) {
|
|
function f() { return 2 }
|
|
let f;
|
|
}
|
|
})();
|
|
`, SyntaxError);
|
|
|
|
// Conflicts between const and function still throw
|
|
assertThrows(`
|
|
(function() {
|
|
if (true) {
|
|
const f;
|
|
function f() { return 2 }
|
|
}
|
|
})();
|
|
`, SyntaxError);
|
|
|
|
assertThrows(`
|
|
(function() {
|
|
if (true) {
|
|
function f() { return 2 }
|
|
const f;
|
|
}
|
|
})();
|
|
`, SyntaxError);
|
|
|
|
// Annex B redefinition semantics still apply with more blocks
|
|
(function() {
|
|
assertEquals(undefined, f); // Annex B
|
|
if (true) {
|
|
assertEquals(undefined, f);
|
|
{ function f() { return 1 } }
|
|
assertEquals(1, f());
|
|
{ function f() { return 2 } }
|
|
assertEquals(2, f());
|
|
}
|
|
assertEquals(2, f()); // Annex B
|
|
})();
|