1 /*
   2  * Copyright (c) 2010, 2013, Oracle and/or its affiliates. All rights reserved.
   3  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
   4  *
   5  * This code is free software; you can redistribute it and/or modify it
   6  * under the terms of the GNU General Public License version 2 only, as
   7  * published by the Free Software Foundation.
   8  *
   9  * This code is distributed in the hope that it will be useful, but WITHOUT
  10  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  11  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
  12  * version 2 for more details (a copy is included in the LICENSE file that
  13  * accompanied this code).
  14  *
  15  * You should have received a copy of the GNU General Public License version
  16  * 2 along with this work; if not, write to the Free Software Foundation,
  17  * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
  18  *
  19  * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
  20  * or visit www.oracle.com if you need additional information or have any
  21  * questions.
  22  */
  23 
  24 /*
  25  * NASHORN-474 : long index support for sparse arrays.
  26  *
  27  * @test
  28  * @run
  29  */
  30 
  31 var a = [];
  32 a[1] = 2;
  33 a[420000000] = 42;
  34 a[-1] = 13;
  35 
  36 print([a[420000000], a[1], a[-1]]);
  37 print(a.length);
  38 
  39 var b = [];
  40 b[0xfffffffe] = 0xfe;
  41 b[0xffffffff] = 0xff;
  42 b[-1] = -13;
  43 print([b[4294967294], b[4294967295], b[-1]]);
  44 print(b.length);
  45 
  46 var c = [,1];
  47 c[0x8ffffff0] = 2;
  48 c[0x8ffffff1] = 3;
  49 c[0x8fffffef] = 4;
  50 c[0] = 5;
  51 c[2] = 6;
  52 c[0x8ffffff3] = 7;
  53 print([c[0],c[1],c[2]] + ";" + [c[0x8fffffef],c[0x8ffffff0],c[0x8ffffff1],c[0x8ffffff2],c[0x8ffffff3]]);
  54 print(c.length);