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

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

?? zk1comp.c

?? Dos6.0
?? C
字號:
/* TS = none */
/*
**  ZK1COMP.C  --  Zeck Compression module - first implementation
**
**  This comes to us from Languages via Excel and is used many places.
**  Still, I altered some of the code to fit my API.  Original sources
**  can be found in \\odin\slm!src\setup\compress.
*/

/*                    Zeck Data Compression Program
**                      (C) Copyright 1989 by Microsoft
**                           Written By Steven Zeck
*/

#include <stdlib.h>
#include <string.h>
#include <ctype.h>

#include <io.h>
#include <fcntl.h>
#include <stdio.h>

#include "..\sutkcomp.h"

#ifdef OS2SU
#include <doscalls.h>
#endif

#include "zk1.h"

#include "setjmp.h"

extern BOOL    fJmpEnvSet;
extern jmp_buf jmpEnv;



/*
**  LONG Lcb_ZK1_CompressToFile(int fhSrc, int fhDest, LONG lcbDestMax)
**
**  Note - this is basically SteveZ's encode() routine.
**
**  Assumes that the header has already been written.
*/
LONG Lcb_ZK1_CompressToFile(int fhSrc, int fhDest, LONG lcbDestMax)
{
    USHORT   us;
    SHORT    ch, cbLen, ibCharCur, ibStringCur, cbMatchLast, ibCodeBuf;
    BYTE     rgbCodeBuf[cbStrMax], mask;
    LONG     libSrcStart = tell(fhSrc);
    LONG     libDestStart = tell(fhDest);
    LONG     lReturn;
    int      iJmpReturn;

    if (!FAllocateLZGlobals(lcbDestMax, (BOOL)TRUE))
        return((LONG)rcOutOfMemory);

    if ((iJmpReturn = setjmp(jmpEnv)) != 0)
        {
        FreeLZGlobals();
        fJmpEnvSet = FALSE;
        return((LONG)iJmpReturn);
        }
    fJmpEnvSet = TRUE;

    if (lcbDestMax != NIL && (LONG)(fpbOutBufEnd - fpbOutBuf) > lcbDestMax)
        fpbOutBufEnd = fpbOutBuf + (SHORT)lcbDestMax;

    fhDestGlobal = fhDest;
    lcbSkipOut = 0L;
    fpbBufDest = NULL;

    LZInitTree();

      /* rgbCodeBuf[1..16] saves eight units of code, and
      ** rgbCodeBuf[0] works as eight flags, "1" representing that the unit
      ** is an unencoded letter (1 byte), "0" a position-and-length pair
      ** (2 bytes).  Thus, eight units require at most 16 bytes of code.
      */
    rgbCodeBuf[0] = 0;
    ibCodeBuf = mask = 1;

      /* Clear the buffer with any character that will appear often. */
    ibStringCur = 0;
    _fmemset(ringBuf, ' ', (ibCharCur = cbBufMax - cbStrMax));

      /* Read cbStrMax bytes into the last cbStrMax bytes of the buffer */
    for (cbLen = 0; cbLen < cbStrMax && (ch = ReadByte(fhSrc)) != EOF; cbLen++)
        ringBuf[ibCharCur + cbLen] = (BYTE)ch;

      /* Insert the cbStrMax strings,
      ** each of which begins with one or more 'space' characters.  Note
      ** the order in which these strings are inserted.  This way,
      ** degenerate trees will be less likely to occur.
      */
    for (us = 1; us <= cbStrMax; us++)
        LZInsertNode(ibCharCur - us);

      /* Finally, insert the whole string just read.  The
      ** global variables cbMatchCur and iMatchCur are set.
      */
    LZInsertNode(ibCharCur);

    do  {
            /* cbMatchCur may be spuriously long near the end of text. */
        if (cbMatchCur > (USHORT)cbLen)
            cbMatchCur = (USHORT)cbLen;

        if (cbMatchCur <= cbIndex)
            {   /* Not long enough match. Send one byte. */
                /* 'send one byte' flag.  Send uncoded. */
            cbMatchCur = 1;
            rgbCodeBuf[0] |= mask;
            rgbCodeBuf[ibCodeBuf++] = ringBuf[ibCharCur];
            }
        else
            {   /* Send position and length pair. Note cbMatchCur > cbIndex. */
            rgbCodeBuf[ibCodeBuf++] = (BYTE)iMatchCur;
            rgbCodeBuf[ibCodeBuf++] = (BYTE)((iMatchCur >> 4 & 0xf0) |
                                                  (cbMatchCur - (cbIndex + 1)));
            }

        if ((mask <<= 1) == 0)   /* Shift mask left one bit. */
            {
                /* Send at most 8 units of code together */
            for (us = 0; us < (USHORT)ibCodeBuf; us++)
                {
                WriteByte(rgbCodeBuf[us]);
                if (fWriteError || fDestFull)
                    goto LExit;
                }

            rgbCodeBuf[0] = 0;
            ibCodeBuf = mask = 1;
            }
        cbMatchLast = cbMatchCur;

        for (us = 0; us < (USHORT)cbMatchLast && (ch = ReadByte(fhSrc)) != EOF;
                                                                           us++)
            {
            LZDeleteNode(ibStringCur);      /* Delete old strings and */
            ringBuf[ibStringCur] = (BYTE)ch;        /* read new bytes */

              /* If the position is near the end of buffer, extend the
              ** buffer to make string comparison easier.
              */
            if (ibStringCur < cbStrMax - 1)
                ringBuf[ibStringCur + cbBufMax] = (BYTE)ch;

              /* ring buffer, increment the position modulo N. */
            ibStringCur = ibStringCur+1 & (cbBufMax - 1);
            ibCharCur = ibCharCur+1 & (cbBufMax - 1);

              /* Register the string in ringBuf[r..r+cbStrMax-1] */
            LZInsertNode(ibCharCur);
            }

        while (us++ < (USHORT)cbMatchLast)         /* After the end of text, */
            {
            LZDeleteNode(ibStringCur);        /* no need to read, but */

            ibStringCur = ibStringCur+1 & (cbBufMax - 1);
            ibCharCur = ibCharCur+1 & (cbBufMax - 1);
            if (--cbLen)
                LZInsertNode(ibCharCur);          /* buffer may not be empty. */
            }
         } while (cbLen > 0); /* length of string to be processed is zero */

    if (ibCodeBuf > 1)                 /* Send remaining code. */
        {
        for (us = 0; us < (USHORT)ibCodeBuf; us++)
            {
            WriteByte(rgbCodeBuf[us]);
            if (fWriteError || fDestFull)
                goto LExit;
            }
        }

    WriteOutBuff(0);

LExit:
    fJmpEnvSet = FALSE;
    FreeLZGlobals();

    if (fWriteError)
        return((LONG)rcWriteError);

    if (lcbDestMax == NIL || fhDest == -1)
        return(lcbDest);

      /* fix fhSrc because we split */
    lReturn = lcbDest;             /* lcbDest gets altered by the Decomp call */

      /* reset fhDest (after header) */
    if (lseek(fhDest, libDestStart, SEEK_SET) == -1L)
        return((LONG)rcWriteSeekError);

      /* lcbDest = uncompressed length of this current piece */
    lcbDest = Lcb_ZK1_DecompressToFile(fhDest, -1, NIL, 0L);
    if (lcbDest < rcNoError)
        return(lcbDest);

      /* reset fhSrc */
    if (lseek(fhSrc, libSrcStart + lcbDest, SEEK_SET) == -1L)
        return((LONG)rcReadSeekError);

    return(lReturn);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品免费久久久久| 久久亚洲一区二区三区四区| 久久九九全国免费| 视频一区二区三区中文字幕| 粉嫩绯色av一区二区在线观看 | 亚洲国产乱码最新视频 | 青青草国产成人av片免费 | 免费高清在线视频一区·| 色婷婷一区二区| 国产日产欧产精品推荐色| 日本欧美在线看| 欧美亚洲国产一区在线观看网站| 国产女人aaa级久久久级| 激情五月播播久久久精品| 欧美日韩一本到| 一区二区三区视频在线观看| 国产成人在线视频网站| 日韩免费看网站| 日韩在线一二三区| 欧美系列在线观看| 一区二区成人在线观看| 99久久精品久久久久久清纯| 久久精品欧美一区二区三区麻豆| 捆绑调教美女网站视频一区| 欧美日韩高清一区二区三区| 一个色妞综合视频在线观看| 99久久99久久久精品齐齐| 中文字幕欧美三区| 国产不卡视频一区| 中文字幕av资源一区| 国产精品中文字幕一区二区三区| 欧美精品一区二区三| 日本vs亚洲vs韩国一区三区 | 91在线观看美女| 国产精品成人免费精品自在线观看 | 91麻豆精品国产91久久久资源速度| 一区二区三区中文在线| 97久久精品人人做人人爽| 日韩理论在线观看| 91亚洲永久精品| 曰韩精品一区二区| 色哟哟日韩精品| 亚洲一区免费观看| 欧美日韩卡一卡二| 日韩av电影天堂| 欧美老肥妇做.爰bbww| 亚洲午夜激情av| 欧美日韩精品一区二区三区四区| 亚洲国产精品影院| 欧美卡1卡2卡| 日本欧美久久久久免费播放网| 91.xcao| 久久91精品久久久久久秒播| 久久久久久久久免费| 国产激情一区二区三区四区| 国产精品久久毛片a| 色综合久久久网| 亚洲一区二区视频在线观看| 欧美色视频一区| 日本视频一区二区| 久久影院午夜论| 成人看片黄a免费看在线| 亚洲人吸女人奶水| 欧美日本免费一区二区三区| 美日韩一区二区| 日本一区二区在线不卡| 91在线免费看| 天涯成人国产亚洲精品一区av| 日韩亚洲欧美中文三级| 国产剧情一区二区三区| 亚洲欧洲av在线| 欧美日韩国产一级| 九九精品视频在线看| 欧美国产一区二区| 91国偷自产一区二区三区成为亚洲经典| 欧美日本精品一区二区三区| 免费观看在线综合| 国产亚洲自拍一区| 色狠狠桃花综合| 天天亚洲美女在线视频| 精品国产乱码久久久久久闺蜜| 成人精品免费网站| 亚洲国产精品人人做人人爽| 精品精品国产高清一毛片一天堂| 99精品久久久久久| 青青草精品视频| 中文字幕一区二区不卡| 欧美日韩高清影院| 成人性生交大片| 五月天视频一区| 国产蜜臀av在线一区二区三区| 欧美三级中文字幕| 国产91色综合久久免费分享| 一区二区三区在线视频观看| 欧美成人三级电影在线| 91国偷自产一区二区开放时间 | 韩国女主播一区| 亚洲欧美国产毛片在线| 日韩欧美一级二级三级| 91视频.com| 精彩视频一区二区三区| 亚洲精品成人悠悠色影视| 精品成人一区二区| 欧美主播一区二区三区| 国产精品1区二区.| 日韩av在线免费观看不卡| √…a在线天堂一区| 日韩精品一区二区三区三区免费 | 九九久久精品视频| 亚洲影院久久精品| 国产精品久久久久影院亚瑟 | 精品久久久三级丝袜| 色婷婷激情综合| 国产乱人伦偷精品视频不卡| 无码av免费一区二区三区试看| 国产精品全国免费观看高清| 精品卡一卡二卡三卡四在线| 欧美四级电影在线观看| 成人福利视频在线| 久久69国产一区二区蜜臀| 亚洲午夜久久久久久久久久久 | 国产精品精品国产色婷婷| 日韩美女视频在线| 欧美日韩国产乱码电影| 91在线你懂得| 成人看片黄a免费看在线| 精品无人区卡一卡二卡三乱码免费卡| 亚洲国产美女搞黄色| 亚洲免费资源在线播放| 国产色产综合色产在线视频| 日韩欧美专区在线| 欧美日韩精品高清| 色吧成人激情小说| 91小宝寻花一区二区三区| 国产+成+人+亚洲欧洲自线| 久久精品国产99国产精品| 五月天激情小说综合| 亚洲国产美女搞黄色| 亚洲精品国产高清久久伦理二区| 国产精品毛片大码女人 | 欧美人与z0zoxxxx视频| 在线看国产一区| 91麻豆免费视频| 99久久精品免费观看| 成人高清av在线| www.99精品| 91一区二区三区在线观看| 99久免费精品视频在线观看| 成人精品国产一区二区4080| 成人一区二区视频| www.欧美色图| 91视频com| 在线观看免费亚洲| 在线看日韩精品电影| 欧美亚洲国产一区在线观看网站| 欧美在线999| 欧美性猛交xxxxxx富婆| 欧美日韩国产综合一区二区| 欧美日韩另类国产亚洲欧美一级| 欧美日韩国产小视频| 欧美精品乱人伦久久久久久| 欧美嫩在线观看| 欧美一级一区二区| 精品国产一区二区三区四区四| 精品国产凹凸成av人导航| ww久久中文字幕| 亚洲国产精品精华液2区45| 国产精品国产三级国产专播品爱网 | 91一区一区三区| 欧美综合天天夜夜久久| 欧美三级日本三级少妇99| 欧美高清性hdvideosex| 欧美tickling挠脚心丨vk| 久久老女人爱爱| 国产精品久久久久久久久果冻传媒| 中文字幕在线免费不卡| 亚洲狠狠丁香婷婷综合久久久| 亚洲成人自拍网| 久久99精品网久久| 国产69精品久久777的优势| 91亚洲精华国产精华精华液| 欧美日韩在线综合| 日韩欧美视频一区| 国产片一区二区| 一区二区三区高清不卡| 日日嗨av一区二区三区四区| 久久99精品国产麻豆婷婷 | 蓝色福利精品导航| 成人综合婷婷国产精品久久免费| 色欧美片视频在线观看在线视频| 欧美日韩国产一级片| 久久人人97超碰com| 亚洲免费伊人电影| 欧美aaaaa成人免费观看视频| 国产成a人亚洲精| 91成人免费电影| 日韩精品在线网站| 亚洲男人的天堂av| 麻豆精品视频在线观看| 成人黄色网址在线观看|