/* * Copyright (c) 2009 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, * CA 95054 USA or visit www.sun.com if you need additional information or * have any questions. */ /* * @test * @bug 6842557 * @summary confirm that shaping works as expected. (Mainly for new characters which were added in Unicode 5) * used where appropriate. */ import java.awt.font.NumericShaper; import java.util.EnumSet; import static java.awt.font.NumericShaper.*; public class ShapingTest { public static void main(String[] args) { NumericShaper ns_old = getContextualShaper(ARABIC | TAMIL | ETHIOPIC, EUROPEAN); NumericShaper ns_new = getContextualShaper(EnumSet.of( Range.ARABIC, Range.TAMIL, Range.ETHIOPIC), Range.EUROPEAN); boolean err = false; String[][] data = { // Arabic "October 10" {"\u0623\u0643\u062a\u0648\u0628\u0631 10", "\u0623\u0643\u062a\u0648\u0628\u0631 \u0661\u0660"}, // Tamil "Year 2009" {"\u0b86\u0ba3\u0bcd\u0b9f\u0bc1 2009", "\u0b86\u0ba3\u0bcd\u0b9f\u0bc1 \u0be8\u0be6\u0be6\u0bef"}, // "\u0be800\u0bef is returned by pre-JDK7 because Tamil zero was not // included in Unicode 4.0.0. // Ethiopic "Syllable 2009" {"\u1200 2009", "\u1200 \u136a00\u1371"}, // Ethiopic zero doesn't exist even in Unicode 5.1.0. }; for (int i = 0; i < data.length; i++) { String expected = data[i][1]; char[] text = data[i][0].toCharArray(); ns_old.shape(text, 0, text.length); String got = new String(text); if (!expected.equals(got)) { err = true; System.err.println("Error with traditional range."); System.err.println(" text = " + data[i][0]); System.err.println(" got = " + got); System.err.println(" expected = " + expected); } else { System.err.println("OK with traditional range."); System.err.println(" text = " + data[i][0]); System.err.println(" got = " + got); System.err.println(" expected = " + expected); } text = data[i][0].toCharArray(); ns_new.shape(text, 0, text.length); got = new String(text); if (!expected.equals(got)) { err = true; System.err.println("Error with new Enum range."); System.err.println(" text = " + data[i][0]); System.err.println(" got = " + got); System.err.println(" expected = " + expected); } else { System.err.println("OK with new Enum range."); System.err.println(" text = " + data[i][0]); System.err.println(" got = " + got); System.err.println(" expected = " + expected); } } if (err) { throw new RuntimeException("shape() returned unexpected value."); } } }