2014-06-04 11:52:17 +00:00
|
|
|
// Copyright 2014 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.
|
|
|
|
|
2017-07-13 11:22:37 +00:00
|
|
|
// Flags: --allow-natives-syntax
|
2014-06-04 11:52:17 +00:00
|
|
|
|
|
|
|
var a = []
|
|
|
|
for (var i = 0; i < 9; i++) a[i] = i + 1;
|
|
|
|
|
|
|
|
function test(f, arg1, arg2, expected) {
|
2019-06-14 10:59:02 +00:00
|
|
|
%PrepareFunctionForOptimization(f);
|
2014-06-04 11:52:17 +00:00
|
|
|
assertEquals(expected, f(arg1));
|
|
|
|
f(arg2);
|
|
|
|
%OptimizeFunctionOnNextCall(f);
|
|
|
|
assertEquals(expected, f(arg1));
|
|
|
|
}
|
|
|
|
|
|
|
|
test(function f0() {
|
|
|
|
return a[7] * a[6] * a[5] * a[4] * a[3] * a[2] * a[1] * a[0];
|
|
|
|
}, 0, 1, 40320);
|
|
|
|
|
|
|
|
test(function f1() {
|
|
|
|
return a[7] * a[6] * a[5] * a[4] * a[10] * a[2] * a[1] * a[0];
|
|
|
|
}, 0, 1, NaN);
|
|
|
|
|
|
|
|
test(function f2() {
|
|
|
|
return a[0] * a[1] * a[2] * a[3] * a[4] * a[5] * a[6] * a[7];
|
|
|
|
}, 0, 1, 40320);
|
|
|
|
|
|
|
|
test(function f3() {
|
|
|
|
return a[3] * a[0] * a[6] * a[7] * a[5] * a[1] * a[4] * a[2];
|
|
|
|
}, 0, 1, 40320);
|
|
|
|
|
|
|
|
test(function f4(b) {
|
|
|
|
return a[b+3] * a[0] * a[b+6] * a[7] * a[b+5] * a[1] * a[b+4] * a[2];
|
|
|
|
}, 0, 1, 40320);
|
|
|
|
|
|
|
|
test(function f5(b) {
|
|
|
|
return a[b+1] * a[0] * a[b+4] * a[7] * a[b+3] * a[1] * a[b+2] * a[2];
|
|
|
|
}, 2, 3, 40320);
|
|
|
|
|
|
|
|
test(function f6(b) {
|
|
|
|
var c;
|
|
|
|
if (b) c = a[3] * a[0] * a[6] * a[7];
|
|
|
|
return c * a[5] * a[1] * a[4] * a[2];
|
|
|
|
}, true, false, 40320);
|
|
|
|
|
|
|
|
test(function f7(b) {
|
|
|
|
var c = a[7];
|
|
|
|
if (b) c *= a[3] * a[0] * a[6];
|
|
|
|
return c * a[5] * a[1] * a[4] * a[2];
|
|
|
|
}, true, false, 40320);
|
|
|
|
|
|
|
|
test(function f8(b) {
|
|
|
|
var c = a[7];
|
|
|
|
if (b) c *= a[3] * a[0] * a[6];
|
|
|
|
return c * a[5] * a[10] * a[4] * a[2];
|
|
|
|
}, true, false, NaN);
|
|
|
|
|
|
|
|
test(function f9(b) {
|
|
|
|
var c = a[1];
|
|
|
|
if (b) {
|
|
|
|
c *= a[3] * a[0] * a[6];
|
|
|
|
} else {
|
|
|
|
c = a[6] * a[5] * a[4];
|
|
|
|
}
|
|
|
|
return c * a[5] * a[7] * a[4] * a[2];
|
|
|
|
}, true, false, 40320);
|
|
|
|
|
|
|
|
test(function fa(b) {
|
|
|
|
var c = a[1];
|
|
|
|
if (b) {
|
|
|
|
c = a[6] * a[b+5] * a[4];
|
|
|
|
} else {
|
|
|
|
c *= a[b+3] * a[0] * a[b+6];
|
|
|
|
}
|
|
|
|
return c * a[5] * a[b+7] * a[4] * a[2];
|
|
|
|
}, 0, 1, 40320);
|
|
|
|
|
|
|
|
test(function fb(b) {
|
|
|
|
var c = a[b-3];
|
|
|
|
if (b != 4) {
|
|
|
|
c = a[6] * a[b+1] * a[4];
|
|
|
|
} else {
|
|
|
|
c *= a[b-1] * a[0] * a[b+2];
|
|
|
|
}
|
|
|
|
return c * a[5] * a[b+3] * a[4] * a[b-2];
|
|
|
|
}, 4, 3, 40320);
|
|
|
|
|
|
|
|
test(function fc(b) {
|
|
|
|
var c = a[b-3];
|
|
|
|
if (b != 4) {
|
|
|
|
c = a[6] * a[b+1] * a[4];
|
|
|
|
} else {
|
|
|
|
c *= a[b-1] * a[0] * a[b+2];
|
|
|
|
}
|
|
|
|
return c * a[5] * a[b+3] * a[4] * a[b-2];
|
|
|
|
}, 6, 3, NaN);
|
|
|
|
|
|
|
|
test(function fd(b) {
|
|
|
|
var c = a[b-3];
|
|
|
|
if (b != 4) {
|
|
|
|
c = a[6] * a[b+1] * a[4];
|
|
|
|
} else {
|
|
|
|
c *= a[b-1] * a[0] * a[b+2];
|
|
|
|
}
|
|
|
|
return c * a[5] * a[b+3] * a[4] * a[b-2];
|
|
|
|
}, 1, 4, NaN);
|
|
|
|
|
|
|
|
test(function fe(b) {
|
|
|
|
var c = 1;
|
|
|
|
for (var i = 1; i < b-1; i++) {
|
|
|
|
c *= a[i-1] * a[i] * a[i+1];
|
|
|
|
}
|
|
|
|
return c;
|
|
|
|
}, 8, 4, (40320 / 8 / 7) * (40320 / 8) * (40320 / 2));
|
|
|
|
|
|
|
|
test(function ff(b) {
|
|
|
|
var c = 0;
|
|
|
|
for (var i = 0; i < b; i++) {
|
|
|
|
c += a[3] * a[0] * a[6] * a[7] * a[5] * a[1] * a[4] * a[2];
|
|
|
|
}
|
|
|
|
return c;
|
|
|
|
}, 100, 4, 40320 * 100);
|