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

📄 libiniparser.c

📁 mtd-utils 是一套更改linux mtd設備的工具
💻 C
📖 第 1 页 / 共 2 页
字号:
  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, const 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_set(dictionary * ini, char * entry, char * val){    return dictionary_set(ini, strlwc(entry), val) ;}/*-------------------------------------------------------------------------*//**  @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	Load a single line from an INI file  @param    input_line  Input line, may be concatenated multi-line input  @param    section     Output space to store section  @param    key         Output space to store key  @param    value       Output space to store value  @return   line_status value *//*--------------------------------------------------------------------------*/static line_status iniparser_line(    char * input_line,    char * section,    char * key,    char * value){       line_status sta ;    char        line[ASCIILINESZ+1];    int         len ;    strcpy(line, strstrip(input_line));    len = (int)strlen(line);    sta = LINE_UNPROCESSED ;    if (len<1) {        /* Empty line */        sta = LINE_EMPTY ;    } else if (line[0]=='#') {        /* Comment line */        sta = LINE_COMMENT ;     } else if (line[0]=='[' && line[len-1]==']') {        /* Section name */        sscanf(line, "[%[^]]", section);        strcpy(section, strstrip(section));        strcpy(section, strlwc(section));        sta = LINE_SECTION ;    } else if (sscanf (line, "%[^=] = \"%[^\"]\"", key, value) == 2           ||  sscanf (line, "%[^=] = '%[^\']'",   key, value) == 2           ||  sscanf (line, "%[^=] = %[^;#]",     key, value) == 2) {        /* Usual key=value, with or without comments */        strcpy(key, strstrip(key));        strcpy(key, strlwc(key));        strcpy(value, strstrip(value));        /*         * sscanf cannot handle '' or "" as empty values         * this is done here         */        if (!strcmp(value, "\"\"") || (!strcmp(value, "''"))) {            value[0]=0 ;        }        sta = LINE_VALUE ;    } else if (sscanf(line, "%[^=] = %[;#]", key, value)==2           ||  sscanf(line, "%[^=] %[=]", key, value) == 2) {        /*         * Special cases:         * key=         * key=;         * key=#         */        strcpy(key, strstrip(key));        strcpy(key, strlwc(key));        value[0]=0 ;        sta = LINE_VALUE ;    } else {        /* Generate syntax error */        sta = LINE_ERROR ;    }    return sta ;}/*-------------------------------------------------------------------------*//**  @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(const char * ininame){    FILE * in ;    char line    [ASCIILINESZ+1] ;    char section [ASCIILINESZ+1] ;    char key     [ASCIILINESZ+1] ;    char tmp     [ASCIILINESZ+1] ;    char val     [ASCIILINESZ+1] ;    int  last=0 ;    int  len ;    int  lineno=0 ;    int  errs=0;    dictionary * dict ;    if ((in=fopen(ininame, "r"))==NULL) {        fprintf(stderr, "iniparser: cannot open %s\n", ininame);        return NULL ;    }    dict = dictionary_new(0) ;    if (!dict) {        fclose(in);        return NULL ;    }    memset(line,    0, ASCIILINESZ);    memset(section, 0, ASCIILINESZ);    memset(key,     0, ASCIILINESZ);    memset(val,     0, ASCIILINESZ);    last=0 ;    while (fgets(line+last, ASCIILINESZ-last, in)!=NULL) {        lineno++ ;        len = (int)strlen(line)-1;        /* Safety check against buffer overflows */        if (line[len]!='\n') {            fprintf(stderr,                    "iniparser: input line too long in %s (%d)\n",                    ininame,                    lineno);            dictionary_del(dict);            fclose(in);            return NULL ;        }        /* Get rid of \n and spaces at end of line */        while ((len>=0) &&                ((line[len]=='\n') || (isspace(line[len])))) {            line[len]=0 ;            len-- ;        }        /* Detect multi-line */        if (line[len]=='\\') {            /* Multi-line value */            last=len ;            continue ;        } else {            last=0 ;        }        switch (iniparser_line(line, section, key, val)) {            case LINE_EMPTY:            case LINE_COMMENT:            break ;            case LINE_SECTION:            errs = dictionary_set(dict, section, NULL);            break ;            case LINE_VALUE:            sprintf(tmp, "%s:%s", section, key);            errs = dictionary_set(dict, tmp, val) ;            break ;            case LINE_ERROR:            fprintf(stderr, "iniparser: syntax error in %s (%d):\n",                    ininame,                    lineno);            fprintf(stderr, "-> %s\n", line);            errs++ ;            break;            default:            break ;        }        memset(line, 0, ASCIILINESZ);        last=0;        if (errs<0) {            fprintf(stderr, "iniparser: memory allocation failure\n");            break ;        }    }    if (errs) {        dictionary_del(dict);        dict = NULL ;    }    fclose(in);    return dict ;}/*-------------------------------------------------------------------------*//**  @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 + -