Diff for /libaitcfg/src/aitcfg.c between versions 1.13 and 1.17

version 1.13, 2016/05/18 15:18:10 version 1.17, 2025/08/19 11:43:53
Line 12  terms: Line 12  terms:
 All of the documentation and software included in the ELWIX and AITNET  All of the documentation and software included in the ELWIX and AITNET
 Releases is copyrighted by ELWIX - Sofia/Bulgaria <info@elwix.org>  Releases is copyrighted by ELWIX - Sofia/Bulgaria <info@elwix.org>
   
Copyright 2004 - 2016Copyright 2004 - 2025
         by Michael Pounov <misho@elwix.org>.  All rights reserved.          by Michael Pounov <misho@elwix.org>.  All rights reserved.
   
 Redistribution and use in source and binary forms, with or without  Redistribution and use in source and binary forms, with or without
Line 71  cfg_tree_cmp(struct tagCfg *a, struct tagCfg *b) Line 71  cfg_tree_cmp(struct tagCfg *a, struct tagCfg *b)
   
         assert(a && b);          assert(a && b);
   
        ret = ((AIT_KEY(&a->cfg_sec) << 16) | AIT_KEY(&a->cfg_attr)) -         ret = ((AIT_KEY(&a->cfg_sec) << 15) | AIT_KEY(&a->cfg_attr)) - 
                ((AIT_KEY(&b->cfg_sec) << 16) | AIT_KEY(&b->cfg_attr));                ((AIT_KEY(&b->cfg_sec) << 15) | AIT_KEY(&b->cfg_attr));
   
         if (ret < 0)          if (ret < 0)
                 return -1;                  return -1;
Line 157  cfgEndConfig(cfg_root_t **pcfg) Line 157  cfgEndConfig(cfg_root_t **pcfg)
 }  }
   
 /*  /*
    * cfgInitConfigExt() - Init existed config root
    *
    * @cfg = Config root
    * return: -1 error or 0 inited config root
    */
   int
   cfgInitConfigExt(cfg_root_t * __restrict cfg)
   {
           if (!cfg) {
                   cfg_SetErr(EINVAL, "Invalid parameter");
                   return -1;
           }
   
           memset(cfg, 0, sizeof(cfg_root_t));
   
           pthread_mutex_init(&cfg->rc_mtx, NULL);
   
           TAILQ_INIT(cfg);
           RB_INIT(cfg);
           return 0;
   }
   
   /*
  * cfgLoadConfig() - Load config from file   * cfgLoadConfig() - Load config from file
  *   *
  * @cfgName = Config filename   * @cfgName = Config filename
Line 169  cfgLoadConfig(const char *cfgName, cfg_root_t * __rest Line 192  cfgLoadConfig(const char *cfgName, cfg_root_t * __rest
         FILE *f;          FILE *f;
         int ret;          int ret;
   
        if (!cfgName || !cfg) {        if (!cfgName || cfgInitConfigExt(cfg)) {
                 cfg_SetErr(EINVAL, "Invalid parameter(s)");                  cfg_SetErr(EINVAL, "Invalid parameter(s)");
                 return -1;                  return -1;
         } else {  
                 pthread_mutex_init(&cfg->rc_mtx, NULL);  
   
                 TAILQ_INIT(cfg);  
                 RB_INIT(cfg);  
         }          }
   
         f = fopen(cfgName, "r");          f = fopen(cfgName, "r");
Line 232  cfgUnloadConfig(cfg_root_t * __restrict cfg) Line 250  cfgUnloadConfig(cfg_root_t * __restrict cfg)
   
         cfgClearConfig(cfg);          cfgClearConfig(cfg);
         pthread_mutex_destroy(&cfg->rc_mtx);          pthread_mutex_destroy(&cfg->rc_mtx);
           memset(&cfg->rc_mtx, 0, sizeof cfg->rc_mtx);
 }  }
   
 /*  /*
Line 257  cfgCreateConfig(const char *csConfigName, cfg_root_t * Line 276  cfgCreateConfig(const char *csConfigName, cfg_root_t *
                 return -1;                  return -1;
         }          }
                   
        ret = cfgWriteConfig(f, cfg, whitespace);        ret = cfgWriteConfigRaw(f, cfg, whitespace);
   
         fclose(f);          fclose(f);
         return ret;          return ret;
Line 321  cfgLoadPasswd(const char *pwdName, pwd_root_t * __rest Line 340  cfgLoadPasswd(const char *pwdName, pwd_root_t * __rest
                 cfg_SetErr(EINVAL, "Invalid parameter(s)");                  cfg_SetErr(EINVAL, "Invalid parameter(s)");
                 return -1;                  return -1;
         } else {          } else {
                   memset(pwd, 0, sizeof(pwd_root_t));
   
                 pthread_mutex_init(&pwd->pwd_mtx, NULL);                  pthread_mutex_init(&pwd->pwd_mtx, NULL);
   
                 SLIST_INIT(pwd);                  SLIST_INIT(pwd);

Removed from v.1.13  
changed lines
  Added in v.1.17


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