adac5956c6
Reason for revert: Causes frequent crashes in Canary: chromium:537816 Original issue's description: > Ship ES2015 sloppy-mode function hoisting, let, class > > This patch doesn't ship all features of ES2015 variable/scoping > changes, notably omitting the removal of legacy const. I think > function hoisting, let and class in sloppy mode can stand to > themselves as a package, and the legacy const change is much > riskier and more likely to be reverted, so my intention is to > pursue those as a separate, follow-on patch. > > R=adamk@chromium.org > BUG=v8:4285,v8:3305 > LOG=Y > CQ_INCLUDE_TRYBOTS=tryserver.chromium.linux:linux_chromium_rel_ng;tryserver.blink:linux_blink_rel > > Committed: https://crrev.com/fcff8588a5a01587643d6c2507c7b882c78a2957 > Cr-Commit-Position: refs/heads/master@{#33133} TBR=adamk@chromium.org # Not skipping CQ checks because original CL landed more than 1 days ago. BUG=v8:4285,v8:3305,chromium:537816 LOG=Y Review URL: https://codereview.chromium.org/1565263002 Cr-Commit-Position: refs/heads/master@{#33162}
67 lines
1.5 KiB
JavaScript
67 lines
1.5 KiB
JavaScript
// 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: --harmony-sloppy --harmony-sloppy-let --harmony-destructuring-bind
|
|
|
|
// let is usable as a variable with var or legacy const, not let or ES6 const
|
|
|
|
(function (){
|
|
assertEquals(undefined, let);
|
|
|
|
var let;
|
|
|
|
let = 5;
|
|
assertEquals(5, let);
|
|
|
|
(function() { var let = 1; assertEquals(1, let); })();
|
|
assertEquals(5, let);
|
|
})();
|
|
|
|
assertThrows(function() { return let; }, ReferenceError);
|
|
|
|
(function() {
|
|
var let, sum = 0;
|
|
for (let in [1, 2, 3, 4]) sum += Number(let);
|
|
assertEquals(6, sum);
|
|
|
|
(function() { for (var let of [4, 5]) sum += let; })();
|
|
assertEquals(15, sum);
|
|
|
|
(function() { for (var let in [6]) sum += Number([6][let]); })();
|
|
assertEquals(21, sum);
|
|
|
|
for (let = 7; let < 8; let++) sum += let;
|
|
assertEquals(28, sum);
|
|
assertEquals(8, let);
|
|
|
|
(function() { for (var let = 8; let < 9; let++) sum += let; })();
|
|
assertEquals(36, sum);
|
|
assertEquals(8, let);
|
|
})();
|
|
|
|
assertThrows(function() { return let; }, ReferenceError);
|
|
|
|
(function () {
|
|
let obj = {};
|
|
var {let} = {let() { return obj; }};
|
|
let().x = 1;
|
|
assertEquals(1, obj.x);
|
|
})();
|
|
|
|
(function () {
|
|
let obj = {};
|
|
const [let] = [function() { return obj; }];
|
|
let().x = 1;
|
|
assertEquals(1, obj.x);
|
|
})();
|
|
|
|
(function() {
|
|
function let() {
|
|
return 1;
|
|
}
|
|
assertEquals(1, let());
|
|
})()
|
|
|
|
assertThrows('for (let of []) {}', SyntaxError);
|