Almost all ktv stuff deleted
This commit is contained in:
@ -79,36 +79,43 @@ CWSRC=\
|
||||
# cw_process_element.c\
|
||||
|
||||
KTVSRC=\
|
||||
cw_ktv_add.c\
|
||||
cw_ktv_cast.c\
|
||||
cw_ktv_replace.c\
|
||||
cfg.c\
|
||||
|
||||
|
||||
# cw_ktv_add.c\
|
||||
cw_ktv_idx_get.c\
|
||||
cw_ktv_mavlcmp.c\
|
||||
cw_ktv_mavlcmp_type_by_name.c\
|
||||
cw_ktv_mavldel.c\
|
||||
|
||||
|
||||
# cw_ktv_parser.c\
|
||||
# cw_ktv_del_sub.c\
|
||||
# cw_ktv_base_exists.c\
|
||||
cw_ktv_add_from_str.c\
|
||||
cw_ktv_get_byte.c\
|
||||
cw_ktv_read_file.c\
|
||||
cw_ktv_readline.c\
|
||||
cw_ktv_save.c\
|
||||
cw_ktv_std_types.c\
|
||||
cw_ktv_read_struct.c\
|
||||
cw_ktv_write_struct.c\
|
||||
|
||||
# cw_ktv_get_byte.c\
|
||||
cw_ktv_get_bool.c\
|
||||
cw_ktv_get_bstr16.c\
|
||||
cw_ktv_set_byte.c\
|
||||
cw_ktv_set_word.c\
|
||||
cw_ktv_set_dword.c\
|
||||
cw_ktv_get.c\
|
||||
cw_ktv_get_word.c\
|
||||
|
||||
# cw_ktv_get_word.c\
|
||||
cw_ktv_get_dword.c\
|
||||
cw_ktv_get_sysptr.c\
|
||||
cw_ktv_get_str.c\
|
||||
cw_ktv_idx_get.c\
|
||||
cw_ktv_mavlcmp.c\
|
||||
cw_ktv_mavlcmp_type_by_name.c\
|
||||
cw_ktv_mavldel.c\
|
||||
cw_ktv_read_file.c\
|
||||
cw_ktv_readline.c\
|
||||
cw_ktv_read_struct.c\
|
||||
cw_ktv_write_struct.c\
|
||||
cw_ktv_std_types.c\
|
||||
cw_ktv_save.c\
|
||||
cfg.c\
|
||||
|
||||
# cw_ktv_parser.c\
|
||||
# cw_ktv_del_sub.c\
|
||||
# cw_ktv_base_exists.c\
|
||||
# cw_ktv_cast.c\
|
||||
cw_ktv_replace.c\
|
||||
cw_ktv_get.c\
|
||||
|
||||
|
||||
LWSRC=\
|
||||
lw_addelem.c\
|
||||
|
43
src/cw/cfg.c
43
src/cw/cfg.c
@ -495,12 +495,18 @@ int cw_cfg_write_to_file(FILE *f, cw_Cfg_t * cfg)
|
||||
}
|
||||
|
||||
|
||||
int cw_cfg_save(const char *filename, cw_Cfg_t *cfg)
|
||||
int cw_cfg_save(const char *filename, cw_Cfg_t *cfg, const char *format, ...)
|
||||
{
|
||||
int rc;
|
||||
FILE *f = fopen(filename, "wb");
|
||||
if (!f)
|
||||
return errno;
|
||||
if (format !=NULL){
|
||||
va_list args;
|
||||
va_start(args,format);
|
||||
vfprintf(f,format,args);
|
||||
va_end(args);
|
||||
}
|
||||
rc = cw_cfg_write_to_file(f, cfg);
|
||||
fclose(f);
|
||||
|
||||
@ -519,7 +525,7 @@ void cw_cfg_iter_init(cw_Cfg_t * cfg, struct cw_Cfg_iter *cfi, const char *base)
|
||||
}
|
||||
|
||||
|
||||
const char *cw_cfg_iter_next(struct cw_Cfg_iter *cfi, const char *key)
|
||||
struct cw_Cfg_entry *cw_cfg_iter_next(struct cw_Cfg_iter *cfi, const char *nnkey)
|
||||
{
|
||||
struct cw_Cfg_entry *e;
|
||||
int bl, kl;
|
||||
@ -541,7 +547,7 @@ const char *cw_cfg_iter_next(struct cw_Cfg_iter *cfi, const char *key)
|
||||
return NULL;
|
||||
else {
|
||||
mavliter_next(&(cfi->it));
|
||||
return e->val;
|
||||
return e;
|
||||
}
|
||||
|
||||
}
|
||||
@ -556,7 +562,7 @@ const char *cw_cfg_iter_next(struct cw_Cfg_iter *cfi, const char *key)
|
||||
return NULL;
|
||||
|
||||
mavliter_next(&(cfi->it));
|
||||
return e->val;
|
||||
return e;
|
||||
}
|
||||
|
||||
|
||||
@ -686,22 +692,45 @@ void cw_cfg_copy(cw_Cfg_t *src, cw_Cfg_t *dst)
|
||||
int exists;
|
||||
struct cw_Cfg_entry * old_elem,*e, new_elem;
|
||||
|
||||
|
||||
e = mavliter_get(&it);
|
||||
new_elem.key = cw_strdup(e->key);
|
||||
new_elem.val = cw_strdup(e->val);
|
||||
|
||||
/* if (1){
|
||||
const char *ov;
|
||||
ov = cw_cfg_get(dst,e->key,NULL);
|
||||
cw_dbg(DBG_X, " REAL OV HERE: %s",ov);
|
||||
}
|
||||
*/
|
||||
|
||||
|
||||
old_elem = mavl_insert(dst,&new_elem,&exists);
|
||||
|
||||
/* cw_dbg(DBG_X, "CPY: %s: %s -> %s [%d]",new_elem.key,new_elem.val,old_elem->val,exists);
|
||||
if (exists){
|
||||
const char *ov;
|
||||
ov = cw_cfg_get(dst,e->key,NULL);
|
||||
cw_dbg(DBG_X, " OV HERE: %s",ov);
|
||||
}
|
||||
*/
|
||||
|
||||
if (!exists){
|
||||
cw_dbg(DBG_X, "New: %s: %s",new_elem.key,new_elem.val);
|
||||
|
||||
|
||||
cw_dbg(DBG_CFG_SET, "New: %s: %s",new_elem.key,new_elem.val);
|
||||
continue;
|
||||
}
|
||||
|
||||
|
||||
|
||||
if (strcmp(new_elem.val,old_elem->val)==0){
|
||||
free((void*)new_elem.key);
|
||||
free((void*)new_elem.val);
|
||||
continue;
|
||||
}
|
||||
|
||||
cw_dbg(DBG_X, "Replace: %s: %s (old: %s)",new_elem.key, new_elem.val, old_elem->val);
|
||||
cw_dbg(DBG_CFG_SET, "Replace: %s: %s (old: %s)",new_elem.key, new_elem.val, old_elem->val);
|
||||
if(dst->del){
|
||||
dst->del(old_elem);
|
||||
}
|
||||
@ -753,7 +782,7 @@ int cw_cfg_base_exists_l(cw_Cfg_t ** cfgs, const char *key)
|
||||
if (cw_cfg_base_exists(cfgs[i],key))
|
||||
return 1;
|
||||
}
|
||||
cw_dbg(DBG_X,"NOX EXISIS: %s in %d",key,i);
|
||||
// cw_dbg(DBG_X,"NOX EXISIS: %s in %d",key,i);
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
@ -28,7 +28,7 @@ struct cw_Cfg_iter{
|
||||
|
||||
const char * cw_cfg_get(cw_Cfg_t * cfg, const char *key, const char *def);
|
||||
|
||||
const char *cw_cfg_iter_next(struct cw_Cfg_iter *cfi, const char *key);
|
||||
struct cw_Cfg_entry *cw_cfg_iter_next(struct cw_Cfg_iter *cfi, const char *key);
|
||||
void cw_cfg_iter_init(cw_Cfg_t * cfg, struct cw_Cfg_iter *cfi, const char *base);
|
||||
|
||||
int cw_cfg_get_bool(cw_Cfg_t * cfg, const char * key, int def);
|
||||
@ -46,7 +46,7 @@ int cw_cfg_base_exists(cw_Cfg_t * cfg, const char *key);
|
||||
uint8_t cw_cfg_get_byte_l(cw_Cfg_t ** cfgs, char *key, uint8_t def);
|
||||
cw_Val_t * cw_cfg_get_val_l(cw_Cfg_t ** cfgs, const char *key, const struct cw_Type *type);
|
||||
int cw_cfg_base_exists_l(cw_Cfg_t ** cfgs, const char *key);
|
||||
int cw_cfg_save(const char *filename, cw_Cfg_t *cfg);
|
||||
int cw_cfg_save(const char *filename, cw_Cfg_t *cfg, const char *format, ...);
|
||||
|
||||
|
||||
|
||||
|
@ -59,7 +59,6 @@ void cw_conn_init(struct cw_Conn * conn)
|
||||
conn->msg_callbacks = mavl_create(msg_callback_cmp,NULL,sizeof(struct msg_callback));
|
||||
|
||||
conn->update_cfg = cw_cfg_create();
|
||||
cw_dbg(DBG_X,"Update CFG ist %p",conn->update_cfg);
|
||||
conn->remote_cfg = cw_cfg_create();
|
||||
conn->local_cfg = cw_cfg_create();
|
||||
}
|
||||
|
@ -7,12 +7,11 @@ int cw_in_generic_with_index(struct cw_ElemHandler *eh,
|
||||
{
|
||||
char key[CW_CFG_MAX_KEY_LEN];
|
||||
int idx;
|
||||
struct cw_Type * type = (struct cw_Type*)eh->type;
|
||||
|
||||
cw_dbg(DBG_X,"Fix cw_in_generic_with_index");
|
||||
stop();
|
||||
idx = cw_get_byte(data);
|
||||
sprintf(key,"%s.%d",eh->key,idx);
|
||||
// cw_cfg_add(params->cfg,key,eh->type,NULL,data+1,len-1);
|
||||
|
||||
type->read(params->cfg,key,data+1,len-1,eh->param);
|
||||
return 1;
|
||||
}
|
||||
|
@ -1,43 +0,0 @@
|
||||
#include "val.h"
|
||||
#include "cw.h"
|
||||
|
||||
#include "log.h"
|
||||
#include "dbg.h"
|
||||
|
||||
cw_Val_t * cw_ktv_add(mavl_t kvtstore, const char *key, const struct cw_Type *type,
|
||||
const void * valguard,
|
||||
const uint8_t * data, int len)
|
||||
{
|
||||
cw_Val_t mdata, *mresult;
|
||||
int exists;
|
||||
mdata.key=cw_strdup(key);
|
||||
mdata.valguard=valguard;
|
||||
|
||||
if (!mdata.key){
|
||||
cw_log(LOG_ERR, "Can't allocate memory for KTV key %s: %s",
|
||||
key,strerror(errno));
|
||||
return NULL;
|
||||
}
|
||||
|
||||
|
||||
mresult = type->get(&mdata,data,len);
|
||||
if (!mresult){
|
||||
cw_log(LOG_ERR, "Can't create kvstore element for key %s of type %s: %s",
|
||||
key,type->name, strerror(errno));
|
||||
free(mdata.key);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
mavl_del(kvtstore,&mdata);
|
||||
mresult = mavl_insert(kvtstore, &mdata, &exists);
|
||||
if (exists){
|
||||
cw_log(LOG_ERR, "Element already exists %s", key);
|
||||
/* element already exists */
|
||||
free(mdata.key);
|
||||
if (type->del)
|
||||
type->del(&mdata);
|
||||
return mresult;
|
||||
}
|
||||
|
||||
return mresult;
|
||||
}
|
@ -1,45 +0,0 @@
|
||||
#include "val.h"
|
||||
#include "cw.h"
|
||||
|
||||
#include "log.h"
|
||||
#include "dbg.h"
|
||||
|
||||
const char * cw_ktv_add_from_str(mavl_t kvtstore, const char *key,
|
||||
const struct cw_Type *type,
|
||||
const void * valguard,
|
||||
const char * str)
|
||||
{
|
||||
cw_Val_t mdata, *mresult;
|
||||
int exists;
|
||||
|
||||
/* cw_dbg(DBG_ELEM,"KVStore (%p,%d) add elem (%s): %s", kvstore, kvstore->count,
|
||||
type->name, key );
|
||||
*/
|
||||
mdata.key=cw_strdup(key);
|
||||
mdata.valguard=valguard;
|
||||
if (!mdata.key){
|
||||
cw_log(LOG_ERR, "Can't allocate memory for key %s: %s",
|
||||
key,strerror(errno));
|
||||
return NULL;
|
||||
}
|
||||
|
||||
mresult = type->from_str(&mdata,str);
|
||||
if (!mresult){
|
||||
cw_log(LOG_ERR, "Can't create kvstore element for key %s of type %s: %s",
|
||||
key,type->name, strerror(errno));
|
||||
free(mdata.key);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
mresult = mavl_insert(kvtstore, &mdata, &exists);
|
||||
if (exists){
|
||||
cw_log(LOG_ERR, "Element already exists %s", key);
|
||||
/* element already exists */
|
||||
free(mdata.key);
|
||||
if (type->del)
|
||||
type->del(&mdata);
|
||||
return key;
|
||||
}
|
||||
|
||||
return mdata.key;
|
||||
}
|
@ -1,29 +0,0 @@
|
||||
#include "val.h"
|
||||
/**
|
||||
* @file
|
||||
* @description Implementation of cw_ktv_base_exisits
|
||||
*/
|
||||
|
||||
|
||||
/**
|
||||
* @brief Check if elements with e certain baskey can be found in
|
||||
* in ktvstore.
|
||||
* @param ktvstore ktvstore to search in
|
||||
* @param basekey basekey to search for
|
||||
* @return The first ktv element belonging to the base eky,
|
||||
* otherwise NULL if no element was found.
|
||||
*
|
||||
*/
|
||||
cw_Val_t * cw_ktv_base_exists(mavl_t ktvstore, const char *basekey)
|
||||
{
|
||||
cw_Val_t * result, search;
|
||||
search.key=(char*)basekey;
|
||||
result = mavl_get_first(ktvstore,&search);
|
||||
if (result == NULL)
|
||||
return NULL;
|
||||
|
||||
if (strncmp(result->key,basekey,strlen(basekey))==0)
|
||||
return result;
|
||||
|
||||
return NULL;
|
||||
}
|
@ -1,14 +0,0 @@
|
||||
#include "val.h"
|
||||
|
||||
cw_Val_t * cw_ktv_cast(cw_Val_t *v,const cw_Type_t * type)
|
||||
{
|
||||
if (strcmp(v->type->name,type->name)==0)
|
||||
return v;
|
||||
if (type->cast==NULL)
|
||||
return NULL;
|
||||
if (!type->cast(v))
|
||||
return NULL;
|
||||
|
||||
return v;
|
||||
}
|
||||
|
@ -1,32 +0,0 @@
|
||||
|
||||
#include "val.h"
|
||||
#include "mavl.h"
|
||||
|
||||
/**
|
||||
* @brief Get a ktv value from a ktv store
|
||||
* @param ktv ktv store
|
||||
* @param key key to search for
|
||||
* @param type type to match
|
||||
* @return A pointer to a #cw_Val_t element, found in the ktv store or
|
||||
* NULL if no element with matching key/type is found.
|
||||
*/
|
||||
cw_Val_t * cw_ktv_get(mavl_t ktv, const char *key, const cw_Type_t * type)
|
||||
{
|
||||
cw_Val_t search, *result;
|
||||
/* we can safely cast from const char * to char *, because
|
||||
* we never will use the search varaiable to store ktv values */
|
||||
search.key=(char*)key;
|
||||
|
||||
result = mavl_get(ktv,&search);
|
||||
if (result == NULL){
|
||||
return NULL;
|
||||
}
|
||||
if (type == NULL){
|
||||
return result;
|
||||
}
|
||||
if (strcmp(type->name,result->type->name)==0){
|
||||
return result;
|
||||
}
|
||||
|
||||
return NULL;
|
||||
}
|
@ -1,11 +0,0 @@
|
||||
#include "val.h"
|
||||
|
||||
uint8_t cw_ktv_get_bool(mavl_t ktv,const char *key, uint8_t def)
|
||||
{
|
||||
cw_Val_t * k;
|
||||
k = cw_ktv_get(ktv,key,CW_TYPE_BOOL);
|
||||
if (k != NULL){
|
||||
return k->val.boolean;
|
||||
}
|
||||
return def;
|
||||
}
|
@ -1,13 +0,0 @@
|
||||
#include "val.h"
|
||||
#include "bstr.h"
|
||||
|
||||
bstr16_t cw_ktv_get_bstr16(mavl_t ktv,const char *key, bstr16_t def)
|
||||
{
|
||||
cw_Val_t * k;
|
||||
k = cw_ktv_get(ktv,key,CW_TYPE_BSTR16);
|
||||
if (k != NULL){
|
||||
return bstr16_create(k->type->data(k),k->type->len(k));
|
||||
}
|
||||
return def;
|
||||
}
|
||||
|
@ -1,11 +0,0 @@
|
||||
#include "val.h"
|
||||
|
||||
uint8_t cw_ktv_get_byte(mavl_t ktv,const char *key, uint8_t def)
|
||||
{
|
||||
cw_Val_t * k;
|
||||
k = cw_ktv_get(ktv,key,CW_TYPE_BYTE);
|
||||
if (k != NULL){
|
||||
return k->val.byte;
|
||||
}
|
||||
return def;
|
||||
}
|
@ -1,11 +0,0 @@
|
||||
#include "val.h"
|
||||
|
||||
uint32_t cw_ktv_get_dword(mavl_t ktv,const char *key, uint32_t def)
|
||||
{
|
||||
cw_Val_t * k;
|
||||
k = cw_ktv_get(ktv,key,CW_TYPE_DWORD);
|
||||
if (k != NULL){
|
||||
return k->val.dword;
|
||||
}
|
||||
return def;
|
||||
}
|
@ -1,11 +0,0 @@
|
||||
#include "val.h"
|
||||
|
||||
char * cw_ktv_get_str(mavl_t ktv,const char *key, char * def)
|
||||
{
|
||||
cw_Val_t * k;
|
||||
k = cw_ktv_get(ktv,key,CW_TYPE_STR);
|
||||
if (k != NULL){
|
||||
return k->val.ptr;
|
||||
}
|
||||
return def;
|
||||
}
|
@ -1,11 +0,0 @@
|
||||
#include "val.h"
|
||||
|
||||
void * cw_ktv_get_sysptr(mavl_t ktv,const char *key, void * def)
|
||||
{
|
||||
cw_Val_t * k;
|
||||
k = cw_ktv_get(ktv,key,CW_TYPE_SYSPTR);
|
||||
if (k != NULL){
|
||||
return k->val.ptr;
|
||||
}
|
||||
return def;
|
||||
}
|
@ -1,11 +0,0 @@
|
||||
#include "val.h"
|
||||
|
||||
uint16_t cw_ktv_get_word(mavl_t ktv,const char *key, uint16_t def)
|
||||
{
|
||||
cw_Val_t * k;
|
||||
k = cw_ktv_get(ktv,key,CW_TYPE_WORD);
|
||||
if (k != NULL){
|
||||
return k->val.word;
|
||||
}
|
||||
return def;
|
||||
}
|
@ -1,126 +0,0 @@
|
||||
#include "val.h"
|
||||
#include "cfg.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_Val_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->s[0]==NULL){
|
||||
return mavlnode_dataptr(lastb);
|
||||
|
||||
}
|
||||
n=n->s[0];
|
||||
}
|
||||
else{
|
||||
lastb=n;
|
||||
if(n->s[1]==NULL){
|
||||
return mavlnode_dataptr(lastb);
|
||||
|
||||
}
|
||||
n=n->s[1];
|
||||
}
|
||||
}
|
||||
return NULL;
|
||||
|
||||
}
|
||||
|
||||
int cw_ktv_idx_get(mavl_t ktv, const char *key)
|
||||
{
|
||||
char ikey[CW_CFG_MAX_KEY_LEN];
|
||||
cw_Val_t search, * result;
|
||||
char *d;
|
||||
|
||||
sprintf(ikey,"%s.%d",key,65536);
|
||||
|
||||
search.key=ikey;
|
||||
/*//result = ktvn(ktv,&search);*/
|
||||
|
||||
result = mavl_get_last(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);
|
||||
}
|
||||
|
||||
|
||||
|
||||
int cw_ktv_idx_get_next(mavl_t ktv, const char *key, int n)
|
||||
{
|
||||
char ikey[CW_CFG_MAX_KEY_LEN];
|
||||
cw_Val_t search, * result;
|
||||
char *d;
|
||||
int i;
|
||||
|
||||
sprintf(ikey,"%s.%d",key,n);
|
||||
|
||||
search.key=ikey;
|
||||
/*//result = ktvn(ktv,&search);*/
|
||||
|
||||
result = mavl_get_first(ktv,&search);
|
||||
|
||||
if (result == NULL){
|
||||
return -1;
|
||||
}
|
||||
|
||||
/*d = strchr(result->key,'.');*/
|
||||
d=NULL;
|
||||
/* for (i = strlen(result->key); i>=0; i--){
|
||||
if (result->key[i]=='/')
|
||||
break;
|
||||
}
|
||||
*/ for (i = strlen(ikey); i>=0; i--){
|
||||
|
||||
if (ikey[i]=='.'){
|
||||
d = result->key+i;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
if (d==NULL){
|
||||
return -1;
|
||||
}
|
||||
|
||||
if(result->key[i]!='.'){
|
||||
return -1;
|
||||
}
|
||||
|
||||
/* if (strncmp(result->key,ikey,d-result->key)!=0)
|
||||
return -1;
|
||||
*/
|
||||
if (strncmp(result->key,ikey,i)!=0)
|
||||
return -1;
|
||||
|
||||
|
||||
return atoi(result->key+i+1);
|
||||
}
|
@ -1,67 +0,0 @@
|
||||
|
||||
#include <ctype.h>
|
||||
|
||||
#include "val.h"
|
||||
/**
|
||||
* @brief Default function to compare two values of type #cw_Val_t.
|
||||
*
|
||||
* @param v1
|
||||
* @param v2
|
||||
* @return
|
||||
*/
|
||||
int cw_ktv_mavlcmp (const void *v1, const void *v2)
|
||||
{
|
||||
char *d1, *d2, *k1, *k2;
|
||||
int l1, l2, rc, i1, i2;
|
||||
|
||||
k1 = ( (cw_Val_t *) v1)->key;
|
||||
k2 = ( (cw_Val_t *) v2)->key;
|
||||
|
||||
while (1) {
|
||||
/* Find dots in both keys */
|
||||
d1 = strchr (k1, '.');
|
||||
d2 = strchr (k2, '.');
|
||||
|
||||
/* if there are no dots, compare keys as normal */
|
||||
if (d1 == NULL || d2 == NULL)
|
||||
return strcmp (k1, k2);
|
||||
|
||||
|
||||
/* calculate the length of the key till dots */
|
||||
l1 = d1 - k1; /*((cw_Val_t *) v1)->key;*/
|
||||
l2 = d2 - k2; /*((cw_Val_t *) v2)->key;*/
|
||||
|
||||
/* if length differs do a normal compare */
|
||||
if (l1 != l2) {
|
||||
return strcmp (k1, k2); /*((cw_Val_t *) v1)->key, ((cw_Val_t *) v2)->key);*/
|
||||
}
|
||||
|
||||
|
||||
rc = strncmp (k1, k2, l1); /*((cw_Val_t *) v1)->key,((cw_Val_t *) v2)->key,l1);*/
|
||||
|
||||
if (rc != 0) {
|
||||
return rc;
|
||||
}
|
||||
|
||||
d1++;
|
||||
d2++;
|
||||
i1 = atoi (d1);
|
||||
i2 = atoi (d2);
|
||||
|
||||
rc = i1 - i2;
|
||||
|
||||
if (rc != 0)
|
||||
return rc;
|
||||
|
||||
while (isdigit (*d1))
|
||||
d1++;
|
||||
|
||||
while (isdigit (*d2))
|
||||
d2++;
|
||||
|
||||
k1=d1;
|
||||
k2=d2;
|
||||
/*return strcmp(d1,d2);*/
|
||||
/*return cw_ktv_mavlcmp(d1,d2);*/
|
||||
}
|
||||
}
|
@ -1,8 +0,0 @@
|
||||
|
||||
#include "val.h"
|
||||
|
||||
int cw_ktv_mavlcmp_type_by_name (const void *v1, const void *v2)
|
||||
{
|
||||
return strcmp ( (*((struct cw_Type**) v1))->name,
|
||||
(*((struct cw_Type**) v2))->name);
|
||||
}
|
@ -1,14 +0,0 @@
|
||||
|
||||
#include <stdlib.h>
|
||||
|
||||
|
||||
#include "val.h"
|
||||
|
||||
void cw_ktv_mavldel(void *data)
|
||||
{
|
||||
struct cw_Val *ktv = data;
|
||||
if (ktv->type->del) {
|
||||
ktv->type->del(data);
|
||||
}
|
||||
free(ktv->key);
|
||||
}
|
@ -1,359 +0,0 @@
|
||||
#include <stdint.h>
|
||||
|
||||
#include "val.h"
|
||||
|
||||
|
||||
static int str_getc(struct cw_Val_Reader * r)
|
||||
{
|
||||
if (r->next==r->maxlen)
|
||||
return EOF;
|
||||
|
||||
return *((uint8_t*)(r->data)+r->next++);
|
||||
}
|
||||
|
||||
static void str_ungetc(struct cw_Val_Reader * r, int c)
|
||||
{
|
||||
if (r->next>0)
|
||||
r->next--;
|
||||
}
|
||||
|
||||
void cw_ktv_init_str_reader(struct cw_Val_Reader *r, const char * str, int len)
|
||||
{
|
||||
memset(r,0,sizeof(struct cw_Val_Reader));
|
||||
r->data = str;
|
||||
r->xgetchar=str_getc;
|
||||
r->ungetchar=str_ungetc;
|
||||
r->maxlen=len;
|
||||
}
|
||||
|
||||
#include <ctype.h>
|
||||
|
||||
#include "val.h"
|
||||
/*
|
||||
struct parser {
|
||||
int line;
|
||||
int pos;
|
||||
int prevpos;
|
||||
char error[256];
|
||||
int quote;
|
||||
FILE *f;
|
||||
int (*getc)(struct parser *);
|
||||
void (*ungetc)(struct parser *)
|
||||
};
|
||||
*/
|
||||
|
||||
|
||||
|
||||
static int get_char(struct cw_Val_Reader *r)
|
||||
{
|
||||
int c;
|
||||
c = r->xgetchar (r);
|
||||
r->pos++;
|
||||
if (c=='\n'){
|
||||
r->prevpos=r->pos;
|
||||
r->line ++;
|
||||
r->pos=0;
|
||||
}
|
||||
return c;
|
||||
}
|
||||
|
||||
|
||||
static void unget_char(struct cw_Val_Reader * r,int c){
|
||||
r->ungetchar(r,c);
|
||||
if (c=='\n'){
|
||||
r->line--;
|
||||
r->pos=r->prevpos;
|
||||
}
|
||||
else
|
||||
r->pos--;
|
||||
}
|
||||
|
||||
|
||||
|
||||
static int get_char_q(struct cw_Val_Reader *p)
|
||||
{
|
||||
int c;
|
||||
|
||||
while(1) {
|
||||
c = get_char(p);
|
||||
if (c==EOF || c=='\n')
|
||||
return c;
|
||||
|
||||
if(c=='"' && !p->quote){
|
||||
p->quote=1;
|
||||
continue;
|
||||
}
|
||||
if(c=='"' && p->quote){
|
||||
p->quote=0;
|
||||
continue;
|
||||
}
|
||||
break;
|
||||
}
|
||||
|
||||
|
||||
if (!p->quote)
|
||||
return c;
|
||||
|
||||
if (c!='\\')
|
||||
return c;
|
||||
|
||||
c = get_char(p);
|
||||
switch(c){
|
||||
case EOF:
|
||||
return c;
|
||||
case 'n':
|
||||
return '\n';
|
||||
|
||||
case '\\':
|
||||
return '\\';
|
||||
case '"':
|
||||
return '"';
|
||||
default:
|
||||
unget_char(p,c);
|
||||
return '\\';
|
||||
}
|
||||
|
||||
/* We will never reach here */
|
||||
/* return c;*/
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
static int skip_chars (struct cw_Val_Reader *r, const char * chars)
|
||||
{
|
||||
int c;
|
||||
|
||||
while ( (c = get_char (r)) != EOF) {
|
||||
if (strchr (chars, c))
|
||||
continue;
|
||||
return c;
|
||||
}
|
||||
return c;
|
||||
}
|
||||
|
||||
static int skip_to_chars (struct cw_Val_Reader *r, const char *chars)
|
||||
{
|
||||
int c;
|
||||
|
||||
while ( (c = get_char (r)) != EOF) {
|
||||
if (strchr (chars, c))
|
||||
return c;
|
||||
}
|
||||
return c;
|
||||
}
|
||||
|
||||
|
||||
|
||||
static int read_key (struct cw_Val_Reader *r, char *key, int max_len)
|
||||
{
|
||||
int c,n;
|
||||
|
||||
do {
|
||||
c = skip_chars (r, " \t\n\a\v");
|
||||
if (c == '#') {
|
||||
c = skip_to_chars (r, "\n\a");
|
||||
} else {
|
||||
break;
|
||||
}
|
||||
} while (c != EOF);
|
||||
|
||||
unget_char(r,c);
|
||||
c=get_char_q(r);
|
||||
|
||||
n=0;
|
||||
while(c!=EOF && n<max_len){
|
||||
if (!r->quote && !isalnum(c) && !strchr("._/-()@#|{}[]\\",c)){
|
||||
unget_char(r,c);
|
||||
break;
|
||||
}
|
||||
|
||||
key[n]=c;
|
||||
c=get_char_q(r);
|
||||
n++;
|
||||
|
||||
}
|
||||
key[n]=0;
|
||||
return n;
|
||||
}
|
||||
|
||||
|
||||
static int skip_to_colon(struct cw_Val_Reader * r)
|
||||
{
|
||||
int c;
|
||||
c = skip_chars (r, " \t");
|
||||
if (c!=':' && c!='='){
|
||||
if (c=='\n'){
|
||||
unget_char(r,c);
|
||||
sprintf(r->error,"Unexpected EOL, colon or equal sign expected.");
|
||||
return -1;
|
||||
}
|
||||
sprintf(r->error,"Colon or equal sign expected.");
|
||||
return -1;
|
||||
}
|
||||
return c;
|
||||
}
|
||||
|
||||
|
||||
static int read_type(struct cw_Val_Reader * r, char *type, int max_len)
|
||||
{
|
||||
int c,n;
|
||||
|
||||
c = skip_to_colon(r);
|
||||
if (c==-1)
|
||||
return -1;
|
||||
if (c=='='){
|
||||
unget_char(r,c);
|
||||
return sprintf(type,"%s","Str");
|
||||
|
||||
}
|
||||
|
||||
c = skip_chars (r, " \t");
|
||||
|
||||
if (c==':'){
|
||||
unget_char(r,c);
|
||||
sprintf(type,"%s","Str");
|
||||
return 0;
|
||||
}
|
||||
|
||||
if (!isalpha(c)){
|
||||
if (c=='\n'){
|
||||
unget_char(r,c);
|
||||
/*sprintf(p->error,"Error at line %d, pos %d: Unexpected EOL.", p->line, p->pos);*/
|
||||
return -1;
|
||||
}
|
||||
|
||||
/*sprintf(p->error,"Error at line %d, pos %d: Letter expected.", p->line, p->pos);*/
|
||||
return -1;
|
||||
}
|
||||
|
||||
n=0;
|
||||
while(c!=EOF && n<max_len){
|
||||
if (!isalnum(c) && !strchr("_/-.()@#|{}[]",c)/*strchr(": \t\n\a",c)*/){
|
||||
unget_char(r,c);
|
||||
break;
|
||||
}
|
||||
|
||||
type[n]=c;
|
||||
c=get_char(r);
|
||||
n++;
|
||||
}
|
||||
type[n]=0;
|
||||
return n;
|
||||
}
|
||||
|
||||
|
||||
static int read_val(struct cw_Val_Reader *r, char *val, int max_len){
|
||||
int c,n,quote;
|
||||
c = skip_to_colon(r);
|
||||
if (c==-1)
|
||||
return -1;
|
||||
c = skip_chars (r, " \t");
|
||||
if (c=='"'){
|
||||
quote=1;
|
||||
c=get_char(r);
|
||||
}
|
||||
else{
|
||||
quote=0;
|
||||
}
|
||||
n=0;
|
||||
while(c!=EOF && n<max_len){
|
||||
if (quote && c=='"'){
|
||||
break;
|
||||
}
|
||||
if (c=='\n'){
|
||||
break;
|
||||
}
|
||||
if (quote){
|
||||
if (c=='\\'){
|
||||
c = get_char(r);
|
||||
switch(c){
|
||||
case 'n':
|
||||
c='\n';
|
||||
break;
|
||||
case '\\':
|
||||
break;
|
||||
case '"':
|
||||
break;
|
||||
default:
|
||||
unget_char(r,c);
|
||||
c='\\';
|
||||
}
|
||||
}
|
||||
}
|
||||
val[n++]=c;
|
||||
c=get_char(r);
|
||||
}
|
||||
|
||||
|
||||
if(!quote && n>0){
|
||||
while(n>0){
|
||||
if (isspace(val[n-1]))
|
||||
n--;
|
||||
else
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
val[n]=0;
|
||||
|
||||
return n;
|
||||
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
int cw_ktv_parse_line (FILE *f, char * key, char * type, char *val)
|
||||
{
|
||||
int n;
|
||||
|
||||
struct parser p;
|
||||
p.line=1;
|
||||
p.pos=0;
|
||||
p.prevpos=0;
|
||||
p.quote=0;
|
||||
p.f=f;
|
||||
|
||||
n = read_key (&p,key,CW_KTV_MAX_KEY_LEN);
|
||||
n = read_type (&p,type,CW_KTV_MAX_KEY_LEN);
|
||||
if (n==-1){
|
||||
return -1;
|
||||
}
|
||||
|
||||
n = read_val (&p,val,CW_KTV_MAX_KEY_LEN);
|
||||
if (n==-1){
|
||||
return -1;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
*/
|
||||
|
||||
|
||||
int cw_ktv_parse_line(struct cw_Val_Reader * r)
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
int cw_ktv_parse_string(struct cw_Val_Reader *r, char *key, char *type, char *val)
|
||||
{
|
||||
|
||||
int n;
|
||||
|
||||
|
||||
|
||||
n = read_key (r,key,CW_KTV_MAX_KEY_LEN);
|
||||
n = read_type(r,type,200);
|
||||
if (n==1)
|
||||
return -1;
|
||||
n = read_val(r,val,200);
|
||||
return n;
|
||||
|
||||
}
|
@ -1,40 +0,0 @@
|
||||
|
||||
#include "val.h"
|
||||
#include "cfg.h"
|
||||
|
||||
int cw_ktv_read_file(FILE * file, mavl_t ktv, mavl_t types)
|
||||
{
|
||||
char key[CW_CFG_MAX_KEY_LEN];
|
||||
char type[256];
|
||||
char val[2048];
|
||||
|
||||
|
||||
int rc;
|
||||
struct cw_Type typesearch, *cwtype;
|
||||
|
||||
|
||||
do {
|
||||
|
||||
rc = cw_ktv_read_line(file,key,type,val);
|
||||
if (rc != 0){
|
||||
continue;
|
||||
}
|
||||
|
||||
typesearch.name=type;
|
||||
|
||||
cwtype = mavl_get_ptr(types,&typesearch);
|
||||
if (cwtype != NULL){
|
||||
/*// printf("Yes! I know the type: %s\n",cwtype->name);*/
|
||||
}
|
||||
else {
|
||||
printf("Unknown type: %s\n",typesearch.name);
|
||||
continue;
|
||||
}
|
||||
|
||||
cw_ktv_add_from_str(ktv,key,cwtype,NULL,val);
|
||||
|
||||
|
||||
}while(rc==0);
|
||||
|
||||
return 0;
|
||||
}
|
@ -1,62 +0,0 @@
|
||||
#include "val.h"
|
||||
#include "dbg.h"
|
||||
#include "cfg.h"
|
||||
|
||||
int cw_ktv_read_struct(mavl_t ktv,const cw_ValStruct_t * stru, const char *pkey,
|
||||
uint8_t * data, int len)
|
||||
{
|
||||
char key[CW_CFG_MAX_KEY_LEN];
|
||||
int pos, i,l;
|
||||
cw_Val_t * result;
|
||||
|
||||
|
||||
pos=0; i=0;
|
||||
while (stru[i].type != NULL){
|
||||
char dbstr[100];
|
||||
if(stru[i].position!=-1)
|
||||
pos=stru[i].position;
|
||||
|
||||
if (stru[i].key!=NULL)
|
||||
sprintf(key,"%s/%s",pkey,stru[i].key);
|
||||
else
|
||||
sprintf(key,"%s",pkey);
|
||||
|
||||
switch (stru[i].len){
|
||||
case CW_KTVSTRUCT_L8:
|
||||
l = cw_get_byte(data+pos);
|
||||
pos ++;
|
||||
break;
|
||||
case CW_KTVSTRUCT_L16:
|
||||
l = cw_get_word(data+pos);
|
||||
pos ++;
|
||||
break;
|
||||
case -1:
|
||||
l = len-pos;
|
||||
break;
|
||||
default:
|
||||
l = stru[i].len;
|
||||
if (pos+l > len){
|
||||
l = len-pos;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
result = cw_ktv_add(ktv,key,stru[i].type,stru[i].valguard,data+pos,l);
|
||||
|
||||
stru[i].type->to_str(result,dbstr,100);
|
||||
cw_dbg(DBG_ELEM_DETAIL, "Read (%d): %s: %s",pos,key,dbstr);
|
||||
printf("READ STRUCT (%d): %s: %s\n",pos,key,dbstr);
|
||||
|
||||
if (stru[i].len==-1)
|
||||
l = result->type->len(result);
|
||||
else
|
||||
l = stru[i].len;
|
||||
|
||||
if(stru[i].position == -1)
|
||||
pos+=l;
|
||||
|
||||
i++;
|
||||
}
|
||||
|
||||
return pos;
|
||||
}
|
@ -1,306 +0,0 @@
|
||||
#include <ctype.h>
|
||||
|
||||
#include "val.h"
|
||||
#include "cfg.h"
|
||||
|
||||
struct parser {
|
||||
int line;
|
||||
int pos;
|
||||
int prevpos;
|
||||
char error[256];
|
||||
int quote;
|
||||
FILE *f;
|
||||
int (*getc)(struct parser *);
|
||||
void (*ungetc)(struct parser *);
|
||||
};
|
||||
|
||||
/*
|
||||
static int pgetc(struct parser *parser)
|
||||
{
|
||||
return fgetc(parser->f);
|
||||
}*/
|
||||
|
||||
static int get_char(struct parser *p)
|
||||
{
|
||||
int c;
|
||||
c = fgetc (p->f);
|
||||
p->pos++;
|
||||
if (c=='\n'){
|
||||
p->prevpos=p->pos;
|
||||
p->line ++;
|
||||
p->pos=0;
|
||||
}
|
||||
return c;
|
||||
}
|
||||
|
||||
|
||||
static void unget_char(struct parser *p,int c){
|
||||
ungetc(c,p->f);
|
||||
if (c=='\n'){
|
||||
p->line--;
|
||||
p->pos=p->prevpos;
|
||||
}
|
||||
else
|
||||
p->pos--;
|
||||
}
|
||||
|
||||
|
||||
|
||||
static int get_char_q(struct parser *p)
|
||||
{
|
||||
int c;
|
||||
|
||||
while(1) {
|
||||
c = get_char(p);
|
||||
if (c==EOF || c=='\n')
|
||||
return c;
|
||||
|
||||
if(c=='"' && !p->quote){
|
||||
p->quote=1;
|
||||
continue;
|
||||
}
|
||||
if(c=='"' && p->quote){
|
||||
p->quote=0;
|
||||
continue;
|
||||
}
|
||||
break;
|
||||
}
|
||||
|
||||
|
||||
if (!p->quote)
|
||||
return c;
|
||||
|
||||
if (c!='\\')
|
||||
return c;
|
||||
|
||||
c = get_char(p);
|
||||
switch(c){
|
||||
case EOF:
|
||||
return c;
|
||||
case 'n':
|
||||
return '\n';
|
||||
|
||||
case '\\':
|
||||
return '\\';
|
||||
case '"':
|
||||
return '"';
|
||||
default:
|
||||
unget_char(p,c);
|
||||
return '\\';
|
||||
}
|
||||
|
||||
/* We will never reach here */
|
||||
/* return c;*/
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
static int skip_chars (struct parser *p, const char * chars)
|
||||
{
|
||||
int c;
|
||||
|
||||
while ( (c = get_char (p)) != EOF) {
|
||||
if (strchr (chars, c))
|
||||
continue;
|
||||
return c;
|
||||
}
|
||||
return c;
|
||||
}
|
||||
|
||||
static int skip_to_chars (struct parser *p, const char *chars)
|
||||
{
|
||||
int c;
|
||||
|
||||
while ( (c = get_char (p)) != EOF) {
|
||||
if (strchr (chars, c))
|
||||
return c;
|
||||
}
|
||||
return c;
|
||||
}
|
||||
|
||||
|
||||
|
||||
static int read_key (struct parser *p, char *key, int max_len)
|
||||
{
|
||||
int c,n;
|
||||
|
||||
do {
|
||||
c = skip_chars (p, " \t\n\a\v");
|
||||
if (c == '#') {
|
||||
c = skip_to_chars (p, "\n\a");
|
||||
|
||||
} else {
|
||||
break;
|
||||
}
|
||||
} while (c != EOF);
|
||||
|
||||
unget_char(p,c);
|
||||
c=get_char_q(p);
|
||||
|
||||
n=0;
|
||||
while(c!=EOF && n<max_len){
|
||||
if (!p->quote && !isalnum(c) && !strchr("._/-()@#|{}[]\\",c)/*strchr(": \t\n\a",c)*/){
|
||||
unget_char(p,c);
|
||||
break;
|
||||
}
|
||||
|
||||
key[n]=c;
|
||||
c=get_char_q(p);
|
||||
n++;
|
||||
|
||||
}
|
||||
key[n]=0;
|
||||
return n;
|
||||
}
|
||||
|
||||
|
||||
static int skip_to_colon(FILE *f,struct parser * p)
|
||||
{
|
||||
int c;
|
||||
c = skip_chars (p, " \t");
|
||||
if (c!=':'){
|
||||
if (c=='\n'){
|
||||
unget_char(p,c);
|
||||
sprintf(p->error,"Error at line %d, pos %d: Unexpected EOL, collon expected.", p->line, p->pos);
|
||||
return 0;
|
||||
}
|
||||
sprintf(p->error,"Error at line %d, pos %d: Collon expected.", p->line, p->pos);
|
||||
return 0;
|
||||
}
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
||||
static int read_type(struct parser *p, char *type, int max_len)
|
||||
{
|
||||
int c,n;
|
||||
|
||||
if (!skip_to_colon(p->f,p))
|
||||
return -1;
|
||||
|
||||
c = skip_chars (p, " \t");
|
||||
|
||||
if (c==':'){
|
||||
unget_char(p,c);
|
||||
sprintf(type,"%s","");
|
||||
return 0;
|
||||
}
|
||||
|
||||
if (!isalpha(c)){
|
||||
if (c=='\n'){
|
||||
unget_char(p,c);
|
||||
sprintf(p->error,"Error at line %d, pos %d: Unexpected EOL.", p->line, p->pos);
|
||||
return -1;
|
||||
}
|
||||
|
||||
sprintf(p->error,"Error at line %d, pos %d: Letter expected.", p->line, p->pos);
|
||||
return -1;
|
||||
}
|
||||
|
||||
n=0;
|
||||
while(c!=EOF && n<max_len){
|
||||
if (!isalnum(c) && !strchr("_/-.()@#|{}[]",c)/*strchr(": \t\n\a",c)*/){
|
||||
unget_char(p,c);
|
||||
break;
|
||||
}
|
||||
|
||||
type[n]=c;
|
||||
c=get_char(p);
|
||||
n++;
|
||||
}
|
||||
type[n]=0;
|
||||
return n;
|
||||
}
|
||||
|
||||
|
||||
static int read_val(struct parser *p, char *val, int max_len){
|
||||
int c,n,quote;
|
||||
if (!skip_to_colon(p->f,p))
|
||||
return -1;
|
||||
c = skip_chars (p, " \t");
|
||||
if (c=='"'){
|
||||
quote=1;
|
||||
c=get_char(p);
|
||||
}
|
||||
else{
|
||||
quote=0;
|
||||
}
|
||||
n=0;
|
||||
while(c!=EOF && n<max_len){
|
||||
if (quote && c=='"'){
|
||||
break;
|
||||
}
|
||||
if (c=='\n'){
|
||||
break;
|
||||
}
|
||||
if (quote){
|
||||
if (c=='\\'){
|
||||
c = get_char(p);
|
||||
switch(c){
|
||||
case 'n':
|
||||
c='\n';
|
||||
break;
|
||||
case '\\':
|
||||
break;
|
||||
case '"':
|
||||
break;
|
||||
default:
|
||||
unget_char(p,c);
|
||||
c='\\';
|
||||
}
|
||||
}
|
||||
}
|
||||
val[n++]=c;
|
||||
c=get_char(p);
|
||||
}
|
||||
|
||||
|
||||
if(!quote && n>0){
|
||||
while(n>0){
|
||||
if (isspace(val[n-1]))
|
||||
n--;
|
||||
else
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
val[n]=0;
|
||||
|
||||
return n;
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
int cw_ktv_read_line (FILE *f, char * key, char * type, char *val)
|
||||
{
|
||||
int n;
|
||||
|
||||
struct parser p;
|
||||
p.line=1;
|
||||
p.pos=0;
|
||||
p.prevpos=0;
|
||||
p.quote=0;
|
||||
p.f=f;
|
||||
|
||||
n = read_key (&p,key,CW_CFG_MAX_KEY_LEN);
|
||||
n = read_type (&p,type,CW_CFG_MAX_KEY_LEN);
|
||||
if (n==-1){
|
||||
return -1;
|
||||
}
|
||||
|
||||
n = read_val (&p,val,CW_CFG_MAX_KEY_LEN);
|
||||
if (n==-1){
|
||||
return -1;
|
||||
}
|
||||
return 0;
|
||||
}
|
@ -1,32 +0,0 @@
|
||||
#include "val.h"
|
||||
#include "cw.h"
|
||||
|
||||
#include "log.h"
|
||||
#include "dbg.h"
|
||||
|
||||
cw_Val_t * cw_ktv_replace(mavl_t kvtstore, const char *key, const struct cw_Type *type,
|
||||
const void * valguard,
|
||||
const uint8_t * data, int len)
|
||||
{
|
||||
cw_Val_t mdata, *mresult;
|
||||
int exists;
|
||||
|
||||
mdata.key=cw_strdup(key);
|
||||
if (!mdata.key){
|
||||
cw_log(LOG_ERR, "Can't allocate memory for KTV key %s: %s",
|
||||
key,strerror(errno));
|
||||
return NULL;
|
||||
}
|
||||
|
||||
mresult = type->get(&mdata,data,len);
|
||||
if (!mresult){
|
||||
cw_log(LOG_ERR, "Can't create kvstore element for key %s of type %s: %s",
|
||||
key,type->name, strerror(errno));
|
||||
free(mdata.key);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
mresult = mavl_replace(kvtstore, &mdata, &exists);
|
||||
|
||||
return mresult;
|
||||
}
|
@ -1,58 +0,0 @@
|
||||
|
||||
#include "val.h"
|
||||
|
||||
|
||||
static int write_str(FILE *outfile,const char *str)
|
||||
{
|
||||
if ( (strchr(str,'\\')!=NULL) || (strchr(str,'"')!=NULL) || (strchr(str,'\n')!=NULL)){
|
||||
fprintf(outfile,"\"");
|
||||
|
||||
while (*str != 0){
|
||||
switch(*str){
|
||||
case '\n':
|
||||
fprintf(outfile,"\\n");
|
||||
break;
|
||||
case '\\':
|
||||
fprintf(outfile,"\\\\");
|
||||
break;
|
||||
case '"':
|
||||
fprintf(outfile,"\\\"");
|
||||
break;
|
||||
default:
|
||||
fprintf(outfile,"%c",*str);
|
||||
break;
|
||||
}
|
||||
str++;
|
||||
}
|
||||
|
||||
fprintf(outfile,"\"");
|
||||
return 1;
|
||||
}
|
||||
|
||||
fprintf(outfile,"%s",str);
|
||||
return 1;
|
||||
}
|
||||
|
||||
int cw_ktv_save(mavl_t ktvstore, const char * filename){
|
||||
mavliter_t it;
|
||||
FILE * outfile;
|
||||
|
||||
outfile = fopen(filename,"w");
|
||||
if (outfile == NULL)
|
||||
return 0;
|
||||
|
||||
mavliter_init(&it,ktvstore);
|
||||
mavliter_foreach(&it){
|
||||
cw_Val_t * val;
|
||||
char buf[4000];
|
||||
val = mavliter_get(&it);
|
||||
val->type->to_str(val,buf,4000);
|
||||
write_str(outfile,val->key);
|
||||
fprintf(outfile," :%s: ",val->type->name);
|
||||
write_str(outfile,buf);
|
||||
fprintf(outfile,"\n");
|
||||
|
||||
}
|
||||
fclose(outfile);
|
||||
return 1;
|
||||
}
|
@ -1,6 +0,0 @@
|
||||
#include "val.h"
|
||||
|
||||
cw_Val_t * cw_ktv_set_byte(mavl_t ktv,const char * key, uint8_t byte)
|
||||
{
|
||||
return cw_ktv_replace(ktv,key,CW_TYPE_BYTE,NULL,&byte,1);
|
||||
}
|
@ -1,6 +0,0 @@
|
||||
#include "val.h"
|
||||
|
||||
cw_Val_t * cw_ktv_set_dword(mavl_t ktv,const char * key, uint32_t dword)
|
||||
{
|
||||
return cw_ktv_replace(ktv,key,CW_TYPE_DWORD,NULL,(void*)&dword,4);
|
||||
}
|
@ -1,6 +0,0 @@
|
||||
#include "val.h"
|
||||
|
||||
cw_Val_t * cw_ktv_set_word(mavl_t ktv,const char * key, uint16_t word)
|
||||
{
|
||||
return cw_ktv_replace(ktv,key,CW_TYPE_WORD,NULL,(void*)&word,2);
|
||||
}
|
@ -1,13 +0,0 @@
|
||||
#include "val.h"
|
||||
|
||||
const cw_Type_t * cw_ktv_std_types[] = {
|
||||
CW_TYPE_BYTE,
|
||||
CW_TYPE_WORD,
|
||||
CW_TYPE_DWORD,
|
||||
CW_TYPE_BSTR16,
|
||||
CW_TYPE_IPADDRESS,
|
||||
CW_TYPE_STR,
|
||||
CW_TYPE_SYSPTR,
|
||||
CW_TYPE_BOOL,
|
||||
NULL
|
||||
};
|
@ -1,77 +0,0 @@
|
||||
#include "val.h"
|
||||
#include "dbg.h"
|
||||
#include "log.h"
|
||||
#include "cfg.h"
|
||||
|
||||
int cw_ktv_write_struct(mavl_t ktv, mavl_t def, const cw_ValStruct_t * stru, const char *pkey,
|
||||
uint8_t * dst)
|
||||
{
|
||||
char key[CW_CFG_MAX_KEY_LEN];
|
||||
int pos, i;
|
||||
cw_Val_t * result;
|
||||
|
||||
pos=0; i=0;
|
||||
for(i=0; stru[i].type != NULL;i++){
|
||||
|
||||
if (stru[i].position!=-1){
|
||||
pos=stru[i].position;
|
||||
}
|
||||
if (stru[i].len!=-1)
|
||||
memset(dst+pos,0,stru[i].len);
|
||||
|
||||
|
||||
if (stru[i].key!=NULL)
|
||||
sprintf(key,"%s/%s",pkey,stru[i].key);
|
||||
else
|
||||
sprintf(key,"%s",pkey);
|
||||
|
||||
printf("Get Key: %s\n",key);
|
||||
result = cw_ktv_get(ktv,key,NULL);
|
||||
|
||||
if(result)
|
||||
{
|
||||
char s[129];
|
||||
result->type->to_str(result,s,128);
|
||||
printf("Content: '%s'\n",s);
|
||||
}
|
||||
|
||||
if (result == NULL && def != NULL){
|
||||
result = cw_ktv_get(def,key,NULL);
|
||||
}
|
||||
|
||||
|
||||
if (result == NULL){
|
||||
cw_log(LOG_ERR,"Can't put %s, no value found, filling zero.",key);
|
||||
memset(dst+pos,0,stru[i].len);
|
||||
}
|
||||
else{
|
||||
result->valguard=stru[i].valguard;
|
||||
if (cw_ktv_cast(result,stru[i].type)==NULL){
|
||||
cw_log(LOG_ERR,"Can't cast key '%s' from %s to %s",key,result->type->name,stru[i].type->name);
|
||||
}
|
||||
/* if (strcmp(stru[i].type->name,result->type->name)){
|
||||
|
||||
|
||||
|
||||
printf("Type mismatch: %s != %s\n",stru[i].type->name,result->type->name);
|
||||
if (stru[i].type->cast != NULL){
|
||||
if (!stru[i].type->cast(result)){
|
||||
cw_log(LOG_ERR,"Can't cast '%s' from %s to %s",key,result->type->name,stru[i].type->name);
|
||||
exit(0);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
*/
|
||||
result->type->put(result,dst+pos);
|
||||
}
|
||||
if (stru[i].len!=-1)
|
||||
pos+=stru[i].len;
|
||||
else
|
||||
pos+=result->type->len(result);
|
||||
|
||||
}
|
||||
|
||||
return pos;
|
||||
}
|
@ -1,22 +1,52 @@
|
||||
|
||||
#include "cw.h"
|
||||
#include "dbg.h"
|
||||
#include "cfg.h"
|
||||
|
||||
int cw_out_generic_with_index(struct cw_ElemHandler * eh,
|
||||
struct cw_ElemHandlerParams * params, uint8_t * dst)
|
||||
|
||||
{
|
||||
stop();
|
||||
char key[CW_CFG_MAX_KEY_LEN];
|
||||
int idx;
|
||||
cw_Val_t * result, search;
|
||||
int len,start;
|
||||
uint8_t * ob;
|
||||
struct cw_Cfg_entry *e;
|
||||
struct cw_Cfg_iter cfi;
|
||||
struct cw_Type * type = (struct cw_Type *)eh->type;
|
||||
int i,l;
|
||||
|
||||
|
||||
idx = 0;
|
||||
ob = dst;
|
||||
|
||||
cw_cfg_iter_init(params->cfg_list[0], &cfi, eh->key);
|
||||
for (i=0; (e = cw_cfg_iter_next(&cfi, NULL)) != NULL; i++){
|
||||
start = params->msgset->header_len(eh);
|
||||
len = cw_put_byte(ob+start,i);
|
||||
|
||||
cw_dbg(DBG_X,"KV: %s - %s",e->key,e->val);
|
||||
// int bwrite(cw_Cfg_t ** cfgs, const char *key, uint8_t *dst, const void * param)
|
||||
l = type->write(params->cfg_list,e->key,ob+start+len,eh->param);
|
||||
if (l==-1)
|
||||
continue;
|
||||
len += l;
|
||||
|
||||
//len += result->type->put(result,ob+start+len);
|
||||
|
||||
ob += params->msgset->write_header(eh,ob,len);
|
||||
|
||||
|
||||
}
|
||||
|
||||
return ob-dst;
|
||||
|
||||
stop();
|
||||
return 0;
|
||||
|
||||
|
||||
|
||||
do {
|
||||
sprintf(key,"%s.%d",eh->key,idx);
|
||||
search.key=key;
|
||||
|
@ -10,7 +10,8 @@ static int get_psk(struct cw_Conn *conn, const char *username, uint8_t ** psk,
|
||||
char key[CW_CFG_MAX_KEY_LEN];
|
||||
cw_Val_t *result;
|
||||
sprintf(key, "%s/%s", "psk", username);
|
||||
result = cw_ktv_get(conn->local_cfg, key, CW_TYPE_BSTR16);
|
||||
stop();
|
||||
// result = cw_ktv_get(conn->local_cfg, key, CW_TYPE_BSTR16);
|
||||
if (result == NULL) {
|
||||
if (conn->dtls_psk != NULL) {
|
||||
*psk = bstr16_data(conn->dtls_psk);
|
||||
|
@ -96,7 +96,7 @@ int cw_compose_message(struct cw_Conn *conn, uint8_t * rawout)
|
||||
|
||||
dst = msgptr+8;
|
||||
len =0;
|
||||
cw_dbg(DBG_X,"setting with update CFG");
|
||||
//cw_dbg(DBG_X,"setting with update CFG");
|
||||
params.conn=conn;
|
||||
params.cfg_list[0]=conn->update_cfg;
|
||||
params.cfg_list[1]=conn->local_cfg;
|
||||
|
@ -217,6 +217,33 @@ static int update_msgdata(struct cw_MsgSet *set, struct cw_MsgData *msgdata,
|
||||
ed.vendor = elemdef->vendor;
|
||||
ed.mand = elemdef->mand;
|
||||
|
||||
/* add/delete/replace message elemeent to/from/in the elements list */
|
||||
switch ( elemdef->op & 0xff){
|
||||
case CW_IGNORE:
|
||||
break;
|
||||
continue;
|
||||
case CW_DELETE:
|
||||
cw_dbg(DBG_MOD, " deleting message element %d %d %d - %s",
|
||||
elemdef->proto,
|
||||
elemdef->vendor, elemdef->id, handler->name);
|
||||
|
||||
mlist_delete(msgdata->elements_list, &ed);
|
||||
mavl_del(msgdata->elements_tree,&ed);
|
||||
continue;
|
||||
break;
|
||||
case CW_APPEND:
|
||||
mlist_append(msgdata->elements_list, &ed);
|
||||
break;
|
||||
default:
|
||||
case CW_REPLACE:
|
||||
if (mlist_replace(msgdata->elements_list, &ed)==NULL){
|
||||
mlist_append(msgdata->elements_list, &ed);
|
||||
}
|
||||
break;
|
||||
}
|
||||
|
||||
|
||||
|
||||
/* add message element to the elements tree */
|
||||
result = mavl_replace(msgdata->elements_tree, &ed, &replaced);
|
||||
|
||||
@ -230,23 +257,6 @@ static int update_msgdata(struct cw_MsgSet *set, struct cw_MsgData *msgdata,
|
||||
elemdef->vendor, elemdef->id, handler->name);
|
||||
}
|
||||
|
||||
/* add/delete/replace message elemeent to/from/in the elements list */
|
||||
switch ( elemdef->op & 0xff){
|
||||
case CW_IGNORE:
|
||||
break;
|
||||
case CW_DELETE:
|
||||
mlist_delete(msgdata->elements_list, &ed);
|
||||
break;
|
||||
case CW_APPEND:
|
||||
mlist_append(msgdata->elements_list, &ed);
|
||||
break;
|
||||
default:
|
||||
case CW_REPLACE:
|
||||
if (mlist_replace(msgdata->elements_list, &ed)==NULL){
|
||||
mlist_append(msgdata->elements_list, &ed);
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
Reference in New Issue
Block a user