add fuzzy search
This commit is contained in:
parent
aae1ba31ac
commit
6256e6f288
|
@ -67,9 +67,6 @@ uint32_t regexAutomStart(FstRegex *regex);
|
||||||
bool regexAutomIsMatch(FstRegex *regex, uint32_t state);
|
bool regexAutomIsMatch(FstRegex *regex, uint32_t state);
|
||||||
bool regexAutomCanMatch(FstRegex *regex, uint32_t state, bool null);
|
bool regexAutomCanMatch(FstRegex *regex, uint32_t state, bool null);
|
||||||
bool regexAutomAccept(FstRegex *regex, uint32_t state, uint8_t byte, uint32_t *result);
|
bool regexAutomAccept(FstRegex *regex, uint32_t state, uint8_t byte, uint32_t *result);
|
||||||
// void regexSetup(FstRegex *regex, uint32_t size, const char *str);
|
|
||||||
|
|
||||||
// uint32_t regexStart()
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,9 +23,9 @@ extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
typedef struct FstSparseSet {
|
typedef struct FstSparseSet {
|
||||||
SArray *dense;
|
uint32_t *dense;
|
||||||
SArray *sparse;
|
uint32_t *sparse;
|
||||||
int32_t size;
|
int32_t size;
|
||||||
} FstSparseSet;
|
} FstSparseSet;
|
||||||
|
|
||||||
FstSparseSet *sparSetCreate(int32_t sz);
|
FstSparseSet *sparSetCreate(int32_t sz);
|
||||||
|
|
|
@ -21,47 +21,44 @@ FstSparseSet *sparSetCreate(int32_t sz) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
ss->dense = taosArrayInit(sz, sizeof(uint32_t));
|
ss->dense = (uint32_t *)taosMemoryCalloc(sz, sizeof(uint32_t));
|
||||||
ss->sparse = taosArrayInit(sz, sizeof(uint32_t));
|
ss->sparse = (uint32_t *)taosMemoryCalloc(sz, sizeof(uint32_t));
|
||||||
ss->size = sz;
|
ss->size = 0;
|
||||||
return ss;
|
return ss;
|
||||||
}
|
}
|
||||||
void sparSetDestroy(FstSparseSet *ss) {
|
void sparSetDestroy(FstSparseSet *ss) {
|
||||||
if (ss == NULL) {
|
if (ss == NULL) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
taosArrayDestroy(ss->dense);
|
taosMemoryFree(ss->dense);
|
||||||
taosArrayDestroy(ss->sparse);
|
taosMemoryFree(ss->sparse);
|
||||||
taosMemoryFree(ss);
|
taosMemoryFree(ss);
|
||||||
}
|
}
|
||||||
uint32_t sparSetLen(FstSparseSet *ss) { return ss == NULL ? 0 : ss->size; }
|
uint32_t sparSetLen(FstSparseSet *ss) {
|
||||||
|
// Get occupied size
|
||||||
|
return ss == NULL ? 0 : ss->size;
|
||||||
|
}
|
||||||
uint32_t sparSetAdd(FstSparseSet *ss, uint32_t ip) {
|
uint32_t sparSetAdd(FstSparseSet *ss, uint32_t ip) {
|
||||||
if (ss == NULL) {
|
if (ss == NULL) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
uint32_t i = ss->size;
|
uint32_t i = ss->size;
|
||||||
taosArraySet(ss->dense, i, &ip);
|
ss->dense[i] = ip;
|
||||||
taosArraySet(ss->sparse, ip, &i);
|
ss->sparse[ip] = i;
|
||||||
ss->size += 1;
|
ss->size += 1;
|
||||||
return i;
|
return i;
|
||||||
}
|
}
|
||||||
uint32_t sparSetGet(FstSparseSet *ss, uint32_t i) {
|
uint32_t sparSetGet(FstSparseSet *ss, uint32_t i) {
|
||||||
if (i >= taosArrayGetSize(ss->dense)) {
|
// check later
|
||||||
return 0;
|
return ss->dense[i];
|
||||||
}
|
|
||||||
uint32_t *v = taosArrayGet(ss->dense, i);
|
|
||||||
return *v;
|
|
||||||
}
|
}
|
||||||
bool sparSetContains(FstSparseSet *ss, uint32_t ip) {
|
bool sparSetContains(FstSparseSet *ss, uint32_t ip) {
|
||||||
if (ip >= taosArrayGetSize(ss->sparse)) {
|
uint32_t i = ss->sparse[ip];
|
||||||
|
if (i < ss->size && ss->dense[i] == ip) {
|
||||||
|
return true;
|
||||||
|
} else {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
uint32_t i = *(uint32_t *)taosArrayGet(ss->sparse, ip);
|
|
||||||
if (i >= taosArrayGetSize(ss->dense)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
uint32_t v = *(uint32_t *)taosArrayGet(ss->dense, i);
|
|
||||||
return v == ip;
|
|
||||||
}
|
}
|
||||||
void sparSetClear(FstSparseSet *ss) {
|
void sparSetClear(FstSparseSet *ss) {
|
||||||
if (ss == NULL) {
|
if (ss == NULL) {
|
||||||
|
|
Loading…
Reference in New Issue