17 #ifndef __UCHARSTRIEBUILDER_H__
18 #define __UCHARSTRIEBUILDER_H__
32 class UCharsTrieElement;
137 virtual int32_t getElementStringLength(int32_t i)
const;
138 virtual char16_t getElementUnit(int32_t i, int32_t unitIndex)
const;
139 virtual int32_t getElementValue(int32_t i)
const;
141 virtual int32_t getLimitOfLinearMatch(int32_t first, int32_t last, int32_t unitIndex)
const;
143 virtual int32_t countElementUnits(int32_t start, int32_t limit, int32_t unitIndex)
const;
144 virtual int32_t skipElementsBySomeUnits(int32_t i, int32_t unitIndex, int32_t count)
const;
145 virtual int32_t indexOfElementWithNextUnit(int32_t i, int32_t unitIndex, char16_t unit)
const;
147 virtual UBool matchNodesCanHaveValues()
const {
return TRUE; }
149 virtual int32_t getMaxBranchLinearSubNodeLength()
const {
return UCharsTrie::kMaxBranchLinearSubNodeLength; }
150 virtual int32_t getMinLinearMatch()
const {
return UCharsTrie::kMinLinearMatch; }
151 virtual int32_t getMaxLinearMatchLength()
const {
return UCharsTrie::kMaxLinearMatchLength; }
153 class UCTLinearMatchNode :
public LinearMatchNode {
155 UCTLinearMatchNode(
const char16_t *units, int32_t len, Node *nextNode);
157 virtual void write(StringTrieBuilder &builder);
162 virtual Node *createLinearMatchNode(int32_t i, int32_t unitIndex, int32_t length,
163 Node *nextNode)
const;
165 UBool ensureCapacity(int32_t length);
166 virtual int32_t write(int32_t unit);
167 int32_t write(
const char16_t *s, int32_t length);
168 virtual int32_t writeElementUnits(int32_t i, int32_t unitIndex, int32_t length);
169 virtual int32_t writeValueAndFinal(int32_t i,
UBool isFinal);
170 virtual int32_t writeValueAndType(
UBool hasValue, int32_t value, int32_t node);
171 virtual int32_t writeDeltaTo(int32_t jumpTarget);
173 UnicodeString strings;
174 UCharsTrieElement *elements;
175 int32_t elementsCapacity;
176 int32_t elementsLength;
181 int32_t ucharsCapacity;
182 int32_t ucharsLength;
187 #endif // __UCHARSTRIEBUILDER_H__