|
|
| version 1.7.2.1, 2012/04/05 11:47:03 | version 1.11, 2012/09/19 15:22:32 |
|---|---|
| Line 49 SUCH DAMAGE. | Line 49 SUCH DAMAGE. |
| static inline struct tagCfg * | static inline struct tagCfg * |
| _selectAttribute(cfg_root_t * __restrict cfg, const char *csSec, const char *csAttr) | _selectAttribute(cfg_root_t * __restrict cfg, const char *csSec, const char *csAttr) |
| { | { |
| struct tagCfg fav; | struct tagCfg fav, *c; |
| if (!cfg) | if (!cfg) |
| return NULL; | return NULL; |
| Line 58 _selectAttribute(cfg_root_t * __restrict cfg, const ch | Line 58 _selectAttribute(cfg_root_t * __restrict cfg, const ch |
| if (csSec && *csSec) | if (csSec && *csSec) |
| AIT_KEY(&fav.cfg_sec) = crcFletcher16((u_short*) csSec, | AIT_KEY(&fav.cfg_sec) = crcFletcher16((u_short*) csSec, |
| io_align(strlen(csSec), 1) / 2); | io_align(strlen(csSec), 2) / 2); |
| if (csAttr) | if (csAttr) |
| AIT_KEY(&fav.cfg_attr) = crcFletcher16((u_short*) csAttr, | AIT_KEY(&fav.cfg_attr) = crcFletcher16((u_short*) csAttr, |
| io_align(strlen(csAttr), 1) / 2); | io_align(strlen(csAttr), 2) / 2); |
| if (!csAttr) | if (!csAttr) |
| return RB_NFIND(tagRC, cfg, &fav); | return RB_NFIND(tagRC, cfg, &fav); |
| else | else { |
| return RB_FIND(tagRC, cfg, &fav); | c = RB_FIND(tagRC, cfg, &fav); |
| if (!c) | |
| return NULL; /* not found */ | |
| do { | |
| if (!strcmp(AIT_GET_STR(&c->cfg_attr), csAttr)) | |
| return c; /* FOUND! */ | |
| } while (RB_NEXT(tagRC, cfg, c) && !cfg_tree_cmp(c, &fav)); | |
| return NULL; /* not found */ | |
| } | |
| } | } |
| /* --------------------------------------------------------------- */ | /* --------------------------------------------------------------- */ |
| Line 93 cfg_findAttribute(cfg_root_t * __restrict cfg, const c | Line 101 cfg_findAttribute(cfg_root_t * __restrict cfg, const c |
| if (csSec && *csSec) | if (csSec && *csSec) |
| AIT_KEY(&fav.cfg_sec) = crcFletcher16((u_short*) csSec, | AIT_KEY(&fav.cfg_sec) = crcFletcher16((u_short*) csSec, |
| io_align(strlen(csSec), 1) / 2); | io_align(strlen(csSec), 2) / 2); |
| if (csAttr) | if (csAttr) |
| AIT_KEY(&fav.cfg_attr) = crcFletcher16((u_short*) csAttr, | AIT_KEY(&fav.cfg_attr) = crcFletcher16((u_short*) csAttr, |
| io_align(strlen(csAttr), 1) / 2); | io_align(strlen(csAttr), 2) / 2); |
| SLIST_FOREACH(av, cfg, cfg_next) { | SLIST_FOREACH(av, cfg, cfg_next) { |
| ++cx; | ++cx; |
| Line 135 cfg_unsetAttribute(cfg_root_t * __restrict cfg, const | Line 143 cfg_unsetAttribute(cfg_root_t * __restrict cfg, const |
| AIT_FREE_VAL(&av->cfg_val); | AIT_FREE_VAL(&av->cfg_val); |
| AIT_FREE_VAL(&av->cfg_attr); | AIT_FREE_VAL(&av->cfg_attr); |
| AIT_FREE_VAL(&av->cfg_sec); | AIT_FREE_VAL(&av->cfg_sec); |
| free(av); | io_free(av); |
| return 1; | return 1; |
| } | } |
| Line 161 cfg_setAttribute(cfg_root_t * __restrict cfg, const ch | Line 169 cfg_setAttribute(cfg_root_t * __restrict cfg, const ch |
| /* adding new element */ | /* adding new element */ |
| section = _selectAttribute(cfg, csSec, NULL); | section = _selectAttribute(cfg, csSec, NULL); |
| av = malloc(sizeof(struct tagCfg)); | av = io_malloc(sizeof(struct tagCfg)); |
| if (!av) { | if (!av) { |
| LOGERR; | LOGERR; |
| return -1; | return -1; |
| Line 179 cfg_setAttribute(cfg_root_t * __restrict cfg, const ch | Line 187 cfg_setAttribute(cfg_root_t * __restrict cfg, const ch |
| if (csSec && *csSec) { | if (csSec && *csSec) { |
| AIT_SET_STR(&av->cfg_sec, csSec); | AIT_SET_STR(&av->cfg_sec, csSec); |
| AIT_KEY(&av->cfg_sec) = crcFletcher16(AIT_GET_LIKE(&av->cfg_sec, u_short*), | AIT_KEY(&av->cfg_sec) = crcFletcher16(AIT_GET_LIKE(&av->cfg_sec, u_short*), |
| io_align(AIT_LEN(&av->cfg_sec) - 1, 1) / 2); | io_align(AIT_LEN(&av->cfg_sec) - 1, 2) / 2); |
| } | } |
| AIT_SET_STR(&av->cfg_val, csVal ? csVal : ""); | AIT_SET_STR(&av->cfg_val, csVal ? csVal : ""); |
| AIT_SET_STR(&av->cfg_attr, csAttr); | AIT_SET_STR(&av->cfg_attr, csAttr); |
| AIT_KEY(&av->cfg_attr) = crcFletcher16(AIT_GET_LIKE(&av->cfg_attr, u_short*), | AIT_KEY(&av->cfg_attr) = crcFletcher16(AIT_GET_LIKE(&av->cfg_attr, u_short*), |
| io_align(AIT_LEN(&av->cfg_attr) - 1, 1) / 2); | io_align(AIT_LEN(&av->cfg_attr) - 1, 2) / 2); |
| CFG_RC_LOCK(cfg); | CFG_RC_LOCK(cfg); |
| RB_INSERT(tagRC, cfg, av); | RB_INSERT(tagRC, cfg, av); |
| Line 192 cfg_setAttribute(cfg_root_t * __restrict cfg, const ch | Line 200 cfg_setAttribute(cfg_root_t * __restrict cfg, const ch |
| return 2; | return 2; |
| } | } |
| if (csVal && strcmp((char*) csVal, (char*) AIT_GET_STR(&av->cfg_val))) { | if (csVal && AIT_ADDR(&av->cfg_val) && |
| strcmp((char*) csVal, (char*) AIT_GET_STR(&av->cfg_val))) { | |
| /* Update element */ | /* Update element */ |
| AIT_FREE_VAL(&av->cfg_val); | AIT_FREE_VAL(&av->cfg_val); |
| AIT_SET_STR(&av->cfg_val, csVal); | AIT_SET_STR(&av->cfg_val, csVal); |
| Line 248 cfg_loadAttribute(cfg_root_t * __restrict cfg, const c | Line 257 cfg_loadAttribute(cfg_root_t * __restrict cfg, const c |
| return -1; | return -1; |
| } | } |
| AIT_INIT_VAL(val); | |
| av = _selectAttribute(cfg, csSec, csAttr); | av = _selectAttribute(cfg, csSec, csAttr); |
| if (!av) { | if (!av) { |
| /* not found item */ | /* not found item */ |
| Line 255 cfg_loadAttribute(cfg_root_t * __restrict cfg, const c | Line 265 cfg_loadAttribute(cfg_root_t * __restrict cfg, const c |
| AIT_SET_STR(val, csDefValue); | AIT_SET_STR(val, csDefValue); |
| ret = AIT_LEN(val); | ret = AIT_LEN(val); |
| } else | } else |
| AIT_INIT(val); | AIT_INIT_VAL(val); |
| return ret; | return ret; |
| } | } |
| if (AIT_ISEMPTY(&av->cfg_val) || !*AIT_GET_LIKE(&av->cfg_val, char*)) { | if (AIT_ISEMPTY(&av->cfg_val) || !AIT_ADDR(&av->cfg_val) || |
| !*AIT_GET_LIKE(&av->cfg_val, char*)) { | |
| /* empty value */ | /* empty value */ |
| if (csDefValue) { | if (csDefValue) { |
| AIT_SET_STR(val, csDefValue); | AIT_SET_STR(val, csDefValue); |
| ret = AIT_LEN(val); | ret = AIT_LEN(val); |
| } else | } else |
| AIT_INIT(val); | AIT_INIT_VAL(val); |
| } else { | } else { |
| /* copy value */ | /* copy value */ |
| AIT_SET_STR(val, AIT_GET_STR(&av->cfg_val)); | AIT_SET_STR(val, AIT_GET_STR(&av->cfg_val)); |