update json_t source

This commit is contained in:
2024-08-14 00:11:02 +02:00
parent 82bd866824
commit 494b835d11
2 changed files with 142 additions and 2 deletions
+140
View File
@@ -516,6 +516,64 @@ long get_size_(struct js_value *js){
long move_current_iter_to_index_(struct js_value *js, size_t index){
if(js->code_type < jstype_object) return -1;
if(js->code_type == jstype_object){
struct js_iterator *iter = js->type.object.iter;
if(index == js->type.object.index) return index;
long size = iter->size;
if(index >= size ){
iter->current = iter->end;
return size - 1;
}
long from_current_index = iter->current->type.object.index - index;
size_t abs_cur_diff = abs(from_current_index);
size_t array_diff_index[3] = {index, abs_cur_diff , size - 1 - index};
size_t index_nearest = ARG_MIN_ARRAY_TYPE_SIZE_T(array_diff_index, 3);
if(index_nearest == 0){
iter->current = iter->begin;
for(size_t i=0; i<array_diff_index[0]; ++i) iter->current = iter->current->type.object.next_object;//next_(iter->current);
}
else if(index_nearest == 2){
iter->current = iter->end;
for(size_t i=0; i < array_diff_index[2]; ++i) iter->current = iter->current->type.object.prev_object;//prev_(iter->current);
}else if(from_current_index >= 0)
for(size_t i=0; i < array_diff_index[1]; ++i) iter->current = iter->current->type.object.prev_object;//prev_(iter->current); prev_(iter->current);
else
for(size_t i=0; i < array_diff_index[1]; ++i) iter->current = iter->current->type.object.next_object;//next_(iter->current); next_(iter->current);
return index;
}else{
struct js_iterator *iter = js->type.array.iter;
if(index == js->type.array.index) return index;
long size = iter->size;
if(index >= size ){
iter->current = iter->end;
return size - 1;
}
long from_current_index = iter->current->type.array.index - index;
size_t abs_cur_diff = abs(from_current_index);
size_t array_diff_index[3] = {index, abs_cur_diff , size - 1 - index};
size_t index_nearest = ARG_MIN_ARRAY_TYPE_SIZE_T(array_diff_index, 3);
if(index_nearest == 0){
iter->current = iter->begin;
for(size_t i=0; i<array_diff_index[0]; ++i) iter->current = iter->current->type.array.next_element;//next_(iter->current);
}
else if(index_nearest == 2){
iter->current = iter->end;
for(size_t i=0; i < array_diff_index[2]; ++i) iter->current = iter->current->type.array.prev_element;//prev_(iter->current);
}else if(from_current_index >= 0)
for(size_t i=0; i < array_diff_index[1]; ++i) iter->current = iter->current->type.array.prev_element;//prev_(iter->current); prev_(iter->current);
else
for(size_t i=0; i < array_diff_index[1]; ++i) iter->current = iter->current->type.array.next_element;//next_(iter->current); next_(iter->current);
return index;
}
#if 0
struct js_iterator *iter = get_iterator_(js);
if(index == get_index_(iter->current)) return index;
//if(js->begin_list == NULL) return 0;
@@ -543,6 +601,7 @@ long move_current_iter_to_index_(struct js_value *js, size_t index){
for(size_t i=0; i < array_diff_index[1]; ++i) iter->current = next_(iter->current);
return index;
#endif
}
struct js_value * get_js_value_of_index_(size_t index, struct js_value *js){
@@ -741,6 +800,80 @@ void add_js_value_index(size_t index, struct js_value *js_to_add, struct js_valu
}
}
void delete_index_js_value(size_t index, struct js_value **js_org){
if((*js_org)->code_type >= jstype_object){
struct js_value *ttmp=NULL;
ttmp = get_js_value_of_index_(index, *js_org);
if((*js_org)->code_type == jstype_object){
struct js_iterator *iter = (*js_org)->type.object.iter;
struct js_value *prevJS = ttmp->type.object.prev_object;
struct js_value *nextJS = ttmp->type.object.next_object;
if(prevJS){
prevJS->type.object.next_object = nextJS;
}else{
iter->begin = nextJS;
}
if(iter->current == ttmp){
iter->current = (nextJS ? nextJS : prevJS) ;
}
if(nextJS){
nextJS->type.object.prev_object = prevJS;
ttmp->type.object.next_object = NULL;
}else{
iter->end == prevJS;
}
if(ttmp == *js_org){
*js_org = nextJS;
}
while(nextJS){
--(nextJS->type.object.index);
nextJS = nextJS->type.object.next_object;
}
--(iter->size);
free_js_value(ttmp);
}else{
struct js_iterator *iter = (*js_org)->type.array.iter;
struct js_value *prevJS = ttmp->type.array.prev_element;
struct js_value *nextJS = ttmp->type.array.next_element;
if(prevJS){
prevJS->type.array.next_element = nextJS;
}else{
iter->begin = nextJS;
}
if(iter->current == ttmp){
iter->current = (nextJS ? nextJS : prevJS) ;
}
if(nextJS){
nextJS->type.array.prev_element = prevJS;
ttmp->type.array.next_element = NULL;
}else{
iter->end == prevJS;
}
if(ttmp == *js_org){
*js_org = nextJS;
}
while(nextJS){
--(nextJS->type.array.index);
nextJS = nextJS->type.array.next_element;
}
--(iter->size);
free_js_value(ttmp);
}
}
}
struct js_iterator * get_iterator_(struct js_value *js){
if(js->code_type == jstype_object) return js->type.object.iter;
if(js->code_type == jstype_array) return js->type.array.iter;
@@ -857,6 +990,7 @@ struct js_value *get_js_value_of_key(char * key, struct js_value *js ){
struct js_value *tmp = js;
while(tmp){
if(strncmp(key,tmp->type.object.key, tmp->type.object.key_length) == 0){
js->type.object.iter->current = tmp;
return tmp; //tmp->type.object.value == value_of_(tmp);
}
tmp = next_(tmp);
@@ -864,6 +998,12 @@ struct js_value *get_js_value_of_key(char * key, struct js_value *js ){
}
return NULL;
}
void delete_key_js_value(char * key, struct js_value **js_org){
struct js_value *js = get_js_value_of_key(key, *js_org);
if(js){
delete_index_js_value(js->type.object.index, js_org);
}
}
/*
void set_value_of_key(char *key, char * value, struct js_value *js ){
+2 -2
View File
@@ -88,8 +88,6 @@ struct js_value {
struct js_array array;
} type;
struct js_value * parent;
// struct js_value * next;
// struct js_value * prev;
};
@@ -115,6 +113,7 @@ struct js_value * create_js_value_array(char * input, struct js_value * parent);
struct js_iterator * create_js_iterator(struct js_value * js);
void add_js_value_index(size_t index, struct js_value *js_to_add, struct js_value **js_org);
void delete_key_js_value(char * key, struct js_value **js_org);
void print_value(struct js_value *js);
@@ -124,6 +123,7 @@ struct js_value *get_js_value_of_key(char * key, struct js_value *js );
struct js_iterator * get_iterator_(struct js_value *js);
void append_js_value(struct js_value *dst, char *input);
void delete_index_js_value(size_t index, struct js_value **js_org);
struct js_value * value_of_(struct js_value * js);