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

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

?? gzjoin.c

?? 一個本地database引擎,支持中文T_Sql查詢,兼容DELPHI標準數據庫控件
?? C
字號:
/* gzjoin -- command to join gzip files into one gzip file

  Copyright (C) 2004 Mark Adler, all rights reserved
  version 1.0, 11 Dec 2004

  This software is provided 'as-is', without any express or implied
  warranty.  In no event will the author be held liable for any damages
  arising from the use of this software.

  Permission is granted to anyone to use this software for any purpose,
  including commercial applications, and to alter it and redistribute it
  freely, subject to the following restrictions:

  1. The origin of this software must not be misrepresented; you must not
     claim that you wrote the original software. If you use this software
     in a product, an acknowledgment in the product documentation would be
     appreciated but is not required.
  2. Altered source versions must be plainly marked as such, and must not be
     misrepresented as being the original software.
  3. This notice may not be removed or altered from any source distribution.

  Mark Adler    madler@alumni.caltech.edu
 */

/*
 * Change history:
 *
 * 1.0  11 Dec 2004     - First version
 * 1.1  12 Jun 2005     - Changed ssize_t to long for portability
 */

/*
   gzjoin takes one or more gzip files on the command line and writes out a
   single gzip file that will uncompress to the concatenation of the
   uncompressed data from the individual gzip files.  gzjoin does this without
   having to recompress any of the data and without having to calculate a new
   crc32 for the concatenated uncompressed data.  gzjoin does however have to
   decompress all of the input data in order to find the bits in the compressed
   data that need to be modified to concatenate the streams.

   gzjoin does not do an integrity check on the input gzip files other than
   checking the gzip header and decompressing the compressed data.  They are
   otherwise assumed to be complete and correct.

   Each joint between gzip files removes at least 18 bytes of previous trailer
   and subsequent header, and inserts an average of about three bytes to the
   compressed data in order to connect the streams.  The output gzip file
   has a minimal ten-byte gzip header with no file name or modification time.

   This program was written to illustrate the use of the Z_BLOCK option of
   inflate() and the crc32_combine() function.  gzjoin will not compile with
   versions of zlib earlier than 1.2.3.
 */

#include <stdio.h>      /* fputs(), fprintf(), fwrite(), putc() */
#include <stdlib.h>     /* exit(), malloc(), free() */
#include <fcntl.h>      /* open() */
#include <unistd.h>     /* close(), read(), lseek() */
#include "zlib.h"
    /* crc32(), crc32_combine(), inflateInit2(), inflate(), inflateEnd() */

#define local static

/* exit with an error (return a value to allow use in an expression) */
local int bail(char *why1, char *why2)
{
    fprintf(stderr, "gzjoin error: %s%s, output incomplete\n", why1, why2);
    exit(1);
    return 0;
}

/* -- simple buffered file input with access to the buffer -- */

#define CHUNK 32768         /* must be a power of two and fit in unsigned */

/* bin buffered input file type */
typedef struct {
    char *name;             /* name of file for error messages */
    int fd;                 /* file descriptor */
    unsigned left;          /* bytes remaining at next */
    unsigned char *next;    /* next byte to read */
    unsigned char *buf;     /* allocated buffer of length CHUNK */
} bin;

/* close a buffered file and free allocated memory */
local void bclose(bin *in)
{
    if (in != NULL) {
        if (in->fd != -1)
            close(in->fd);
        if (in->buf != NULL)
            free(in->buf);
        free(in);
    }
}

/* open a buffered file for input, return a pointer to type bin, or NULL on
   failure */
local bin *bopen(char *name)
{
    bin *in;

    in = malloc(sizeof(bin));
    if (in == NULL)
        return NULL;
    in->buf = malloc(CHUNK);
    in->fd = open(name, O_RDONLY, 0);
    if (in->buf == NULL || in->fd == -1) {
        bclose(in);
        return NULL;
    }
    in->left = 0;
    in->next = in->buf;
    in->name = name;
    return in;
}

/* load buffer from file, return -1 on read error, 0 or 1 on success, with
   1 indicating that end-of-file was reached */
local int bload(bin *in)
{
    long len;

    if (in == NULL)
        return -1;
    if (in->left != 0)
        return 0;
    in->next = in->buf;
    do {
        len = (long)read(in->fd, in->buf + in->left, CHUNK - in->left);
        if (len < 0)
            return -1;
        in->left += (unsigned)len;
    } while (len != 0 && in->left < CHUNK);
    return len == 0 ? 1 : 0;
}

/* get a byte from the file, bail if end of file */
#define bget(in) (in->left ? 0 : bload(in), \
                  in->left ? (in->left--, *(in->next)++) : \
                    bail("unexpected end of file on ", in->name))

/* get a four-byte little-endian unsigned integer from file */
local unsigned long bget4(bin *in)
{
    unsigned long val;

    val = bget(in);
    val += (unsigned long)(bget(in)) << 8;
    val += (unsigned long)(bget(in)) << 16;
    val += (unsigned long)(bget(in)) << 24;
    return val;
}

/* skip bytes in file */
local void bskip(bin *in, unsigned skip)
{
    /* check pointer */
    if (in == NULL)
        return;

    /* easy case -- skip bytes in buffer */
    if (skip <= in->left) {
        in->left -= skip;
        in->next += skip;
        return;
    }

    /* skip what's in buffer, discard buffer contents */
    skip -= in->left;
    in->left = 0;

    /* seek past multiples of CHUNK bytes */
    if (skip > CHUNK) {
        unsigned left;

        left = skip & (CHUNK - 1);
        if (left == 0) {
            /* exact number of chunks: seek all the way minus one byte to check
               for end-of-file with a read */
            lseek(in->fd, skip - 1, SEEK_CUR);
            if (read(in->fd, in->buf, 1) != 1)
                bail("unexpected end of file on ", in->name);
            return;
        }

        /* skip the integral chunks, update skip with remainder */
        lseek(in->fd, skip - left, SEEK_CUR);
        skip = left;
    }

    /* read more input and skip remainder */
    bload(in);
    if (skip > in->left)
        bail("unexpected end of file on ", in->name);
    in->left -= skip;
    in->next += skip;
}

/* -- end of buffered input functions -- */

/* skip the gzip header from file in */
local void gzhead(bin *in)
{
    int flags;

    /* verify gzip magic header and compression method */
    if (bget(in) != 0x1f || bget(in) != 0x8b || bget(in) != 8)
        bail(in->name, " is not a valid gzip file");

    /* get and verify flags */
    flags = bget(in);
    if ((flags & 0xe0) != 0)
        bail("unknown reserved bits set in ", in->name);

    /* skip modification time, extra flags, and os */
    bskip(in, 6);

    /* skip extra field if present */
    if (flags & 4) {
        unsigned len;

        len = bget(in);
        len += (unsigned)(bget(in)) << 8;
        bskip(in, len);
    }

    /* skip file name if present */
    if (flags & 8)
        while (bget(in) != 0)
            ;

    /* skip comment if present */
    if (flags & 16)
        while (bget(in) != 0)
            ;

    /* skip header crc if present */
    if (flags & 2)
        bskip(in, 2);
}

/* write a four-byte little-endian unsigned integer to out */
local void put4(unsigned long val, FILE *out)
{
    putc(val & 0xff, out);
    putc((val >> 8) & 0xff, out);
    putc((val >> 16) & 0xff, out);
    putc((val >> 24) & 0xff, out);
}

/* Load up zlib stream from buffered input, bail if end of file */
local void zpull(z_streamp strm, bin *in)
{
    if (in->left == 0)
        bload(in);
    if (in->left == 0)
        bail("unexpected end of file on ", in->name);
    strm->avail_in = in->left;
    strm->next_in = in->next;
}

/* Write header for gzip file to out and initialize trailer. */
local void gzinit(unsigned long *crc, unsigned long *tot, FILE *out)
{
    fwrite("\x1f\x8b\x08\0\0\0\0\0\0\xff", 1, 10, out);
    *crc = crc32(0L, Z_NULL, 0);
    *tot = 0;
}

/* Copy the compressed data from name, zeroing the last block bit of the last
   block if clr is true, and adding empty blocks as needed to get to a byte
   boundary.  If clr is false, then the last block becomes the last block of
   the output, and the gzip trailer is written.  crc and tot maintains the
   crc and length (modulo 2^32) of the output for the trailer.  The resulting
   gzip file is written to out.  gzinit() must be called before the first call
   of gzcopy() to write the gzip header and to initialize crc and tot. */
local void gzcopy(char *name, int clr, unsigned long *crc, unsigned long *tot,
                  FILE *out)
{
    int ret;                /* return value from zlib functions */
    int pos;                /* where the "last block" bit is in byte */
    int last;               /* true if processing the last block */
    bin *in;                /* buffered input file */
    unsigned char *start;   /* start of compressed data in buffer */
    unsigned char *junk;    /* buffer for uncompressed data -- discarded */
    z_off_t len;            /* length of uncompressed data (support > 4 GB) */
    z_stream strm;          /* zlib inflate stream */

    /* open gzip file and skip header */
    in = bopen(name);
    if (in == NULL)
        bail("could not open ", name);
    gzhead(in);

    /* allocate buffer for uncompressed data and initialize raw inflate
       stream */
    junk = malloc(CHUNK);
    strm.zalloc = Z_NULL;
    strm.zfree = Z_NULL;
    strm.opaque = Z_NULL;
    strm.avail_in = 0;
    strm.next_in = Z_NULL;
    ret = inflateInit2(&strm, -15);
    if (junk == NULL || ret != Z_OK)
        bail("out of memory", "");

    /* inflate and copy compressed data, clear last-block bit if requested */
    len = 0;
    zpull(&strm, in);
    start = strm.next_in;
    last = start[0] & 1;
    if (last && clr)
        start[0] &= ~1;
    strm.avail_out = 0;
    for (;;) {
        /* if input used and output done, write used input and get more */
        if (strm.avail_in == 0 && strm.avail_out != 0) {
            fwrite(start, 1, strm.next_in - start, out);
            start = in->buf;
            in->left = 0;
            zpull(&strm, in);
        }

        /* decompress -- return early when end-of-block reached */
        strm.avail_out = CHUNK;
        strm.next_out = junk;
        ret = inflate(&strm, Z_BLOCK);
        switch (ret) {
        case Z_MEM_ERROR:
            bail("out of memory", "");
        case Z_DATA_ERROR:
            bail("invalid compressed data in ", in->name);
        }

        /* update length of uncompressed data */
        len += CHUNK - strm.avail_out;

        /* check for block boundary (only get this when block copied out) */
        if (strm.data_type & 128) {
            /* if that was the last block, then done */
            if (last)
                break;

            /* number of unused bits in last byte */
            pos = strm.data_type & 7;

            /* find the next last-block bit */
            if (pos != 0) {
                /* next last-block bit is in last used byte */
                pos = 0x100 >> pos;
                last = strm.next_in[-1] & pos;
                if (last && clr)
                    strm.next_in[-1] &= ~pos;
            }
            else {
                /* next last-block bit is in next unused byte */
                if (strm.avail_in == 0) {
                    /* don't have that byte yet -- get it */
                    fwrite(start, 1, strm.next_in - start, out);
                    start = in->buf;
                    in->left = 0;
                    zpull(&strm, in);
                }
                last = strm.next_in[0] & 1;
                if (last && clr)
                    strm.next_in[0] &= ~1;
            }
        }
    }

    /* update buffer with unused input */
    in->left = strm.avail_in;
    in->next = strm.next_in;

    /* copy used input, write empty blocks to get to byte boundary */
    pos = strm.data_type & 7;
    fwrite(start, 1, in->next - start - 1, out);
    last = in->next[-1];
    if (pos == 0 || !clr)
        /* already at byte boundary, or last file: write last byte */
        putc(last, out);
    else {
        /* append empty blocks to last byte */
        last &= ((0x100 >> pos) - 1);       /* assure unused bits are zero */
        if (pos & 1) {
            /* odd -- append an empty stored block */
            putc(last, out);
            if (pos == 1)
                putc(0, out);               /* two more bits in block header */
            fwrite("\0\0\xff\xff", 1, 4, out);
        }
        else {
            /* even -- append 1, 2, or 3 empty fixed blocks */
            switch (pos) {
            case 6:
                putc(last | 8, out);
                last = 0;
            case 4:
                putc(last | 0x20, out);
                last = 0;
            case 2:
                putc(last | 0x80, out);
                putc(0, out);
            }
        }
    }

    /* update crc and tot */
    *crc = crc32_combine(*crc, bget4(in), len);
    *tot += (unsigned long)len;

    /* clean up */
    inflateEnd(&strm);
    free(junk);
    bclose(in);

    /* write trailer if this is the last gzip file */
    if (!clr) {
        put4(*crc, out);
        put4(*tot, out);
    }
}

/* join the gzip files on the command line, write result to stdout */
int main(int argc, char **argv)
{
    unsigned long crc, tot;     /* running crc and total uncompressed length */

    /* skip command name */
    argc--;
    argv++;

    /* show usage if no arguments */
    if (argc == 0) {
        fputs("gzjoin usage: gzjoin f1.gz [f2.gz [f3.gz ...]] > fjoin.gz\n",
              stderr);
        return 0;
    }

    /* join gzip files on command line and write to stdout */
    gzinit(&crc, &tot, stdout);
    while (argc--)
        gzcopy(*argv++, argc, &crc, &tot, stdout);

    /* done */
    return 0;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品制服美女久久| 麻豆免费看一区二区三区| 精品国产一区二区三区四区四| 欧美伊人久久大香线蕉综合69 | 亚洲成av人片在线| 亚洲综合无码一区二区| 自拍偷拍国产亚洲| 亚洲精品v日韩精品| 一区二区三区中文在线| 亚洲男人都懂的| 亚洲第一主播视频| 美女脱光内衣内裤视频久久网站| 天天做天天摸天天爽国产一区| 亚洲大片精品永久免费| 奇米一区二区三区| 国产jizzjizz一区二区| 99久久婷婷国产综合精品| 色综合久久久网| 欧美日韩精品电影| 精品剧情v国产在线观看在线| 精品剧情v国产在线观看在线| 国产女同性恋一区二区| 亚洲特级片在线| 午夜视频一区二区| 精品影视av免费| www.亚洲激情.com| 欧美群妇大交群的观看方式| 精品处破学生在线二十三| 精品国一区二区三区| 国产精品麻豆99久久久久久| 亚洲bt欧美bt精品| 国模大尺度一区二区三区| aaa亚洲精品一二三区| 69精品人人人人| 中文字幕精品在线不卡| 亚洲国产视频一区| 国产老肥熟一区二区三区| 欧美伊人久久久久久午夜久久久久| 精品国产在天天线2019| 亚洲国产精品天堂| 国产成人亚洲综合a∨婷婷图片| 在线这里只有精品| 国产日产欧美一区| 一区二区三区四区五区视频在线观看 | 日韩免费看的电影| 1024亚洲合集| 国产盗摄一区二区| 欧美精品九九99久久| 国产片一区二区三区| 天天色综合天天| 色婷婷av一区二区三区软件 | 亚洲一区二区三区四区五区中文 | 一区二区三区免费看视频| 国产精品一二三在| 欧美精品乱码久久久久久按摩| 国产精品成人在线观看| 美日韩黄色大片| 欧美在线看片a免费观看| 国产精品亲子伦对白| 久久成人免费电影| 欧美猛男男办公室激情| 亚洲男帅同性gay1069| 亚洲高清免费在线| 日韩精品专区在线| 午夜国产精品影院在线观看| 91在线你懂得| 亚洲色图丝袜美腿| 99久久免费视频.com| 国产午夜精品一区二区| 久草在线在线精品观看| 欧美美女黄视频| 亚洲成在线观看| 在线视频一区二区三| 一区二区三区美女视频| 色综合中文综合网| 国产91在线观看丝袜| 精品国产乱码久久久久久牛牛| 日韩在线卡一卡二| 精品视频在线免费| 伊人一区二区三区| 欧美色综合影院| 午夜视频在线观看一区二区三区| 欧美午夜精品久久久久久孕妇| 一区二区三区在线观看动漫 | 另类小说图片综合网| 91精品国产欧美一区二区18| 日韩vs国产vs欧美| 精品美女一区二区| 国产超碰在线一区| 亚洲日本va在线观看| 欧美系列在线观看| 免费黄网站欧美| 国产精品网友自拍| 在线亚洲人成电影网站色www| 一区二区三区日韩在线观看| 欧美日韩精品欧美日韩精品一| 日韩va亚洲va欧美va久久| 精品国产91乱码一区二区三区| 国产精品自拍三区| 亚洲最新在线观看| 欧美一区二区大片| 丁香五精品蜜臀久久久久99网站| 日本一区二区免费在线| 99精品国产热久久91蜜凸| 亚洲aaa精品| 久久久噜噜噜久久人人看| www.av亚洲| 日本不卡一区二区| 国产精品女人毛片| 欧美性猛片aaaaaaa做受| 免费在线看成人av| 成人欧美一区二区三区视频网页| 欧美性生活久久| 懂色av一区二区三区免费看| 香蕉久久一区二区不卡无毒影院| 久久久久久电影| 欧美四级电影网| 国产成人精品综合在线观看| 亚洲国产精品自拍| 国产精品欧美一区二区三区| 欧美肥妇bbw| 91亚洲精品乱码久久久久久蜜桃| 日本人妖一区二区| 亚洲精品视频观看| 国产网红主播福利一区二区| 欧美日韩mp4| kk眼镜猥琐国模调教系列一区二区| 手机精品视频在线观看| 中文字幕亚洲不卡| 国产欧美日韩三级| 欧美一级一区二区| 欧美性生活一区| 91亚洲大成网污www| 国产精华液一区二区三区| 日韩国产精品91| 一区二区三区四区高清精品免费观看| 久久久久久久精| 日韩一级免费观看| 欧美日韩国产一二三| eeuss鲁片一区二区三区在线看| 国产一区二区免费在线| 美女免费视频一区二区| 亚洲综合区在线| 一个色妞综合视频在线观看| 18成人在线观看| 亚洲图片激情小说| 一区视频在线播放| 国产精品国产三级国产普通话蜜臀 | www.欧美日韩| 成人av电影在线观看| 成人妖精视频yjsp地址| 粉嫩高潮美女一区二区三区| 国产精品综合一区二区三区| 国产一区二区伦理片| 精品一区二区三区的国产在线播放| 日本女人一区二区三区| 美女高潮久久久| 久久av中文字幕片| 国产久卡久卡久卡久卡视频精品| 国产精品一级片在线观看| 国模大尺度一区二区三区| 国产乱人伦偷精品视频不卡| 国产不卡视频在线播放| a级精品国产片在线观看| 色综合久久久久| 欧美午夜精品久久久久久孕妇| 欧美日产在线观看| 日韩欧美激情在线| 久久综合资源网| 中文字幕在线视频一区| 亚洲免费在线看| 日韩综合一区二区| 狠狠色丁香婷婷综合| av男人天堂一区| 欧美亚洲禁片免费| www一区二区| 艳妇臀荡乳欲伦亚洲一区| 久久精品国产秦先生| 白白色亚洲国产精品| 欧美亚洲一区三区| 久久综合狠狠综合久久综合88| 最新欧美精品一区二区三区| 亚洲成人tv网| 成人免费的视频| 欧美年轻男男videosbes| 国产欧美日韩综合精品一区二区| 亚洲另类一区二区| 久久精品av麻豆的观看方式| www.在线成人| 日韩一级欧美一级| 亚洲欧美日韩国产中文在线| 蜜桃视频免费观看一区| 97国产精品videossex| 日韩欧美中文字幕制服| 成人免费在线播放视频| 免费久久精品视频| 在线国产亚洲欧美| 欧美激情在线看| 捆绑紧缚一区二区三区视频| 在线观看不卡一区|