亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? cfgs.c

?? 用c/c++實現的一個CMPP API
?? C
字號:
/***************************************************************************  Copyright    : 2001-2002, ASPIRE TECHNOLOGIES (SHENZHEN) LTD.  Program ID   : cfgs.c  Description  : 配置讀取接口函數  Version      : CMPP API 1.5a  Functions    : 內部函數  Modification Log:       DATE         AUTHOR          DESCRIPTION --------------------------------------------------------------------------       11/26/2002   sunjun            Create***************************************************************************/#include <ctype.h>#include "os.h"#include "cfgs.h"int gnCfgsCaseRestrict=0;/*  0: No Restrict: Group | Ident all UPPER/LOWER to fit.    1: Restrict:    Group | Ident all Restrict case fit.*//************************************************************ *  desc:    Left Trim the String inputed. ************************************************************/void    vCfgsLTrim( char * sOprt ){    int nHead, nCurr;    if( NULL == sOprt )        return ;    nHead = nCurr = 0;    while( 0 != isspace((int)*(sOprt+nCurr)) )        nCurr++;    while( '\0' != (*(sOprt+nCurr)) )    {        *(sOprt+nHead) = *(sOprt+nCurr);        nHead++, nCurr++;    }    *(sOprt+nHead) = *(sOprt+nCurr);    return ;}/***************  end of vCfgsLTrim() ***********************//************************************************************ *  desc:   Right Trim the String inputed. ************************************************************/void    vCfgsRTrim( char * sOprt ){    char *sTail;    if( NULL == sOprt )        return ;    if( 0 == (int)strlen(sOprt) )        return ;    sTail = sOprt+strlen(sOprt)-1;    while( 0 != isspace((int)*sTail) && sTail >= sOprt )    {        *sTail = '\0';        sTail--;    }    return ;}/************************************************************ *  desc:   Trim both end of the String inputed. ************************************************************/void    vCfgsATrim( char * sOprt ){    if( NULL == sOprt )        return ;    vCfgsRTrim( sOprt );    vCfgsLTrim( sOprt );    return ;}/************************************************************ *  desc:   Replace the Char Escaped by '\\' with SpecialChar. *  \b,\t,\n,\r,\MacCFGS_CharDivide,\\,... *  ret:   void. ************************************************************/void    vCfgsEscCh( char * sOprt, bool_t bDivide ){    char    * sSrc, * sDst;    int     nModified;    if( NULL == sOprt )    {        return ;    }    sSrc = sDst = sOprt;    nModified = 0;    while( '\0' != *sSrc )    {        if( bDivide && MacCFGS_CharDivide == *sSrc )        {            *sDst = '\0';            return ;        }        else if( '\\' != *sSrc && 0 == nModified )        {            sSrc++;            sDst++;        }        else if( '\\' != *sSrc && 0 != nModified )        {            *sDst = *sSrc;            sSrc++;            sDst++;        }        else        {            switch( *(sSrc+1) )            {            case    'b':                *sDst = '\b';                sSrc += 2;                sDst += 1;                break;            case    'n':                *sDst = '\n';                sSrc += 2;                sDst += 1;                break;            case    'r':                *sDst = '\r';                sSrc += 2;                sDst += 1;                break;            case    't':                *sDst = '\t';                sSrc += 2;                sDst += 1;                break;            case    MacCFGS_CharDivide:                *sDst = MacCFGS_CharDivide;                sSrc += 2;                sDst += 1;                break;            case    '\0':                sSrc += 1;                break;            default:                sSrc += 1;                break;            }            nModified += 1;        }    }    //    end of while()_Loop    *sDst = '\0';    return ;}/************************************************************ *    desc:    read the Item configed in the IniFile with String Value. *    rett:    char *. *    retv:    !=NULL:    success. *               NULL:    failed. *    memo:    No Trim at Content. ************************************************************/char*   sCfgsReadString( char * sFileName, char * sGroupName,                        char * sIdentName, char * sRet, int nSize ){    FILE    * lfd_src;    char    sGName[MacCFGS_LineLength];    char    sIName[MacCFGS_LineLength];    char    sIdent[MacCFGS_LineLength];    char    sGroup[MacCFGS_LineLength];    char    *sTmp;    int     nTmp, nLen;    if( NULL == sFileName ||        NULL == sGroupName || NULL == sIdentName ||        NULL == sRet )        return NULL;    lfd_src = fopen( sFileName, "r" );    if( NULL == lfd_src )        return NULL;    strcpy( sRet, "" );    sTmp = NULL;    snprintf( sIName, sizeof(sIName), "%s", sGroupName );    vCfgsATrim( sIName );    snprintf( sGName, sizeof(sGName), "[%s]", sIName );    snprintf( sIName, sizeof(sIName), "%s", sIdentName );    vCfgsATrim( sIName );    if( 0 == strlen(sGName) || 0 == strlen(sIName) )    {        fclose( lfd_src );        return NULL;    }    if( 0 == gnCfgsCaseRestrict )    {        nLen = (int)strlen(sGName);        for( nTmp=0; nTmp<nLen; nTmp++ )            sGName[nTmp] = (char)toupper(sGName[nTmp]);        nLen = (int)strlen(sIName);        for( nTmp=0; nTmp<nLen; nTmp++ )            sIName[nTmp] = (char)toupper(sIName[nTmp]);    }    //    Find Group    nLen = (int)strlen(sGName);    //    nLen >= 2    while( 1 )    {        if( NULL == fgets(sGroup,sizeof(sGroup),lfd_src) )        {            fclose( lfd_src );            return NULL;        }        vCfgsEscCh( sGroup, B_TRUE );        vCfgsATrim( sGroup );        if( (int)strlen(sGroup) != nLen )            continue;        for( nTmp=0; nTmp<nLen; nTmp++ )            sGroup[nTmp] = (char)toupper(sGroup[nTmp]);        if( 0 == strcmp(sGroup,sGName) )            break;    //    Group found    }    //    Find Ident    nLen = (int)strlen(sIName);    //    nLen >= 0    while( 1 )    {        if( NULL == fgets(sIdent,sizeof(sIdent),lfd_src) )        {            fclose( lfd_src );            return NULL;        }    //    if( (int)strlen(sIdent) <= nLen )    //    nLen >= 0    //        continue;        if( '\n' == sIdent[strlen(sIdent)-1] )            sIdent[strlen(sIdent)-1] = '\0';        vCfgsEscCh( sIdent, B_TRUE );        vCfgsLTrim( sIdent );        if( MacCFGS_LeftsQuote == sIdent[0] &&            NULL != strchr(sIdent,MacCFGS_RightQuote) )        {            fclose( lfd_src );            return NULL;        }        for( nTmp=0; nTmp<nLen; nTmp++ )            sIdent[nTmp] = (char)toupper(sIdent[nTmp]);        if( 0 == strncmp(sIdent,sIName,nLen) )        {            sTmp = sIdent+nLen;            while( isspace( (int)*sTmp) )                sTmp++;            if( MacCFGS_CharAssign != *sTmp )                continue;            else            {                sTmp++;    //    goto Content                break;    //    Ident found            }        }    }    fclose( lfd_src );    vCfgsATrim( sTmp );    snprintf( sRet, nSize, "%s", sTmp );    return sRet;}/************************************************************ *    desc:    read the Item configed in the IniFile with Number Value. *    rett:    char *. *    retv:    !NULL:    success. *              NULL:    failed. ************************************************************/char*   sCfgsReadNumber( char * sFileName, char * sGroupName,                        char * sIdentName, int * pnRet ){    static char    sRst[ MacCFGS_LineLength ], * sRet;    if( NULL == pnRet )        return NULL;    *pnRet = 0;    memset( sRst, 0,sizeof(sRst) );    sRet = sCfgsReadString( sFileName, sGroupName,        sIdentName, sRst, sizeof(sRst) );    vCfgsATrim( sRst );    if( NULL != sRet )        *pnRet = atoi( sRst );    return sRet;}/************************************************************ *    desc:    read the Item configed in the IniFile with LongNu Value. *    rett:    char *. *    retv:    !NULL:    success. *            NULL:    failed. ************************************************************/char*   sCfgsReadLongNu( char * sFileName, char * sGroupName,                        char * sIdentName, long * plRet ){    static char    sRst[ MacCFGS_LineLength ], * sRet;    if( NULL == plRet )        return NULL;    *plRet = 0;    memset( sRst, 0,sizeof(sRst) );    sRet = sCfgsReadString( sFileName, sGroupName,        sIdentName, sRst, sizeof(sRst) );    vCfgsATrim( sRst );    if( NULL != sRet )        *plRet = atol( sRst );    return sRet;}/************************************************************ * desc: read the name of group with offset: nGrpOff.       * * rett: char *.                                            * * retv: NULL: fail. !=NULL: succ. (==sGrpNam)              * ************************************************************/char*   sCfgsReadGrpOff( char * sFileName, int nGrpOff,                        char * sGrpNam, int nSize ){    FILE    * lfp_src;    char    sGName[ MacCFGS_LineLength ];    int        i, nLen;    if( NULL == sFileName || nGrpOff < 0 ||        NULL == sGrpNam   || nSize   < 0 )        return NULL;    lfp_src = fopen( sFileName, "r" );    if( NULL == lfp_src )        return NULL;    strcpy( sGrpNam, "" );    //    Find Group    for( i=0; i<=nGrpOff; )    {        if( NULL == fgets(sGName,sizeof(sGName),lfp_src) )        {            fclose( lfp_src );            return NULL;        }        vCfgsEscCh( sGName, B_TRUE );        vCfgsATrim( sGName );        nLen = (int)strlen(sGName);        if( nLen <= 2 )            continue;        if( MacCFGS_LeftsQuote != sGName[0] ||            MacCFGS_RightQuote != sGName[nLen-1] )            continue;        if( i < nGrpOff )        {            i += 1;            continue;        }        fclose( lfp_src );        snprintf( sGrpNam, nSize, "%.*s", nLen-2, sGName+1 );        return sGrpNam;    }    fclose( lfp_src );    return NULL;}/************************************************************ * desc: read the ident(say Item) line with offset: nItmLin * *       which in group specialed by name: sSect.           * * rett: char *.                                            * * retv: NULL: fail. !=NULL: succ. (==sItmLin)              * ************************************************************/char*   sCfgsReadItmLin( char * sFileName, char * sSect, int nItmLin,                        char * sItmLin, int nSize ){    FILE    * lfp_src;    char    sGName[ MacCFGS_LineLength ], sIName[ MacCFGS_LineLength ];    char    sIdent[ MacCFGS_LineLength ];    char    sGroup[ MacCFGS_LineLength ];    char    * sTmp;    int        i, nTmp, nLen;    if( NULL == sFileName || NULL == sSect || nItmLin < 0 ||        NULL == sItmLin   || nSize < 0 )        return NULL;    lfp_src = fopen( sFileName, "r" );    if( NULL == lfp_src )        return NULL;    strcpy( sItmLin, "" );    sTmp = NULL;    snprintf( sIName, sizeof(sIName), "%s", sSect );    vCfgsATrim( sIName );    nLen = snprintf( sGName, sizeof(sGName), "[%s]", sIName );    if( 2 >= (int)strlen(sGName) )    {        fclose( lfp_src );        return NULL;    }    if( 0 == gnCfgsCaseRestrict )    {        nLen = (int)strlen(sGName);        for( nTmp=0; nTmp<nLen; nTmp++ )            sGName[nTmp] = (char)toupper(sGName[nTmp]);    }    //    Find Group    while( 1 )    {        if( NULL == fgets(sGroup,sizeof(sGroup),lfp_src) )        {            fclose( lfp_src );            return NULL;        }        vCfgsEscCh( sGroup, B_TRUE );        vCfgsATrim( sGroup );        if( (int)strlen(sGroup) != nLen )            continue;        for( nTmp=0; nTmp<nLen; nTmp++ )            sGroup[nTmp] = (char)toupper(sGroup[nTmp]);        if( 0 == strcmp(sGroup,sGName) )            break;    //    Group found    }    //    end of Find Group    //    Find ItmLin    for( i=0; i<= nItmLin; )    {        if( NULL == fgets(sIdent,sizeof(sIdent),lfp_src) )        {            fclose( lfp_src );            return NULL;        }        nLen = (int)strlen(sIdent);        if( nLen <= 1 )            continue;        if( '\n' == sIdent[nLen-1] )            sIdent[nLen-1] = (char)0;        vCfgsEscCh( sIdent, B_TRUE );        vCfgsLTrim( sIdent );        if( MacCFGS_LeftsQuote == sIdent[0] )        {            fclose( lfp_src );            return NULL;        }        sTmp = strchr( sIdent, MacCFGS_CharAssign );        if( NULL == sTmp || sTmp == sIdent )            continue;        if( i <  nItmLin )        {            i += 1;            continue;        }        fclose( lfp_src );        snprintf( sItmLin, nSize, "%s", sIdent );        return sItmLin;    }    //    end of Find ItmLin    fclose( lfp_src );    return NULL;}/************************************************************ * desc: use dynamic parameters to read data in CfgItem     * *       which is specialed by GroupName:sSect &            * *       IdentName:sIdnt, formated by sDatFmt.              * * rett: int.                                               * * retv: the number of successfully mitached and assigned   * *       input items ( specialed by ... ).                  * *       <0: failed. =0: No assigned.                       * ************************************************************//*int nvCfgsReadItmDat( char * sFile, char * sSect, char * sIdnt,                     char * sDatFmt, ... ){    va_list    lvalist;    char    sString[ MacCFGS_LineLength ];    int     nRet;    sString[0] = 0;    if( NULL == sCfgsReadString( sFile, sSect, sIdnt,        sString, sizeof(sString) ) )        return -1;    va_start( lvalist, sDatFmt );    nRet = _vsscanf( sString, sDatFmt, lvalist );    va_end( lvalist );    return nRet;}*//************************************************************ * desc: use dynamic parameters to read data in CfgItem     * *       which is specialed by GroupName:sSect &            * *       IdentOffset:nItmOff, formated by sItmFmt.          * * rett: int.                                               * * retv: the number of successfully mitached and assigned   * *       input items ( specialed by ... ).                  * *       <0: failed. =0: No assigned.                       * ************************************************************/ /*int nvCfgsReadItmOff(char * sFile, char * sSect, int nItmOff, char * sItmFmt, ...){    va_list    lvalist;    char    sString[ MacCFGS_LineLength ], *sTmp;    int     nRet;    sString[0] = 0;    if( NULL == sCfgsReadItmLin( sFile, sSect, nItmOff,        sString, sizeof(sString) ) )        return -1;    sTmp = strchr( sString, MacCFGS_CharAssign );    if( NULL == sTmp )        return 0;    sTmp += 1;    va_start( lvalist, sItmFmt );    nRet = vsscanf( sTmp, sItmFmt, lvalist );    va_end( lvalist );    return nRet;}*/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91视频www| 欧美不卡123| ...av二区三区久久精品| 国产福利一区二区三区视频| 日韩一区二区三区视频| 国产一区二区三区在线观看精品 | 精品国产sm最大网站免费看| 国产精品久久久久久一区二区三区| 日韩vs国产vs欧美| 综合欧美亚洲日本| 在线一区二区三区四区五区| 亚洲成av人片观看| 国产日产欧美一区二区视频| 欧美色偷偷大香| 国产91精品久久久久久久网曝门| 亚洲欧美日韩久久| 精品久久人人做人人爱| 在线免费视频一区二区| 激情伊人五月天久久综合| 亚洲美女区一区| 国产精品欧美一级免费| 色悠久久久久综合欧美99| 精品一二线国产| 蜜臀va亚洲va欧美va天堂| 一区二区三区中文字幕电影| 国产日韩综合av| 精品成人一区二区三区| 777奇米四色成人影色区| 91亚洲国产成人精品一区二三 | 亚洲欧洲精品一区二区三区 | 成人app网站| 国产成人精品1024| 国产精品资源在线| 国产资源在线一区| 国产精品996| 国产一区在线观看视频| 国产在线一区二区| 高清不卡一区二区| 日本高清不卡aⅴ免费网站| 欧美在线播放高清精品| 久久91精品国产91久久小草| 免费成人在线影院| 蜜臀av性久久久久av蜜臀妖精| 亚洲一区二区av电影| 亚洲一区影音先锋| 亚洲成人一区二区| 蜜桃在线一区二区三区| 蜜桃视频在线观看一区| 国产精品一级在线| 一本色道久久综合精品竹菊| 欧美少妇xxx| 欧美日韩国产成人在线免费| 久久久亚洲欧洲日产国码αv| 中文字幕在线一区免费| 日韩电影免费在线看| 成人性视频免费网站| 欧美日韩aaaaaa| 欧美夫妻性生活| 中文文精品字幕一区二区| 亚洲精品高清在线| 国产99久久精品| 91麻豆精品久久久久蜜臀| 日本一区二区三区四区在线视频| 亚洲精品免费一二三区| 极品尤物av久久免费看| 欧美亚洲高清一区二区三区不卡| 欧美一区二区在线看| 亚洲一区二区三区四区在线免费观看 | 午夜久久久久久| 99re视频精品| 中文字幕人成不卡一区| 不卡电影一区二区三区| 国产午夜精品久久久久久久| 激情文学综合丁香| 日韩欧美在线1卡| 久久99这里只有精品| 精品美女一区二区三区| 美女爽到高潮91| 久久久精品影视| 一本色道**综合亚洲精品蜜桃冫| 欧美激情一区二区三区在线| 成人丝袜18视频在线观看| 综合久久久久久| 欧美色区777第一页| 麻豆国产精品官网| 中文字幕一区在线观看| 欧美性大战久久久久久久蜜臀| 天天色天天爱天天射综合| 欧美精品一区二区三| 91丨九色porny丨蝌蚪| 亚洲欧美日韩一区| 日韩欧美中文字幕一区| 成人美女视频在线观看18| 午夜视频一区二区三区| 制服丝袜亚洲播放| 99久久综合99久久综合网站| 一区二区久久久| 2021中文字幕一区亚洲| 色婷婷av久久久久久久| 狠狠色狠狠色合久久伊人| 亚洲一区二区三区四区不卡| 中文字幕电影一区| 精品噜噜噜噜久久久久久久久试看| 色噜噜夜夜夜综合网| 国产成人自拍在线| 狠狠色狠狠色合久久伊人| 亚洲成人免费av| 午夜激情综合网| 亚洲午夜一区二区| 综合久久久久久久| 中文字幕五月欧美| 亚洲老妇xxxxxx| 亚洲欧美日本在线| 一区二区三区四区乱视频| 国产精品国产自产拍高清av| 日本一区二区在线不卡| 国产日韩欧美不卡在线| 中文在线免费一区三区高中清不卡| 精品精品欲导航| 中文字幕欧美三区| 中文字幕亚洲成人| 亚洲一二三四在线观看| 最近日韩中文字幕| 亚洲欧美色图小说| 免费观看久久久4p| 色哟哟日韩精品| 欧美tk丨vk视频| 亚洲欧美日韩中文播放| 亚洲超碰97人人做人人爱| 蜜臀av性久久久久蜜臀aⅴ四虎 | 亚洲欧洲综合另类| 轻轻草成人在线| 国产成人av一区二区三区在线| www.欧美精品一二区| 69成人精品免费视频| 国产精品毛片a∨一区二区三区| 一区二区日韩电影| 国产成人免费在线观看| 欧美午夜精品久久久久久孕妇| 日韩欧美亚洲一区二区| 亚洲成人免费影院| 色综合久久中文字幕| 国产色一区二区| 国产精品18久久久久| 欧美一区二区在线免费播放| 亚洲另类春色校园小说| 国产99久久久国产精品免费看| 欧美日本一区二区三区| 中文字幕在线一区免费| 高清久久久久久| 国产精品三级av| www.日韩av| 亚洲男同1069视频| www.亚洲精品| 自拍偷拍国产精品| 99久久久久久| 亚洲高清免费观看高清完整版在线观看 | 91在线视频播放地址| 中文字幕一区二区三区不卡 | 大桥未久av一区二区三区中文| 欧美一区二区在线观看| 另类小说色综合网站| 欧美变态tickling挠脚心| 国产精品一二三| 中文字幕不卡一区| 99国内精品久久| 日韩有码一区二区三区| 日韩久久久久久| 99亚偷拍自图区亚洲| 亚洲午夜在线电影| 精品福利在线导航| 色婷婷综合五月| 奇米影视一区二区三区| 欧美精品一区二| 91.com视频| 国产成人无遮挡在线视频| 午夜电影一区二区| 久久久www免费人成精品| 欧美在线一二三四区| 久久99精品国产麻豆不卡| 亚洲精品免费一二三区| 欧美激情资源网| 精品国产一区二区在线观看| 91丨porny丨首页| 丁香一区二区三区| 捆绑调教一区二区三区| 中文字幕在线不卡| 欧美国产综合色视频| 日韩欧美国产三级电影视频| 色成年激情久久综合| 91一区二区三区在线观看| 国产精品一区二区久久不卡| 美女一区二区三区在线观看| 日韩精品一级二级| 日韩1区2区日韩1区2区| 青草av.久久免费一区| 日韩 欧美一区二区三区| 久久精品免费看| 精品一区二区免费| 国产精品18久久久久|