/* ********************************************************************** * Copyright (C) 1999, 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 */ virtual int32_t length() const = 0; /** * 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 */ virtual UChar charAt(UTextOffset offset) const = 0; /** * 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 */ virtual UChar32 char32At(UTextOffset offset) const = 0; /** * 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 */ 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. protected: /** * Default constructor. */ Replaceable(); }; inline Replaceable::Replaceable() {} inline Replaceable::~Replaceable() {} #endif