ICU 76.1 76.1
|
UnicodeReplacer
defines a protocol for objects that replace a range of characters in a Replaceable string with output text.
More...
#include <unirepl.h>
Public Member Functions | |
virtual | ~UnicodeReplacer () |
Destructor. | |
virtual int32_t | replace (Replaceable &text, int32_t start, int32_t limit, int32_t &cursor)=0 |
Replace characters in 'text' from 'start' to 'limit' with the output text of this object. | |
virtual UnicodeString & | toReplacerPattern (UnicodeString &result, UBool escapeUnprintable) const =0 |
Returns a string representation of this replacer. | |
virtual void | addReplacementSetTo (UnicodeSet &toUnionTo) const =0 |
Union the set of all characters that may output by this object into the given set. | |
UnicodeReplacer
defines a protocol for objects that replace a range of characters in a Replaceable string with output text.
The replacement is done via the Replaceable API so as to preserve out-of-band data.
This is a mixin class.
|
pure virtual |
Union the set of all characters that may output by this object into the given set.
toUnionTo | the set into which to union the output characters |
|
pure virtual |
Replace characters in 'text' from 'start' to 'limit' with the output text of this object.
Update the 'cursor' parameter to give the cursor position and return the length of the replacement text.
text | the text to be matched |
start | inclusive start index of text to be replaced |
limit | exclusive end index of text to be replaced; must be greater than or equal to start |
cursor | output parameter for the cursor position. Not all replacer objects will update this, but in a complete tree of replacer objects, representing the entire output side of a transliteration rule, at least one must update it. |
|
pure virtual |
Returns a string representation of this replacer.
If the result of calling this function is passed to the appropriate parser, typically TransliteratorParser, it will produce another replacer that is equal to this one.
result | the string to receive the pattern. Previous contents will be deleted. |
escapeUnprintable | if true then convert unprintable character to their hex escape representations, \uxxxx or \Uxxxxxxxx. Unprintable characters are defined by Utility.isUnprintable(). |