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

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

?? unzip.c

?? 手機嵌入式Linux下可用的busybox源碼
?? C
?? 第 1 頁 / 共 3 頁
字號:
/* vi: set sw=4 ts=4: *//* * gunzip implementation for busybox * * Based on GNU gzip v1.2.4 Copyright (C) 1992-1993 Jean-loup Gailly. * * Originally adjusted for busybox by Sven Rudolph <sr1@inf.tu-dresden.de> * based on gzip sources * * Adjusted further by Erik Andersen <andersee@debian.org> to support * files as well as stdin/stdout, and to generally behave itself wrt * command line handling. * * General cleanup to better adhere to the style guide and make use of * standard busybox functions by Glenn McGrath <bug1@optushome.com.au> * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * * * gzip (GNU zip) -- compress files with zip algorithm and 'compress' interface * Copyright (C) 1992-1993 Jean-loup Gailly * The unzip code was written and put in the public domain by Mark Adler. * Portions of the lzw code are derived from the public domain 'compress' * written by Spencer Thomas, Joe Orost, James Woods, Jim McKie, Steve Davies, * Ken Turkowski, Dave Mack and Peter Jannesen. * * See the license_msg below and the file COPYING for the software license. * See the file algorithm.doc for the compression algorithms and file formats. */#if 0static char *license_msg[] = {	"   Copyright (C) 1992-1993 Jean-loup Gailly",	"   This program is free software; you can redistribute it and/or modify",	"   it under the terms of the GNU General Public License as published by",	"   the Free Software Foundation; either version 2, or (at your option)",	"   any later version.",	"",	"   This program is distributed in the hope that it will be useful,",	"   but WITHOUT ANY WARRANTY; without even the implied warranty of",	"   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the",	"   GNU General Public License for more details.",	"",	"   You should have received a copy of the GNU General Public License",	"   along with this program; if not, write to the Free Software",	"   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.",	0};#endif#include <sys/types.h>#include <sys/wait.h>#include <signal.h>#include <stdlib.h>#include <string.h>#include "libbb.h"static FILE *in_file, *out_file;/* these are freed by gz_close */static unsigned char *window;static unsigned long *crc_table;static unsigned long crc; /* shift register contents *//* Return codes from gzip */static const int ERROR = 1;/* * window size--must be a power of two, and *  at least 32K for zip's deflate method  */static const int WSIZE = 0x8000;/* If BMAX needs to be larger than 16, then h and x[] should be ulg. */static const int BMAX = 16;		/* maximum bit length of any code (16 for explode) */static const int N_MAX = 288;		/* maximum number of codes in any set */static long bytes_out;		/* number of output bytes */static unsigned long outcnt;	/* bytes in output buffer */static unsigned hufts;		/* track memory usage */static unsigned long bb;			/* bit buffer */static unsigned bk;		/* bits in bit buffer */typedef struct huft_s {	unsigned char e;		/* number of extra bits or operation */	unsigned char b;		/* number of bits in this code or subcode */	union {		unsigned short n;		/* literal, length base, or distance base */		struct huft_s *t;	/* pointer to next level of table */	} v;} huft_t;static const unsigned short mask_bits[] = {	0x0000,	0x0001, 0x0003, 0x0007, 0x000f, 0x001f, 0x003f, 0x007f, 0x00ff,	0x01ff, 0x03ff, 0x07ff, 0x0fff, 0x1fff, 0x3fff, 0x7fff, 0xffff};//static int error_number = 0;/* ======================================================================== * Signal and error handler. */ static void abort_gzip(){	error_msg("gzip aborted\n");	exit(ERROR);}static void make_crc_table(){	unsigned long table_entry;      /* crc shift register */	unsigned long poly = 0;      /* polynomial exclusive-or pattern */	int i;                /* counter for all possible eight bit values */	int k;                /* byte being shifted into crc apparatus */	/* terms of polynomial defining this crc (except x^32): */	static int p[] = {0,1,2,4,5,7,8,10,11,12,16,22,23,26};	/* initial shift register value */	crc = 0xffffffffL;		crc_table = (unsigned long *) malloc(256 * sizeof(unsigned long));	/* Make exclusive-or pattern from polynomial (0xedb88320) */	for (i = 0; i < sizeof(p)/sizeof(int); i++)		poly |= 1L << (31 - p[i]);	/* Compute and print table of CRC's, five per line */	for (i = 0; i < 256; i++) {		table_entry = i;	   /* The idea to initialize the register with the byte instead of	     * zero was stolen from Haruhiko Okumura's ar002	     */		for (k = 8; k; k--) {			table_entry = table_entry & 1 ? (table_entry >> 1) ^ poly : table_entry >> 1;		}		crc_table[i]=table_entry;	}}/* =========================================================================== * Write the output window window[0..outcnt-1] and update crc and bytes_out. * (Used for the decompressed data only.) */static void flush_window(void){	int n;	if (outcnt == 0)		return;	for (n = 0; n < outcnt; n++) {		crc = crc_table[((int) crc ^ (window[n])) & 0xff] ^ (crc >> 8);	}	if (fwrite(window, 1, outcnt, out_file) != outcnt) {		error_msg_and_die("Couldnt write");	}	bytes_out += (unsigned long) outcnt;	outcnt = 0;}/* * Free the malloc'ed tables built by huft_build(), which makes a linked * list of the tables it made, with the links in a dummy first entry of * each table.  * t: table to free */static int huft_free(huft_t *t){	huft_t *p, *q;	/* Go through linked list, freeing from the malloced (t[-1]) address. */	p = t;	while (p != (huft_t *) NULL) {		q = (--p)->v.t;		free((char *) p);		p = q;	}	return 0;}/* Given a list of code lengths and a maximum table size, make a set of * tables to decode that set of codes.  Return zero on success, one if * the given code set is incomplete (the tables are still built in this * case), two if the input is invalid (all zero length codes or an * oversubscribed set of lengths), and three if not enough memory. * * b:	code lengths in bits (all assumed <= BMAX) * n:	number of codes (assumed <= N_MAX) * s:	number of simple-valued codes (0..s-1) * d:	list of base values for non-simple codes * e:	list of extra bits for non-simple codes * t:	result: starting table * m:	maximum lookup bits, returns actual */static int huft_build(unsigned int *b, const unsigned int n, const unsigned int s, 	const unsigned short *d, const unsigned short *e, huft_t **t, int *m){	unsigned a;		/* counter for codes of length k */	unsigned c[BMAX + 1];	/* bit length count table */	unsigned f;		/* i repeats in table every f entries */	int g;			/* maximum code length */	int h;			/* table level */	register unsigned i;	/* counter, current code */	register unsigned j;	/* counter */	register int k;		/* number of bits in current code */	int l;			/* bits per table (returned in m) */	register unsigned *p;		/* pointer into c[], b[], or v[] */	register huft_t *q;	/* points to current table */	huft_t r;		/* table entry for structure assignment */	huft_t *u[BMAX];	/* table stack */	unsigned v[N_MAX];	/* values in order of bit length */	register int w;		/* bits before this table == (l * h) */	unsigned x[BMAX + 1];	/* bit offsets, then code stack */	unsigned *xp;		/* pointer into x */	int y;			/* number of dummy codes added */	unsigned z;		/* number of entries in current table */	/* Generate counts for each bit length */	memset ((void *)(c), 0, sizeof(c));	p = b;	i = n;	do {		c[*p]++;	/* assume all entries <= BMAX */		p++;		/* Can't combine with above line (Solaris bug) */	} while (--i);	if (c[0] == n) {	/* null input--all zero length codes */		*t = (huft_t *) NULL;		*m = 0;		return 0;	}	/* Find minimum and maximum length, bound *m by those */	l = *m;	for (j = 1; j <= BMAX; j++)		if (c[j])			break;	k = j;				/* minimum code length */	if ((unsigned) l < j)		l = j;	for (i = BMAX; i; i--)		if (c[i])			break;	g = i;				/* maximum code length */	if ((unsigned) l > i)		l = i;	*m = l;	/* Adjust last length count to fill out codes, if needed */	for (y = 1 << j; j < i; j++, y <<= 1)		if ((y -= c[j]) < 0)			return 2;	/* bad input: more codes than bits */	if ((y -= c[i]) < 0)		return 2;	c[i] += y;	/* Generate starting offsets into the value table for each length */	x[1] = j = 0;	p = c + 1;	xp = x + 2;	while (--i) {			/* note that i == g from above */		*xp++ = (j += *p++);	}	/* Make a table of values in order of bit lengths */	p = b;	i = 0;	do {		if ((j = *p++) != 0)			v[x[j]++] = i;	} while (++i < n);	/* Generate the Huffman codes and for each, make the table entries */	x[0] = i = 0;			/* first Huffman code is zero */	p = v;				/* grab values in bit order */	h = -1;				/* no tables yet--level -1 */	w = -l;				/* bits decoded == (l * h) */	u[0] = (huft_t *) NULL;	/* just to keep compilers happy */	q = (huft_t *) NULL;	/* ditto */	z = 0;				/* ditto */	/* go through the bit lengths (k already is bits in shortest code) */	for (; k <= g; k++) {		a = c[k];		while (a--) {			/* here i is the Huffman code of length k bits for value *p */			/* make tables up to required level */			while (k > w + l) {				h++;				w += l;		/* previous table always l bits */				/* compute minimum size table less than or equal to l bits */				z = (z = g - w) > (unsigned) l ? l : z;	/* upper limit on table size */				if ((f = 1 << (j = k - w)) > a + 1) {	/* try a k-w bit table *//* too few codes for k-w bit table */					f -= a + 1;	/* deduct codes from patterns left */					xp = c + k;					while (++j < z) {	/* try smaller tables up to z bits */						if ((f <<= 1) <= *++xp)							break;	/* enough codes to use up j bits */						f -= *xp;	/* else deduct codes from patterns */					}				}				z = 1 << j;		/* table entries for j-bit table */				/* allocate and link in new table */				if ((q = (huft_t *) xmalloc((z + 1) * sizeof(huft_t))) == NULL) {					if (h) {						huft_free(u[0]);					}					return 3;	/* not enough memory */				}				hufts += z + 1;	/* track memory usage */				*t = q + 1;		/* link to list for huft_free() */				*(t = &(q->v.t)) = NULL;				u[h] = ++q;		/* table starts after link */				/* connect to last table, if there is one */				if (h) {					x[h] = i;	/* save pattern for backing up */					r.b = (unsigned char) l;	/* bits to dump before this table */					r.e = (unsigned char) (16 + j);	/* bits in this table */					r.v.t = q;	/* pointer to this table */					j = i >> (w - l);	/* (get around Turbo C bug) */					u[h - 1][j] = r;	/* connect to last table */				}			}			/* set up table entry in r */			r.b = (unsigned char) (k - w);			if (p >= v + n)				r.e = 99;		/* out of values--invalid code */			else if (*p < s) {				r.e = (unsigned char) (*p < 256 ? 16 : 15);	/* 256 is end-of-block code */				r.v.n = (unsigned short) (*p);	/* simple code is just the value */				p++;			/* one compiler does not like *p++ */			} else {				r.e = (unsigned char) e[*p - s];	/* non-simple--look up in lists */				r.v.n = d[*p++ - s];			}			/* fill code-like entries with r */			f = 1 << (k - w);			for (j = i >> w; j < z; j += f)				q[j] = r;			/* backwards increment the k-bit code i */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品国产免费视频| 26uuuu精品一区二区| 粉嫩av亚洲一区二区图片| 日韩avvvv在线播放| 三级亚洲高清视频| 亚洲一区二区三区视频在线 | 欧美优质美女网站| 一本色道a无线码一区v| 色偷偷88欧美精品久久久| www.日韩av| 99re66热这里只有精品3直播| av成人老司机| 色婷婷综合久久久久中文| 色噜噜狠狠成人网p站| 在线日韩国产精品| 欧美日韩dvd在线观看| 欧日韩精品视频| 欧美高清你懂得| 欧美一级高清片| 欧美成人国产一区二区| 久久午夜色播影院免费高清 | 1区2区3区精品视频| **网站欧美大片在线观看| 亚洲乱码国产乱码精品精可以看 | 欧美变态tickling挠脚心| 日韩精品专区在线影院重磅| 久久久久久久久久久电影| 国产精品久久久久婷婷| 亚洲制服丝袜在线| 蜜臀av性久久久久蜜臀aⅴ | 色婷婷亚洲精品| 欧美二区三区的天堂| 精品三级在线观看| 国产精品卡一卡二| 五月天亚洲精品| 国产精品亚洲午夜一区二区三区 | 欧美一区二区三级| 国产欧美日产一区| 一区二区在线免费| 狠狠久久亚洲欧美| 91一区二区三区在线观看| 91 com成人网| 中文字幕免费在线观看视频一区| 亚洲成人一区在线| 国产很黄免费观看久久| 欧美日韩国产成人在线免费| 国产日产精品1区| 午夜精品视频在线观看| 国产精品伊人色| 欧美日韩国产欧美日美国产精品| 精品国产sm最大网站免费看| 亚洲精品乱码久久久久久久久 | 毛片av一区二区| 99久久99久久久精品齐齐| 日韩美女主播在线视频一区二区三区| 国产精品女上位| 久久不见久久见中文字幕免费| 日本韩国一区二区| 国产精品无遮挡| 国产精品资源在线看| 日韩一区二区三| 一区二区欧美在线观看| 成人国产精品免费观看视频| 久久综合色之久久综合| 亚洲bt欧美bt精品777| 93久久精品日日躁夜夜躁欧美| 欧美大尺度电影在线| 亚洲成av人片在线观看| 欧美影视一区在线| 亚洲色图制服丝袜| 在线看国产一区| 亚洲人精品一区| 成人短视频下载| 国产精品无遮挡| 成人午夜电影网站| 中文无字幕一区二区三区| 精品无人区卡一卡二卡三乱码免费卡| 欧美日韩精品电影| 日韩国产精品大片| 欧美日韩国产电影| 日韩精品一级二级| 678五月天丁香亚洲综合网| 一区二区三区不卡视频| 欧美在线色视频| 亚洲一二三级电影| 精品视频123区在线观看| 亚洲午夜三级在线| 911精品产国品一二三产区| 午夜影院久久久| 欧美一区二区黄| 蜜桃精品视频在线| 久久精品欧美日韩精品| 岛国精品在线播放| 又紧又大又爽精品一区二区| 欧美午夜精品久久久久久超碰| 亚洲gay无套男同| 日韩欧美一二三区| 国产宾馆实践打屁股91| 国产精品人成在线观看免费 | 亚洲国产精品久久人人爱蜜臀| 91久久线看在观草草青青| 亚洲国产成人av好男人在线观看| 91精品久久久久久久久99蜜臂| 蜜臀av性久久久久av蜜臀妖精| 国产偷国产偷精品高清尤物| 91日韩在线专区| 日日摸夜夜添夜夜添国产精品| 欧美大尺度电影在线| 欧美视频精品在线| 久久99精品国产.久久久久| 国产亚洲精品中文字幕| 在线精品视频免费观看| 日韩不卡手机在线v区| 国产喂奶挤奶一区二区三区| 欧美亚洲免费在线一区| 精品一区二区在线看| 亚洲欧美自拍偷拍| 欧美电视剧在线看免费| 91国产免费观看| 国产一区二区三区在线观看精品| 亚洲欧美国产三级| 欧美v国产在线一区二区三区| 99re8在线精品视频免费播放| 美女视频黄a大片欧美| 一区二区三区欧美视频| 久久亚洲二区三区| 欧美三级在线看| 成人精品免费看| 国产一区二区主播在线| 亚洲资源在线观看| 久久一区二区视频| 欧美日韩二区三区| 色婷婷狠狠综合| 国产成人在线视频免费播放| 蜜桃精品视频在线| 亚洲码国产岛国毛片在线| 久久久噜噜噜久久人人看| 欧美日韩美女一区二区| k8久久久一区二区三区| 韩国一区二区在线观看| 亚洲成人动漫av| 亚洲欧洲一区二区三区| 国产亚洲综合性久久久影院| 久久亚洲欧美国产精品乐播| 7777精品伊人久久久大香线蕉经典版下载 | 久久久久久久久97黄色工厂| 8v天堂国产在线一区二区| 91小视频在线| 国产精品亚洲第一区在线暖暖韩国| 亚洲成人黄色影院| 亚洲一卡二卡三卡四卡| 亚洲靠逼com| 亚洲人午夜精品天堂一二香蕉| 欧美激情一区二区三区四区| 欧美变态口味重另类| 日韩精品一区二区三区swag| 欧美大肚乱孕交hd孕妇| 日韩一区二区在线免费观看| 日韩一级大片在线| 欧美一级一区二区| 日韩欧美一级二级三级久久久| 5566中文字幕一区二区电影| 欧美喷潮久久久xxxxx| 欧美日韩国产综合久久| 欧美日韩夫妻久久| 欧美一区二区精品| 精品播放一区二区| 久久久精品tv| 综合久久一区二区三区| 亚洲精品第一国产综合野| 亚洲国产日韩综合久久精品| 亚洲成人av电影在线| 久草这里只有精品视频| 国产成人免费视频| 成人黄色大片在线观看| 91激情在线视频| 欧美一区二区三区免费在线看| 欧美大片免费久久精品三p| 久久久久亚洲蜜桃| 中文字幕在线观看一区| 亚洲午夜精品网| 国产精品1区二区.| 99视频精品全部免费在线| 91国偷自产一区二区三区成为亚洲经典 | 成人激情黄色小说| 91精彩视频在线观看| 日韩一区二区在线观看视频播放| 国产日韩欧美综合在线| 中文字幕一区二区三区在线播放 | 免费观看一级特黄欧美大片| 精品无人区卡一卡二卡三乱码免费卡| 国产精品一区二区x88av| av不卡免费在线观看| 欧美日韩你懂的| 久久久久久久精| 亚洲成人一二三| 粉嫩欧美一区二区三区高清影视| 欧美中文字幕一区二区三区亚洲| 久久综合五月天婷婷伊人| 一区二区三区视频在线看|