/* ********************************************************************** * Copyright (C) 1999-2003, International Business Machines * Corporation and others. All Rights Reserved. ********************************************************************** * Date Name Description * 12/09/99 aliu Ported from Java. ********************************************************************** */ #ifndef COLLATIONTHAITEST_H #define COLLATIONTHAITEST_H #include "unicode/utypes.h" #if !UCONFIG_NO_COLLATION #include "tscoll.h" class CollationThaiTest : public IntlTestCollator { Collator* coll; // Thai collator public: CollationThaiTest(); virtual ~CollationThaiTest(); void runIndexedTest( int32_t index, UBool exec, const char* &name, char* par = NULL ); private: /** * Read the external dictionary file, which is already in proper * sorted order, and confirm that the collator compares each line as * preceding the following line. */ void TestDictionary(void); /** * Odd corner conditions taken from "How to Sort Thai Without Rewriting Sort", * by Doug Cooper, http://seasrc.th.net/paper/thaisort.zip */ void TestCornerCases(void); /** * Read the external names list, and confirms that the collator * gets the same results when comparing lines one to another * using regular and iterative comparison. */ void TestNamesList(void); /** * test that invalid Thai sorts properly */ void TestInvalidThai(void); /** * test that reording is done properly */ void TestReordering(void); private: void compareArray(Collator& c, const char* tests[], int32_t testsLength); int8_t sign(int32_t i); /** * Set a UnicodeString corresponding to the given string. Use * UnicodeString and the default converter, unless we see the sequence * "\\u", in which case we interpret the subsequent escape. */ UnicodeString& parseChars(UnicodeString& result, const char* chars); }; #endif /* #if !UCONFIG_NO_COLLATION */ #endif