f136a0f401
FossilOrigin-Name: 8aeb5208592d4c31a07b3eba10aa247483f9648fbaba38eb844cb02e074f31b9
74 lines
1.1 KiB
C
74 lines
1.1 KiB
C
#include "ktv.h"
|
|
|
|
void * ktvn(struct mavl *t ,const void *search)
|
|
{
|
|
|
|
struct mavlnode *n,/**lastl,*/*lastb;
|
|
lastb = NULL; /*lastl=NULL;*/
|
|
n = t->root;
|
|
while(n){
|
|
int rc;
|
|
/* const cw_KTV_t;*//* *c1,*c2;*/
|
|
/*c1=search;
|
|
c2=mavlnode_dataptr(n);
|
|
*/
|
|
|
|
rc = t->cmp(search,mavlnode_dataptr(n));
|
|
|
|
/*printf("Compare: %s %s = %d\n",c1->key,c2->key, rc);*/
|
|
|
|
if (rc==0){
|
|
return NULL;
|
|
|
|
}
|
|
|
|
if (rc<0){
|
|
/*lastl = n;*/
|
|
if (n->left==NULL){
|
|
return mavlnode_dataptr(lastb);
|
|
|
|
}
|
|
n=n->left;
|
|
}
|
|
else{
|
|
lastb=n;
|
|
if(n->right==NULL){
|
|
return mavlnode_dataptr(lastb);
|
|
|
|
}
|
|
n=n->right;
|
|
}
|
|
}
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int cw_ktv_idx_get(mavl_t ktv, const char *key, int idx, const cw_Type_t * type)
|
|
{
|
|
char ikey[CW_KTV_MAX_KEY_LEN];
|
|
cw_KTV_t search, * result;
|
|
char *d;
|
|
|
|
sprintf(ikey,"%s.%d",key,65536);
|
|
|
|
search.key=ikey;
|
|
result = ktvn(ktv,&search);
|
|
|
|
if (result == NULL){
|
|
return -1;
|
|
}
|
|
|
|
d = strchr(result->key,'.');
|
|
if (d==NULL){
|
|
return -1;
|
|
}
|
|
|
|
if (strncmp(result->key,ikey,d-result->key)!=0)
|
|
return -1;
|
|
|
|
return atoi(d+1);
|
|
}
|