2017-09-27 00:25:20 +00:00
|
|
|
// © 2017 and later: Unicode, Inc. and others.
|
|
|
|
// License & terms of use: http://www.unicode.org/copyright.html
|
|
|
|
|
2017-10-04 22:51:06 +00:00
|
|
|
#include "unicode/utypes.h"
|
|
|
|
|
2018-04-23 23:02:26 +00:00
|
|
|
#if !UCONFIG_NO_FORMATTING
|
2017-09-27 05:31:57 +00:00
|
|
|
#ifndef __NUMBER_STRINGBUILDER_H__
|
|
|
|
#define __NUMBER_STRINGBUILDER_H__
|
2017-09-27 00:25:20 +00:00
|
|
|
|
|
|
|
|
|
|
|
#include <cstdint>
|
2017-09-27 05:31:57 +00:00
|
|
|
#include "unicode/numfmt.h"
|
|
|
|
#include "unicode/ustring.h"
|
|
|
|
#include "cstring.h"
|
|
|
|
#include "uassert.h"
|
2017-09-27 00:25:20 +00:00
|
|
|
#include "number_types.h"
|
|
|
|
|
|
|
|
U_NAMESPACE_BEGIN namespace number {
|
|
|
|
namespace impl {
|
|
|
|
|
2017-09-27 18:50:44 +00:00
|
|
|
class U_I18N_API NumberStringBuilder : public UMemory {
|
2017-09-27 00:25:20 +00:00
|
|
|
private:
|
|
|
|
static const int32_t DEFAULT_CAPACITY = 40;
|
|
|
|
|
|
|
|
template<typename T>
|
|
|
|
union ValueOrHeapArray {
|
|
|
|
T value[DEFAULT_CAPACITY];
|
|
|
|
struct {
|
|
|
|
T *ptr;
|
|
|
|
int32_t capacity;
|
|
|
|
} heap;
|
|
|
|
};
|
|
|
|
|
|
|
|
public:
|
|
|
|
NumberStringBuilder();
|
|
|
|
|
|
|
|
~NumberStringBuilder();
|
|
|
|
|
|
|
|
NumberStringBuilder(const NumberStringBuilder &other);
|
|
|
|
|
|
|
|
NumberStringBuilder &operator=(const NumberStringBuilder &other);
|
|
|
|
|
|
|
|
int32_t length() const;
|
|
|
|
|
|
|
|
int32_t codePointCount() const;
|
|
|
|
|
|
|
|
inline char16_t charAt(int32_t index) const {
|
|
|
|
U_ASSERT(index >= 0);
|
|
|
|
U_ASSERT(index < fLength);
|
|
|
|
return getCharPtr()[fZero + index];
|
|
|
|
}
|
|
|
|
|
|
|
|
inline Field fieldAt(int32_t index) const {
|
|
|
|
U_ASSERT(index >= 0);
|
|
|
|
U_ASSERT(index < fLength);
|
|
|
|
return getFieldPtr()[fZero + index];
|
|
|
|
}
|
|
|
|
|
|
|
|
UChar32 getFirstCodePoint() const;
|
|
|
|
|
|
|
|
UChar32 getLastCodePoint() const;
|
|
|
|
|
|
|
|
UChar32 codePointAt(int32_t index) const;
|
|
|
|
|
|
|
|
UChar32 codePointBefore(int32_t index) const;
|
|
|
|
|
|
|
|
NumberStringBuilder &clear();
|
|
|
|
|
|
|
|
int32_t appendCodePoint(UChar32 codePoint, Field field, UErrorCode &status);
|
|
|
|
|
|
|
|
int32_t insertCodePoint(int32_t index, UChar32 codePoint, Field field, UErrorCode &status);
|
|
|
|
|
|
|
|
int32_t append(const UnicodeString &unistr, Field field, UErrorCode &status);
|
|
|
|
|
|
|
|
int32_t insert(int32_t index, const UnicodeString &unistr, Field field, UErrorCode &status);
|
|
|
|
|
|
|
|
int32_t insert(int32_t index, const UnicodeString &unistr, int32_t start, int32_t end, Field field,
|
|
|
|
UErrorCode &status);
|
|
|
|
|
2018-01-10 02:44:23 +00:00
|
|
|
int32_t splice(int32_t startThis, int32_t endThis, const UnicodeString &unistr,
|
|
|
|
int32_t startOther, int32_t endOther, Field field, UErrorCode& status);
|
|
|
|
|
2017-09-27 00:25:20 +00:00
|
|
|
int32_t append(const NumberStringBuilder &other, UErrorCode &status);
|
|
|
|
|
|
|
|
int32_t insert(int32_t index, const NumberStringBuilder &other, UErrorCode &status);
|
|
|
|
|
2018-03-28 03:42:12 +00:00
|
|
|
/**
|
|
|
|
* Gets a "safe" UnicodeString that can be used even after the NumberStringBuilder is destructed.
|
|
|
|
* */
|
2017-09-27 00:25:20 +00:00
|
|
|
UnicodeString toUnicodeString() const;
|
|
|
|
|
2018-03-28 03:42:12 +00:00
|
|
|
/**
|
|
|
|
* Gets an "unsafe" UnicodeString that is valid only as long as the NumberStringBuilder is alive and
|
|
|
|
* unchanged. Slightly faster than toUnicodeString().
|
|
|
|
*/
|
|
|
|
const UnicodeString toTempUnicodeString() const;
|
|
|
|
|
2017-09-27 00:25:20 +00:00
|
|
|
UnicodeString toDebugString() const;
|
|
|
|
|
|
|
|
const char16_t *chars() const;
|
|
|
|
|
|
|
|
bool contentEquals(const NumberStringBuilder &other) const;
|
|
|
|
|
2018-05-03 01:34:19 +00:00
|
|
|
bool nextFieldPosition(FieldPosition& fp, UErrorCode& status) const;
|
2017-09-27 00:25:20 +00:00
|
|
|
|
2018-05-03 01:34:19 +00:00
|
|
|
void getAllFieldPositions(FieldPositionIterator& fpi, UErrorCode& status) const;
|
2017-09-27 00:25:20 +00:00
|
|
|
|
|
|
|
private:
|
|
|
|
bool fUsingHeap = false;
|
|
|
|
ValueOrHeapArray<char16_t> fChars;
|
|
|
|
ValueOrHeapArray<Field> fFields;
|
|
|
|
int32_t fZero = DEFAULT_CAPACITY / 2;
|
|
|
|
int32_t fLength = 0;
|
|
|
|
|
|
|
|
inline char16_t *getCharPtr() {
|
|
|
|
return fUsingHeap ? fChars.heap.ptr : fChars.value;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline const char16_t *getCharPtr() const {
|
|
|
|
return fUsingHeap ? fChars.heap.ptr : fChars.value;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline Field *getFieldPtr() {
|
|
|
|
return fUsingHeap ? fFields.heap.ptr : fFields.value;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline const Field *getFieldPtr() const {
|
|
|
|
return fUsingHeap ? fFields.heap.ptr : fFields.value;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline int32_t getCapacity() const {
|
|
|
|
return fUsingHeap ? fChars.heap.capacity : DEFAULT_CAPACITY;
|
|
|
|
}
|
|
|
|
|
|
|
|
int32_t prepareForInsert(int32_t index, int32_t count, UErrorCode &status);
|
|
|
|
|
|
|
|
int32_t prepareForInsertHelper(int32_t index, int32_t count, UErrorCode &status);
|
2018-01-10 02:44:23 +00:00
|
|
|
|
|
|
|
int32_t remove(int32_t index, int32_t count);
|
2017-09-27 00:25:20 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace impl
|
|
|
|
} // namespace number
|
|
|
|
U_NAMESPACE_END
|
|
|
|
|
|
|
|
|
2017-09-27 05:31:57 +00:00
|
|
|
#endif //__NUMBER_STRINGBUILDER_H__
|
|
|
|
|
|
|
|
#endif /* #if !UCONFIG_NO_FORMATTING */
|