22 #ifndef __BYTESTRIEBUILDER_H__
23 #define __BYTESTRIEBUILDER_H__
27 #if U_SHOW_CPLUSPLUS_API
35 class BytesTrieElement;
132 virtual int32_t getElementStringLength(int32_t i)
const;
133 virtual char16_t getElementUnit(int32_t i, int32_t byteIndex)
const;
134 virtual int32_t getElementValue(int32_t i)
const;
136 virtual int32_t getLimitOfLinearMatch(int32_t first, int32_t last, int32_t byteIndex)
const;
138 virtual int32_t countElementUnits(int32_t start, int32_t limit, int32_t byteIndex)
const;
139 virtual int32_t skipElementsBySomeUnits(int32_t i, int32_t byteIndex, int32_t count)
const;
140 virtual int32_t indexOfElementWithNextUnit(int32_t i, int32_t byteIndex, char16_t
byte)
const;
142 virtual UBool matchNodesCanHaveValues()
const {
return FALSE; }
144 virtual int32_t getMaxBranchLinearSubNodeLength()
const {
return BytesTrie::kMaxBranchLinearSubNodeLength; }
145 virtual int32_t getMinLinearMatch()
const {
return BytesTrie::kMinLinearMatch; }
146 virtual int32_t getMaxLinearMatchLength()
const {
return BytesTrie::kMaxLinearMatchLength; }
151 class BTLinearMatchNode :
public LinearMatchNode {
153 BTLinearMatchNode(
const char *units, int32_t len, Node *nextNode);
155 virtual void write(StringTrieBuilder &builder);
160 virtual Node *createLinearMatchNode(int32_t i, int32_t byteIndex, int32_t length,
161 Node *nextNode)
const;
163 UBool ensureCapacity(int32_t length);
164 virtual int32_t write(int32_t
byte);
165 int32_t write(
const char *b, int32_t length);
166 virtual int32_t writeElementUnits(int32_t i, int32_t byteIndex, int32_t length);
167 virtual int32_t writeValueAndFinal(int32_t i,
UBool isFinal);
168 virtual int32_t writeValueAndType(
UBool hasValue, int32_t value, int32_t node);
169 virtual int32_t writeDeltaTo(int32_t jumpTarget);
172 BytesTrieElement *elements;
173 int32_t elementsCapacity;
174 int32_t elementsLength;
179 int32_t bytesCapacity;
187 #endif // __BYTESTRIEBUILDER_H__