|
1 /* |
|
2 ********************************************************************** |
|
3 * Copyright (c) 2002-2011, International Business Machines Corporation |
|
4 * and others. All Rights Reserved. |
|
5 ********************************************************************** |
|
6 * Date Name Description |
|
7 * 02/04/2002 aliu Creation. |
|
8 ********************************************************************** |
|
9 */ |
|
10 |
|
11 #ifndef FUNCREPL_H |
|
12 #define FUNCREPL_H |
|
13 |
|
14 #include "unicode/utypes.h" |
|
15 |
|
16 #if !UCONFIG_NO_TRANSLITERATION |
|
17 |
|
18 #include "unicode/unifunct.h" |
|
19 #include "unicode/unirepl.h" |
|
20 |
|
21 U_NAMESPACE_BEGIN |
|
22 |
|
23 class Transliterator; |
|
24 |
|
25 /** |
|
26 * A replacer that calls a transliterator to generate its output text. |
|
27 * The input text to the transliterator is the output of another |
|
28 * UnicodeReplacer object. That is, this replacer wraps another |
|
29 * replacer with a transliterator. |
|
30 * |
|
31 * @author Alan Liu |
|
32 */ |
|
33 class FunctionReplacer : public UnicodeFunctor, public UnicodeReplacer { |
|
34 |
|
35 private: |
|
36 |
|
37 /** |
|
38 * The transliterator. Must not be null. OWNED. |
|
39 */ |
|
40 Transliterator* translit; |
|
41 |
|
42 /** |
|
43 * The replacer object. This generates text that is then |
|
44 * processed by 'translit'. Must not be null. OWNED. |
|
45 */ |
|
46 UnicodeFunctor* replacer; |
|
47 |
|
48 public: |
|
49 |
|
50 /** |
|
51 * Construct a replacer that takes the output of the given |
|
52 * replacer, passes it through the given transliterator, and emits |
|
53 * the result as output. |
|
54 */ |
|
55 FunctionReplacer(Transliterator* adoptedTranslit, |
|
56 UnicodeFunctor* adoptedReplacer); |
|
57 |
|
58 /** |
|
59 * Copy constructor. |
|
60 */ |
|
61 FunctionReplacer(const FunctionReplacer& other); |
|
62 |
|
63 /** |
|
64 * Destructor |
|
65 */ |
|
66 virtual ~FunctionReplacer(); |
|
67 |
|
68 /** |
|
69 * Implement UnicodeFunctor |
|
70 */ |
|
71 virtual UnicodeFunctor* clone() const; |
|
72 |
|
73 /** |
|
74 * UnicodeFunctor API. Cast 'this' to a UnicodeReplacer* pointer |
|
75 * and return the pointer. |
|
76 */ |
|
77 virtual UnicodeReplacer* toReplacer() const; |
|
78 |
|
79 /** |
|
80 * UnicodeReplacer API |
|
81 */ |
|
82 virtual int32_t replace(Replaceable& text, |
|
83 int32_t start, |
|
84 int32_t limit, |
|
85 int32_t& cursor); |
|
86 |
|
87 /** |
|
88 * UnicodeReplacer API |
|
89 */ |
|
90 virtual UnicodeString& toReplacerPattern(UnicodeString& rule, |
|
91 UBool escapeUnprintable) const; |
|
92 |
|
93 /** |
|
94 * Implement UnicodeReplacer |
|
95 */ |
|
96 virtual void addReplacementSetTo(UnicodeSet& toUnionTo) const; |
|
97 |
|
98 /** |
|
99 * UnicodeFunctor API |
|
100 */ |
|
101 virtual void setData(const TransliterationRuleData*); |
|
102 |
|
103 /** |
|
104 * ICU "poor man's RTTI", returns a UClassID for the actual class. |
|
105 */ |
|
106 virtual UClassID getDynamicClassID() const; |
|
107 |
|
108 /** |
|
109 * ICU "poor man's RTTI", returns a UClassID for this class. |
|
110 */ |
|
111 static UClassID U_EXPORT2 getStaticClassID(); |
|
112 }; |
|
113 |
|
114 U_NAMESPACE_END |
|
115 |
|
116 #endif /* #if !UCONFIG_NO_TRANSLITERATION */ |
|
117 #endif |
|
118 |
|
119 //eof |