OLD | NEW |
(Empty) | |
| 1 /* |
| 2 ******************************************************************************* |
| 3 * |
| 4 * Copyright (C) 2001-2008, International Business Machines |
| 5 * Corporation and others. All Rights Reserved. |
| 6 * |
| 7 ******************************************************************************* |
| 8 * file name: casetrn.h |
| 9 * encoding: US-ASCII |
| 10 * tab size: 8 (not used) |
| 11 * indentation:4 |
| 12 * |
| 13 * created on: 2004sep03 |
| 14 * created by: Markus W. Scherer |
| 15 * |
| 16 * Implementation class for lower-/upper-/title-casing transliterators. |
| 17 */ |
| 18 |
| 19 #ifndef __CASETRN_H__ |
| 20 #define __CASETRN_H__ |
| 21 |
| 22 #include "unicode/utypes.h" |
| 23 |
| 24 #if !UCONFIG_NO_TRANSLITERATION |
| 25 |
| 26 #include "unicode/translit.h" |
| 27 #include "ucase.h" |
| 28 |
| 29 U_NAMESPACE_BEGIN |
| 30 |
| 31 /** |
| 32 * A transliterator that performs locale-sensitive |
| 33 * case mapping. |
| 34 */ |
| 35 class CaseMapTransliterator : public Transliterator { |
| 36 public: |
| 37 /** |
| 38 * Constructs a transliterator. |
| 39 * @param loc the given locale. |
| 40 * @param id the transliterator ID. |
| 41 * @param map the full case mapping function (see ucase.h) |
| 42 */ |
| 43 CaseMapTransliterator(const UnicodeString &id, UCaseMapFull *map); |
| 44 |
| 45 /** |
| 46 * Destructor. |
| 47 */ |
| 48 virtual ~CaseMapTransliterator(); |
| 49 |
| 50 /** |
| 51 * Copy constructor. |
| 52 */ |
| 53 CaseMapTransliterator(const CaseMapTransliterator&); |
| 54 |
| 55 /** |
| 56 * Transliterator API. |
| 57 * @return a copy of the object. |
| 58 */ |
| 59 virtual Transliterator* clone(void) const = 0; |
| 60 |
| 61 /** |
| 62 * ICU "poor man's RTTI", returns a UClassID for the actual class. |
| 63 */ |
| 64 //virtual UClassID getDynamicClassID() const; |
| 65 |
| 66 /** |
| 67 * ICU "poor man's RTTI", returns a UClassID for this class. |
| 68 */ |
| 69 U_I18N_API static UClassID U_EXPORT2 getStaticClassID(); |
| 70 |
| 71 protected: |
| 72 /** |
| 73 * Implements {@link Transliterator#handleTransliterate}. |
| 74 * @param text the buffer holding transliterated and |
| 75 * untransliterated text |
| 76 * @param offset the start and limit of the text, the position |
| 77 * of the cursor, and the start and limit of transliterat
ion. |
| 78 * @param incremental if true, assume more text may be coming after |
| 79 * pos.contextLimit. Otherwise, assume the text is compl
ete. |
| 80 */ |
| 81 virtual void handleTransliterate(Replaceable& text, |
| 82 UTransPosition& offsets, |
| 83 UBool isIncremental) const; |
| 84 |
| 85 const UCaseProps *fCsp; |
| 86 UCaseMapFull *fMap; |
| 87 |
| 88 private: |
| 89 /** |
| 90 * Assignment operator. |
| 91 */ |
| 92 CaseMapTransliterator& operator=(const CaseMapTransliterator&); |
| 93 |
| 94 }; |
| 95 |
| 96 U_NAMESPACE_END |
| 97 |
| 98 /** case context iterator using a Replaceable. This must be a C function because
it is a callback. */ |
| 99 U_CFUNC UChar32 U_CALLCONV |
| 100 utrans_rep_caseContextIterator(void *context, int8_t dir); |
| 101 |
| 102 #endif /* #if !UCONFIG_NO_TRANSLITERATION */ |
| 103 |
| 104 #endif |
OLD | NEW |