/* This file is part of libcapwap. libcapwap is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. libcapwap is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with Foobar. If not, see . */ #include #include "cw.h" #include "val.h" #include "dbg.h" static cw_Val_t *get(cw_Val_t * data, const uint8_t * src, int len) { data->type = &cw_type_byte; data->val.byte = cw_get_byte(src); return data; } static int put(const cw_Val_t *data, uint8_t * dst) { return cw_put_byte(dst, data->val.byte); } static const char * get_guardstr(int val, const cw_ValValRange_t * valrange) { if (valrange==NULL) return NULL; while(valrange->name!=NULL){ if(val>=valrange->min && val<=valrange->max) return valrange->name; valrange++; } return NULL; } static int to_str(const cw_Val_t *data, char *dst, int max_len) { if (data->valguard!=NULL){ const char * name; name = get_guardstr(data->val.byte,data->valguard); if (name != NULL){ return sprintf(dst,"%s",name); } } /*if (max_len<3){ return 0; }*/ return sprintf(dst, "%d", data->val.byte); } static int get_guardval(const char *str, const cw_ValValRange_t * valrange) { while(valrange->name!=NULL){ if(strcmp(str,valrange->name)==0) return valrange->min; valrange++; } return -1; } static cw_Val_t *from_str(cw_Val_t * data, const char *src) { data->type = &cw_type_byte; if (data->valguard != NULL){ int rc; rc = get_guardval(src,data->valguard); if (rc != -1){ data->val.byte = rc; return data; } } data->val.byte = atoi(src); return data; } static int len (cw_Val_t * data) { return sizeof(data->val.byte); } static void * data(cw_Val_t * data) { return &data->val.byte; } static const char * get_type_name(cw_Val_t *data) { if (data->valguard != NULL){ return CW_TYPE_STR->name; } return CW_TYPE_BYTE->name; } static int cast(cw_Val_t * data) { if (strcmp(data->type->name,CW_TYPE_BYTE->name)==0) return 1; if (strcmp(data->type->name,CW_TYPE_STR->name)==0){ char *src = data->val.ptr; CW_TYPE_BYTE->from_str(data,src); free(src); return 1; } return 0; } static int bread(cw_Cfg_t *cfg, const char * key, const uint8_t *src, int len, const void *param) { uint8_t n,i; int l; char skey[CW_CFG_MAX_KEY_LEN]; const struct cw_ValArrayDef * def = param; const int (*fun)(cw_Cfg_t*,const char *k,const uint8_t *s,int len,const void *p,int *l) = def->get_count; n = fun(cfg,key,src,len,param,&l); for (i=0; itype->read(cfg,skey,src,len,def->param); } return l; } static int bwrite(cw_Cfg_t ** cfgs, const char *key, uint8_t *dst, const void * param) { int i,l; char skey[CW_CFG_MAX_KEY_LEN]; const struct cw_ValArrayDef * def = param; const int (*fun)(cw_Cfg_t**,const char *k, uint8_t *s,const void *p,int l) = def->put_count; i=0,l=0; do { sprintf(skey,"%s.%d",key,i); // printf("iSKEY %s\n",skey); i++; if (cw_cfg_get_l(cfgs,skey,NULL)==NULL){ break; } l+=def->type->write(cfgs,skey,dst,def->param); }while(1); // printf("LEN: %d (K: %s)\n",l,key); fun(cfgs,key,dst,param,l); return l; } const struct cw_Type cw_type_array = { "Array", /* name */ NULL, /* del */ put, /* put */ get, /* get */ to_str, /* to_str */ from_str, /* from_str */ len, /* len */ data, /* data */ get_type_name, /* get_type_name */ cast, bread, bwrite };