OLD | NEW |
| (Empty) |
1 /* | |
2 ********************************************************************** | |
3 * Copyright (C) 1999-2003, International Business Machines | |
4 * Corporation and others. All Rights Reserved. | |
5 ********************************************************************** | |
6 * Date Name Description | |
7 * 12/09/99 aliu Ported from Java. | |
8 ********************************************************************** | |
9 */ | |
10 | |
11 #ifndef COLLATIONTHAITEST_H | |
12 #define COLLATIONTHAITEST_H | |
13 | |
14 #include "unicode/utypes.h" | |
15 | |
16 #if !UCONFIG_NO_COLLATION | |
17 | |
18 #include "tscoll.h" | |
19 | |
20 class CollationThaiTest : public IntlTestCollator { | |
21 Collator* coll; // Thai collator | |
22 | |
23 public: | |
24 | |
25 CollationThaiTest(); | |
26 virtual ~CollationThaiTest(); | |
27 | |
28 void runIndexedTest( int32_t index, UBool exec, const char* &name, char* par
= NULL ); | |
29 | |
30 private: | |
31 | |
32 /** | |
33 * Read the external dictionary file, which is already in proper | |
34 * sorted order, and confirm that the collator compares each line as | |
35 * preceding the following line. | |
36 */ | |
37 void TestDictionary(void); | |
38 | |
39 /** | |
40 * Odd corner conditions taken from "How to Sort Thai Without Rewriting Sort
", | |
41 * by Doug Cooper, http://seasrc.th.net/paper/thaisort.zip | |
42 */ | |
43 void TestCornerCases(void); | |
44 | |
45 /** | |
46 * Read the external names list, and confirms that the collator | |
47 * gets the same results when comparing lines one to another | |
48 * using regular and iterative comparison. | |
49 */ | |
50 void TestNamesList(void); | |
51 | |
52 /** | |
53 * test that invalid Thai sorts properly | |
54 */ | |
55 void TestInvalidThai(void); | |
56 | |
57 /** | |
58 * test that reording is done properly | |
59 */ | |
60 void TestReordering(void); | |
61 | |
62 private: | |
63 | |
64 void compareArray(Collator& c, const char* tests[], | |
65 int32_t testsLength); | |
66 | |
67 int8_t sign(int32_t i); | |
68 | |
69 /** | |
70 * Set a UnicodeString corresponding to the given string. Use | |
71 * UnicodeString and the default converter, unless we see the sequence | |
72 * "\\u", in which case we interpret the subsequent escape. | |
73 */ | |
74 UnicodeString& parseChars(UnicodeString& result, | |
75 const char* chars); | |
76 }; | |
77 | |
78 #endif /* #if !UCONFIG_NO_COLLATION */ | |
79 | |
80 #endif | |
OLD | NEW |