9ed5596ade
This became temporarily a big issue, because spreads are desugared into do-expressions. This patch fixes the problem with having spreads as parameter initializers in arrow expressions, e.g., this line would crash: [], ((x = [...[42]]) => x)(); R=rossberg@chromium.org BUG=chromium:578038 LOG=N Review URL: https://codereview.chromium.org/1581403007 Cr-Commit-Position: refs/heads/master@{#33365}
17 lines
533 B
JavaScript
17 lines
533 B
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-do-expressions
|
|
|
|
(function testWithoutOtherLiteral() {
|
|
var result = ((x = [...[42]]) => x)();
|
|
assertEquals(result, [42]);
|
|
})();
|
|
|
|
(function testWithSomeOtherLiteral() {
|
|
[]; // important: an array literal before the arrow function
|
|
var result = ((x = [...[42]]) => x)(); // will core dump, if not fixed.
|
|
assertEquals(result, [42]);
|
|
})();
|