/* ************************************************************************** * Copyright (C) 1999-2001, International Business Machines Corporation and * others. All Rights Reserved. ************************************************************************** * Date Name Description * 11/17/99 aliu Creation. Ported from java. Modified to * match current UnicodeString API. Forced * to use name "handleReplaceBetween" because * of existing methods in UnicodeString. ************************************************************************** */ #ifndef REP_H #define REP_H #include "unicode/utypes.h" class UnicodeString; /** * Replaceable is an abstract base class representing a * string of characters that supports the replacement of a range of * itself with a new string of characters. It is used by APIs that * change a piece of text while retaining style attributes. In other * words, an implicit aspect of the Replaceable API is * that during a replace operation, new characters take on the * attributes, if any, of the old characters. For example, if the * string "the bold font" has range (4, 8) replaced with * "strong", then it becomes "the strong font". * *

Replaceable specifies ranges using an initial * offset and a limit offset. The range of characters thus specified * includes the characters at offset initial..limit-1. That is, the * start offset is inclusive, and the limit offset is exclusive. * *

Replaceable also includes API to access characters * in the string: length(), charAt(), and * extractBetween(). * * @author Alan Liu * @draft */ class U_COMMON_API Replaceable { public: /** * Destructor. * @draft */ virtual ~Replaceable(); /** * Return the number of characters in the text. * @return number of characters in text * @draft ICU 1.8 */ inline int32_t length() const; /** * Return the Unicode code unit at the given offset into the text. * @param offset an integer between 0 and length()-1 * inclusive * @return code unit of text at given offset * @draft ICU 1.8 */ inline UChar charAt(UTextOffset offset) const; /** * Return the Unicode code point that contains the code unit * at the given offset into the text. * @param offset an integer between 0 and length()-1 * inclusive that indicates the text offset of any of the code units * that will be assembled into a code point (21-bit value) and returned * @return code point of text at given offset * @draft ICU 1.8 */ inline UChar32 char32At(UTextOffset offset) const; /** * Copy characters from this object into the destination character * array. The first character to be copied is at index * srcStart; the last character to be copied is at * index srcLimit-1 (thus the total number of * characters to be copied is srcLimit-srcStart). The * characters are copied into the subarray of dst * starting at index dstStart and ending at index * dstStart + (srcLimit-srcStart) - 1. * * @param srcStart the beginning index to copy, inclusive; 0 * <= srcStart <= srcLimit. * @param srcLimit the ending index to copy, exclusive; * srcStart <= srcLimit <= length(). * @param dst the destination array. * @param dstStart the start offset in the destination array. * @draft */ /* THIS API IS NOT NEEDED, BUT KEPT HERE AS A COMMENT IN CASE OF FUTURE NEED. CURRENTLY INDIVIDUAL CHARACTER ACCESS SUFFICES. */ /* virtual void extractBetween(UTextOffset srcStart, UTextOffset srcLimit, UChar* dst, UTextOffset dstStart = 0) const = 0; */ /** * Replace a substring of this object with the given text. If the * characters being replaced have attributes, the new characters * that replace them should be given the same attributes. * * @param start the beginning index, inclusive; 0 <= start * <= limit. * @param limit the ending index, exclusive; start <= limit * <= length(). * @param text the text to replace characters start * to limit - 1 * @draft */ virtual void handleReplaceBetween(UTextOffset start, UTextOffset limit, const UnicodeString& text) = 0; // Note: All other methods in this class take the names of // existing UnicodeString methods. This method is the exception. // It is named differently because all replace methods of // UnicodeString return a UnicodeString&. The 'between' is // required in order to conform to the UnicodeString naming // convention; API taking start/length are named , and // those taking start/limit are named . The // 'handle' is added because 'replaceBetween' and // 'doReplaceBetween' are already taken. /** * Copy a substring of this object, retaining attribute (out-of-band) * information. This method is used to duplicate or reorder substrings. * The destination index must not overlap the source range. * Implementations that do not care about maintaining out-of-band * information during copying may use the naive implementation: * *

 char[] text = new char[limit - start];
     * getChars(start, limit, text, 0);
     * replace(dest, dest, text, 0, limit - start);
* * @param start the beginning index, inclusive; 0 <= start <= * limit. * @param limit the ending index, exclusive; start <= limit <= * length(). * @param dest the destination index. The characters from * start..limit-1 will be copied to dest. * Implementations of this method may assume that dest <= start || * dest >= limit. */ virtual void copy(int32_t start, int32_t limit, int32_t dest) = 0; protected: /** * Default constructor. */ Replaceable(); /** * Virtual version of length(). */ virtual int32_t getLength() const = 0; /** * Virtual version of charAt(). */ virtual UChar getCharAt(UTextOffset offset) const = 0; /** * Virtual version of char32At(). */ virtual UChar32 getChar32At(UTextOffset offset) const = 0; }; inline Replaceable::Replaceable() {} inline Replaceable::~Replaceable() {} inline int32_t Replaceable::length() const { return getLength(); } inline UChar Replaceable::charAt(UTextOffset offset) const { return getCharAt(offset); } inline UChar32 Replaceable::char32At(UTextOffset offset) const { return getChar32At(offset); } #endif