Diff for /libaitcfg/src/parse.c between versions 1.2.2.2 and 1.5.2.2

version 1.2.2.2, 2009/09/09 20:42:07 version 1.5.2.2, 2010/03/22 19:16:34
Line 8 Line 8
 *************************************************************************/  *************************************************************************/
 #include "global.h"  #include "global.h"
 #include "aitcfg.h"  #include "aitcfg.h"
 #include "tools.h"  
   
   
 // cfgDbg() Debug/Log operation  // cfgDbg() Debug/Log operation
Line 119  int ReadConfig(FILE *f, sl_config * __restrict cfg) Line 118  int ReadConfig(FILE *f, sl_config * __restrict cfg)
         while (!feof(f)) {          while (!feof(f)) {
                 memset(szLine, 0, MAX_STR + 1);                  memset(szLine, 0, MAX_STR + 1);
                 fgets((char*) szLine, MAX_STR, f);                  fgets((char*) szLine, MAX_STR, f);
                trim(szLine);                io_TrimStr(szLine);
 #ifdef __DEBUG  #ifdef __DEBUG
                 cfgDbg(stdout, "DEBUG:: RAW |%s|\n", szLine);                  cfgDbg(stdout, "DEBUG:: RAW |%s|\n", szLine);
 #endif  #endif
Line 185  int ReadConfig(FILE *f, sl_config * __restrict cfg) Line 184  int ReadConfig(FILE *f, sl_config * __restrict cfg)
                         psAttr = szLine;                          psAttr = szLine;
                         psVal = (szLine + pos + 1);                          psVal = (szLine + pos + 1);
                         szLine[pos] = 0;                          szLine[pos] = 0;
                        rtrim(psAttr);                        io_RTrimStr(psAttr);
                        ltrim(psVal);                        io_LTrimStr(psVal);
                         io_UnquotStr(psVal);
 #ifdef __DEBUG  #ifdef __DEBUG
                         cfgDbg(stdout, "DEBUG:: Attr(%p) ->%s size=%d Value(%p) ->%s size=%d\n",                           cfgDbg(stdout, "DEBUG:: Attr(%p) ->%s size=%d Value(%p) ->%s size=%d\n", 
                                         psAttr, psAttr, strlen((char*) psAttr), psVal, psVal, strlen((char*) psVal));                                          psAttr, psAttr, strlen((char*) psAttr), psVal, psVal, strlen((char*) psVal));
Line 236  int WriteConfig(FILE *f, sl_config * __restrict cfg) Line 236  int WriteConfig(FILE *f, sl_config * __restrict cfg)
 int cfg_WriteConfig(FILE *f, sl_config * __restrict cfg)  int cfg_WriteConfig(FILE *f, sl_config * __restrict cfg)
 {  {
         return cfgWrite(f, cfg, 0);          return cfgWrite(f, cfg, 0);
   }
   
   /*
    * ConcatConfig() Concat two list in one
    * @cfg = Head list element of main list
    * @add_cfg = Head list element of added list
    * return: 0 ok; -1 error:: can`t concat lists
   */
   int ConcatConfig(sl_config * __restrict cfg, sl_config * __restrict add_cfg)
   {
           struct tagPair *item;
           int ret = 0;
   
           if (!cfg || !add_cfg)
                   return -1;
   
           for (item = cfg->slh_first; item->sle_next; item = item->sle_next);
           item->sle_next = add_cfg->slh_first;
   
           add_cfg->slh_first = NULL;
   
           return ret;
   }
   
   /*
    * MergeConfig() Marge two list in one cfg and destroy add_cfg
    * @cfg = Head list element of main list
    * @add_cfg = Head list element of merged list (destroy after all!)
    * return: 0 ok; -1 error:: can`t merge lists
   */
   int MergeConfig(sl_config * __restrict cfg, sl_config * __restrict add_cfg)
   {
           struct tagPair *item, *merge, *add_next, *next = NULL;
           int flg;
   
           if (!cfg || !add_cfg)
                   return -1;
   
           item = add_cfg->slh_first;
           while (item) {
                   add_next = item->sle_next;
   
                   for (flg = 0, merge = cfg->slh_first, next = merge->sle_next; next; 
                                   merge = merge->sle_next, next = merge->sle_next) {
                           if (!merge->psSection && !item->psSection) {
                                   flg = 1;
                                   merge->sle_next = item;
                                   item->sle_next = next;
                                   break;
                           }
                           if (merge->psSection && item->psSection && 
                                           !strcmp((char*) merge->psSection, (char*) item->psSection)) {
                                   flg = 1;
                                   merge->sle_next = item;
                                   item->sle_next = next;
                                   break;
                           }
                   }
   
                   if (!flg) {
                           if (!merge->sle_next) {
                                   merge->sle_next = item;
                                   item->sle_next = NULL;
                           } else
                                   return -1;
                   }
   
                   item = add_next;
           }
   
           add_cfg->slh_first = NULL;
   
           return 0;
 }  }

Removed from v.1.2.2.2  
changed lines
  Added in v.1.5.2.2


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>