| // © 2018 and later: Unicode, Inc. and others. |
| // License & terms of use: http://www.unicode.org/copyright.html |
| |
| #include "unicode/utypes.h" |
| |
| #if !UCONFIG_NO_FORMATTING |
| #ifndef __NUMPARSE_STRINGSEGMENT_H__ |
| #define __NUMPARSE_STRINGSEGMENT_H__ |
| |
| #include "unicode/unistr.h" |
| #include "unicode/uniset.h" |
| |
| U_NAMESPACE_BEGIN |
| |
| |
| /** |
| * A mutable UnicodeString wrapper with a variable offset and length and |
| * support for case folding. The charAt, length, and subSequence methods all |
| * operate relative to the fixed offset into the UnicodeString. |
| * |
| * Intended to be useful for parsing. |
| * |
| * CAUTION: Since this class is mutable, it must not be used anywhere that an |
| * immutable object is required, like in a cache or as the key of a hash map. |
| * |
| * @author sffc (Shane Carr) |
| */ |
| // Exported as U_I18N_API for tests |
| class U_I18N_API StringSegment : public UMemory { |
| public: |
| StringSegment(const UnicodeString& str, bool ignoreCase); |
| |
| int32_t getOffset() const; |
| |
| void setOffset(int32_t start); |
| |
| /** |
| * Equivalent to <code>setOffset(getOffset()+delta)</code>. |
| * |
| * <p> |
| * This method is usually called by a Matcher to register that a char was consumed. If the char is |
| * strong (it usually is, except for things like whitespace), follow this with a call to |
| * {@link ParsedNumber#setCharsConsumed}. For more information on strong chars, see that method. |
| */ |
| void adjustOffset(int32_t delta); |
| |
| /** |
| * Adjusts the offset by the width of the current code point, either 1 or 2 chars. |
| */ |
| void adjustOffsetByCodePoint(); |
| |
| void setLength(int32_t length); |
| |
| void resetLength(); |
| |
| int32_t length() const; |
| |
| char16_t charAt(int32_t index) const; |
| |
| UChar32 codePointAt(int32_t index) const; |
| |
| UnicodeString toUnicodeString() const; |
| |
| const UnicodeString toTempUnicodeString() const; |
| |
| /** |
| * Returns the first code point in the string segment, or -1 if the string starts with an invalid |
| * code point. |
| * |
| * <p> |
| * <strong>Important:</strong> Most of the time, you should use {@link #startsWith}, which handles case |
| * folding logic, instead of this method. |
| */ |
| UChar32 getCodePoint() const; |
| |
| /** |
| * Returns true if the first code point of this StringSegment equals the given code point. |
| * |
| * <p> |
| * This method will perform case folding if case folding is enabled for the parser. |
| */ |
| bool startsWith(UChar32 otherCp) const; |
| |
| /** |
| * Returns true if the first code point of this StringSegment is in the given UnicodeSet. |
| */ |
| bool startsWith(const UnicodeSet& uniset) const; |
| |
| /** |
| * Returns true if there is at least one code point of overlap between this StringSegment and the |
| * given UnicodeString. |
| */ |
| bool startsWith(const UnicodeString& other) const; |
| |
| /** |
| * Returns the length of the prefix shared by this StringSegment and the given UnicodeString. For |
| * example, if this string segment is "aab", and the char sequence is "aac", this method returns 2, |
| * since the first 2 characters are the same. |
| * |
| * <p> |
| * This method only returns offsets along code point boundaries. |
| * |
| * <p> |
| * This method will perform case folding if case folding was enabled in the constructor. |
| * |
| * <p> |
| * IMPORTANT: The given UnicodeString must not be empty! It is the caller's responsibility to check. |
| */ |
| int32_t getCommonPrefixLength(const UnicodeString& other); |
| |
| /** |
| * Like {@link #getCommonPrefixLength}, but never performs case folding, even if case folding is |
| * enabled for the parser. |
| */ |
| int32_t getCaseSensitivePrefixLength(const UnicodeString& other); |
| |
| bool operator==(const UnicodeString& other) const; |
| |
| private: |
| const UnicodeString& fStr; |
| int32_t fStart; |
| int32_t fEnd; |
| bool fFoldCase; |
| |
| int32_t getPrefixLengthInternal(const UnicodeString& other, bool foldCase); |
| |
| static bool codePointsEqual(UChar32 cp1, UChar32 cp2, bool foldCase); |
| }; |
| |
| |
| U_NAMESPACE_END |
| |
| #endif //__NUMPARSE_STRINGSEGMENT_H__ |
| #endif /* #if !UCONFIG_NO_FORMATTING */ |