add core struct
This commit is contained in:
parent
077b89db17
commit
df646e9a51
|
@ -33,6 +33,8 @@ typedef struct FstBuilderNode {
|
|||
|
||||
FstBuilderNode *fstBuilderNodeDefault();
|
||||
|
||||
FstBuilderNode *fstBuilderNodeClone(FstBuilderNode *src);
|
||||
|
||||
void fstBuilderNodeCloneFrom(FstBuilderNode *dst, FstBuilderNode *src);
|
||||
|
||||
#endif
|
||||
|
|
|
@ -54,5 +54,4 @@ FstRegistry* fstRegistryCreate(uint64_t tableSize, uint64_t mruSize);
|
|||
|
||||
FstRegistryEntry* fstRegistryGetEntry(FstRegistry *registry, FstBuilderNode *bNode);
|
||||
|
||||
uint64_t fstRegistryHash(FstRegistry *registry, FstBuilderNode *node);
|
||||
#endif
|
||||
|
|
|
@ -22,6 +22,26 @@ FstBuilderNode *fstBuilderNodeDefault() {
|
|||
return bn;
|
||||
}
|
||||
|
||||
FstBuilderNode *fstBuilderNodeClone(FstBuilderNode *src) {
|
||||
FstBuilderNode *node = malloc(sizeof(FstBuilderNode));
|
||||
if (node == NULL) { return NULL; }
|
||||
|
||||
|
||||
size_t sz = taosArrayGetSize(src->trans);
|
||||
SArray *trans = taosArrayInit(sz, sizeof(FstTransition));
|
||||
|
||||
for (size_t i = 0; i < sz; i++) {
|
||||
FstTransition *tran = taosArrayGet(src->trans, i);
|
||||
FstTransition t = *tran;
|
||||
taosArrayPush(trans, &t);
|
||||
}
|
||||
|
||||
node->trans = trans;
|
||||
node->isFinal = src->isFinal;
|
||||
node->finalOutput = src->finalOutput;
|
||||
return node;
|
||||
|
||||
}
|
||||
// not destroy src, User's bussiness
|
||||
void fstBuilderNodeCloneFrom(FstBuilderNode *dst, FstBuilderNode *src) {
|
||||
if (dst == NULL || src == NULL) { return; }
|
||||
|
|
Loading…
Reference in New Issue