/* * Copyright (c) 2024, Intel Corporation. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions. */ /* * @test * @bug 8320448 * @summary test String indexOf() intrinsic * @run driver IndexOf */ /* * @test * @bug 8320448 * @summary test String indexOf() intrinsic * @requires vm.cpu.features ~= ".*avx2.*" * @requires vm.compiler2.enabled * @run main/othervm -XX:+IgnoreUnrecognizedVMOptions -Xcomp -XX:-TieredCompilation -XX:UseAVX=2 -XX:+UnlockDiagnosticVMOptions -XX:+EnableX86ECoreOpts -XX:-CheckJNICalls IndexOf */ public class IndexOf { final int scope = 32*2+16+8; final char a, aa, b, c, d; enum Encoding {LL, UU, UL; } final Encoding ae; int failures; IndexOf(Encoding _ae) { failures = 0; ae = _ae; switch (ae) { case LL: a = 'a'; aa = a; b = 'b'; c = 'c'; d = 'd'; break; case UU: a = '\u0061'; aa = a; b = '\u0062'; c = '\u1063'; d = '\u0064'; break; default: //case UL: a = 'a'; aa = '\u1061'; b = 'b'; c = 'c'; d = 'd'; break; } } // needle =~ /ab*d/ // badNeedle =~ /ab*db*d/ interface Append {void append(int pos, char cc);} String newNeedle(int size, int badPosition) { if (size<2) {throw new RuntimeException("Fix testcase "+size);} StringBuilder needle = new StringBuilder(size); Append n = (int pos, char cc) -> { if (pos == badPosition) needle.append(c); else needle.append(cc); }; n.append(0, a); for (int i=1; isize) {throw new RuntimeException("Fix testcase "+nPosition+" "+needle.length()+" "+size);} StringBuilder haystack = new StringBuilder(size); int i = 0; for (; isize) {throw new RuntimeException("Fix testcase "+nPosition+" "+needle.length()+" "+size);} StringBuilder haystack = new StringBuilder(size); int i = 0; for (; ihaystack_len) return -1; if (-1 != "Hello".indexOf("HelloWorld", 3)) { System.out.println("FAILED: if (needle_len>haystack_len) return -1"); failures++; } return this; } IndexOf test1() { // Test expected to find one needle for (int nSize = 2; nSize