test/script/basic/NASHORN-258.js

changeset 0
b1a7da25b547
child 952
6d5471a497fb
     1.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     1.2 +++ b/test/script/basic/NASHORN-258.js	Wed Apr 27 01:36:41 2016 +0800
     1.3 @@ -0,0 +1,79 @@
     1.4 +/*
     1.5 + * Copyright (c) 2010, 2013, Oracle and/or its affiliates. All rights reserved.
     1.6 + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
     1.7 + * 
     1.8 + * This code is free software; you can redistribute it and/or modify it
     1.9 + * under the terms of the GNU General Public License version 2 only, as
    1.10 + * published by the Free Software Foundation.
    1.11 + * 
    1.12 + * This code is distributed in the hope that it will be useful, but WITHOUT
    1.13 + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
    1.14 + * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
    1.15 + * version 2 for more details (a copy is included in the LICENSE file that
    1.16 + * accompanied this code).
    1.17 + * 
    1.18 + * You should have received a copy of the GNU General Public License version
    1.19 + * 2 along with this work; if not, write to the Free Software Foundation,
    1.20 + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
    1.21 + * 
    1.22 + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
    1.23 + * or visit www.oracle.com if you need additional information or have any
    1.24 + * questions.
    1.25 + */
    1.26 +
    1.27 +/**
    1.28 + * NASHORN-258 : Broken slot assignments to non constant members of multidimensional arrays in OP=
    1.29 + *
    1.30 + * @test
    1.31 + * @run
    1.32 + */
    1.33 +
    1.34 +function test3(a) {
    1.35 +    for (i = 0; i < a.length ; i++) {
    1.36 +	for (j = 0; j < a[i].length ; j++) {
    1.37 +	    for (k = 0; k < a[i][j].length ; k++) {
    1.38 +		a[i][j][k] *= 8;
    1.39 +	    }
    1.40 +	}
    1.41 +    }
    1.42 +}
    1.43 +
    1.44 +function test3local(a) {
    1.45 +    for (var i = 0; i < a.length ; i++) {
    1.46 +	for (var j = 0; j < a[i].length ; j++) {
    1.47 +	    for (var k = 0; k < a[i][j].length ; k++) {
    1.48 +		a[i][j][k] *= 8;
    1.49 +	    }
    1.50 +	}
    1.51 +    }
    1.52 +}
    1.53 +
    1.54 +var array = [ [[1,1,1],[1,1,1],[1,1,1]],
    1.55 +	      [[1,1,1],[1,1,1],[1,1,1]],
    1.56 +	      [[1,1,1],[1,1,1],[1,1,1]] ];
    1.57 +	      
    1.58 +test3(array);
    1.59 +print(array);
    1.60 +
    1.61 +test3local(array);
    1.62 +print(array);
    1.63 +
    1.64 +function outer() {
    1.65 +    
    1.66 +    var array2 = [ [[1,1,1],[1,1,1],[1,1,1]],
    1.67 +		   [[1,1,1],[1,1,1],[1,1,1]],
    1.68 +		   [[1,1,1],[1,1,1],[1,1,1]] ];
    1.69 +    
    1.70 +    var f =  function inner() {
    1.71 +	for (var i = 0; i < array2.length ; i++) {
    1.72 +	    for (var j = 0; j < array2[i].length ; j++) {
    1.73 +		array2[i][j][2] *= 8;
    1.74 +	    }
    1.75 +	}	
    1.76 +    };
    1.77 +
    1.78 +    f();
    1.79 +    print(array2);
    1.80 +}
    1.81 +
    1.82 +outer();

mercurial