⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 iniparser.c

📁 一个使用anci c实现的ini处理程序
💻 C
📖 第 1 页 / 共 2 页
字号:
        return def ;    lc_key = strdup(strlwc(key));    sval = dictionary_get(d, lc_key, def);    free(lc_key);    return sval ;}/*-------------------------------------------------------------------------*//**  @brief    Get the string associated to a key, convert to an int  @param    d Dictionary to search  @param    key Key string to look for  @param    notfound Value to return in case of error  @return   integer  This function queries a dictionary for a key. A key as read from an  ini file is given as "section:key". If the key cannot be found,  the notfound value is returned. *//*--------------------------------------------------------------------------*/int iniparser_getint(dictionary * d, char * key, int notfound){    char    *   str ;    str = iniparser_getstring(d, key, INI_INVALID_KEY);    if (str==INI_INVALID_KEY) return notfound ;    return atoi(str);}/*-------------------------------------------------------------------------*//**  @brief    Get the string associated to a key, convert to a double  @param    d Dictionary to search  @param    key Key string to look for  @param    notfound Value to return in case of error  @return   double  This function queries a dictionary for a key. A key as read from an  ini file is given as "section:key". If the key cannot be found,  the notfound value is returned. *//*--------------------------------------------------------------------------*/double iniparser_getdouble(dictionary * d, char * key, double notfound){    char    *   str ;    str = iniparser_getstring(d, key, INI_INVALID_KEY);    if (str==INI_INVALID_KEY) return notfound ;    return atof(str);}/*-------------------------------------------------------------------------*//**  @brief    Get the string associated to a key, convert to a boolean  @param    d Dictionary to search  @param    key Key string to look for  @param    notfound Value to return in case of error  @return   integer  This function queries a dictionary for a key. A key as read from an  ini file is given as "section:key". If the key cannot be found,  the notfound value is returned.  A true boolean is found if one of the following is matched:  - A string starting with 'y'  - A string starting with 'Y'  - A string starting with 't'  - A string starting with 'T'  - A string starting with '1'  A false boolean is found if one of the following is matched:  - A string starting with 'n'  - A string starting with 'N'  - A string starting with 'f'  - A string starting with 'F'  - A string starting with '0'  The notfound value returned if no boolean is identified, does not  necessarily have to be 0 or 1. *//*--------------------------------------------------------------------------*/int iniparser_getboolean(dictionary * d, char * key, int notfound){    char    *   c ;    int         ret ;    c = iniparser_getstring(d, key, INI_INVALID_KEY);    if (c==INI_INVALID_KEY) return notfound ;    if (c[0]=='y' || c[0]=='Y' || c[0]=='1' || c[0]=='t' || c[0]=='T') {        ret = 1 ;    } else if (c[0]=='n' || c[0]=='N' || c[0]=='0' || c[0]=='f' || c[0]=='F') {        ret = 0 ;    } else {        ret = notfound ;    }    return ret;}/*-------------------------------------------------------------------------*//**  @brief    Finds out if a given entry exists in a dictionary  @param    ini     Dictionary to search  @param    entry   Name of the entry to look for  @return   integer 1 if entry exists, 0 otherwise  Finds out if a given entry exists in the dictionary. Since sections  are stored as keys with NULL associated values, this is the only way  of querying for the presence of sections in a dictionary. *//*--------------------------------------------------------------------------*/int iniparser_find_entry(    dictionary  *   ini,    char        *   entry){    int found=0 ;    if (iniparser_getstring(ini, entry, INI_INVALID_KEY)!=INI_INVALID_KEY) {        found = 1 ;    }    return found ;}/*-------------------------------------------------------------------------*//**  @brief    Set an entry in a dictionary.  @param    ini     Dictionary to modify.  @param    entry   Entry to modify (entry name)  @param    val     New value to associate to the entry.  @return   int 0 if Ok, -1 otherwise.  If the given entry can be found in the dictionary, it is modified to  contain the provided value. If it cannot be found, -1 is returned.  It is Ok to set val to NULL. *//*--------------------------------------------------------------------------*/int iniparser_setstr(dictionary * ini, char * entry, char * val){    dictionary_set(ini, strlwc(entry), val);    return 0 ;}/*-------------------------------------------------------------------------*//**  @brief    Delete an entry in a dictionary  @param    ini     Dictionary to modify  @param    entry   Entry to delete (entry name)  @return   void  If the given entry can be found, it is deleted from the dictionary. *//*--------------------------------------------------------------------------*/void iniparser_unset(dictionary * ini, char * entry){    dictionary_unset(ini, strlwc(entry));}/*-------------------------------------------------------------------------*//**  @brief    Parse an ini file and return an allocated dictionary object  @param    ininame Name of the ini file to read.  @return   Pointer to newly allocated dictionary  This is the parser for ini files. This function is called, providing  the name of the file to be read. It returns a dictionary object that  should not be accessed directly, but through accessor functions  instead.  The returned dictionary must be freed using iniparser_freedict(). *//*--------------------------------------------------------------------------*/dictionary * iniparser_load(char * ininame){    dictionary  *   d ;    char        lin[ASCIILINESZ+1];    char        sec[ASCIILINESZ+1];    char        key[ASCIILINESZ+1];    char        val[ASCIILINESZ+1];    char    *   where ;    FILE    *   ini ;    int         lineno ;    if ((ini=fopen(ininame, "r"))==NULL) {        return NULL ;    }    sec[0]=0;    /*     * Initialize a new dictionary entry     */    d = dictionary_new(0);    lineno = 0 ;    while (fgets(lin, ASCIILINESZ, ini)!=NULL) {        lineno++ ;        where = strskp(lin); /* Skip leading spaces */        if (*where==';' || *where=='#' || *where==0)            continue ; /* Comment lines */        else {            if (sscanf(where, "[%[^]]", sec)==1) {                /* Valid section name */                strcpy(sec, strlwc(sec));                iniparser_add_entry(d, sec, NULL, NULL);            } else if (sscanf (where, "%[^=] = \"%[^\"]\"", key, val) == 2                   ||  sscanf (where, "%[^=] = '%[^\']'",   key, val) == 2                   ||  sscanf (where, "%[^=] = %[^;#]",     key, val) == 2) {                strcpy(key, strlwc(strcrop(key)));                /*                 * sscanf cannot handle "" or '' as empty value,                 * this is done here                 */                if (!strcmp(val, "\"\"") || !strcmp(val, "''")) {                    val[0] = (char)0;                } else {                    strcpy(val, strcrop(val));                }                iniparser_add_entry(d, sec, key, val);            }        }    }    fclose(ini);    return d ;}/*-------------------------------------------------------------------------*//**  @brief    Free all memory associated to an ini dictionary  @param    d Dictionary to free  @return   void  Free all memory associated to an ini dictionary.  It is mandatory to call this function before the dictionary object  gets out of the current context. *//*--------------------------------------------------------------------------*/void iniparser_freedict(dictionary * d){    dictionary_del(d);}/* vim: set ts=4 et sw=4 tw=75 */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -