Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1072)

Unified Diff: icu46/source/test/intltest/decoll.cpp

Issue 5516007: Check in the pristine copy of ICU 4.6... (Closed) Base URL: svn://chrome-svn/chrome/trunk/deps/third_party/
Patch Set: Created 10 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « icu46/source/test/intltest/decoll.h ('k') | icu46/source/test/intltest/dtfmapts.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: icu46/source/test/intltest/decoll.cpp
===================================================================
--- icu46/source/test/intltest/decoll.cpp (revision 0)
+++ icu46/source/test/intltest/decoll.cpp (revision 0)
@@ -0,0 +1,146 @@
+/********************************************************************
+ * 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 */
Property changes on: icu46/source/test/intltest/decoll.cpp
___________________________________________________________________
Added: svn:eol-style
+ LF
« no previous file with comments | « icu46/source/test/intltest/decoll.h ('k') | icu46/source/test/intltest/dtfmapts.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698