2237106ae2
Where the arguments have already been inlined, we can replace these calls with a direct call. We have to make sure that the iteration over the arguments is not observable. Also factor out the large chunk of logic shared with ReduceJSConstructWithSpread. BUG=v8:5932 Change-Id: I6c4fac670028fbd8ca82c4474d4392231573bc49 Reviewed-on: https://chromium-review.googlesource.com/439329 Reviewed-by: Benedikt Meurer <bmeurer@chromium.org> Commit-Queue: Peter Marshall <petermarshall@chromium.org> Cr-Commit-Position: refs/heads/master@{#43039}
38 lines
740 B
JavaScript
38 lines
740 B
JavaScript
// Copyright 2017 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: --allow-natives-syntax
|
|
|
|
(function modifyArrayIterator() {
|
|
'use strict';
|
|
|
|
function maxWithZero(...args) {
|
|
return Math.max(0, ...args);
|
|
}
|
|
|
|
function testMax(x, y) {
|
|
return maxWithZero(x, y);
|
|
}
|
|
|
|
testMax(1, 2);
|
|
testMax(1, 2);
|
|
% OptimizeFunctionOnNextCall(testMax);
|
|
var r = testMax(1, 2);
|
|
|
|
assertEquals(2, r);
|
|
|
|
Object.defineProperty(Array.prototype, Symbol.iterator, {
|
|
value: function*
|
|
() {
|
|
yield 3;
|
|
yield 4;
|
|
},
|
|
configurable: true
|
|
});
|
|
|
|
var r2 = testMax(1, 2);
|
|
|
|
assertEquals(4, r2);
|
|
})();
|