ICU-8277 change interpretation of Zzzz in the collation reordering codes

X-SVN-Rev: 29365
This commit is contained in:
Stuart Gill 2011-01-27 20:56:28 +00:00
parent 37bf7cf633
commit ff9448fe98
2 changed files with 29 additions and 154 deletions

View File

@ -1,6 +1,6 @@
/**
*******************************************************************************
* Copyright (C) 1996-2010, International Business Machines Corporation and *
* Copyright (C) 1996-2011, International Business Machines Corporation and *
* others. All Rights Reserved. *
*******************************************************************************
*/
@ -3835,7 +3835,9 @@ public final class RuleBasedCollator extends Collator {
* be moved are copied to their same location in the final table.
*/
boolean fromTheBottom = true;
for (int reorderCodesIndex = 0; reorderCodesIndex < internalReorderCodes.length; reorderCodesIndex++) {
int reorderCodesIndex = -1;
for (int reorderCodesCount = 0; reorderCodesCount < internalReorderCodes.length; reorderCodesCount++) {
reorderCodesIndex += fromTheBottom ? 1 : -1;
int next = internalReorderCodes[reorderCodesIndex];
if (next == UCOL_REORDER_CODE_IGNORE) {
continue;
@ -3847,6 +3849,7 @@ public final class RuleBasedCollator extends Collator {
throw new IllegalArgumentException("Illegal collation reorder codes - two \"from the end\" markers.");
}
fromTheBottom = false;
reorderCodesIndex = internalReorderCodes.length;
continue;
}

View File

@ -1,7 +1,7 @@
/*
*******************************************************************************
* Copyright (C) 2002-2010, International Business Machines Corporation and *
* Copyright (C) 2002-2011, International Business Machines Corporation and *
* others. All Rights Reserved. *
*******************************************************************************
*/
@ -3064,157 +3064,6 @@ public class CollationMiscTest extends TestFmwk {
}
}
// public void TestGreekFirstReorder(){
// String[] testSourceCases = {
// "\u0041",
// "\u03b1\u0041",
// "\u0061",
// "\u0041\u0061",
// "\u0391",
// };
//
// String[] testTargetCases = {
// "\u03b1",
// "\u0041\u03b1",
// "\u0391",
// "\u0391\u03b1",
// "\u0391",
// };
//
// int[] results = {
// 1,
// -1,
// 1,
// 1,
// 0
// };
//
// Collator myCollation;
// String rules = "[reorder Grek]";
// try {
// myCollation = new RuleBasedCollator(rules);
// } catch (Exception e) {
// warnln("ERROR: in creation of rule based collator");
// return;
// }
// myCollation.setDecomposition(Collator.CANONICAL_DECOMPOSITION);
// myCollation.setStrength(Collator.TERTIARY);
// for (int i = 0; i < testSourceCases.length; i++)
// {
// CollationTest.doTest(this, (RuleBasedCollator)myCollation,
// testSourceCases[i], testTargetCases[i],
// results[i]);
// }
//
// try {
// myCollation = new RuleBasedCollator("");
// } catch (Exception e) {
// warnln("ERROR: in creation of rule based collator");
// return;
// }
// myCollation.setDecomposition(Collator.CANONICAL_DECOMPOSITION);
// myCollation.setStrength(Collator.TERTIARY);
// myCollation.setScriptOrder(new int[]{UScript.GREEK});
// for (int i = 0; i < testSourceCases.length; i++)
// {
// CollationTest.doTest(this, (RuleBasedCollator)myCollation,
// testSourceCases[i], testTargetCases[i],
// results[i]);
// }
//
// try {
// myCollation = new RuleBasedCollator("");
// } catch (Exception e) {
// warnln("ERROR: in creation of rule based collator");
// return;
// }
// myCollation.setDecomposition(Collator.CANONICAL_DECOMPOSITION);
// myCollation.setStrength(Collator.TERTIARY);
// myCollation.setScriptOrder(UScript.GREEK);
// for (int i = 0; i < testSourceCases.length; i++)
// {
// CollationTest.doTest(this, (RuleBasedCollator)myCollation,
// testSourceCases[i], testTargetCases[i],
// results[i]);
// }
// }
//
// public void TestUnknownReorder(){
// String[] testSourceCases = {
// "\u0041",
// "\u0041",
// "\u0031",
// "\u0391",
// "\u0031",
// };
//
// String[] testTargetCases = {
// "\u03b1",
// "\u0031",
// "\u0391",
// "\u099d",
// "\u0032",
// };
//
// int[] results = {
// -1,
// 1,
// 1,
// -1,
// -1
// };
//
// Collator myCollation;
// String rules = "[reorder Latn Zzzz Zyyy]";
// try {
// myCollation = new RuleBasedCollator(rules);
// } catch (Exception e) {
// warnln("ERROR: in creation of rule based collator");
// return;
// }
// myCollation.setDecomposition(Collator.CANONICAL_DECOMPOSITION);
// myCollation.setStrength(Collator.TERTIARY);
// for (int i = 0; i < testSourceCases.length ; i++)
// {
// CollationTest.doTest(this, (RuleBasedCollator)myCollation,
// testSourceCases[i], testTargetCases[i],
// results[i]);
// }
//
// try {
// myCollation = new RuleBasedCollator("");
// } catch (Exception e) {
// warnln("ERROR: in creation of rule based collator");
// return;
// }
// myCollation.setDecomposition(Collator.CANONICAL_DECOMPOSITION);
// myCollation.setStrength(Collator.TERTIARY);
// myCollation.setScriptOrder(new int[]{UScript.LATIN, UScript.UNKNOWN, UScript.COMMON});
// for (int i = 0; i < testSourceCases.length ; i++)
// {
// CollationTest.doTest(this, (RuleBasedCollator)myCollation,
// testSourceCases[i], testTargetCases[i],
// results[i]);
// }
//
// try {
// myCollation = new RuleBasedCollator("");
// } catch (Exception e) {
// warnln("ERROR: in creation of rule based collator");
// return;
// }
// myCollation.setDecomposition(Collator.CANONICAL_DECOMPOSITION);
// myCollation.setStrength(Collator.TERTIARY);
// myCollation.setScriptOrder(UScript.LATIN, UScript.UNKNOWN, UScript.COMMON);
// for (int i = 0; i < testSourceCases.length ; i++)
// {
// CollationTest.doTest(this, (RuleBasedCollator)myCollation,
// testSourceCases[i], testTargetCases[i],
// results[i]);
// }
// }
/*
* This test ensures that characters placed before a character in a different script have the same lead byte
* in their collation key before and after script reordering.
@ -3627,4 +3476,27 @@ public class CollationMiscTest extends TestFmwk {
/* Test collation reordering API */
doTestOneReorderingAPITestCase(privateUseCharacterStrings, apiRules);
}
public void TestMultipleReorder()
{
String[] strRules = {
"[reorder Grek Zzzz DIGIT Latn Hani]"
};
int[] apiRules = {
UScript.GREEK, UScript.UNKNOWN, ReorderCodes.DIGIT, UScript.LATIN, UScript.HAN
};
OneTestCase[] collationTestCases = {
new OneTestCase("\u0391", "\u0041", -1),
new OneTestCase("\u0031", "\u0041", -1),
new OneTestCase("u0041", "\u4e00", -1),
};
/* Test rules creation */
doTestCollation(collationTestCases, strRules);
/* Test collation reordering API */
doTestOneReorderingAPITestCase(collationTestCases, apiRules);
}
}