Index: icu46/source/i18n/rbt.h |
=================================================================== |
--- icu46/source/i18n/rbt.h (revision 0) |
+++ icu46/source/i18n/rbt.h (revision 0) |
@@ -0,0 +1,473 @@ |
+/* |
+********************************************************************** |
+* Copyright (C) 1999-2007, International Business Machines |
+* Corporation and others. All Rights Reserved. |
+********************************************************************** |
+* Date Name Description |
+* 11/17/99 aliu Creation. |
+********************************************************************** |
+*/ |
+#ifndef RBT_H |
+#define RBT_H |
+ |
+#include "unicode/utypes.h" |
+ |
+#if !UCONFIG_NO_TRANSLITERATION |
+ |
+#include "unicode/translit.h" |
+#include "unicode/utypes.h" |
+#include "unicode/parseerr.h" |
+#include "unicode/udata.h" |
+ |
+#define U_ICUDATA_TRANSLIT U_ICUDATA_NAME U_TREE_SEPARATOR_STRING "translit" |
+ |
+U_NAMESPACE_BEGIN |
+ |
+class TransliterationRuleData; |
+ |
+/** |
+ * <code>RuleBasedTransliterator</code> is a transliterator |
+ * that reads a set of rules in order to determine how to perform |
+ * translations. Rule sets are stored in resource bundles indexed by |
+ * name. Rules within a rule set are separated by semicolons (';'). |
+ * To include a literal semicolon, prefix it with a backslash ('\'). |
+ * Whitespace, as defined by <code>Character.isWhitespace()</code>, |
+ * is ignored. If the first non-blank character on a line is '#', |
+ * the entire line is ignored as a comment. </p> |
+ * |
+ * <p>Each set of rules consists of two groups, one forward, and one |
+ * reverse. This is a convention that is not enforced; rules for one |
+ * direction may be omitted, with the result that translations in |
+ * that direction will not modify the source text. In addition, |
+ * bidirectional forward-reverse rules may be specified for |
+ * symmetrical transformations.</p> |
+ * |
+ * <p><b>Rule syntax</b> </p> |
+ * |
+ * <p>Rule statements take one of the following forms: </p> |
+ * |
+ * <dl> |
+ * <dt><code>$alefmadda=\u0622;</code></dt> |
+ * <dd><strong>Variable definition.</strong> The name on the |
+ * left is assigned the text on the right. In this example, |
+ * after this statement, instances of the left hand name, |
+ * "<code>$alefmadda</code>", will be replaced by |
+ * the Unicode character U+0622. Variable names must begin |
+ * with a letter and consist only of letters, digits, and |
+ * underscores. Case is significant. Duplicate names cause |
+ * an exception to be thrown, that is, variables cannot be |
+ * redefined. The right hand side may contain well-formed |
+ * text of any length, including no text at all ("<code>$empty=;</code>"). |
+ * The right hand side may contain embedded <code>UnicodeSet</code> |
+ * patterns, for example, "<code>$softvowel=[eiyEIY]</code>".</dd> |
+ * <dd> </dd> |
+ * <dt><code>ai>$alefmadda;</code></dt> |
+ * <dd><strong>Forward translation rule.</strong> This rule |
+ * states that the string on the left will be changed to the |
+ * string on the right when performing forward |
+ * transliteration.</dd> |
+ * <dt> </dt> |
+ * <dt><code>ai<$alefmadda;</code></dt> |
+ * <dd><strong>Reverse translation rule.</strong> This rule |
+ * states that the string on the right will be changed to |
+ * the string on the left when performing reverse |
+ * transliteration.</dd> |
+ * </dl> |
+ * |
+ * <dl> |
+ * <dt><code>ai<>$alefmadda;</code></dt> |
+ * <dd><strong>Bidirectional translation rule.</strong> This |
+ * rule states that the string on the right will be changed |
+ * to the string on the left when performing forward |
+ * transliteration, and vice versa when performing reverse |
+ * transliteration.</dd> |
+ * </dl> |
+ * |
+ * <p>Translation rules consist of a <em>match pattern</em> and an <em>output |
+ * string</em>. The match pattern consists of literal characters, |
+ * optionally preceded by context, and optionally followed by |
+ * context. Context characters, like literal pattern characters, |
+ * must be matched in the text being transliterated. However, unlike |
+ * literal pattern characters, they are not replaced by the output |
+ * text. For example, the pattern "<code>abc{def}</code>" |
+ * indicates the characters "<code>def</code>" must be |
+ * preceded by "<code>abc</code>" for a successful match. |
+ * If there is a successful match, "<code>def</code>" will |
+ * be replaced, but not "<code>abc</code>". The final '<code>}</code>' |
+ * is optional, so "<code>abc{def</code>" is equivalent to |
+ * "<code>abc{def}</code>". Another example is "<code>{123}456</code>" |
+ * (or "<code>123}456</code>") in which the literal |
+ * pattern "<code>123</code>" must be followed by "<code>456</code>". |
+ * </p> |
+ * |
+ * <p>The output string of a forward or reverse rule consists of |
+ * characters to replace the literal pattern characters. If the |
+ * output string contains the character '<code>|</code>', this is |
+ * taken to indicate the location of the <em>cursor</em> after |
+ * replacement. The cursor is the point in the text at which the |
+ * next replacement, if any, will be applied. The cursor is usually |
+ * placed within the replacement text; however, it can actually be |
+ * placed into the precending or following context by using the |
+ * special character '<code>@</code>'. Examples:</p> |
+ * |
+ * <blockquote> |
+ * <p><code>a {foo} z > | @ bar; # foo -> bar, move cursor |
+ * before a<br> |
+ * {foo} xyz > bar @@|; # foo -> bar, cursor between |
+ * y and z</code></p> |
+ * </blockquote> |
+ * |
+ * <p><b>UnicodeSet</b></p> |
+ * |
+ * <p><code>UnicodeSet</code> patterns may appear anywhere that |
+ * makes sense. They may appear in variable definitions. |
+ * Contrariwise, <code>UnicodeSet</code> patterns may themselves |
+ * contain variable references, such as "<code>$a=[a-z];$not_a=[^$a]</code>", |
+ * or "<code>$range=a-z;$ll=[$range]</code>".</p> |
+ * |
+ * <p><code>UnicodeSet</code> patterns may also be embedded directly |
+ * into rule strings. Thus, the following two rules are equivalent:</p> |
+ * |
+ * <blockquote> |
+ * <p><code>$vowel=[aeiou]; $vowel>'*'; # One way to do this<br> |
+ * [aeiou]>'*'; |
+ * # |
+ * Another way</code></p> |
+ * </blockquote> |
+ * |
+ * <p>See {@link UnicodeSet} for more documentation and examples.</p> |
+ * |
+ * <p><b>Segments</b></p> |
+ * |
+ * <p>Segments of the input string can be matched and copied to the |
+ * output string. This makes certain sets of rules simpler and more |
+ * general, and makes reordering possible. For example:</p> |
+ * |
+ * <blockquote> |
+ * <p><code>([a-z]) > $1 $1; |
+ * # |
+ * double lowercase letters<br> |
+ * ([:Lu:]) ([:Ll:]) > $2 $1; # reverse order of Lu-Ll pairs</code></p> |
+ * </blockquote> |
+ * |
+ * <p>The segment of the input string to be copied is delimited by |
+ * "<code>(</code>" and "<code>)</code>". Up to |
+ * nine segments may be defined. Segments may not overlap. In the |
+ * output string, "<code>$1</code>" through "<code>$9</code>" |
+ * represent the input string segments, in left-to-right order of |
+ * definition.</p> |
+ * |
+ * <p><b>Anchors</b></p> |
+ * |
+ * <p>Patterns can be anchored to the beginning or the end of the text. This is done with the |
+ * special characters '<code>^</code>' and '<code>$</code>'. For example:</p> |
+ * |
+ * <blockquote> |
+ * <p><code>^ a > 'BEG_A'; # match 'a' at start of text<br> |
+ * a > 'A'; # match other instances |
+ * of 'a'<br> |
+ * z $ > 'END_Z'; # match 'z' at end of text<br> |
+ * z > 'Z'; # match other instances |
+ * of 'z'</code></p> |
+ * </blockquote> |
+ * |
+ * <p>It is also possible to match the beginning or the end of the text using a <code>UnicodeSet</code>. |
+ * This is done by including a virtual anchor character '<code>$</code>' at the end of the |
+ * set pattern. Although this is usually the match chafacter for the end anchor, the set will |
+ * match either the beginning or the end of the text, depending on its placement. For |
+ * example:</p> |
+ * |
+ * <blockquote> |
+ * <p><code>$x = [a-z$]; # match 'a' through 'z' OR anchor<br> |
+ * $x 1 > 2; # match '1' after a-z or at the start<br> |
+ * 3 $x > 4; # match '3' before a-z or at the end</code></p> |
+ * </blockquote> |
+ * |
+ * <p><b>Example</b> </p> |
+ * |
+ * <p>The following example rules illustrate many of the features of |
+ * the rule language. </p> |
+ * |
+ * <table border="0" cellpadding="4"> |
+ * <tr> |
+ * <td valign="top">Rule 1.</td> |
+ * <td valign="top" nowrap><code>abc{def}>x|y</code></td> |
+ * </tr> |
+ * <tr> |
+ * <td valign="top">Rule 2.</td> |
+ * <td valign="top" nowrap><code>xyz>r</code></td> |
+ * </tr> |
+ * <tr> |
+ * <td valign="top">Rule 3.</td> |
+ * <td valign="top" nowrap><code>yz>q</code></td> |
+ * </tr> |
+ * </table> |
+ * |
+ * <p>Applying these rules to the string "<code>adefabcdefz</code>" |
+ * yields the following results: </p> |
+ * |
+ * <table border="0" cellpadding="4"> |
+ * <tr> |
+ * <td valign="top" nowrap><code>|adefabcdefz</code></td> |
+ * <td valign="top">Initial state, no rules match. Advance |
+ * cursor.</td> |
+ * </tr> |
+ * <tr> |
+ * <td valign="top" nowrap><code>a|defabcdefz</code></td> |
+ * <td valign="top">Still no match. Rule 1 does not match |
+ * because the preceding context is not present.</td> |
+ * </tr> |
+ * <tr> |
+ * <td valign="top" nowrap><code>ad|efabcdefz</code></td> |
+ * <td valign="top">Still no match. Keep advancing until |
+ * there is a match...</td> |
+ * </tr> |
+ * <tr> |
+ * <td valign="top" nowrap><code>ade|fabcdefz</code></td> |
+ * <td valign="top">...</td> |
+ * </tr> |
+ * <tr> |
+ * <td valign="top" nowrap><code>adef|abcdefz</code></td> |
+ * <td valign="top">...</td> |
+ * </tr> |
+ * <tr> |
+ * <td valign="top" nowrap><code>adefa|bcdefz</code></td> |
+ * <td valign="top">...</td> |
+ * </tr> |
+ * <tr> |
+ * <td valign="top" nowrap><code>adefab|cdefz</code></td> |
+ * <td valign="top">...</td> |
+ * </tr> |
+ * <tr> |
+ * <td valign="top" nowrap><code>adefabc|defz</code></td> |
+ * <td valign="top">Rule 1 matches; replace "<code>def</code>" |
+ * with "<code>xy</code>" and back up the cursor |
+ * to before the '<code>y</code>'.</td> |
+ * </tr> |
+ * <tr> |
+ * <td valign="top" nowrap><code>adefabcx|yz</code></td> |
+ * <td valign="top">Although "<code>xyz</code>" is |
+ * present, rule 2 does not match because the cursor is |
+ * before the '<code>y</code>', not before the '<code>x</code>'. |
+ * Rule 3 does match. Replace "<code>yz</code>" |
+ * with "<code>q</code>".</td> |
+ * </tr> |
+ * <tr> |
+ * <td valign="top" nowrap><code>adefabcxq|</code></td> |
+ * <td valign="top">The cursor is at the end; |
+ * transliteration is complete.</td> |
+ * </tr> |
+ * </table> |
+ * |
+ * <p>The order of rules is significant. If multiple rules may match |
+ * at some point, the first matching rule is applied. </p> |
+ * |
+ * <p>Forward and reverse rules may have an empty output string. |
+ * Otherwise, an empty left or right hand side of any statement is a |
+ * syntax error. </p> |
+ * |
+ * <p>Single quotes are used to quote any character other than a |
+ * digit or letter. To specify a single quote itself, inside or |
+ * outside of quotes, use two single quotes in a row. For example, |
+ * the rule "<code>'>'>o''clock</code>" changes the |
+ * string "<code>></code>" to the string "<code>o'clock</code>". |
+ * </p> |
+ * |
+ * <p><b>Notes</b> </p> |
+ * |
+ * <p>While a RuleBasedTransliterator is being built, it checks that |
+ * the rules are added in proper order. For example, if the rule |
+ * "a>x" is followed by the rule "ab>y", |
+ * then the second rule will throw an exception. The reason is that |
+ * the second rule can never be triggered, since the first rule |
+ * always matches anything it matches. In other words, the first |
+ * rule <em>masks</em> the second rule. </p> |
+ * |
+ * @author Alan Liu |
+ * @internal Use transliterator factory methods instead since this class will be removed in that release. |
+ */ |
+class RuleBasedTransliterator : public Transliterator { |
+private: |
+ /** |
+ * The data object is immutable, so we can freely share it with |
+ * other instances of RBT, as long as we do NOT own this object. |
+ * TODO: data is no longer immutable. See bugs #1866, 2155 |
+ */ |
+ TransliterationRuleData* fData; |
+ |
+ /** |
+ * If true, we own the data object and must delete it. |
+ */ |
+ UBool isDataOwned; |
+ |
+public: |
+ |
+ /** |
+ * Constructs a new transliterator from the given rules. |
+ * @param rules rules, separated by ';' |
+ * @param direction either FORWARD or REVERSE. |
+ * @exception IllegalArgumentException if rules are malformed. |
+ * @internal Use transliterator factory methods instead since this class will be removed in that release. |
+ */ |
+ RuleBasedTransliterator(const UnicodeString& id, |
+ const UnicodeString& rules, |
+ UTransDirection direction, |
+ UnicodeFilter* adoptedFilter, |
+ UParseError& parseError, |
+ UErrorCode& status); |
+ |
+ /** |
+ * Constructs a new transliterator from the given rules. |
+ * @param rules rules, separated by ';' |
+ * @param direction either FORWARD or REVERSE. |
+ * @exception IllegalArgumentException if rules are malformed. |
+ * @internal Use transliterator factory methods instead since this class will be removed in that release. |
+ */ |
+ /*RuleBasedTransliterator(const UnicodeString& id, |
+ const UnicodeString& rules, |
+ UTransDirection direction, |
+ UnicodeFilter* adoptedFilter, |
+ UErrorCode& status);*/ |
+ |
+ /** |
+ * Covenience constructor with no filter. |
+ * @internal Use transliterator factory methods instead since this class will be removed in that release. |
+ */ |
+ /*RuleBasedTransliterator(const UnicodeString& id, |
+ const UnicodeString& rules, |
+ UTransDirection direction, |
+ UErrorCode& status);*/ |
+ |
+ /** |
+ * Covenience constructor with no filter and FORWARD direction. |
+ * @internal Use transliterator factory methods instead since this class will be removed in that release. |
+ */ |
+ /*RuleBasedTransliterator(const UnicodeString& id, |
+ const UnicodeString& rules, |
+ UErrorCode& status);*/ |
+ |
+ /** |
+ * Covenience constructor with FORWARD direction. |
+ * @internal Use transliterator factory methods instead since this class will be removed in that release. |
+ */ |
+ /*RuleBasedTransliterator(const UnicodeString& id, |
+ const UnicodeString& rules, |
+ UnicodeFilter* adoptedFilter, |
+ UErrorCode& status);*/ |
+private: |
+ |
+ friend class TransliteratorRegistry; // to access TransliterationRuleData convenience ctor |
+ /** |
+ * Covenience constructor. |
+ * @param id the id for the transliterator. |
+ * @param theData the rule data for the transliterator. |
+ * @param adoptedFilter the filter for the transliterator |
+ */ |
+ RuleBasedTransliterator(const UnicodeString& id, |
+ const TransliterationRuleData* theData, |
+ UnicodeFilter* adoptedFilter = 0); |
+ |
+ |
+ friend class Transliterator; // to access following ct |
+ |
+ /** |
+ * Internal constructor. |
+ * @param id the id for the transliterator. |
+ * @param theData the rule data for the transliterator. |
+ * @param isDataAdopted determine who will own the 'data' object. True, the caller should not delete 'data'. |
+ */ |
+ RuleBasedTransliterator(const UnicodeString& id, |
+ TransliterationRuleData* data, |
+ UBool isDataAdopted); |
+ |
+public: |
+ |
+ /** |
+ * Copy constructor. |
+ * @internal Use transliterator factory methods instead since this class will be removed in that release. |
+ */ |
+ RuleBasedTransliterator(const RuleBasedTransliterator&); |
+ |
+ virtual ~RuleBasedTransliterator(); |
+ |
+ /** |
+ * Implement Transliterator API. |
+ * @internal Use transliterator factory methods instead since this class will be removed in that release. |
+ */ |
+ virtual Transliterator* clone(void) const; |
+ |
+protected: |
+ /** |
+ * Implements {@link Transliterator#handleTransliterate}. |
+ * @internal Use transliterator factory methods instead since this class will be removed in that release. |
+ */ |
+ virtual void handleTransliterate(Replaceable& text, UTransPosition& offsets, |
+ UBool isIncremental) const; |
+ |
+public: |
+ /** |
+ * Return a representation of this transliterator as source rules. |
+ * These rules will produce an equivalent transliterator if used |
+ * to construct a new transliterator. |
+ * @param result the string to receive the rules. Previous |
+ * contents will be deleted. |
+ * @param escapeUnprintable if TRUE then convert unprintable |
+ * character to their hex escape representations, \uxxxx or |
+ * \Uxxxxxxxx. Unprintable characters are those other than |
+ * U+000A, U+0020..U+007E. |
+ * @internal Use transliterator factory methods instead since this class will be removed in that release. |
+ */ |
+ virtual UnicodeString& toRules(UnicodeString& result, |
+ UBool escapeUnprintable) const; |
+ |
+protected: |
+ /** |
+ * Implement Transliterator framework |
+ */ |
+ virtual void handleGetSourceSet(UnicodeSet& result) const; |
+ |
+public: |
+ /** |
+ * Override Transliterator framework |
+ */ |
+ virtual UnicodeSet& getTargetSet(UnicodeSet& result) const; |
+ |
+ /** |
+ * Return the class ID for this class. This is useful only for |
+ * comparing to a return value from getDynamicClassID(). For example: |
+ * <pre> |
+ * . Base* polymorphic_pointer = createPolymorphicObject(); |
+ * . if (polymorphic_pointer->getDynamicClassID() == |
+ * . Derived::getStaticClassID()) ... |
+ * </pre> |
+ * @return The class ID for all objects of this class. |
+ * @internal Use transliterator factory methods instead since this class will be removed in that release. |
+ */ |
+ U_I18N_API static UClassID U_EXPORT2 getStaticClassID(void); |
+ |
+ /** |
+ * Returns a unique class ID <b>polymorphically</b>. This method |
+ * is to implement a simple version of RTTI, since not all C++ |
+ * compilers support genuine RTTI. Polymorphic operator==() and |
+ * clone() methods call this method. |
+ * |
+ * @return The class ID for this object. All objects of a given |
+ * class have the same class ID. Objects of other classes have |
+ * different class IDs. |
+ */ |
+ virtual UClassID getDynamicClassID(void) const; |
+ |
+private: |
+ |
+ void _construct(const UnicodeString& rules, |
+ UTransDirection direction, |
+ UParseError& parseError, |
+ UErrorCode& status); |
+}; |
+ |
+ |
+U_NAMESPACE_END |
+ |
+#endif /* #if !UCONFIG_NO_TRANSLITERATION */ |
+ |
+#endif |
Property changes on: icu46/source/i18n/rbt.h |
___________________________________________________________________ |
Added: svn:eol-style |
+ LF |