// © 2016 and later: Unicode, Inc. and others. // License & terms of use: http://www.unicode.org/copyright.html /******************************************************************** * COPYRIGHT: * Copyright (c) 1997-2009, International Business Machines Corporation and * others. All Rights Reserved. ********************************************************************/ #include "unicode/utypes.h" #if !UCONFIG_NO_COLLATION #include "decoll.h" #ifndef _COLL #include "unicode/coll.h" #endif #ifndef _TBLCOLL #include "unicode/tblcoll.h" #endif #ifndef _UNISTR #include "unicode/unistr.h" #endif #ifndef _SORTKEY #include "unicode/sortkey.h" #endif #ifndef _DECOLL #include "decoll.h" #endif #include "sfwdchit.h" CollationGermanTest::CollationGermanTest() : myCollation(0) { UErrorCode status = U_ZERO_ERROR; myCollation = Collator::createInstance(Locale::getGermany(), status); if(!myCollation || U_FAILURE(status)) { errcheckln(status, __FILE__ "failed to create! err " + UnicodeString(u_errorName(status))); /* if it wasn't already: */ delete myCollation; myCollation = NULL; } } CollationGermanTest::~CollationGermanTest() { delete myCollation; } const UChar CollationGermanTest::testSourceCases[][CollationGermanTest::MAX_TOKEN_LEN] = { {0x47, 0x72, 0x00F6, 0x00DF, 0x65, 0}, {0x61, 0x62, 0x63, 0}, {0x54, 0x00F6, 0x6e, 0x65, 0}, {0x54, 0x00F6, 0x6e, 0x65, 0}, {0x54, 0x00F6, 0x6e, 0x65, 0}, {0x61, 0x0308, 0x62, 0x63, 0}, {0x00E4, 0x62, 0x63, 0}, {0x00E4, 0x62, 0x63, 0}, {0x53, 0x74, 0x72, 0x61, 0x00DF, 0x65, 0}, {0x65, 0x66, 0x67, 0}, {0x00E4, 0x62, 0x63, 0}, {0x53, 0x74, 0x72, 0x61, 0x00DF, 0x65, 0} }; const UChar CollationGermanTest::testTargetCases[][CollationGermanTest::MAX_TOKEN_LEN] = { {0x47, 0x72, 0x6f, 0x73, 0x73, 0x69, 0x73, 0x74, 0}, {0x61, 0x0308, 0x62, 0x63, 0}, {0x54, 0x6f, 0x6e, 0}, {0x54, 0x6f, 0x64, 0}, {0x54, 0x6f, 0x66, 0x75, 0}, {0x41, 0x0308, 0x62, 0x63, 0}, {0x61, 0x0308, 0x62, 0x63, 0}, {0x61, 0x65, 0x62, 0x63, 0}, {0x53, 0x74, 0x72, 0x61, 0x73, 0x73, 0x65, 0}, {0x65, 0x66, 0x67, 0}, {0x61, 0x65, 0x62, 0x63, 0}, {0x53, 0x74, 0x72, 0x61, 0x73, 0x73, 0x65, 0} }; const Collator::EComparisonResult CollationGermanTest::results[][2] = { // Primary Tertiary { Collator::LESS, Collator::LESS }, { Collator::EQUAL, Collator::LESS }, { Collator::GREATER, Collator::GREATER }, { Collator::GREATER, Collator::GREATER }, { Collator::GREATER, Collator::GREATER }, { Collator::EQUAL, Collator::LESS }, { Collator::EQUAL, Collator::EQUAL }, { Collator::LESS, Collator::LESS }, { Collator::EQUAL, Collator::GREATER }, { Collator::EQUAL, Collator::EQUAL }, { Collator::LESS, Collator::LESS }, { Collator::EQUAL, Collator::GREATER } }; void CollationGermanTest::TestTertiary(/* char* par */) { if(myCollation == NULL ) { dataerrln("decoll: cannot start test, collator is null\n"); return; } int32_t i = 0; UErrorCode status = U_ZERO_ERROR; myCollation->setStrength(Collator::TERTIARY); myCollation->setAttribute(UCOL_NORMALIZATION_MODE, UCOL_ON, status); for (i = 0; i < 12 ; i++) { doTest(myCollation, testSourceCases[i], testTargetCases[i], results[i][1]); } } void CollationGermanTest::TestPrimary(/* char* par */) { if(myCollation == NULL ) { dataerrln("decoll: cannot start test, collator is null\n"); return; } int32_t i; UErrorCode status = U_ZERO_ERROR; myCollation->setStrength(Collator::PRIMARY); myCollation->setAttribute(UCOL_NORMALIZATION_MODE, UCOL_ON, status); for (i = 0; i < 12 ; i++) { doTest(myCollation, testSourceCases[i], testTargetCases[i], results[i][0]); } } void CollationGermanTest::runIndexedTest( int32_t index, UBool exec, const char* &name, char* /*par*/ ) { if (exec) logln("TestSuite CollationGermanTest: "); switch (index) { case 0: name = "TestPrimary"; if (exec) TestPrimary(/* par */); break; case 1: name = "TestTertiary"; if (exec) TestTertiary(/* par */); break; default: name = ""; break; } } #endif /* #if !UCONFIG_NO_COLLATION */