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

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

?? win32.c

?? zip壓縮
?? C
?? 第 1 頁 / 共 5 頁
字號:
        if (G.filename[0] == '/') {            G.renamed_fullpath = TRUE;            pathcomp[0] = '/';  /* copy the '/' and terminate */            pathcomp[1] = '\0';            ++cp;        } else if (isalpha((uch)G.filename[0]) && G.filename[1] == ':') {            G.renamed_fullpath = TRUE;            pp = pathcomp;            *pp++ = *cp++;      /* copy the "d:" (+ '/', possibly) */            *pp++ = *cp++;            if (*cp == '/')                *pp++ = *cp++;  /* otherwise add "./"? */            *pp = '\0';        }    }    /* pathcomp is ignored unless renamed_fullpath is TRUE: */    if ((error = checkdir(__G__ pathcomp, INIT)) != 0)    /* init path buffer */        return error;           /* ...unless no mem or vol label on hard disk */    *pathcomp = '\0';           /* initialize translation buffer */    pp = pathcomp;              /* point to translation buffer */    if (!renamed) {             /* cp already set if renamed */        if (uO.jflag)           /* junking directories */            cp = (char *)MBSRCHR(G.filename, '/');        if (cp == NULL)         /* no '/' or not junking dirs */            cp = G.filename;    /* point to internal zipfile-member pathname */        else            ++cp;               /* point to start of last component of path */    }/*---------------------------------------------------------------------------    Begin main loop through characters in filename.  ---------------------------------------------------------------------------*/    for (; (workch = (uch)*cp) != 0; INCSTR(cp)) {        switch (workch) {        case '/':             /* can assume -j flag not given */            *pp = '\0';            maskDOSdevice(__G__ pathcomp);            if (((error = checkdir(__G__ pathcomp, APPEND_DIR)) & MPN_MASK)                 > MPN_INF_TRUNC)                return error;            pp = pathcomp;    /* reset conversion buffer for next piece */            lastsemi = NULL;  /* leave directory semi-colons alone */            break;        case '.':            if (pp == pathcomp) {       /* nothing appended yet... */                if (cp[1] == '/') {     /* don't bother appending "./" to */                    ++cp;               /*  the path: skip behind the '/' */                    break;                } else if (!uO.ddotflag && cp[1] == '.' && cp[2] == '/') {                    /* "../" dir traversal detected */                    cp += 2;            /*  skip over behind the '/' */                    killed_ddot = TRUE; /*  set "show message" flag */                    break;                }            }            *pp++ = '.';            break;        case ':':             /* drive names not stored in zipfile, */        case '<':             /*  so no colons allowed */        case '>':             /* no redirection symbols allowed either */        case '|':             /* no pipe signs allowed */        case '"':             /* no double quotes allowed */        case '?':             /* no wildcards allowed */        case '*':            *pp++ = '_';      /* these rules apply equally to FAT and NTFS */            break;        case ';':             /* start of VMS version? */            lastsemi = pp;    /* remove VMS version later... */            *pp++ = ';';      /*  but keep semicolon for now */            break;#ifdef ACORN_FTYPE_NFS        case ',':             /* NFS filetype extension */            lastcomma = pp;            *pp++ = ',';      /* keep for now; may need to remove */            break;            /*  later, if requested */#endif        case ' ':             /* keep spaces unless specifically */            /* NT cannot create filenames with spaces on FAT volumes */            if (uO.sflag || IsVolumeOldFAT(__G__ G.filename))                *pp++ = '_';            else                *pp++ = ' ';            break;        default:            /* allow European characters in filenames: */            if (isprint(workch) || workch >= 127)#ifdef _MBCS            {                memcpy(pp, cp, CLEN(cp));                INCSTR(pp);            }#else                *pp++ = (char)workch;#endif        } /* end switch */    } /* end while loop */    /* Show warning when stripping insecure "parent dir" path components */    if (killed_ddot && QCOND2) {        Info(slide, 0, ((char *)slide,          "warning:  skipped \"../\" path component(s) in %s\n",          FnFilter1(G.filename)));        if (!(error & ~MPN_MASK))            error = (error & MPN_MASK) | PK_WARN;    }/*---------------------------------------------------------------------------    Report if directory was created (and no file to create:  filename ended    in '/'), check name to be sure it exists, and combine path and name be-    fore exiting.  ---------------------------------------------------------------------------*/    if (lastchar(G.filename, G.fnlen) == '/') {        checkdir(__G__ G.filename, GETPATH);        if (G.created_dir) {#ifdef __RSXNT__        /* RSXNT/EMX C rtl uses OEM charset */            char *ansi_name = (char *)alloca(strlen(G.filename) + 1);            INTERN_TO_ISO(G.filename, ansi_name);#           define Ansi_Fname  ansi_name#else#           define Ansi_Fname  G.filename#endif            if (QCOND2) {                Info(slide, 0, ((char *)slide, "   creating: %-22s\n",                  FnFilter1(G.filename)));            }            /* set file attributes:               The default for newly created directories is "DIR attribute               flags set", so there is no need to change attributes unless               one of the DOS style attribute flags is set. The readonly               attribute need not be masked, since it does not prevent               modifications in the new directory. */            if(G.pInfo->file_attr & (0x7F & ~FILE_ATTRIBUTE_DIRECTORY)) {                if (!SetFileAttributes(Ansi_Fname, G.pInfo->file_attr & 0x7F))                    Info(slide, 1, ((char *)slide,                      "\nwarning (%d): could not set file attributes for %s\n",                      (int)GetLastError(), FnFilter1(G.filename)));            }#ifdef NTSD_EAS            /* set extra fields, both stored-in-zipfile and .LONGNAME flavors */            if (G.extra_field) { /* zipfile e.f. may have extended attribs */                int err = EvalExtraFields(__G__ G.filename, G.extra_field,                                          G.lrec.extra_field_length);                if (err == IZ_EF_TRUNC) {                    if (uO.qflag)                        Info(slide, 1, ((char *)slide, "%-22s ",                          FnFilter1(G.filename)));                    Info(slide, 1, ((char *)slide, LoadFarString(TruncNTSD),                      makeword(G.extra_field+2)-10, uO.qflag? "\n":""));                }            }#endif /* NTSD_EAS */            /* set dir time (note trailing '/') */            return (error & ~MPN_MASK) | MPN_CREATED_DIR;        }        /* dir existed already; don't look for data to extract */        return (error & ~MPN_MASK) | MPN_INF_SKIP;    }    *pp = '\0';                   /* done with pathcomp:  terminate it */    /* if not saving them, remove VMS version numbers (appended "###") */    if (!uO.V_flag && lastsemi) {        pp = lastsemi + 1;        /* semi-colon was kept:  expect #'s after */        while (isdigit((uch)(*pp)))            ++pp;        if (*pp == '\0')          /* only digits between ';' and end:  nuke */            *lastsemi = '\0';    }#ifdef ACORN_FTYPE_NFS    /* translate Acorn filetype information if asked to do so */    if (uO.acorn_nfs_ext &&        (ef_spark = (RO_extra_block *)                    getRISCOSexfield(G.extra_field, G.lrec.extra_field_length))        != (RO_extra_block *)NULL)    {        /* file *must* have a RISC OS extra field */        long ft = (long)makelong((ef_spark->loadaddr);        /*32-bit*/        if (lastcomma) {            pp = lastcomma + 1;            while (isxdigit((uch)(*pp))) ++pp;            if (pp == lastcomma+4 && *pp == '\0') *lastcomma='\0'; /* nuke */        }        if ((ft & 1<<31)==0) ft=0x000FFD00;        sprintf(pathcomp+strlen(pathcomp), ",%03x", (int)(ft>>8) & 0xFFF);    }#endif /* ACORN_FTYPE_NFS */    maskDOSdevice(__G__ pathcomp);    if (*pathcomp == '\0') {        Info(slide, 1, ((char *)slide, "mapname:  conversion of %s failed\n",          FnFilter1(G.filename)));        return (error & ~MPN_MASK) | MPN_ERR_SKIP;    }    checkdir(__G__ pathcomp, APPEND_NAME);  /* returns 1 if truncated: care? */    checkdir(__G__ G.filename, GETPATH);    if (G.pInfo->vollabel) {    /* set the volume label now */        char drive[4];#ifdef __RSXNT__        /* RSXNT/EMX C rtl uses OEM charset */        char *ansi_name = (char *)alloca(strlen(G.filename) + 1);        INTERN_TO_ISO(G.filename, ansi_name);#       define Ansi_Fname  ansi_name#else#       define Ansi_Fname  G.filename#endif        /* Build a drive string, e.g. "b:" */        drive[0] = (char)('a' + G.nLabelDrive - 1);        strcpy(drive + 1, ":\\");        if (QCOND2)            Info(slide, 0, ((char *)slide, "labelling %s %-22s\n", drive,              FnFilter1(G.filename)));        if (!SetVolumeLabel(drive, Ansi_Fname)) {            Info(slide, 1, ((char *)slide,              "mapname:  error setting volume label\n"));            return (error & ~MPN_MASK) | MPN_ERR_SKIP;        }        /* success:  skip the "extraction" quietly */        return (error & ~MPN_MASK) | MPN_INF_SKIP;#undef Ansi_Fname    }    Trace((stderr, "mapname returns with filename = [%s] (error = %d)\n\n",      FnFilter1(G.filename), error));    return error;} /* end function mapname() *//****************************//* Function maskDOSdevice() *//****************************/static void maskDOSdevice(__G__ pathcomp)    __GDEF    char *pathcomp;{/*---------------------------------------------------------------------------    Put an underscore in front of the file name if the file name is a    DOS/WINDOWS device name like CON.*, AUX.*, PRN.*, etc. Trying to    extract such a file would fail at best and wedge us at worst.  ---------------------------------------------------------------------------*/#if !defined(S_IFCHR) && defined(_S_IFCHR)#  define S_IFCHR _S_IFCHR#endif#if !defined(S_ISCHR)# if defined(_S_ISCHR)#  define S_ISCHR(m) _S_ISCHR(m)# elif defined(S_IFCHR)#  define S_ISCHR(m) ((m) & S_IFCHR)# endif#endif#ifdef DEBUG    if (stat(pathcomp, &G.statbuf) == 0) {        Trace((stderr,               "maskDOSdevice() stat(\"%s\", buf) st_mode result: %X, %o\n",               FnFilter1(pathcomp), G.statbuf.st_mode, G.statbuf.st_mode));    } else {        Trace((stderr, "maskDOSdevice() stat(\"%s\", buf) failed\n",               FnFilter1(pathcomp)));    }#endif    if (stat(pathcomp, &G.statbuf) == 0 && S_ISCHR(G.statbuf.st_mode)) {        extent i;        /* pathcomp contains a name of a DOS character device (builtin or         * installed device driver).         * Prepend a '_' to allow creation of the item in the file system.         */        for (i = strlen(pathcomp) + 1; i > 0; --i)            pathcomp[i] = pathcomp[i - 1];        pathcomp[0] = '_';    }} /* end function maskDOSdevice() *//**********************//* Function map2fat() */        /* Not quite identical to OS/2 version *//**********************/static void map2fat(pathcomp, pEndFAT)    char *pathcomp, **pEndFAT;{    char *ppc = pathcomp;       /* variable pointer to pathcomp */    char *pEnd = *pEndFAT;      /* variable pointer to buildpathFAT */    char *pBegin = *pEndFAT;    /* constant pointer to start of this comp. */    char *last_dot = NULL;      /* last dot not converted to underscore */    register unsigned workch;   /* hold the character being tested */    /* Only need check those characters which are legal in NTFS but not     * in FAT:  to get here, must already have passed through mapname.     * Also must truncate path component to ensure 8.3 compliance.     */    while ((workch = (uch)*ppc++) != 0) {        switch (workch) {            case '[':            case ']':            case '+':            case ',':            case ';':            case '=':                *pEnd++ = '_';      /* convert brackets to underscores */                break;            case '.':                if (pEnd == *pEndFAT) {   /* nothing appended yet... */                    if (*ppc == '\0')     /* don't bother appending a */                        break;            /*  "./" component to the path */                    else if (*ppc == '.' && ppc[1] == '\0') {   /* "../" */                        *pEnd++ = '.';    /*  add first dot, */                        *pEnd++ = '.';    /*  add second dot, and */                        ++ppc;            /*  skip over to pathcomp's end */                    } else {              /* FAT doesn't allow null filename */                        *pEnd++ = '_';    /*  bodies, so map .exrc -> _exrc */                    }                     /*  (_.exr would keep max 3 chars) */                } else {                  /* found dot within path component */                    last_dot = pEnd;      /*  point at last dot so far... */                    *pEnd++ = '_';        /*  convert to underscore for now */                }                break;            default:                *pEnd++ = (char)workch;        } /* end switch */    } /* end while loop */    *pEnd = '\0';                 /* terminate buildpathFAT */    /* NOTE:  keep in mind that pEnd points to the end of the path     * component, and *pEndFAT still points to the *beginning* of it...     * Also note that the algorithm does not try to get too fancy:     * if there are no dots already, the name either gets truncated     * at 8 characters or the last underscore is converted to a dot     * (only if more characters are saved that way).  In no case is     * a dot inserted between existing characters.     */    if (last_dot == NULL) {       /* no dots:  check for underscores... */        char *plu = MBSRCHR(pBegin, '_');   /* pointer to last underscore */        if ((plu != NULL) &&      /* found underscore: convert to dot? */            (MIN(plu - pBegin, 8) + MIN(pEnd - plu - 1, 3) > 8)) {            last_dot = plu;       /* be lazy:  drop through to next if-blk */        } else if ((pEnd - *pEndFAT) > 8) {            /* no underscore; or converting underscore to dot would save less               chars than leaving everything in the basename */            *pEndFAT += 8;        /* truncate at 8 chars */            **pEndFAT = '\0';        } else            *pEndFAT = pEnd;      /* whole thing fits into 8 chars or less */    }    if (last_dot != NULL) {       /* one dot is OK: */        *last_dot = '.';          /* put it back in */        if ((last_dot - pBegin) > 8) {            char *p, *q;            int i;            p = last_dot;            q = last_dot = pBegin + 8;            for (i = 0;  (i < 4) && *p;  ++i)  /* too many chars in basename: */                *q++ 

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
2020国产精品久久精品美国| 欧美日韩成人综合| 国产精品久久国产精麻豆99网站| 国内不卡的二区三区中文字幕| 日韩视频在线永久播放| 寂寞少妇一区二区三区| 国产欧美视频在线观看| 91小视频在线免费看| 亚洲福利一区二区三区| 日韩免费一区二区| 丁香桃色午夜亚洲一区二区三区| 中文字幕五月欧美| 欧美精品粉嫩高潮一区二区| 激情图区综合网| 成人免费视频在线观看| 欧美狂野另类xxxxoooo| 国产一区在线观看视频| 日韩理论在线观看| 91精品国产高清一区二区三区蜜臀 | 91国产福利在线| 日本不卡不码高清免费观看| 久久久亚洲国产美女国产盗摄| 成+人+亚洲+综合天堂| 亚洲一区二区三区在线看| 精品国产乱码久久久久久免费| 成人免费电影视频| 天天综合网天天综合色| 中文字幕在线一区| 欧美一区二区三区视频在线观看| 国产精品一二一区| 亚洲成人自拍偷拍| 国产精品美女一区二区在线观看| 91精品国产免费| 97se亚洲国产综合自在线| 免费看日韩精品| 亚洲精品乱码久久久久久日本蜜臀| 日韩欧美在线观看一区二区三区| av不卡一区二区三区| 久久精品噜噜噜成人88aⅴ| 成人免费在线播放视频| 欧美精品一区二区久久婷婷 | 欧美日韩中文字幕一区二区| 国产黄色精品视频| 青青草国产成人99久久| 一区二区三区**美女毛片| 久久久精品免费网站| 欧美精品久久天天躁| 99国产精品久| 成人免费视频网站在线观看| 裸体在线国模精品偷拍| 亚洲精品乱码久久久久久久久| 国产日韩欧美电影| 精品国精品国产| 4438成人网| 欧美久久久久久久久久| 色婷婷久久久亚洲一区二区三区| 国产精品69毛片高清亚洲| 久久99久久久久久久久久久| 亚洲电影一级黄| 亚洲午夜免费视频| 一区二区三区在线视频免费观看| 国产精品久久777777| 国产午夜精品一区二区三区视频| 日韩欧美亚洲一区二区| 欧美一区三区四区| 337p亚洲精品色噜噜| 欧美日韩国产另类一区| 色老汉一区二区三区| 91尤物视频在线观看| 成a人片亚洲日本久久| 成人影视亚洲图片在线| 国产激情一区二区三区四区 | 波多野结衣视频一区| 成人涩涩免费视频| 99视频精品免费视频| 不卡av在线免费观看| www.日本不卡| 色偷偷一区二区三区| 欧美日韩在线三级| 欧美美女一区二区在线观看| 欧美精品在线观看播放| 日韩一级在线观看| 精品久久久久99| 久久久99久久| 国产精品欧美一区二区三区| 1024国产精品| 一级特黄大欧美久久久| 亚洲成人精品一区| 青青青爽久久午夜综合久久午夜| 精品综合久久久久久8888| 国产精品一区二区无线| 99re这里只有精品视频首页| 欧洲国内综合视频| 日韩午夜激情视频| 国产亚洲短视频| 亚洲女厕所小便bbb| 午夜久久久久久久久| 蜜桃一区二区三区在线| 国产精品综合av一区二区国产馆| 99久久精品国产麻豆演员表| 欧美色视频在线观看| 2019国产精品| 一区二区三区四区不卡在线| 婷婷中文字幕一区三区| 国产福利91精品一区二区三区| 99在线精品观看| 日韩一区二区三区三四区视频在线观看 | 亚洲电影一区二区三区| 九色综合国产一区二区三区| av在线不卡观看免费观看| 正在播放亚洲一区| 久久综合给合久久狠狠狠97色69| 日韩伦理免费电影| 精品在线观看视频| 一本一道久久a久久精品 | 亚洲v中文字幕| 国产成人在线看| 欧美三级在线视频| 国产无人区一区二区三区| 一区二区日韩电影| 国产一区二区三区高清播放| 在线亚洲一区观看| 久久久综合视频| 亚洲超碰精品一区二区| 成人福利视频在线| 日韩精品中午字幕| 亚洲精品成人天堂一二三| 国产一区在线观看视频| 欧洲国内综合视频| 国产欧美在线观看一区| 青青草国产成人99久久| 色婷婷综合五月| 欧美国产一区二区在线观看 | 国产一区二区久久| 欧美日韩国产综合久久| 综合分类小说区另类春色亚洲小说欧美 | 亚洲综合丝袜美腿| 粉嫩av亚洲一区二区图片| 91精品国产一区二区三区蜜臀| 伊人开心综合网| 成人黄色免费短视频| 欧美r级在线观看| 日韩不卡免费视频| 欧美色窝79yyyycom| 亚洲人吸女人奶水| av不卡免费在线观看| 国产区在线观看成人精品| 美女视频黄频大全不卡视频在线播放| 日本韩国视频一区二区| 亚洲欧洲av在线| 国产精品1区2区3区| wwwwww.欧美系列| 精品一区二区影视| 欧美电影免费观看完整版| 日韩在线一二三区| 欧美日韩精品欧美日韩精品一| 亚洲欧洲制服丝袜| 色综合久久天天| 夜色激情一区二区| 91福利在线播放| 亚洲国产一区二区三区青草影视| 色噜噜狠狠色综合欧洲selulu| 亚洲三级在线观看| 91美女精品福利| 一区二区三区91| 欧美日本一区二区| 日韩电影在线观看一区| 欧美男生操女生| 日韩电影在线观看电影| 日韩区在线观看| 国产综合久久久久久鬼色| 精品国产乱码久久久久久久 | 开心九九激情九九欧美日韩精美视频电影 | 狠狠色丁香久久婷婷综合_中| 91精品国产综合久久精品麻豆 | 欧美96一区二区免费视频| 91精品国产品国语在线不卡| 免费成人美女在线观看.| 日韩视频在线你懂得| 激情综合色综合久久| 欧美xxxxxxxxx| 丰满少妇久久久久久久| 亚洲欧洲在线观看av| 日本韩国欧美三级| 日韩1区2区3区| 久久这里只有精品视频网| 成人精品视频一区二区三区| 亚洲精品少妇30p| 欧美一区二区三区不卡| 国内精品伊人久久久久av影院| 欧美激情一区不卡| 91福利精品第一导航| 爽好久久久欧美精品| 精品电影一区二区| 91原创在线视频| 日本欧美一区二区三区乱码| 国产欧美va欧美不卡在线| 欧美最猛黑人xxxxx猛交| 丝袜亚洲另类欧美| 国产婷婷一区二区|