mirror of
				https://github.com/tc39/test262.git
				synced 2025-10-31 11:44:31 +01:00 
			
		
		
		
	sourceRevisionAtLastExport: 33f2fb0e53d135f0ee17cfccd9d993eb2a6f47de targetRevisionAtLastExport: 31340cbd9add103f586d501b0c3354b7b182abc0
		
			
				
	
	
		
			124 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			124 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| // 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.
 | |
| 
 | |
| // Flags: --allow-natives-syntax
 | |
| 
 | |
| var a = []
 | |
| for (var i = 0; i < 9; i++) a[i] = i + 1;
 | |
| 
 | |
| function test(f, arg1, arg2, expected) {
 | |
|   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);
 |