v8/test/mjsunit/es6/super-with-spread-modify-next.js
petermarshall 409d018005 [turbofan] Reduce CallConstructWithSpread where iteration is not observable.
Where the arguments have already been inlined, we can replace these calls with a
direct call to construct. We have to make sure that the iteration over the arguments is not observable.

BUG=v8:5895

Review-Url: https://codereview.chromium.org/2659623002
Cr-Commit-Position: refs/heads/master@{#42765}
2017-01-30 10:29:05 +00:00

57 lines
1.2 KiB
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 modifyNext() {
'use strict';
class Point {
constructor(x, y) {
this.x = x;
this.y = y;
}
}
class ArgumentsPoint extends Point {
constructor() {
super(...arguments);
}
}
var a = [];
var ai = a[Symbol.iterator]();
var original_next = ai.__proto__['next'];
function testArgumentsPoint(x, y) {
return new ArgumentsPoint(x, y);
}
testArgumentsPoint(1, 2);
testArgumentsPoint(1, 2);
% OptimizeFunctionOnNextCall(testArgumentsPoint);
var r = testArgumentsPoint(1, 2);
assertInstanceof(r, ArgumentsPoint);
assertInstanceof(r, Point);
assertEquals(r.x, 1);
assertEquals(r.y, 2);
var called = 0;
Object.defineProperty(ai.__proto__, 'next', {
get: function() {
called++;
return original_next;
}
});
var r2 = testArgumentsPoint(1, 2);
assertEquals(3, called);
assertInstanceof(r2, ArgumentsPoint);
assertInstanceof(r2, Point);
assertEquals(r2.x, 1);
assertEquals(r2.y, 2);
})();