1 /* 2 ******************************************************************************* 3 * Copyright (C) 2011-2012, International Business Machines 4 * Corporation and others. All Rights Reserved. 5 ******************************************************************************* 6 * file name: appendable.h 7 * encoding: US-ASCII 8 * tab size: 8 (not used) 9 * indentation:4 10 * 11 * created on: 2010dec07 12 * created by: Markus W. Scherer 13 */ 14 15 #ifndef __APPENDABLE_H__ 16 #define __APPENDABLE_H__ 17 18 /** 19 * \file 20 * \brief C++ API: Appendable class: Sink for Unicode code points and 16-bit code units (UChars). 21 */ 22 23 #include "unicode/utypes.h" 24 #include "unicode/uobject.h" 25 26 U_NAMESPACE_BEGIN 27 28 class UnicodeString; 29 30 /** 31 * Base class for objects to which Unicode characters and strings can be appended. 32 * Combines elements of Java Appendable and ICU4C ByteSink. 33 * 34 * This class can be used in APIs where it does not matter whether the actual destination is 35 * a UnicodeString, a UChar[] array, a UnicodeSet, or any other object 36 * that receives and processes characters and/or strings. 37 * 38 * Implementation classes must implement at least appendCodeUnit(UChar). 39 * The base class provides default implementations for the other methods. 40 * 41 * The methods do not take UErrorCode parameters. 42 * If an error occurs (e.g., out-of-memory), 43 * in addition to returning FALSE from failing operations, 44 * the implementation must prevent unexpected behavior (e.g., crashes) 45 * from further calls and should make the error condition available separately 46 * (e.g., store a UErrorCode, make/keep a UnicodeString bogus). 47 * @stable ICU 4.8 48 */ 49 class U_COMMON_API Appendable : public UObject { 50 public: 51 /** 52 * Destructor. 53 * @stable ICU 4.8 54 */ 55 ~Appendable(); 56 57 /** 58 * Appends a 16-bit code unit. 59 * @param c code unit 60 * @return TRUE if the operation succeeded 61 * @stable ICU 4.8 62 */ 63 virtual UBool appendCodeUnit(UChar c) = 0; 64 65 /** 66 * Appends a code point. 67 * The default implementation calls appendCodeUnit(UChar) once or twice. 68 * @param c code point 0..0x10ffff 69 * @return TRUE if the operation succeeded 70 * @stable ICU 4.8 71 */ 72 virtual UBool appendCodePoint(UChar32 c); 73 74 /** 75 * Appends a string. 76 * The default implementation calls appendCodeUnit(UChar) for each code unit. 77 * @param s string, must not be NULL if length!=0 78 * @param length string length, or -1 if NUL-terminated 79 * @return TRUE if the operation succeeded 80 * @stable ICU 4.8 81 */ 82 virtual UBool appendString(const UChar *s, int32_t length); 83 84 /** 85 * Tells the object that the caller is going to append roughly 86 * appendCapacity UChars. A subclass might use this to pre-allocate 87 * a larger buffer if necessary. 88 * The default implementation does nothing. (It always returns TRUE.) 89 * @param appendCapacity estimated number of UChars that will be appended 90 * @return TRUE if the operation succeeded 91 * @stable ICU 4.8 92 */ 93 virtual UBool reserveAppendCapacity(int32_t appendCapacity); 94 95 /** 96 * Returns a writable buffer for appending and writes the buffer's capacity to 97 * *resultCapacity. Guarantees *resultCapacity>=minCapacity. 98 * May return a pointer to the caller-owned scratch buffer which must have 99 * scratchCapacity>=minCapacity. 100 * The returned buffer is only valid until the next operation 101 * on this Appendable. 102 * 103 * After writing at most *resultCapacity UChars, call appendString() with the 104 * pointer returned from this function and the number of UChars written. 105 * Many appendString() implementations will avoid copying UChars if this function 106 * returned an internal buffer. 107 * 108 * Partial usage example: 109 * \code 110 * int32_t capacity; 111 * UChar* buffer = app.getAppendBuffer(..., &capacity); 112 * ... Write n UChars into buffer, with n <= capacity. 113 * app.appendString(buffer, n); 114 * \endcode 115 * In many implementations, that call to append will avoid copying UChars. 116 * 117 * If the Appendable allocates or reallocates an internal buffer, it should use 118 * the desiredCapacityHint if appropriate. 119 * If a caller cannot provide a reasonable guess at the desired capacity, 120 * it should pass desiredCapacityHint=0. 121 * 122 * If a non-scratch buffer is returned, the caller may only pass 123 * a prefix to it to appendString(). 124 * That is, it is not correct to pass an interior pointer to appendString(). 125 * 126 * The default implementation always returns the scratch buffer. 127 * 128 * @param minCapacity required minimum capacity of the returned buffer; 129 * must be non-negative 130 * @param desiredCapacityHint desired capacity of the returned buffer; 131 * must be non-negative 132 * @param scratch default caller-owned buffer 133 * @param scratchCapacity capacity of the scratch buffer 134 * @param resultCapacity pointer to an integer which will be set to the 135 * capacity of the returned buffer 136 * @return a buffer with *resultCapacity>=minCapacity 137 * @stable ICU 4.8 138 */ 139 virtual UChar *getAppendBuffer(int32_t minCapacity, 140 int32_t desiredCapacityHint, 141 UChar *scratch, int32_t scratchCapacity, 142 int32_t *resultCapacity); 143 }; 144 145 /** 146 * An Appendable implementation which writes to a UnicodeString. 147 * 148 * This class is not intended for public subclassing. 149 * @stable ICU 4.8 150 */ 151 class U_COMMON_API UnicodeStringAppendable : public Appendable { 152 public: 153 /** 154 * Aliases the UnicodeString (keeps its reference) for writing. 155 * @param s The UnicodeString to which this Appendable will write. 156 * @stable ICU 4.8 157 */ 158 explicit UnicodeStringAppendable(UnicodeString &s) : str(s) {} 159 160 /** 161 * Destructor. 162 * @stable ICU 4.8 163 */ 164 ~UnicodeStringAppendable(); 165 166 /** 167 * Appends a 16-bit code unit to the string. 168 * @param c code unit 169 * @return TRUE if the operation succeeded 170 * @stable ICU 4.8 171 */ 172 virtual UBool appendCodeUnit(UChar c); 173 174 /** 175 * Appends a code point to the string. 176 * @param c code point 0..0x10ffff 177 * @return TRUE if the operation succeeded 178 * @stable ICU 4.8 179 */ 180 virtual UBool appendCodePoint(UChar32 c); 181 182 /** 183 * Appends a string to the UnicodeString. 184 * @param s string, must not be NULL if length!=0 185 * @param length string length, or -1 if NUL-terminated 186 * @return TRUE if the operation succeeded 187 * @stable ICU 4.8 188 */ 189 virtual UBool appendString(const UChar *s, int32_t length); 190 191 /** 192 * Tells the UnicodeString that the caller is going to append roughly 193 * appendCapacity UChars. 194 * @param appendCapacity estimated number of UChars that will be appended 195 * @return TRUE if the operation succeeded 196 * @stable ICU 4.8 197 */ 198 virtual UBool reserveAppendCapacity(int32_t appendCapacity); 199 200 /** 201 * Returns a writable buffer for appending and writes the buffer's capacity to 202 * *resultCapacity. Guarantees *resultCapacity>=minCapacity. 203 * May return a pointer to the caller-owned scratch buffer which must have 204 * scratchCapacity>=minCapacity. 205 * The returned buffer is only valid until the next write operation 206 * on the UnicodeString. 207 * 208 * For details see Appendable::getAppendBuffer(). 209 * 210 * @param minCapacity required minimum capacity of the returned buffer; 211 * must be non-negative 212 * @param desiredCapacityHint desired capacity of the returned buffer; 213 * must be non-negative 214 * @param scratch default caller-owned buffer 215 * @param scratchCapacity capacity of the scratch buffer 216 * @param resultCapacity pointer to an integer which will be set to the 217 * capacity of the returned buffer 218 * @return a buffer with *resultCapacity>=minCapacity 219 * @stable ICU 4.8 220 */ 221 virtual UChar *getAppendBuffer(int32_t minCapacity, 222 int32_t desiredCapacityHint, 223 UChar *scratch, int32_t scratchCapacity, 224 int32_t *resultCapacity); 225 226 private: 227 UnicodeString &str; 228 }; 229 230 U_NAMESPACE_END 231 232 #endif // __APPENDABLE_H__ 233