/*
* Copyright (c) 2008, Oracle and/or its affiliates. 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 4888843
* @summary verify that surrogate pairs representing codepoints with R or AL directionality
* and correctly recognized and reordered.
*/
import java.text.Bidi;
public class BidiSurrogateTest {
private static final String RTLS = new String(Character.toChars(0x10800)); // surrogate code point with R directionality
private static final String LTRS = new String(Character.toChars(0x107ff)); // surrogate code point with L directionality
private static final String LRE = "\u202a";
private static final String RLE = "\u202b";
private static final String PDF = "\u202c";
public static void main(String[] args) {
new BidiSurrogateTest().test();
}
void test() {
test0();
test1();
}
void test0() {
// test unpaired surrogates - should have L directionality
testRequiresBidi("\ud800", false); // unpaired lead surrogate
testRequiresBidi("\udc00", false); // unpaired trail surrogate
testRequiresBidi("\udc00\ud800", false); // out of order surrogates
testRequiresBidi("a\udc00b\ud800c", false); // out of order surrogates split
testRequiresBidi(LTRS, false); // supplementary with L
testRequiresBidi(RTLS, true); // supplementary with R
testRequiresBidi("a" + RTLS + "b", true); // R supplementary in LTR text
testRequiresBidi(LTRS + RTLS, true); // R supplementary in LTR supplementary text
testRequiresBidi(LRE, false); // LRE lone embedding
testRequiresBidi(RLE, true); // RLE lone embedding
testRequiresBidi(PDF, false); // PDF lone pop embedding
}
void testRequiresBidi(String string, boolean requiresBidi) {
char[] text = string.toCharArray();
if (Bidi.requiresBidi(text, 0, text.length) != requiresBidi) {
throw new RuntimeException("testRequiresBidi failed with '" + string + "', " + requiresBidi);
}
}
void test1() {
// test that strings with surrogate runs process surrogate directionality ok
testBidi("This is a string with " + LTRS + " in it.", false);
testBidi("This is a string with \ud800 in it.", false);
testBidi("This is a string with \u0640 in it.", 22, 1);
testBidi(RTLS, true);
testBidi("This is a string with " + RTLS + RTLS + RTLS + " in it.", 22, 6);
}
void testBidi(String string, boolean directionIsRTL) {
Bidi bidi = new Bidi(string, Bidi.DIRECTION_DEFAULT_LEFT_TO_RIGHT);
if (bidi.isMixed()) {
throw new RuntimeException("bidi is mixed");
}
if (bidi.isRightToLeft() != directionIsRTL) {
throw new RuntimeException("bidi is not " + (directionIsRTL ? "rtl" : "ltr"));
}
}
void testBidi(String string, int rtlstart, int rtllength) {
Bidi bidi = new Bidi(string, Bidi.DIRECTION_DEFAULT_LEFT_TO_RIGHT);
for (int i = 0; i < bidi.getRunCount(); ++i) {
if ((bidi.getRunLevel(i) & 1) != 0) {
if (bidi.getRunStart(i) != rtlstart ||
bidi.getRunLimit(i) != rtlstart + rtllength) {
throw new RuntimeException("first rtl run didn't match " + rtlstart + ", " + rtllength);
}
break;
}
}
}
}