Compare commits
8 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
14763ac7c6 | ||
|
|
c34c1fcbb1 | ||
|
|
02b6cf579f | ||
|
|
965fe72aed | ||
|
|
b8c9ecb076 | ||
|
|
6759211ad8 | ||
|
|
7850e4e406 | ||
|
|
ebd3c2c0e7 |
232
ChangeLog
232
ChangeLog
@@ -1,6 +1,238 @@
|
|||||||
|
|
||||||
ChangeLog file for zlib
|
ChangeLog file for zlib
|
||||||
|
|
||||||
|
Changes in 1.1.3 (9 July 1998)
|
||||||
|
- fix "an inflate input buffer bug that shows up on rare but persistent
|
||||||
|
occasions" (Mark)
|
||||||
|
- fix gzread and gztell for concatenated .gz files (Didier Le Botlan)
|
||||||
|
- fix gzseek(..., SEEK_SET) in write mode
|
||||||
|
- fix crc check after a gzeek (Frank Faubert)
|
||||||
|
- fix miniunzip when the last entry in a zip file is itself a zip file
|
||||||
|
(J Lillge)
|
||||||
|
- add contrib/asm586 and contrib/asm686 (Brian Raiter)
|
||||||
|
See http://www.muppetlabs.com/~breadbox/software/assembly.html
|
||||||
|
- add support for Delphi 3 in contrib/delphi (Bob Dellaca)
|
||||||
|
- add support for C++Builder 3 and Delphi 3 in contrib/delphi2 (Davide Moretti)
|
||||||
|
- do not exit prematurely in untgz if 0 at start of block (Magnus Holmgren)
|
||||||
|
- use macro EXTERN instead of extern to support DLL for BeOS (Sander Stoks)
|
||||||
|
- added a FAQ file
|
||||||
|
|
||||||
|
- Support gzdopen on Mac with Metrowerks (Jason Linhart)
|
||||||
|
- Do not redefine Byte on Mac (Brad Pettit & Jason Linhart)
|
||||||
|
- define SEEK_END too if SEEK_SET is not defined (Albert Chin-A-Young)
|
||||||
|
- avoid some warnings with Borland C (Tom Tanner)
|
||||||
|
- fix a problem in contrib/minizip/zip.c for 16-bit MSDOS (Gilles Vollant)
|
||||||
|
- emulate utime() for WIN32 in contrib/untgz (Gilles Vollant)
|
||||||
|
- allow several arguments to configure (Tim Mooney, Frodo Looijaard)
|
||||||
|
- use libdir and includedir in Makefile.in (Tim Mooney)
|
||||||
|
- support shared libraries on OSF1 V4 (Tim Mooney)
|
||||||
|
- remove so_locations in "make clean" (Tim Mooney)
|
||||||
|
- fix maketree.c compilation error (Glenn, Mark)
|
||||||
|
- Python interface to zlib now in Python 1.5 (Jeremy Hylton)
|
||||||
|
- new Makefile.riscos (Rich Walker)
|
||||||
|
- initialize static descriptors in trees.c for embedded targets (Nick Smith)
|
||||||
|
- use "foo-gz" in example.c for RISCOS and VMS (Nick Smith)
|
||||||
|
- add the OS/2 files in Makefile.in too (Andrew Zabolotny)
|
||||||
|
- fix fdopen and halloc macros for Microsoft C 6.0 (Tom Lane)
|
||||||
|
- fix maketree.c to allow clean compilation of inffixed.h (Mark)
|
||||||
|
- fix parameter check in deflateCopy (Gunther Nikl)
|
||||||
|
- cleanup trees.c, use compressed_len only in debug mode (Christian Spieler)
|
||||||
|
- Many portability patches by Christian Spieler:
|
||||||
|
. zutil.c, zutil.h: added "const" for zmem*
|
||||||
|
. Make_vms.com: fixed some typos
|
||||||
|
. Make_vms.com: msdos/Makefile.*: removed zutil.h from some dependency lists
|
||||||
|
. msdos/Makefile.msc: remove "default rtl link library" info from obj files
|
||||||
|
. msdos/Makefile.*: use model-dependent name for the built zlib library
|
||||||
|
. msdos/Makefile.emx, nt/Makefile.emx, nt/Makefile.gcc:
|
||||||
|
new makefiles, for emx (DOS/OS2), emx&rsxnt and mingw32 (Windows 9x / NT)
|
||||||
|
- use define instead of typedef for Bytef also for MSC small/medium (Tom Lane)
|
||||||
|
- replace __far with _far for better portability (Christian Spieler, Tom Lane)
|
||||||
|
- fix test for errno.h in configure (Tim Newsham)
|
||||||
|
|
||||||
|
Changes in 1.1.2 (19 March 98)
|
||||||
|
- added contrib/minzip, mini zip and unzip based on zlib (Gilles Vollant)
|
||||||
|
See http://www.winimage.com/zLibDll/unzip.html
|
||||||
|
- preinitialize the inflate tables for fixed codes, to make the code
|
||||||
|
completely thread safe (Mark)
|
||||||
|
- some simplifications and slight speed-up to the inflate code (Mark)
|
||||||
|
- fix gzeof on non-compressed files (Allan Schrum)
|
||||||
|
- add -std1 option in configure for OSF1 to fix gzprintf (Martin Mokrejs)
|
||||||
|
- use default value of 4K for Z_BUFSIZE for 16-bit MSDOS (Tim Wegner + Glenn)
|
||||||
|
- added os2/Makefile.def and os2/zlib.def (Andrew Zabolotny)
|
||||||
|
- add shared lib support for UNIX_SV4.2MP (MATSUURA Takanori)
|
||||||
|
- do not wrap extern "C" around system includes (Tom Lane)
|
||||||
|
- mention zlib binding for TCL in README (Andreas Kupries)
|
||||||
|
- added amiga/Makefile.pup for Amiga powerUP SAS/C PPC (Andreas Kleinert)
|
||||||
|
- allow "make install prefix=..." even after configure (Glenn Randers-Pehrson)
|
||||||
|
- allow "configure --prefix $HOME" (Tim Mooney)
|
||||||
|
- remove warnings in example.c and gzio.c (Glenn Randers-Pehrson)
|
||||||
|
- move Makefile.sas to amiga/Makefile.sas
|
||||||
|
|
||||||
|
Changes in 1.1.1 (27 Feb 98)
|
||||||
|
- fix macros _tr_tally_* in deflate.h for debug mode (Glenn Randers-Pehrson)
|
||||||
|
- remove block truncation heuristic which had very marginal effect for zlib
|
||||||
|
(smaller lit_bufsize than in gzip 1.2.4) and degraded a little the
|
||||||
|
compression ratio on some files. This also allows inlining _tr_tally for
|
||||||
|
matches in deflate_slow.
|
||||||
|
- added msdos/Makefile.w32 for WIN32 Microsoft Visual C++ (Bob Frazier)
|
||||||
|
|
||||||
|
Changes in 1.1.0 (24 Feb 98)
|
||||||
|
- do not return STREAM_END prematurely in inflate (John Bowler)
|
||||||
|
- revert to the zlib 1.0.8 inflate to avoid the gcc 2.8.0 bug (Jeremy Buhler)
|
||||||
|
- compile with -DFASTEST to get compression code optimized for speed only
|
||||||
|
- in minigzip, try mmap'ing the input file first (Miguel Albrecht)
|
||||||
|
- increase size of I/O buffers in minigzip.c and gzio.c (not a big gain
|
||||||
|
on Sun but significant on HP)
|
||||||
|
|
||||||
|
- add a pointer to experimental unzip library in README (Gilles Vollant)
|
||||||
|
- initialize variable gcc in configure (Chris Herborth)
|
||||||
|
|
||||||
|
Changes in 1.0.9 (17 Feb 1998)
|
||||||
|
- added gzputs and gzgets functions
|
||||||
|
- do not clear eof flag in gzseek (Mark Diekhans)
|
||||||
|
- fix gzseek for files in transparent mode (Mark Diekhans)
|
||||||
|
- do not assume that vsprintf returns the number of bytes written (Jens Krinke)
|
||||||
|
- replace EXPORT with ZEXPORT to avoid conflict with other programs
|
||||||
|
- added compress2 in zconf.h, zlib.def, zlib.dnt
|
||||||
|
- new asm code from Gilles Vollant in contrib/asm386
|
||||||
|
- simplify the inflate code (Mark):
|
||||||
|
. Replace ZALLOC's in huft_build() with single ZALLOC in inflate_blocks_new()
|
||||||
|
. ZALLOC the length list in inflate_trees_fixed() instead of using stack
|
||||||
|
. ZALLOC the value area for huft_build() instead of using stack
|
||||||
|
. Simplify Z_FINISH check in inflate()
|
||||||
|
|
||||||
|
- Avoid gcc 2.8.0 comparison bug a little differently than zlib 1.0.8
|
||||||
|
- in inftrees.c, avoid cc -O bug on HP (Farshid Elahi)
|
||||||
|
- in zconf.h move the ZLIB_DLL stuff earlier to avoid problems with
|
||||||
|
the declaration of FAR (Gilles VOllant)
|
||||||
|
- install libz.so* with mode 755 (executable) instead of 644 (Marc Lehmann)
|
||||||
|
- read_buf buf parameter of type Bytef* instead of charf*
|
||||||
|
- zmemcpy parameters are of type Bytef*, not charf* (Joseph Strout)
|
||||||
|
- do not redeclare unlink in minigzip.c for WIN32 (John Bowler)
|
||||||
|
- fix check for presence of directories in "make install" (Ian Willis)
|
||||||
|
|
||||||
|
Changes in 1.0.8 (27 Jan 1998)
|
||||||
|
- fixed offsets in contrib/asm386/gvmat32.asm (Gilles Vollant)
|
||||||
|
- fix gzgetc and gzputc for big endian systems (Markus Oberhumer)
|
||||||
|
- added compress2() to allow setting the compression level
|
||||||
|
- include sys/types.h to get off_t on some systems (Marc Lehmann & QingLong)
|
||||||
|
- use constant arrays for the static trees in trees.c instead of computing
|
||||||
|
them at run time (thanks to Ken Raeburn for this suggestion). To create
|
||||||
|
trees.h, compile with GEN_TREES_H and run "make test".
|
||||||
|
- check return code of example in "make test" and display result
|
||||||
|
- pass minigzip command line options to file_compress
|
||||||
|
- simplifying code of inflateSync to avoid gcc 2.8 bug
|
||||||
|
|
||||||
|
- support CC="gcc -Wall" in configure -s (QingLong)
|
||||||
|
- avoid a flush caused by ftell in gzopen for write mode (Ken Raeburn)
|
||||||
|
- fix test for shared library support to avoid compiler warnings
|
||||||
|
- zlib.lib -> zlib.dll in msdos/zlib.rc (Gilles Vollant)
|
||||||
|
- check for TARGET_OS_MAC in addition to MACOS (Brad Pettit)
|
||||||
|
- do not use fdopen for Metrowerks on Mac (Brad Pettit))
|
||||||
|
- add checks for gzputc and gzputc in example.c
|
||||||
|
- avoid warnings in gzio.c and deflate.c (Andreas Kleinert)
|
||||||
|
- use const for the CRC table (Ken Raeburn)
|
||||||
|
- fixed "make uninstall" for shared libraries
|
||||||
|
- use Tracev instead of Trace in infblock.c
|
||||||
|
- in example.c use correct compressed length for test_sync
|
||||||
|
- suppress +vnocompatwarnings in configure for HPUX (not always supported)
|
||||||
|
|
||||||
|
Changes in 1.0.7 (20 Jan 1998)
|
||||||
|
- fix gzseek which was broken in write mode
|
||||||
|
- return error for gzseek to negative absolute position
|
||||||
|
- fix configure for Linux (Chun-Chung Chen)
|
||||||
|
- increase stack space for MSC (Tim Wegner)
|
||||||
|
- get_crc_table and inflateSyncPoint are EXPORTed (Gilles Vollant)
|
||||||
|
- define EXPORTVA for gzprintf (Gilles Vollant)
|
||||||
|
- added man page zlib.3 (Rick Rodgers)
|
||||||
|
- for contrib/untgz, fix makedir() and improve Makefile
|
||||||
|
|
||||||
|
- check gzseek in write mode in example.c
|
||||||
|
- allocate extra buffer for seeks only if gzseek is actually called
|
||||||
|
- avoid signed/unsigned comparisons (Tim Wegner, Gilles Vollant)
|
||||||
|
- add inflateSyncPoint in zconf.h
|
||||||
|
- fix list of exported functions in nt/zlib.dnt and mdsos/zlib.def
|
||||||
|
|
||||||
|
Changes in 1.0.6 (19 Jan 1998)
|
||||||
|
- add functions gzprintf, gzputc, gzgetc, gztell, gzeof, gzseek, gzrewind and
|
||||||
|
gzsetparams (thanks to Roland Giersig and Kevin Ruland for some of this code)
|
||||||
|
- Fix a deflate bug occuring only with compression level 0 (thanks to
|
||||||
|
Andy Buckler for finding this one).
|
||||||
|
- In minigzip, pass transparently also the first byte for .Z files.
|
||||||
|
- return Z_BUF_ERROR instead of Z_OK if output buffer full in uncompress()
|
||||||
|
- check Z_FINISH in inflate (thanks to Marc Schluper)
|
||||||
|
- Implement deflateCopy (thanks to Adam Costello)
|
||||||
|
- make static libraries by default in configure, add --shared option.
|
||||||
|
- move MSDOS or Windows specific files to directory msdos
|
||||||
|
- suppress the notion of partial flush to simplify the interface
|
||||||
|
(but the symbol Z_PARTIAL_FLUSH is kept for compatibility with 1.0.4)
|
||||||
|
- suppress history buffer provided by application to simplify the interface
|
||||||
|
(this feature was not implemented anyway in 1.0.4)
|
||||||
|
- next_in and avail_in must be initialized before calling inflateInit or
|
||||||
|
inflateInit2
|
||||||
|
- add EXPORT in all exported functions (for Windows DLL)
|
||||||
|
- added Makefile.nt (thanks to Stephen Williams)
|
||||||
|
- added the unsupported "contrib" directory:
|
||||||
|
contrib/asm386/ by Gilles Vollant <info@winimage.com>
|
||||||
|
386 asm code replacing longest_match().
|
||||||
|
contrib/iostream/ by Kevin Ruland <kevin@rodin.wustl.edu>
|
||||||
|
A C++ I/O streams interface to the zlib gz* functions
|
||||||
|
contrib/iostream2/ by Tyge L<>vset <Tyge.Lovset@cmr.no>
|
||||||
|
Another C++ I/O streams interface
|
||||||
|
contrib/untgz/ by "Pedro A. Aranda Guti\irrez" <paag@tid.es>
|
||||||
|
A very simple tar.gz file extractor using zlib
|
||||||
|
contrib/visual-basic.txt by Carlos Rios <c_rios@sonda.cl>
|
||||||
|
How to use compress(), uncompress() and the gz* functions from VB.
|
||||||
|
- pass params -f (filtered data), -h (huffman only), -1 to -9 (compression
|
||||||
|
level) in minigzip (thanks to Tom Lane)
|
||||||
|
|
||||||
|
- use const for rommable constants in deflate
|
||||||
|
- added test for gzseek and gztell in example.c
|
||||||
|
- add undocumented function inflateSyncPoint() (hack for Paul Mackerras)
|
||||||
|
- add undocumented function zError to convert error code to string
|
||||||
|
(for Tim Smithers)
|
||||||
|
- Allow compilation of gzio with -DNO_DEFLATE to avoid the compression code.
|
||||||
|
- Use default memcpy for Symantec MSDOS compiler.
|
||||||
|
- Add EXPORT keyword for check_func (needed for Windows DLL)
|
||||||
|
- add current directory to LD_LIBRARY_PATH for "make test"
|
||||||
|
- create also a link for libz.so.1
|
||||||
|
- added support for FUJITSU UXP/DS (thanks to Toshiaki Nomura)
|
||||||
|
- use $(SHAREDLIB) instead of libz.so in Makefile.in (for HPUX)
|
||||||
|
- added -soname for Linux in configure (Chun-Chung Chen,
|
||||||
|
- assign numbers to the exported functions in zlib.def (for Windows DLL)
|
||||||
|
- add advice in zlib.h for best usage of deflateSetDictionary
|
||||||
|
- work around compiler bug on Atari (cast Z_NULL in call of s->checkfn)
|
||||||
|
- allow compilation with ANSI keywords only enabled for TurboC in large model
|
||||||
|
- avoid "versionString"[0] (Borland bug)
|
||||||
|
- add NEED_DUMMY_RETURN for Borland
|
||||||
|
- use variable z_verbose for tracing in debug mode (L. Peter Deutsch).
|
||||||
|
- allow compilation with CC
|
||||||
|
- defined STDC for OS/2 (David Charlap)
|
||||||
|
- limit external names to 8 chars for MVS (Thomas Lund)
|
||||||
|
- in minigzip.c, use static buffers only for 16-bit systems
|
||||||
|
- fix suffix check for "minigzip -d foo.gz"
|
||||||
|
- do not return an error for the 2nd of two consecutive gzflush() (Felix Lee)
|
||||||
|
- use _fdopen instead of fdopen for MSC >= 6.0 (Thomas Fanslau)
|
||||||
|
- added makelcc.bat for lcc-win32 (Tom St Denis)
|
||||||
|
- in Makefile.dj2, use copy and del instead of install and rm (Frank Donahoe)
|
||||||
|
- Avoid expanded $Id$. Use "rcs -kb" or "cvs admin -kb" to avoid Id expansion.
|
||||||
|
- check for unistd.h in configure (for off_t)
|
||||||
|
- remove useless check parameter in inflate_blocks_free
|
||||||
|
- avoid useless assignment of s->check to itself in inflate_blocks_new
|
||||||
|
- do not flush twice in gzclose (thanks to Ken Raeburn)
|
||||||
|
- rename FOPEN as F_OPEN to avoid clash with /usr/include/sys/file.h
|
||||||
|
- use NO_ERRNO_H instead of enumeration of operating systems with errno.h
|
||||||
|
- work around buggy fclose on pipes for HP/UX
|
||||||
|
- support zlib DLL with BORLAND C++ 5.0 (thanks to Glenn Randers-Pehrson)
|
||||||
|
- fix configure if CC is already equal to gcc
|
||||||
|
|
||||||
|
Changes in 1.0.5 (3 Jan 98)
|
||||||
|
- Fix inflate to terminate gracefully when fed corrupted or invalid data
|
||||||
|
- Use const for rommable constants in inflate
|
||||||
|
- Eliminate memory leaks on error conditions in inflate
|
||||||
|
- Removed some vestigial code in inflate
|
||||||
|
- Update web address in README
|
||||||
|
|
||||||
Changes in 1.0.4 (24 Jul 96)
|
Changes in 1.0.4 (24 Jul 96)
|
||||||
- In very rare conditions, deflate(s, Z_FINISH) could fail to produce an EOF
|
- In very rare conditions, deflate(s, Z_FINISH) could fail to produce an EOF
|
||||||
bit, so the decompressor could decompress all the correct data but went
|
bit, so the decompressor could decompress all the correct data but went
|
||||||
|
|||||||
72
FAQ
Normal file
72
FAQ
Normal file
@@ -0,0 +1,72 @@
|
|||||||
|
|
||||||
|
Frequently Asked Questions about zlib
|
||||||
|
|
||||||
|
|
||||||
|
If your question is not there, please check the zlib home page
|
||||||
|
http://www.cdrom.com/pub/infozip/zlib/ which may have more recent information.
|
||||||
|
|
||||||
|
|
||||||
|
1) I need a Windows DLL
|
||||||
|
2) I need a Visual Basic interface to zlib
|
||||||
|
3) compress() returns Z_BUF_ERROR
|
||||||
|
4) deflate or inflate returns Z_BUF_ERROR
|
||||||
|
5) Where is the zlib documentation (man pages, etc...)?
|
||||||
|
6) Why don't you use GNU autoconf, libtool, etc...?
|
||||||
|
7) There is a bug in zlib.
|
||||||
|
8) I get "undefined reference to gzputc"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
1) I need a Windows DLL
|
||||||
|
|
||||||
|
The zlib sources can be compiled without change to produce a DLL.
|
||||||
|
If you want a precompiled DLL, see http://www.winimage.com/zLibDll
|
||||||
|
|
||||||
|
|
||||||
|
2) I need a Visual Basic interface to zlib
|
||||||
|
|
||||||
|
See http://www.tcfb.com/dowseware/cmp-z-it.zip
|
||||||
|
http://web2.airmail.net/markn/articles/zlibtool/zlibtool.htm
|
||||||
|
and contrib/visual-basic.txt
|
||||||
|
|
||||||
|
3) compress() returns Z_BUF_ERROR
|
||||||
|
|
||||||
|
Make sure that before the call of compress, the length of the
|
||||||
|
compressed buffer is equal to the total size of the compressed buffer
|
||||||
|
and not zero. For Visual Basic, check that this parameter is passed
|
||||||
|
by reference ("as any"), not by value ("as long").
|
||||||
|
|
||||||
|
|
||||||
|
4) deflate or inflate returns Z_BUF_ERROR
|
||||||
|
|
||||||
|
Make sure that before the call avail_in and avail_out are not zero.
|
||||||
|
|
||||||
|
|
||||||
|
5) Where is the zlib documentation (man pages, etc...)?
|
||||||
|
|
||||||
|
It's in zlib.h for the moment. Volunteers to transform this
|
||||||
|
to man pages, please contact jloup@gzip.org. Examples of zlib usage
|
||||||
|
are in the files example.c and minigzip.c.
|
||||||
|
|
||||||
|
|
||||||
|
6) Why don't you use GNU autoconf, libtool, etc...?
|
||||||
|
|
||||||
|
Because we would like to keep zlib as a very small and simple package.
|
||||||
|
zlib is rather portable and doesn't need much configuration.
|
||||||
|
|
||||||
|
|
||||||
|
7) There is a bug in zlib.
|
||||||
|
|
||||||
|
Most of the time, such problems are due to an incorrect usage
|
||||||
|
of zlib. Please try to reproduce the problem with a small
|
||||||
|
program and send us the corresponding source at zlib@quest.jpl.nasa.gov
|
||||||
|
Do not send multi-megabyte data files without prior agreement.
|
||||||
|
|
||||||
|
|
||||||
|
8) I get "undefined reference to gzputc"
|
||||||
|
|
||||||
|
If "make test" produces something like
|
||||||
|
example.o(.text+0x174):
|
||||||
|
check that you don't have old files libz.* in /usr/lib, /usr/local/lib
|
||||||
|
or /usr/X11R6/lib. Remove old versions then do "make install".
|
||||||
|
|
||||||
73
INDEX
73
INDEX
@@ -1,22 +1,35 @@
|
|||||||
ChangeLog history of changes
|
ChangeLog history of changes
|
||||||
INDEX this file
|
INDEX this file
|
||||||
Make_vms.com script for Vax/VMS
|
FAQ Frequently Asked Questions about zlib
|
||||||
Makefile makefile for Unix (generated by configure)
|
Make_vms.com script for Vax/VMS
|
||||||
Makefile.b32 makefile for Borland C++ 32-bit
|
Makefile makefile for Unix (generated by configure)
|
||||||
Makefile.bor makefile for Borland C/C++ 16-bit
|
Makefile.in makefile for Unix (template for configure)
|
||||||
Makefile.dj2 makefile for DJGPP 2.x
|
Makefile.riscos makefile for RISCOS
|
||||||
Makefile.in makefile for Unix (template for configure)
|
README guess what
|
||||||
Makefile.msc makefile for Microsoft C 16-bit
|
algorithm.txt description of the (de)compression algorithm
|
||||||
Makefile.riscos makefile for RISCOS
|
configure configure script for Unix
|
||||||
Makefile.sas makefile for Amiga SAS/C
|
descrip.mms makefile for Vax/VMS
|
||||||
Makefile.tc makefile for Turbo C
|
zlib.3 mini man page for zlib (volunteers to write full
|
||||||
Makefile.wat makefile for Watcom C
|
man pages from zlib.h welcome. write to jloup@gzip.org)
|
||||||
README guess what
|
|
||||||
algorithm.doc description of the compression & decompression algorithms
|
amiga/Makefile.sas makefile for Amiga SAS/C
|
||||||
configure configure script for Unix
|
amiga/Makefile.pup makefile for Amiga powerUP SAS/C PPC
|
||||||
descrip.mms makefile for Vax/VMS
|
|
||||||
zlib.def definition file for Windows DLL
|
msdos/Makefile.w32 makefile for Microsoft Visual C++ 32-bit
|
||||||
zlib.rc definition file for Windows DLL
|
msdos/Makefile.b32 makefile for Borland C++ 32-bit
|
||||||
|
msdos/Makefile.bor makefile for Borland C/C++ 16-bit
|
||||||
|
msdos/Makefile.dj2 makefile for DJGPP 2.x
|
||||||
|
msdos/Makefile.emx makefile for EMX 0.9c (32-bit DOS/OS2)
|
||||||
|
msdos/Makefile.msc makefile for Microsoft C 16-bit
|
||||||
|
msdos/Makefile.tc makefile for Turbo C
|
||||||
|
msdos/Makefile.wat makefile for Watcom C
|
||||||
|
msdos/zlib.def definition file for Windows DLL
|
||||||
|
msdos/zlib.rc definition file for Windows DLL
|
||||||
|
|
||||||
|
nt/Makefile.nt makefile for Windows NT
|
||||||
|
nt/zlib.dnt definition file for Windows NT DLL
|
||||||
|
nt/Makefile.emx makefile for EMX 0.9c/RSXNT 1.41 (Win32 Intel)
|
||||||
|
nt/Makefile.gcc makefile for Windows NT using GCC (mingw32)
|
||||||
|
|
||||||
|
|
||||||
zlib public header files (must be kept):
|
zlib public header files (must be kept):
|
||||||
@@ -41,6 +54,7 @@ inftrees.c
|
|||||||
inftrees.h
|
inftrees.h
|
||||||
infutil.c
|
infutil.c
|
||||||
infutil.h
|
infutil.h
|
||||||
|
maketree.c
|
||||||
trees.c
|
trees.c
|
||||||
uncompr.c
|
uncompr.c
|
||||||
zutil.c
|
zutil.c
|
||||||
@@ -49,3 +63,24 @@ zutil.h
|
|||||||
source files for sample programs:
|
source files for sample programs:
|
||||||
example.c
|
example.c
|
||||||
minigzip.c
|
minigzip.c
|
||||||
|
|
||||||
|
unsupported contribution by third parties
|
||||||
|
|
||||||
|
contrib/asm386/ by Gilles Vollant <info@winimage.com>
|
||||||
|
386 asm code replacing longest_match().
|
||||||
|
|
||||||
|
contrib/minizip/ by Gilles Vollant <info@winimage.com>
|
||||||
|
Mini zip and unzip based on zlib
|
||||||
|
See http://www.winimage.com/zLibDll/unzip.html
|
||||||
|
|
||||||
|
contrib/iostream/ by Kevin Ruland <kevin@rodin.wustl.edu>
|
||||||
|
A C++ I/O streams interface to the zlib gz* functions
|
||||||
|
|
||||||
|
contrib/iostream2/ by Tyge L<>vset <Tyge.Lovset@cmr.no>
|
||||||
|
Another C++ I/O streams interface
|
||||||
|
|
||||||
|
contrib/untgz/ by "Pedro A. Aranda Guti\irrez" <paag@tid.es>
|
||||||
|
A very simple tar.gz extractor using zlib
|
||||||
|
|
||||||
|
contrib/visual-basic.txt by Carlos Rios <c_rios@sonda.cl>
|
||||||
|
How to use compress(), uncompress() and the gz* functions from VB.
|
||||||
|
|||||||
@@ -28,15 +28,15 @@ $ if f$search("SYS$SYSTEM:MMS.EXE").eqs.""
|
|||||||
$ then
|
$ then
|
||||||
$ dele example.obj;*,minigzip.obj;*
|
$ dele example.obj;*,minigzip.obj;*
|
||||||
$ CALL MAKE adler32.OBJ "CC ''CCOPT' adler32" -
|
$ CALL MAKE adler32.OBJ "CC ''CCOPT' adler32" -
|
||||||
adler32.c zutil.h zlib.h zconf.h
|
adler32.c zlib.h zconf.h
|
||||||
$ CALL MAKE compress.OBJ "CC ''CCOPT' compress" -
|
$ CALL MAKE compress.OBJ "CC ''CCOPT' compress" -
|
||||||
compress.c zlib.h zconf.h
|
compress.c zlib.h zconf.h
|
||||||
$ CALL MAKE crc32.OBJ "CC ''CCOPT' crc32" -
|
$ CALL MAKE crc32.OBJ "CC ''CCOPT' crc32" -
|
||||||
crc32.c zutil.h zlib.h zconf.h
|
crc32.c zlib.h zconf.h
|
||||||
$ CALL MAKE deflate.OBJ "CC ''CCOPT' deflate" -
|
$ CALL MAKE deflate.OBJ "CC ''CCOPT' deflate" -
|
||||||
deflatec.c deflate.h zutil.h zlib.h zconf.h
|
deflate.c deflate.h zutil.h zlib.h zconf.h
|
||||||
$ CALL MAKE gzio.OBJ "CC ''CCOPT' gzio" -
|
$ CALL MAKE gzio.OBJ "CC ''CCOPT' gzio" -
|
||||||
gsio.c zutil.h zlib.h zconf.h
|
gzio.c zutil.h zlib.h zconf.h
|
||||||
$ CALL MAKE infblock.OBJ "CC ''CCOPT' infblock" -
|
$ CALL MAKE infblock.OBJ "CC ''CCOPT' infblock" -
|
||||||
infblock.c zutil.h zlib.h zconf.h infblock.h
|
infblock.c zutil.h zlib.h zconf.h infblock.h
|
||||||
$ CALL MAKE infcodes.OBJ "CC ''CCOPT' infcodes" -
|
$ CALL MAKE infcodes.OBJ "CC ''CCOPT' infcodes" -
|
||||||
|
|||||||
102
Makefile
102
Makefile
@@ -1,10 +1,11 @@
|
|||||||
# Makefile for zlib
|
# Makefile for zlib
|
||||||
# Copyright (C) 1995-1996 Jean-loup Gailly.
|
# Copyright (C) 1995-1998 Jean-loup Gailly.
|
||||||
# For conditions of distribution and use, see copyright notice in zlib.h
|
# For conditions of distribution and use, see copyright notice in zlib.h
|
||||||
|
|
||||||
# To compile and test, type:
|
# To compile and test, type:
|
||||||
# ./configure; make test
|
# ./configure; make test
|
||||||
# The call of configure is optional if you don't have special requirements
|
# The call of configure is optional if you don't have special requirements
|
||||||
|
# If you wish to build zlib as a shared library, use: ./configure -s
|
||||||
|
|
||||||
# To install /usr/local/lib/libz.* and /usr/local/include/zlib.h, type:
|
# To install /usr/local/lib/libz.* and /usr/local/include/zlib.h, type:
|
||||||
# make install
|
# make install
|
||||||
@@ -21,38 +22,68 @@ CFLAGS=-O
|
|||||||
|
|
||||||
LDFLAGS=-L. -lz
|
LDFLAGS=-L. -lz
|
||||||
LDSHARED=$(CC)
|
LDSHARED=$(CC)
|
||||||
|
CPP=$(CC) -E
|
||||||
|
|
||||||
VER=1.0.4
|
VER=1.1.3
|
||||||
LIBS=libz.a
|
LIBS=libz.a
|
||||||
|
SHAREDLIB=libz.so
|
||||||
|
|
||||||
AR=ar rc
|
AR=ar rc
|
||||||
RANLIB=ranlib
|
RANLIB=ranlib
|
||||||
TAR=tar
|
TAR=tar
|
||||||
|
SHELL=/bin/sh
|
||||||
|
|
||||||
prefix=/usr/local
|
prefix = /usr/local
|
||||||
exec_prefix = $(prefix)
|
exec_prefix = ${prefix}
|
||||||
|
libdir = ${exec_prefix}/lib
|
||||||
|
includedir = ${prefix}/include
|
||||||
|
|
||||||
OBJS = adler32.o compress.o crc32.o gzio.o uncompr.o deflate.o trees.o \
|
OBJS = adler32.o compress.o crc32.o gzio.o uncompr.o deflate.o trees.o \
|
||||||
zutil.o inflate.o infblock.o inftrees.o infcodes.o infutil.o inffast.o
|
zutil.o inflate.o infblock.o inftrees.o infcodes.o infutil.o inffast.o
|
||||||
|
|
||||||
|
OBJA =
|
||||||
|
# to use the asm code: make OBJA=match.o
|
||||||
|
|
||||||
TEST_OBJS = example.o minigzip.o
|
TEST_OBJS = example.o minigzip.o
|
||||||
|
|
||||||
DISTFILES = README INDEX ChangeLog configure Make*[a-z0-9] descrip.mms \
|
DISTFILES = README FAQ INDEX ChangeLog configure Make*[a-z0-9] *.[ch] *.mms \
|
||||||
zlib.def zlib.rc algorithm.doc *.[ch]
|
algorithm.txt zlib.3 msdos/Make*[a-z0-9] msdos/zlib.def msdos/zlib.rc \
|
||||||
|
nt/Make*[a-z0-9] nt/zlib.dnt amiga/Make*.??? os2/M*.os2 os2/zlib.def \
|
||||||
|
contrib/RE*.contrib contrib/*.txt contrib/asm386/*.asm contrib/asm386/*.c \
|
||||||
|
contrib/asm386/*.bat contrib/asm386/zlibvc.d?? contrib/asm[56]86/*.?86 \
|
||||||
|
contrib/asm[56]86/*.S contrib/iostream/*.cpp \
|
||||||
|
contrib/iostream/*.h contrib/iostream2/*.h contrib/iostream2/*.cpp \
|
||||||
|
contrib/untgz/Makefile contrib/untgz/*.c contrib/untgz/*.w32 \
|
||||||
|
contrib/minizip/[CM]*[pe] contrib/minizip/*.[ch] contrib/minizip/*.[td]?? \
|
||||||
|
contrib/delphi*/*.???
|
||||||
|
|
||||||
all: example minigzip
|
all: example minigzip
|
||||||
|
|
||||||
test: all
|
test: all
|
||||||
./example
|
@LD_LIBRARY_PATH=.:$(LD_LIBRARY_PATH) ; export LD_LIBRARY_PATH; \
|
||||||
echo hello world | ./minigzip | ./minigzip -d
|
echo hello world | ./minigzip | ./minigzip -d || \
|
||||||
|
echo ' *** minigzip test FAILED ***' ; \
|
||||||
|
if ./example; then \
|
||||||
|
echo ' *** zlib test OK ***'; \
|
||||||
|
else \
|
||||||
|
echo ' *** zlib test FAILED ***'; \
|
||||||
|
fi
|
||||||
|
|
||||||
libz.a: $(OBJS)
|
libz.a: $(OBJS) $(OBJA)
|
||||||
$(AR) $@ $(OBJS)
|
$(AR) $@ $(OBJS) $(OBJA)
|
||||||
-@ ($(RANLIB) $@ || true) 2>/dev/null
|
-@ ($(RANLIB) $@ || true) >/dev/null 2>&1
|
||||||
|
|
||||||
libz.so.$(VER): $(OBJS)
|
match.o: match.S
|
||||||
|
$(CPP) match.S > _match.s
|
||||||
|
$(CC) -c _match.s
|
||||||
|
mv _match.o match.o
|
||||||
|
rm -f _match.s
|
||||||
|
|
||||||
|
$(SHAREDLIB).$(VER): $(OBJS)
|
||||||
$(LDSHARED) -o $@ $(OBJS)
|
$(LDSHARED) -o $@ $(OBJS)
|
||||||
rm -f libz.so; ln -s $@ libz.so
|
rm -f $(SHAREDLIB) $(SHAREDLIB).1
|
||||||
|
ln -s $@ $(SHAREDLIB)
|
||||||
|
ln -s $@ $(SHAREDLIB).1
|
||||||
|
|
||||||
example: example.o $(LIBS)
|
example: example.o $(LIBS)
|
||||||
$(CC) $(CFLAGS) -o $@ example.o $(LDFLAGS)
|
$(CC) $(CFLAGS) -o $@ example.o $(LDFLAGS)
|
||||||
@@ -61,37 +92,50 @@ minigzip: minigzip.o $(LIBS)
|
|||||||
$(CC) $(CFLAGS) -o $@ minigzip.o $(LDFLAGS)
|
$(CC) $(CFLAGS) -o $@ minigzip.o $(LDFLAGS)
|
||||||
|
|
||||||
install: $(LIBS)
|
install: $(LIBS)
|
||||||
-@if [ ! $(prefix)/include ]; then mkdir $(prefix)/include; fi
|
-@if [ ! -d $(includedir) ]; then mkdir $(includedir); fi
|
||||||
-@if [ ! $(exec_prefix)/lib ]; then mkdir $(exec_prefix)/lib; fi
|
-@if [ ! -d $(libdir) ]; then mkdir $(libdir); fi
|
||||||
cp zlib.h zconf.h $(prefix)/include
|
cp zlib.h zconf.h $(includedir)
|
||||||
chmod 644 $(prefix)/include/zlib.h $(prefix)/include/zconf.h
|
chmod 644 $(includedir)/zlib.h $(includedir)/zconf.h
|
||||||
cp $(LIBS) $(exec_prefix)/lib
|
cp $(LIBS) $(libdir)
|
||||||
cd $(exec_prefix)/lib; chmod 644 $(LIBS)
|
cd $(libdir); chmod 755 $(LIBS)
|
||||||
-@(cd $(exec_prefix)/lib; $(RANLIB) libz.a || true) >/dev/null 2>&1
|
-@(cd $(libdir); $(RANLIB) libz.a || true) >/dev/null 2>&1
|
||||||
cd $(exec_prefix)/lib; if test -f libz.so.$(VER); then \
|
cd $(libdir); if test -f $(SHAREDLIB).$(VER); then \
|
||||||
ln -s libz.so.$(VER) libz.so; \
|
rm -f $(SHAREDLIB) $(SHAREDLIB).1; \
|
||||||
|
ln -s $(SHAREDLIB).$(VER) $(SHAREDLIB); \
|
||||||
|
ln -s $(SHAREDLIB).$(VER) $(SHAREDLIB).1; \
|
||||||
|
(ldconfig || true) >/dev/null 2>&1; \
|
||||||
fi
|
fi
|
||||||
# The ranlib in install is needed on NeXTSTEP which checks file times
|
# The ranlib in install is needed on NeXTSTEP which checks file times
|
||||||
|
# ldconfig is for Linux
|
||||||
|
|
||||||
uninstall:
|
uninstall:
|
||||||
cd $(exec_prefix)/lib; rm -f $(LIBS); \
|
cd $(includedir); \
|
||||||
if test -f libz.so; then \
|
v=$(VER); \
|
||||||
v=`sed -n '/VERSION "/s/.*"\(.*\)".*/\1/p'<$(prefix)/include/zlib.h`;\
|
if test -f zlib.h; then \
|
||||||
rm -f libz.so.$$v libz.so; \
|
v=`sed -n '/VERSION "/s/.*"\(.*\)".*/\1/p' < zlib.h`; \
|
||||||
|
rm -f zlib.h zconf.h; \
|
||||||
|
fi; \
|
||||||
|
cd $(libdir); rm -f libz.a; \
|
||||||
|
if test -f $(SHAREDLIB).$$v; then \
|
||||||
|
rm -f $(SHAREDLIB).$$v $(SHAREDLIB) $(SHAREDLIB).1; \
|
||||||
fi
|
fi
|
||||||
cd $(prefix)/include; rm -f zlib.h zconf.h
|
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
rm -f *.o *~ example minigzip libz.a libz.so* foo.gz
|
rm -f *.o *~ example minigzip libz.a libz.so* foo.gz so_locations \
|
||||||
|
_match.s maketree
|
||||||
|
|
||||||
|
distclean: clean
|
||||||
|
|
||||||
zip:
|
zip:
|
||||||
mv Makefile Makefile~; cp -p Makefile.in Makefile
|
mv Makefile Makefile~; cp -p Makefile.in Makefile
|
||||||
|
rm -f test.c ztest*.c contrib/minizip/test.zip
|
||||||
v=`sed -n -e 's/\.//g' -e '/VERSION "/s/.*"\(.*\)".*/\1/p' < zlib.h`;\
|
v=`sed -n -e 's/\.//g' -e '/VERSION "/s/.*"\(.*\)".*/\1/p' < zlib.h`;\
|
||||||
zip -ul9 zlib$$v $(DISTFILES)
|
zip -ul9 zlib$$v $(DISTFILES)
|
||||||
mv Makefile~ Makefile
|
mv Makefile~ Makefile
|
||||||
|
|
||||||
dist:
|
dist:
|
||||||
mv Makefile Makefile~; cp -p Makefile.in Makefile
|
mv Makefile Makefile~; cp -p Makefile.in Makefile
|
||||||
|
rm -f test.c ztest*.c contrib/minizip/test.zip
|
||||||
d=zlib-`sed -n '/VERSION "/s/.*"\(.*\)".*/\1/p' < zlib.h`;\
|
d=zlib-`sed -n '/VERSION "/s/.*"\(.*\)".*/\1/p' < zlib.h`;\
|
||||||
rm -f $$d.tar.gz; \
|
rm -f $$d.tar.gz; \
|
||||||
if test ! -d ../$$d; then rm -f ../$$d; ln -s `pwd` ../$$d; fi; \
|
if test ! -d ../$$d; then rm -f ../$$d; ln -s `pwd` ../$$d; fi; \
|
||||||
@@ -125,6 +169,6 @@ inflate.o: zutil.h zlib.h zconf.h infblock.h
|
|||||||
inftrees.o: zutil.h zlib.h zconf.h inftrees.h
|
inftrees.o: zutil.h zlib.h zconf.h inftrees.h
|
||||||
infutil.o: zutil.h zlib.h zconf.h infblock.h inftrees.h infcodes.h infutil.h
|
infutil.o: zutil.h zlib.h zconf.h infblock.h inftrees.h infcodes.h infutil.h
|
||||||
minigzip.o: zlib.h zconf.h
|
minigzip.o: zlib.h zconf.h
|
||||||
trees.o: deflate.h zutil.h zlib.h zconf.h
|
trees.o: deflate.h zutil.h zlib.h zconf.h trees.h
|
||||||
uncompr.o: zlib.h zconf.h
|
uncompr.o: zlib.h zconf.h
|
||||||
zutil.o: zutil.h zlib.h zconf.h
|
zutil.o: zutil.h zlib.h zconf.h
|
||||||
|
|||||||
105
Makefile.bor
105
Makefile.bor
@@ -1,105 +0,0 @@
|
|||||||
# Makefile for zlib
|
|
||||||
# Borland C++ ************ UNTESTED ***********
|
|
||||||
|
|
||||||
# To use, do "make -fmakefile.bor"
|
|
||||||
# To compile in small model, set below: MODEL=-ms
|
|
||||||
|
|
||||||
# WARNING: the small model is supported but only for small values of
|
|
||||||
# MAX_WBITS and MAX_MEM_LEVEL. For example:
|
|
||||||
# -DMAX_WBITS=11 -DDEF_WBITS=11 -DMAX_MEM_LEVEL=3
|
|
||||||
# If you wish to reduce the memory requirements (default 256K for big
|
|
||||||
# objects plus a few K), you can add to CFLAGS below:
|
|
||||||
# -DMAX_MEM_LEVEL=7 -DMAX_WBITS=14
|
|
||||||
# See zconf.h for details about the memory requirements.
|
|
||||||
|
|
||||||
# ------------- Turbo C++, Borland C++ -------------
|
|
||||||
MODEL=-ml
|
|
||||||
CFLAGS=-O2 -Z $(MODEL)
|
|
||||||
CC=bcc
|
|
||||||
LD=bcc
|
|
||||||
LIB=tlib
|
|
||||||
# replace bcc with tcc for Turbo C++ 1.0, with bcc32 for the 32 bit version
|
|
||||||
LDFLAGS=$(MODEL)
|
|
||||||
O=.obj
|
|
||||||
|
|
||||||
# variables
|
|
||||||
OBJ1 = adler32$(O) compress$(O) crc32$(O) gzio$(O) uncompr$(O) deflate$(O) \
|
|
||||||
trees$(O)
|
|
||||||
OBJP1 = adler32$(O)+compress$(O)+crc32$(O)+gzio$(O)+uncompr$(O)+deflate$(O)+\
|
|
||||||
trees$(O)
|
|
||||||
OBJ2 = zutil$(O) inflate$(O) infblock$(O) inftrees$(O) infcodes$(O) \
|
|
||||||
infutil$(O) inffast$(O)
|
|
||||||
OBJP2 = zutil$(O)+inflate$(O)+infblock$(O)+inftrees$(O)+infcodes$(O)+\
|
|
||||||
infutil$(O)+inffast$(O)
|
|
||||||
|
|
||||||
all: test
|
|
||||||
|
|
||||||
adler32.obj: adler32.c zutil.h zlib.h zconf.h
|
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
|
||||||
|
|
||||||
compress.obj: compress.c zlib.h zconf.h
|
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
|
||||||
|
|
||||||
crc32.obj: crc32.c zutil.h zlib.h zconf.h
|
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
|
||||||
|
|
||||||
deflate.obj: deflate.c deflate.h zutil.h zlib.h zconf.h
|
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
|
||||||
|
|
||||||
gzio.obj: gzio.c zutil.h zlib.h zconf.h
|
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
|
||||||
|
|
||||||
infblock.obj: infblock.c zutil.h zlib.h zconf.h infblock.h inftrees.h\
|
|
||||||
infcodes.h infutil.h
|
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
|
||||||
|
|
||||||
infcodes.obj: infcodes.c zutil.h zlib.h zconf.h inftrees.h infutil.h\
|
|
||||||
infcodes.h inffast.h
|
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
|
||||||
|
|
||||||
inflate.obj: inflate.c zutil.h zlib.h zconf.h infblock.h
|
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
|
||||||
|
|
||||||
inftrees.obj: inftrees.c zutil.h zlib.h zconf.h inftrees.h
|
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
|
||||||
|
|
||||||
infutil.obj: infutil.c zutil.h zlib.h zconf.h inftrees.h infutil.h
|
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
|
||||||
|
|
||||||
inffast.obj: inffast.c zutil.h zlib.h zconf.h inftrees.h infutil.h inffast.h
|
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
|
||||||
|
|
||||||
trees.obj: trees.c deflate.h zutil.h zlib.h zconf.h
|
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
|
||||||
|
|
||||||
uncompr.obj: uncompr.c zlib.h zconf.h
|
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
|
||||||
|
|
||||||
zutil.obj: zutil.c zutil.h zlib.h zconf.h
|
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
|
||||||
|
|
||||||
example.obj: example.c zlib.h zconf.h
|
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
|
||||||
|
|
||||||
minigzip.obj: minigzip.c zlib.h zconf.h
|
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
|
||||||
|
|
||||||
# we must cut the command line to fit in the MS/DOS 128 byte limit:
|
|
||||||
zlib.lib: $(OBJ1) $(OBJ2)
|
|
||||||
del zlib.lib
|
|
||||||
$(LIB) zlib +$(OBJP1)
|
|
||||||
$(LIB) zlib +$(OBJP2)
|
|
||||||
|
|
||||||
example.exe: example.obj zlib.lib
|
|
||||||
$(LD) $(LDFLAGS) example.obj zlib.lib
|
|
||||||
|
|
||||||
minigzip.exe: minigzip.obj zlib.lib
|
|
||||||
$(LD) $(LDFLAGS) minigzip.obj zlib.lib
|
|
||||||
|
|
||||||
test: example.exe minigzip.exe
|
|
||||||
example
|
|
||||||
echo hello world | minigzip | minigzip -d
|
|
||||||
|
|
||||||
#clean:
|
|
||||||
# del *.obj
|
|
||||||
# del *.exe
|
|
||||||
102
Makefile.in
102
Makefile.in
@@ -1,10 +1,11 @@
|
|||||||
# Makefile for zlib
|
# Makefile for zlib
|
||||||
# Copyright (C) 1995-1996 Jean-loup Gailly.
|
# Copyright (C) 1995-1998 Jean-loup Gailly.
|
||||||
# For conditions of distribution and use, see copyright notice in zlib.h
|
# For conditions of distribution and use, see copyright notice in zlib.h
|
||||||
|
|
||||||
# To compile and test, type:
|
# To compile and test, type:
|
||||||
# ./configure; make test
|
# ./configure; make test
|
||||||
# The call of configure is optional if you don't have special requirements
|
# The call of configure is optional if you don't have special requirements
|
||||||
|
# If you wish to build zlib as a shared library, use: ./configure -s
|
||||||
|
|
||||||
# To install /usr/local/lib/libz.* and /usr/local/include/zlib.h, type:
|
# To install /usr/local/lib/libz.* and /usr/local/include/zlib.h, type:
|
||||||
# make install
|
# make install
|
||||||
@@ -21,38 +22,68 @@ CFLAGS=-O
|
|||||||
|
|
||||||
LDFLAGS=-L. -lz
|
LDFLAGS=-L. -lz
|
||||||
LDSHARED=$(CC)
|
LDSHARED=$(CC)
|
||||||
|
CPP=$(CC) -E
|
||||||
|
|
||||||
VER=1.0.4
|
VER=1.1.3
|
||||||
LIBS=libz.a
|
LIBS=libz.a
|
||||||
|
SHAREDLIB=libz.so
|
||||||
|
|
||||||
AR=ar rc
|
AR=ar rc
|
||||||
RANLIB=ranlib
|
RANLIB=ranlib
|
||||||
TAR=tar
|
TAR=tar
|
||||||
|
SHELL=/bin/sh
|
||||||
|
|
||||||
prefix=/usr/local
|
prefix = /usr/local
|
||||||
exec_prefix = $(prefix)
|
exec_prefix = ${prefix}
|
||||||
|
libdir = ${exec_prefix}/lib
|
||||||
|
includedir = ${prefix}/include
|
||||||
|
|
||||||
OBJS = adler32.o compress.o crc32.o gzio.o uncompr.o deflate.o trees.o \
|
OBJS = adler32.o compress.o crc32.o gzio.o uncompr.o deflate.o trees.o \
|
||||||
zutil.o inflate.o infblock.o inftrees.o infcodes.o infutil.o inffast.o
|
zutil.o inflate.o infblock.o inftrees.o infcodes.o infutil.o inffast.o
|
||||||
|
|
||||||
|
OBJA =
|
||||||
|
# to use the asm code: make OBJA=match.o
|
||||||
|
|
||||||
TEST_OBJS = example.o minigzip.o
|
TEST_OBJS = example.o minigzip.o
|
||||||
|
|
||||||
DISTFILES = README INDEX ChangeLog configure Make*[a-z0-9] descrip.mms \
|
DISTFILES = README FAQ INDEX ChangeLog configure Make*[a-z0-9] *.[ch] *.mms \
|
||||||
zlib.def zlib.rc algorithm.doc *.[ch]
|
algorithm.txt zlib.3 msdos/Make*[a-z0-9] msdos/zlib.def msdos/zlib.rc \
|
||||||
|
nt/Make*[a-z0-9] nt/zlib.dnt amiga/Make*.??? os2/M*.os2 os2/zlib.def \
|
||||||
|
contrib/RE*.contrib contrib/*.txt contrib/asm386/*.asm contrib/asm386/*.c \
|
||||||
|
contrib/asm386/*.bat contrib/asm386/zlibvc.d?? contrib/asm[56]86/*.?86 \
|
||||||
|
contrib/asm[56]86/*.S contrib/iostream/*.cpp \
|
||||||
|
contrib/iostream/*.h contrib/iostream2/*.h contrib/iostream2/*.cpp \
|
||||||
|
contrib/untgz/Makefile contrib/untgz/*.c contrib/untgz/*.w32 \
|
||||||
|
contrib/minizip/[CM]*[pe] contrib/minizip/*.[ch] contrib/minizip/*.[td]?? \
|
||||||
|
contrib/delphi*/*.???
|
||||||
|
|
||||||
all: example minigzip
|
all: example minigzip
|
||||||
|
|
||||||
test: all
|
test: all
|
||||||
./example
|
@LD_LIBRARY_PATH=.:$(LD_LIBRARY_PATH) ; export LD_LIBRARY_PATH; \
|
||||||
echo hello world | ./minigzip | ./minigzip -d
|
echo hello world | ./minigzip | ./minigzip -d || \
|
||||||
|
echo ' *** minigzip test FAILED ***' ; \
|
||||||
|
if ./example; then \
|
||||||
|
echo ' *** zlib test OK ***'; \
|
||||||
|
else \
|
||||||
|
echo ' *** zlib test FAILED ***'; \
|
||||||
|
fi
|
||||||
|
|
||||||
libz.a: $(OBJS)
|
libz.a: $(OBJS) $(OBJA)
|
||||||
$(AR) $@ $(OBJS)
|
$(AR) $@ $(OBJS) $(OBJA)
|
||||||
-@ ($(RANLIB) $@ || true) 2>/dev/null
|
-@ ($(RANLIB) $@ || true) >/dev/null 2>&1
|
||||||
|
|
||||||
libz.so.$(VER): $(OBJS)
|
match.o: match.S
|
||||||
|
$(CPP) match.S > _match.s
|
||||||
|
$(CC) -c _match.s
|
||||||
|
mv _match.o match.o
|
||||||
|
rm -f _match.s
|
||||||
|
|
||||||
|
$(SHAREDLIB).$(VER): $(OBJS)
|
||||||
$(LDSHARED) -o $@ $(OBJS)
|
$(LDSHARED) -o $@ $(OBJS)
|
||||||
rm -f libz.so; ln -s $@ libz.so
|
rm -f $(SHAREDLIB) $(SHAREDLIB).1
|
||||||
|
ln -s $@ $(SHAREDLIB)
|
||||||
|
ln -s $@ $(SHAREDLIB).1
|
||||||
|
|
||||||
example: example.o $(LIBS)
|
example: example.o $(LIBS)
|
||||||
$(CC) $(CFLAGS) -o $@ example.o $(LDFLAGS)
|
$(CC) $(CFLAGS) -o $@ example.o $(LDFLAGS)
|
||||||
@@ -61,37 +92,50 @@ minigzip: minigzip.o $(LIBS)
|
|||||||
$(CC) $(CFLAGS) -o $@ minigzip.o $(LDFLAGS)
|
$(CC) $(CFLAGS) -o $@ minigzip.o $(LDFLAGS)
|
||||||
|
|
||||||
install: $(LIBS)
|
install: $(LIBS)
|
||||||
-@if [ ! $(prefix)/include ]; then mkdir $(prefix)/include; fi
|
-@if [ ! -d $(includedir) ]; then mkdir $(includedir); fi
|
||||||
-@if [ ! $(exec_prefix)/lib ]; then mkdir $(exec_prefix)/lib; fi
|
-@if [ ! -d $(libdir) ]; then mkdir $(libdir); fi
|
||||||
cp zlib.h zconf.h $(prefix)/include
|
cp zlib.h zconf.h $(includedir)
|
||||||
chmod 644 $(prefix)/include/zlib.h $(prefix)/include/zconf.h
|
chmod 644 $(includedir)/zlib.h $(includedir)/zconf.h
|
||||||
cp $(LIBS) $(exec_prefix)/lib
|
cp $(LIBS) $(libdir)
|
||||||
cd $(exec_prefix)/lib; chmod 644 $(LIBS)
|
cd $(libdir); chmod 755 $(LIBS)
|
||||||
-@(cd $(exec_prefix)/lib; $(RANLIB) libz.a || true) >/dev/null 2>&1
|
-@(cd $(libdir); $(RANLIB) libz.a || true) >/dev/null 2>&1
|
||||||
cd $(exec_prefix)/lib; if test -f libz.so.$(VER); then \
|
cd $(libdir); if test -f $(SHAREDLIB).$(VER); then \
|
||||||
ln -s libz.so.$(VER) libz.so; \
|
rm -f $(SHAREDLIB) $(SHAREDLIB).1; \
|
||||||
|
ln -s $(SHAREDLIB).$(VER) $(SHAREDLIB); \
|
||||||
|
ln -s $(SHAREDLIB).$(VER) $(SHAREDLIB).1; \
|
||||||
|
(ldconfig || true) >/dev/null 2>&1; \
|
||||||
fi
|
fi
|
||||||
# The ranlib in install is needed on NeXTSTEP which checks file times
|
# The ranlib in install is needed on NeXTSTEP which checks file times
|
||||||
|
# ldconfig is for Linux
|
||||||
|
|
||||||
uninstall:
|
uninstall:
|
||||||
cd $(exec_prefix)/lib; rm -f $(LIBS); \
|
cd $(includedir); \
|
||||||
if test -f libz.so; then \
|
v=$(VER); \
|
||||||
v=`sed -n '/VERSION "/s/.*"\(.*\)".*/\1/p'<$(prefix)/include/zlib.h`;\
|
if test -f zlib.h; then \
|
||||||
rm -f libz.so.$$v libz.so; \
|
v=`sed -n '/VERSION "/s/.*"\(.*\)".*/\1/p' < zlib.h`; \
|
||||||
|
rm -f zlib.h zconf.h; \
|
||||||
|
fi; \
|
||||||
|
cd $(libdir); rm -f libz.a; \
|
||||||
|
if test -f $(SHAREDLIB).$$v; then \
|
||||||
|
rm -f $(SHAREDLIB).$$v $(SHAREDLIB) $(SHAREDLIB).1; \
|
||||||
fi
|
fi
|
||||||
cd $(prefix)/include; rm -f zlib.h zconf.h
|
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
rm -f *.o *~ example minigzip libz.a libz.so* foo.gz
|
rm -f *.o *~ example minigzip libz.a libz.so* foo.gz so_locations \
|
||||||
|
_match.s maketree
|
||||||
|
|
||||||
|
distclean: clean
|
||||||
|
|
||||||
zip:
|
zip:
|
||||||
mv Makefile Makefile~; cp -p Makefile.in Makefile
|
mv Makefile Makefile~; cp -p Makefile.in Makefile
|
||||||
|
rm -f test.c ztest*.c contrib/minizip/test.zip
|
||||||
v=`sed -n -e 's/\.//g' -e '/VERSION "/s/.*"\(.*\)".*/\1/p' < zlib.h`;\
|
v=`sed -n -e 's/\.//g' -e '/VERSION "/s/.*"\(.*\)".*/\1/p' < zlib.h`;\
|
||||||
zip -ul9 zlib$$v $(DISTFILES)
|
zip -ul9 zlib$$v $(DISTFILES)
|
||||||
mv Makefile~ Makefile
|
mv Makefile~ Makefile
|
||||||
|
|
||||||
dist:
|
dist:
|
||||||
mv Makefile Makefile~; cp -p Makefile.in Makefile
|
mv Makefile Makefile~; cp -p Makefile.in Makefile
|
||||||
|
rm -f test.c ztest*.c contrib/minizip/test.zip
|
||||||
d=zlib-`sed -n '/VERSION "/s/.*"\(.*\)".*/\1/p' < zlib.h`;\
|
d=zlib-`sed -n '/VERSION "/s/.*"\(.*\)".*/\1/p' < zlib.h`;\
|
||||||
rm -f $$d.tar.gz; \
|
rm -f $$d.tar.gz; \
|
||||||
if test ! -d ../$$d; then rm -f ../$$d; ln -s `pwd` ../$$d; fi; \
|
if test ! -d ../$$d; then rm -f ../$$d; ln -s `pwd` ../$$d; fi; \
|
||||||
@@ -125,6 +169,6 @@ inflate.o: zutil.h zlib.h zconf.h infblock.h
|
|||||||
inftrees.o: zutil.h zlib.h zconf.h inftrees.h
|
inftrees.o: zutil.h zlib.h zconf.h inftrees.h
|
||||||
infutil.o: zutil.h zlib.h zconf.h infblock.h inftrees.h infcodes.h infutil.h
|
infutil.o: zutil.h zlib.h zconf.h infblock.h inftrees.h infcodes.h infutil.h
|
||||||
minigzip.o: zlib.h zconf.h
|
minigzip.o: zlib.h zconf.h
|
||||||
trees.o: deflate.h zutil.h zlib.h zconf.h
|
trees.o: deflate.h zutil.h zlib.h zconf.h trees.h
|
||||||
uncompr.o: zlib.h zconf.h
|
uncompr.o: zlib.h zconf.h
|
||||||
zutil.o: zutil.h zlib.h zconf.h
|
zutil.o: zutil.h zlib.h zconf.h
|
||||||
|
|||||||
145
Makefile.riscos
145
Makefile.riscos
@@ -1,8 +1,9 @@
|
|||||||
# Project: zlib_1_03
|
# Project: zlib_1_03
|
||||||
|
# Patched for zlib 1.1.2 rw@shadow.org.uk 19980430
|
||||||
|
# test works out-of-the-box, installs `somewhere' on demand
|
||||||
|
|
||||||
# Toolflags:
|
# Toolflags:
|
||||||
CCflags = -c -depend !Depend -IC: -g -throwback -DRISCOS -fnah
|
CCflags = -c -depend !Depend -IC: -g -throwback -DRISCOS -fah
|
||||||
C++flags = -c -depend !Depend -IC: -throwback
|
C++flags = -c -depend !Depend -IC: -throwback
|
||||||
Linkflags = -aif -c++ -o $@
|
Linkflags = -aif -c++ -o $@
|
||||||
ObjAsmflags = -throwback -NoCache -depend !Depend
|
ObjAsmflags = -throwback -NoCache -depend !Depend
|
||||||
@@ -10,37 +11,141 @@ CMHGflags =
|
|||||||
LibFileflags = -c -l -o $@
|
LibFileflags = -c -l -o $@
|
||||||
Squeezeflags = -o $@
|
Squeezeflags = -o $@
|
||||||
|
|
||||||
|
# change the line below to where _you_ want the library installed.
|
||||||
|
libdest = lib:zlib
|
||||||
|
|
||||||
# Final targets:
|
# Final targets:
|
||||||
@.zlib_lib: @.o.adler32 @.o.compress @.o.crc32 @.o.deflate @.o.gzio \
|
@.lib: @.o.adler32 @.o.compress @.o.crc32 @.o.deflate @.o.gzio \
|
||||||
@.o.infblock @.o.infcodes @.o.inffast @.o.inflate @.o.inftrees @.o.infutil @.o.trees \
|
@.o.infblock @.o.infcodes @.o.inffast @.o.inflate @.o.inftrees @.o.infutil @.o.trees \
|
||||||
@.o.uncompress @.o.zutil
|
@.o.uncompr @.o.zutil
|
||||||
LibFile $(LibFileflags) @.o.adler32 @.o.compress @.o.crc32 @.o.deflate \
|
LibFile $(LibFileflags) @.o.adler32 @.o.compress @.o.crc32 @.o.deflate \
|
||||||
@.o.gzio @.o.infblock @.o.infcodes @.o.inffast @.o.inflate @.o.inftrees @.o.infutil \
|
@.o.gzio @.o.infblock @.o.infcodes @.o.inffast @.o.inflate @.o.inftrees @.o.infutil \
|
||||||
@.o.trees @.o.uncompress @.o.zutil
|
@.o.trees @.o.uncompr @.o.zutil
|
||||||
@.test: @.tests.minigzip @.tests.example
|
test: @.minigzip @.example @.lib
|
||||||
echo Please run "Test" in directory tests
|
@copy @.lib @.libc A~C~DF~L~N~P~Q~RS~TV
|
||||||
@.tests.minigzip: @.o.minigzip @.zlib_lib C:o.Stubs
|
@echo running tests: hang on.
|
||||||
Link $(Linkflags) @.o.minigzip @.zlib_lib C:o.Stubs
|
@/@.minigzip -f -9 libc
|
||||||
@.tests.example: @.o.example @.zlib_lib C:o.Stubs
|
@/@.minigzip -d libc-gz
|
||||||
Link $(Linkflags) @.o.example @.zlib_lib C:o.Stubs
|
@/@.minigzip -f -1 libc
|
||||||
|
@/@.minigzip -d libc-gz
|
||||||
|
@/@.minigzip -h -9 libc
|
||||||
|
@/@.minigzip -d libc-gz
|
||||||
|
@/@.minigzip -h -1 libc
|
||||||
|
@/@.minigzip -d libc-gz
|
||||||
|
@/@.minigzip -9 libc
|
||||||
|
@/@.minigzip -d libc-gz
|
||||||
|
@/@.minigzip -1 libc
|
||||||
|
@/@.minigzip -d libc-gz
|
||||||
|
@diff @.lib @.libc
|
||||||
|
@echo that should have reported '@.lib and @.libc identical' if you have diff.
|
||||||
|
@/@.example @.fred @.fred
|
||||||
|
@echo that will have given lots of hello!'s.
|
||||||
|
|
||||||
|
@.minigzip: @.o.minigzip @.lib C:o.Stubs
|
||||||
|
Link $(Linkflags) @.o.minigzip @.lib C:o.Stubs
|
||||||
|
@.example: @.o.example @.lib C:o.Stubs
|
||||||
|
Link $(Linkflags) @.o.example @.lib C:o.Stubs
|
||||||
|
|
||||||
|
install: @.lib
|
||||||
|
cdir $(libdest)
|
||||||
|
cdir $(libdest).h
|
||||||
|
@copy @.h.zlib $(libdest).h.zlib A~C~DF~L~N~P~Q~RS~TV
|
||||||
|
@copy @.h.zconf $(libdest).h.zconf A~C~DF~L~N~P~Q~RS~TV
|
||||||
|
@copy @.lib $(libdest).lib A~C~DF~L~N~P~Q~RS~TV
|
||||||
|
@echo okay, installed zlib in $(libdest)
|
||||||
|
|
||||||
|
clean:; remove @.minigzip
|
||||||
|
remove @.example
|
||||||
|
remove @.libc
|
||||||
|
-wipe @.o.* F~r~cV
|
||||||
|
remove @.fred
|
||||||
|
|
||||||
# User-editable dependencies:
|
# User-editable dependencies:
|
||||||
.c.o:
|
.c.o:
|
||||||
cc $(ccflags) -o $@ $<
|
cc $(ccflags) -o $@ $<
|
||||||
|
|
||||||
# Static dependencies:
|
# Static dependencies:
|
||||||
@.o.example: @.tests.c.example
|
|
||||||
cc $(ccflags) -o @.o.example @.tests.c.example
|
|
||||||
@.o.minigzip: @.tests.c.minigzip
|
|
||||||
cc $(ccflags) -o @.o.minigzip @.tests.c.minigzip
|
|
||||||
|
|
||||||
|
|
||||||
# Dynamic dependencies:
|
# Dynamic dependencies:
|
||||||
o.minigzip: tests.c.minigzip
|
o.example: c.example
|
||||||
o.minigzip: h.zlib
|
|
||||||
o.minigzip: h.zconf
|
|
||||||
o.example: tests.c.example
|
|
||||||
o.example: h.zlib
|
o.example: h.zlib
|
||||||
o.example: h.zconf
|
o.example: h.zconf
|
||||||
|
o.minigzip: c.minigzip
|
||||||
|
o.minigzip: h.zlib
|
||||||
|
o.minigzip: h.zconf
|
||||||
|
o.adler32: c.adler32
|
||||||
|
o.adler32: h.zlib
|
||||||
|
o.adler32: h.zconf
|
||||||
|
o.compress: c.compress
|
||||||
|
o.compress: h.zlib
|
||||||
|
o.compress: h.zconf
|
||||||
|
o.crc32: c.crc32
|
||||||
|
o.crc32: h.zlib
|
||||||
|
o.crc32: h.zconf
|
||||||
|
o.deflate: c.deflate
|
||||||
|
o.deflate: h.deflate
|
||||||
|
o.deflate: h.zutil
|
||||||
|
o.deflate: h.zlib
|
||||||
|
o.deflate: h.zconf
|
||||||
|
o.gzio: c.gzio
|
||||||
|
o.gzio: h.zutil
|
||||||
|
o.gzio: h.zlib
|
||||||
|
o.gzio: h.zconf
|
||||||
|
o.infblock: c.infblock
|
||||||
|
o.infblock: h.zutil
|
||||||
|
o.infblock: h.zlib
|
||||||
|
o.infblock: h.zconf
|
||||||
|
o.infblock: h.infblock
|
||||||
|
o.infblock: h.inftrees
|
||||||
|
o.infblock: h.infcodes
|
||||||
|
o.infblock: h.infutil
|
||||||
|
o.infcodes: c.infcodes
|
||||||
|
o.infcodes: h.zutil
|
||||||
|
o.infcodes: h.zlib
|
||||||
|
o.infcodes: h.zconf
|
||||||
|
o.infcodes: h.inftrees
|
||||||
|
o.infcodes: h.infblock
|
||||||
|
o.infcodes: h.infcodes
|
||||||
|
o.infcodes: h.infutil
|
||||||
|
o.infcodes: h.inffast
|
||||||
|
o.inffast: c.inffast
|
||||||
|
o.inffast: h.zutil
|
||||||
|
o.inffast: h.zlib
|
||||||
|
o.inffast: h.zconf
|
||||||
|
o.inffast: h.inftrees
|
||||||
|
o.inffast: h.infblock
|
||||||
|
o.inffast: h.infcodes
|
||||||
|
o.inffast: h.infutil
|
||||||
|
o.inffast: h.inffast
|
||||||
|
o.inflate: c.inflate
|
||||||
|
o.inflate: h.zutil
|
||||||
|
o.inflate: h.zlib
|
||||||
|
o.inflate: h.zconf
|
||||||
|
o.inflate: h.infblock
|
||||||
|
o.inftrees: c.inftrees
|
||||||
|
o.inftrees: h.zutil
|
||||||
|
o.inftrees: h.zlib
|
||||||
|
o.inftrees: h.zconf
|
||||||
|
o.inftrees: h.inftrees
|
||||||
|
o.inftrees: h.inffixed
|
||||||
|
o.infutil: c.infutil
|
||||||
|
o.infutil: h.zutil
|
||||||
|
o.infutil: h.zlib
|
||||||
|
o.infutil: h.zconf
|
||||||
|
o.infutil: h.infblock
|
||||||
|
o.infutil: h.inftrees
|
||||||
|
o.infutil: h.infcodes
|
||||||
|
o.infutil: h.infutil
|
||||||
|
o.trees: c.trees
|
||||||
|
o.trees: h.deflate
|
||||||
|
o.trees: h.zutil
|
||||||
|
o.trees: h.zlib
|
||||||
|
o.trees: h.zconf
|
||||||
|
o.trees: h.trees
|
||||||
|
o.uncompr: c.uncompr
|
||||||
|
o.uncompr: h.zlib
|
||||||
|
o.uncompr: h.zconf
|
||||||
|
o.zutil: c.zutil
|
||||||
|
o.zutil: h.zutil
|
||||||
|
o.zutil: h.zlib
|
||||||
|
o.zutil: h.zconf
|
||||||
|
|||||||
117
README
117
README
@@ -1,74 +1,123 @@
|
|||||||
zlib 1.0.4 is a general purpose data compression library. All the code
|
zlib 1.1.3 is a general purpose data compression library. All the code
|
||||||
is reentrant (thread safe). The data format used by the zlib library
|
is thread safe. The data format used by the zlib library
|
||||||
is described by RFCs (Request for Comments) 1950 to 1952 in the files
|
is described by RFCs (Request for Comments) 1950 to 1952 in the files
|
||||||
ftp://ds.internic.net/rfc/rfc1950.txt (zlib format), rfc1951.txt (deflate
|
ftp://ds.internic.net/rfc/rfc1950.txt (zlib format), rfc1951.txt (deflate
|
||||||
format) and rfc1952.txt (gzip format). These documents are also available in
|
format) and rfc1952.txt (gzip format). These documents are also available in
|
||||||
other formats from ftp://ftp.uu.net/graphics/png/documents/zlib/zdoc-index.html
|
other formats from ftp://ftp.uu.net/graphics/png/documents/zlib/zdoc-index.html
|
||||||
|
|
||||||
All functions of the compression library are documented in the file
|
All functions of the compression library are documented in the file zlib.h
|
||||||
zlib.h. A usage example of the library is given in the file example.c
|
(volunteer to write man pages welcome, contact jloup@gzip.org). A usage
|
||||||
which also tests that the library is working correctly. Another
|
example of the library is given in the file example.c which also tests that
|
||||||
example is given in the file minigzip.c. The compression library itself
|
the library is working correctly. Another example is given in the file
|
||||||
is composed of all source files except example.c and minigzip.c.
|
minigzip.c. The compression library itself is composed of all source files
|
||||||
|
except example.c and minigzip.c.
|
||||||
|
|
||||||
To compile all files and run the test program, follow the instructions
|
To compile all files and run the test program, follow the instructions
|
||||||
given at the top of Makefile. In short "make test; make install"
|
given at the top of Makefile. In short "make test; make install"
|
||||||
should work for most machines. For MSDOS, use one of the special
|
should work for most machines. For Unix: "configure; make test; make install"
|
||||||
makefiles such as Makefile.msc; for VMS, use Make_vms.com or descrip.mms.
|
For MSDOS, use one of the special makefiles such as Makefile.msc.
|
||||||
|
For VMS, use Make_vms.com or descrip.mms.
|
||||||
|
|
||||||
Questions about zlib should be sent to <zlib@quest.jpl.nasa.gov> or,
|
Questions about zlib should be sent to <zlib@quest.jpl.nasa.gov>, or to
|
||||||
if this fails, to the addresses given below in the Copyright section.
|
Gilles Vollant <info@winimage.com> for the Windows DLL version.
|
||||||
The zlib home page is http://quest.jpl.nasa.gov/zlib/
|
The zlib home page is http://www.cdrom.com/pub/infozip/zlib/
|
||||||
|
The official zlib ftp site is ftp://ftp.cdrom.com/pub/infozip/zlib/
|
||||||
|
Before reporting a problem, please check those sites to verify that
|
||||||
|
you have the latest version of zlib; otherwise get the latest version and
|
||||||
|
check whether the problem still exists or not.
|
||||||
|
|
||||||
The changes made in version 1.0.4 are documented in the file ChangeLog.
|
Mark Nelson <markn@tiny.com> wrote an article about zlib for the Jan. 1997
|
||||||
The main changes since 1.0.3 are:
|
issue of Dr. Dobb's Journal; a copy of the article is available in
|
||||||
|
http://web2.airmail.net/markn/articles/zlibtool/zlibtool.htm
|
||||||
|
|
||||||
- In very rare conditions, deflate(s, Z_FINISH) could fail to produce an EOF
|
The changes made in version 1.1.3 are documented in the file ChangeLog.
|
||||||
bit, so the decompressor could decompress all the correct data but went
|
The main changes since 1.1.2 are:
|
||||||
on to attempt decompressing extra garbage data. This affected minigzip too.
|
|
||||||
- zlibVersion and gzerror return const char* (needed for DLL)
|
|
||||||
- port to RISCOS (no fdopen, no multiple dots, no unlink, no fileno)
|
|
||||||
|
|
||||||
|
- fix "an inflate input buffer bug that shows up on rare but persistent
|
||||||
|
occasions" (Mark)
|
||||||
|
- fix gzread and gztell for concatenated .gz files (Didier Le Botlan)
|
||||||
|
- fix gzseek(..., SEEK_SET) in write mode
|
||||||
|
- fix crc check after a gzeek (Frank Faubert)
|
||||||
|
- fix miniunzip when the last entry in a zip file is itself a zip file
|
||||||
|
(J Lillge)
|
||||||
|
- add contrib/asm586 and contrib/asm686 (Brian Raiter)
|
||||||
|
See http://www.muppetlabs.com/~breadbox/software/assembly.html
|
||||||
|
- add support for Delphi 3 in contrib/delphi (Bob Dellaca)
|
||||||
|
- add support for C++Builder 3 and Delphi 3 in contrib/delphi2 (Davide Moretti)
|
||||||
|
- do not exit prematurely in untgz if 0 at start of block (Magnus Holmgren)
|
||||||
|
- use macro EXTERN instead of extern to support DLL for BeOS (Sander Stoks)
|
||||||
|
- added a FAQ file
|
||||||
|
|
||||||
|
plus many changes for portability.
|
||||||
|
|
||||||
|
Unsupported third party contributions are provided in directory "contrib".
|
||||||
|
|
||||||
|
A Java implementation of zlib is available in the Java Development Kit 1.1
|
||||||
|
http://www.javasoft.com/products/JDK/1.1/docs/api/Package-java.util.zip.html
|
||||||
|
See the zlib home page http://www.cdrom.com/pub/infozip/zlib/ for details.
|
||||||
|
|
||||||
A Perl interface to zlib written by Paul Marquess <pmarquess@bfsec.bt.co.uk>
|
A Perl interface to zlib written by Paul Marquess <pmarquess@bfsec.bt.co.uk>
|
||||||
is in the CPAN (Comprehensive Perl Archive Network) sites, such as:
|
is in the CPAN (Comprehensive Perl Archive Network) sites, such as:
|
||||||
ftp://ftp.cis.ufl.edu/pub/perl/CPAN/modules/by-module/Compress/Compress-Zlib*
|
ftp://ftp.cis.ufl.edu/pub/perl/CPAN/modules/by-module/Compress/Compress-Zlib*
|
||||||
|
|
||||||
|
A Python interface to zlib written by A.M. Kuchling <amk@magnet.com>
|
||||||
|
is available in Python 1.5 and later versions, see
|
||||||
|
http://www.python.org/doc/lib/module-zlib.html
|
||||||
|
|
||||||
|
A zlib binding for TCL written by Andreas Kupries <a.kupries@westend.com>
|
||||||
|
is availlable at http://www.westend.com/~kupries/doc/trf/man/man.html
|
||||||
|
|
||||||
|
An experimental package to read and write files in .zip format,
|
||||||
|
written on top of zlib by Gilles Vollant <info@winimage.com>, is
|
||||||
|
available at http://www.winimage.com/zLibDll/unzip.html
|
||||||
|
and also in the contrib/minizip directory of zlib.
|
||||||
|
|
||||||
|
|
||||||
Notes for some targets:
|
Notes for some targets:
|
||||||
|
|
||||||
- For Turbo C the small model is supported only with reduced performance to
|
- To build a Windows DLL version, include in a DLL project zlib.def, zlib.rc
|
||||||
avoid any far allocation; it was tested with -DMAX_WBITS=11 -DMAX_MEM_LEVEL=3
|
and all .c files except example.c and minigzip.c; compile with -DZLIB_DLL
|
||||||
|
The zlib DLL support was initially done by Alessandro Iacopetti and is
|
||||||
|
now maintained by Gilles Vollant <info@winimage.com>. Check the zlib DLL
|
||||||
|
home page at http://www.winimage.com/zLibDll
|
||||||
|
|
||||||
- For 64-bit Iris, deflate.c must be compiled without any optimization.
|
From Visual Basic, you can call the DLL functions which do not take
|
||||||
|
a structure as argument: compress, uncompress and all gz* functions.
|
||||||
|
See contrib/visual-basic.txt for more information, or get
|
||||||
|
http://www.tcfb.com/dowseware/cmp-z-it.zip
|
||||||
|
|
||||||
|
- For 64-bit Irix, deflate.c must be compiled without any optimization.
|
||||||
With -O, one libpng test fails. The test works in 32 bit mode (with
|
With -O, one libpng test fails. The test works in 32 bit mode (with
|
||||||
the -32 compiler flag). The compiler bug has been reported to SGI.
|
the -n32 compiler flag). The compiler bug has been reported to SGI.
|
||||||
|
|
||||||
- zlib doesn't work with gcc 2.6.3 on a DEC 3000/300LX under OSF/1 2.1
|
- zlib doesn't work with gcc 2.6.3 on a DEC 3000/300LX under OSF/1 2.1
|
||||||
it works when compiled with cc.
|
it works when compiled with cc.
|
||||||
|
|
||||||
- zlib doesn't work on HP-UX 9.05 with one cc compiler (the one not
|
- on Digital Unix 4.0D (formely OSF/1) on AlphaServer, the cc option -std1
|
||||||
accepting the -O option). It works with the other cc compiler.
|
is necessary to get gzprintf working correctly. This is done by configure.
|
||||||
|
|
||||||
- To build a Windows DLL version, include in a DLL project zlib.def, zlib.rc
|
- zlib doesn't work on HP-UX 9.05 with some versions of /bin/cc. It works
|
||||||
and all .c files except example.c and minigzip.c; compile with -DZLIB_DLL
|
with other compilers. Use "make test" to check your compiler.
|
||||||
For help on building a zlib DLL, contact Alessandro Iacopetti
|
|
||||||
<iaco@email.alessandria.alpcom.it> http://lisa.unial.it/iaco ,
|
|
||||||
or contact Brad Clarke <bclarke@cyberus.ca>.
|
|
||||||
|
|
||||||
- gzdopen is not supported on RISCOS
|
- gzdopen is not supported on RISCOS, BEOS and by some Mac compilers.
|
||||||
|
|
||||||
|
- For Turbo C the small model is supported only with reduced performance to
|
||||||
|
avoid any far allocation; it was tested with -DMAX_WBITS=11 -DMAX_MEM_LEVEL=3
|
||||||
|
|
||||||
|
- For PalmOs, see http://www.cs.uit.no/~perm/PASTA/pilot/software.html
|
||||||
|
Per Harald Myrvang <perm@stud.cs.uit.no>
|
||||||
|
|
||||||
|
|
||||||
Acknowledgments:
|
Acknowledgments:
|
||||||
|
|
||||||
The deflate format used by zlib was defined by Phil Katz. The deflate
|
The deflate format used by zlib was defined by Phil Katz. The deflate
|
||||||
and zlib specifications were written by Peter Deutsch. Thanks to all the
|
and zlib specifications were written by L. Peter Deutsch. Thanks to all the
|
||||||
people who reported problems and suggested various improvements in zlib;
|
people who reported problems and suggested various improvements in zlib;
|
||||||
they are too numerous to cite here.
|
they are too numerous to cite here.
|
||||||
|
|
||||||
Copyright notice:
|
Copyright notice:
|
||||||
|
|
||||||
(C) 1995-1996 Jean-loup Gailly and Mark Adler
|
(C) 1995-1998 Jean-loup Gailly and Mark Adler
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied
|
This software is provided 'as-is', without any express or implied
|
||||||
warranty. In no event will the authors be held liable for any damages
|
warranty. In no event will the authors be held liable for any damages
|
||||||
@@ -87,7 +136,7 @@ Copyright notice:
|
|||||||
3. This notice may not be removed or altered from any source distribution.
|
3. This notice may not be removed or altered from any source distribution.
|
||||||
|
|
||||||
Jean-loup Gailly Mark Adler
|
Jean-loup Gailly Mark Adler
|
||||||
gzip@prep.ai.mit.edu madler@alumni.caltech.edu
|
jloup@gzip.org madler@alumni.caltech.edu
|
||||||
|
|
||||||
If you use the zlib library in a product, we would appreciate *not*
|
If you use the zlib library in a product, we would appreciate *not*
|
||||||
receiving lengthy legal documents to sign. The sources are provided
|
receiving lengthy legal documents to sign. The sources are provided
|
||||||
|
|||||||
@@ -1,9 +1,9 @@
|
|||||||
/* adler32.c -- compute the Adler-32 checksum of a data stream
|
/* adler32.c -- compute the Adler-32 checksum of a data stream
|
||||||
* Copyright (C) 1995-1996 Mark Adler
|
* Copyright (C) 1995-1998 Mark Adler
|
||||||
* For conditions of distribution and use, see copyright notice in zlib.h
|
* For conditions of distribution and use, see copyright notice in zlib.h
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* $Id: adler32.c,v 1.10 1996/05/22 11:52:18 me Exp $ */
|
/* @(#) $Id$ */
|
||||||
|
|
||||||
#include "zlib.h"
|
#include "zlib.h"
|
||||||
|
|
||||||
@@ -18,7 +18,7 @@
|
|||||||
#define DO16(buf) DO8(buf,0); DO8(buf,8);
|
#define DO16(buf) DO8(buf,0); DO8(buf,8);
|
||||||
|
|
||||||
/* ========================================================================= */
|
/* ========================================================================= */
|
||||||
uLong adler32(adler, buf, len)
|
uLong ZEXPORT adler32(adler, buf, len)
|
||||||
uLong adler;
|
uLong adler;
|
||||||
const Bytef *buf;
|
const Bytef *buf;
|
||||||
uInt len;
|
uInt len;
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
1. Compression algorithm (deflate)
|
1. Compression algorithm (deflate)
|
||||||
|
|
||||||
The deflation algorithm used by zlib (also zip and gzip) is a variation of
|
The deflation algorithm used by gzip (also zip and zlib) is a variation of
|
||||||
LZ77 (Lempel-Ziv 1977, see reference below). It finds duplicated strings in
|
LZ77 (Lempel-Ziv 1977, see reference below). It finds duplicated strings in
|
||||||
the input data. The second occurrence of a string is replaced by a
|
the input data. The second occurrence of a string is replaced by a
|
||||||
pointer to the previous string, in the form of a pair (distance,
|
pointer to the previous string, in the form of a pair (distance,
|
||||||
@@ -35,12 +35,12 @@ parameter of deflateInit). So deflate() does not always find the longest
|
|||||||
possible match but generally finds a match which is long enough.
|
possible match but generally finds a match which is long enough.
|
||||||
|
|
||||||
deflate() also defers the selection of matches with a lazy evaluation
|
deflate() also defers the selection of matches with a lazy evaluation
|
||||||
mechanism. After a match of length N has been found, deflate() searches for a
|
mechanism. After a match of length N has been found, deflate() searches for
|
||||||
longer match at the next input byte. If a longer match is found, the
|
a longer match at the next input byte. If a longer match is found, the
|
||||||
previous match is truncated to a length of one (thus producing a single
|
previous match is truncated to a length of one (thus producing a single
|
||||||
literal byte) and the longer match is emitted afterwards. Otherwise,
|
literal byte) and the process of lazy evaluation begins again. Otherwise,
|
||||||
the original match is kept, and the next match search is attempted only
|
the original match is kept, and the next match search is attempted only N
|
||||||
N steps later.
|
steps later.
|
||||||
|
|
||||||
The lazy match evaluation is also subject to a runtime parameter. If
|
The lazy match evaluation is also subject to a runtime parameter. If
|
||||||
the current match is long enough, deflate() reduces the search for a longer
|
the current match is long enough, deflate() reduces the search for a longer
|
||||||
@@ -57,6 +57,8 @@ but saves time since there are both fewer insertions and fewer searches.
|
|||||||
|
|
||||||
2. Decompression algorithm (inflate)
|
2. Decompression algorithm (inflate)
|
||||||
|
|
||||||
|
2.1 Introduction
|
||||||
|
|
||||||
The real question is, given a Huffman tree, how to decode fast. The most
|
The real question is, given a Huffman tree, how to decode fast. The most
|
||||||
important realization is that shorter codes are much more common than
|
important realization is that shorter codes are much more common than
|
||||||
longer codes, so pay attention to decoding the short codes fast, and let
|
longer codes, so pay attention to decoding the short codes fast, and let
|
||||||
@@ -91,8 +93,114 @@ interesting to see if optimizing the first level table for other
|
|||||||
applications gave values within a bit or two of the flat code size.
|
applications gave values within a bit or two of the flat code size.
|
||||||
|
|
||||||
|
|
||||||
|
2.2 More details on the inflate table lookup
|
||||||
|
|
||||||
|
Ok, you want to know what this cleverly obfuscated inflate tree actually
|
||||||
|
looks like. You are correct that it's not a Huffman tree. It is simply a
|
||||||
|
lookup table for the first, let's say, nine bits of a Huffman symbol. The
|
||||||
|
symbol could be as short as one bit or as long as 15 bits. If a particular
|
||||||
|
symbol is shorter than nine bits, then that symbol's translation is duplicated
|
||||||
|
in all those entries that start with that symbol's bits. For example, if the
|
||||||
|
symbol is four bits, then it's duplicated 32 times in a nine-bit table. If a
|
||||||
|
symbol is nine bits long, it appears in the table once.
|
||||||
|
|
||||||
|
If the symbol is longer than nine bits, then that entry in the table points
|
||||||
|
to another similar table for the remaining bits. Again, there are duplicated
|
||||||
|
entries as needed. The idea is that most of the time the symbol will be short
|
||||||
|
and there will only be one table look up. (That's whole idea behind data
|
||||||
|
compression in the first place.) For the less frequent long symbols, there
|
||||||
|
will be two lookups. If you had a compression method with really long
|
||||||
|
symbols, you could have as many levels of lookups as is efficient. For
|
||||||
|
inflate, two is enough.
|
||||||
|
|
||||||
|
So a table entry either points to another table (in which case nine bits in
|
||||||
|
the above example are gobbled), or it contains the translation for the symbol
|
||||||
|
and the number of bits to gobble. Then you start again with the next
|
||||||
|
ungobbled bit.
|
||||||
|
|
||||||
|
You may wonder: why not just have one lookup table for how ever many bits the
|
||||||
|
longest symbol is? The reason is that if you do that, you end up spending
|
||||||
|
more time filling in duplicate symbol entries than you do actually decoding.
|
||||||
|
At least for deflate's output that generates new trees every several 10's of
|
||||||
|
kbytes. You can imagine that filling in a 2^15 entry table for a 15-bit code
|
||||||
|
would take too long if you're only decoding several thousand symbols. At the
|
||||||
|
other extreme, you could make a new table for every bit in the code. In fact,
|
||||||
|
that's essentially a Huffman tree. But then you spend two much time
|
||||||
|
traversing the tree while decoding, even for short symbols.
|
||||||
|
|
||||||
|
So the number of bits for the first lookup table is a trade of the time to
|
||||||
|
fill out the table vs. the time spent looking at the second level and above of
|
||||||
|
the table.
|
||||||
|
|
||||||
|
Here is an example, scaled down:
|
||||||
|
|
||||||
|
The code being decoded, with 10 symbols, from 1 to 6 bits long:
|
||||||
|
|
||||||
|
A: 0
|
||||||
|
B: 10
|
||||||
|
C: 1100
|
||||||
|
D: 11010
|
||||||
|
E: 11011
|
||||||
|
F: 11100
|
||||||
|
G: 11101
|
||||||
|
H: 11110
|
||||||
|
I: 111110
|
||||||
|
J: 111111
|
||||||
|
|
||||||
|
Let's make the first table three bits long (eight entries):
|
||||||
|
|
||||||
|
000: A,1
|
||||||
|
001: A,1
|
||||||
|
010: A,1
|
||||||
|
011: A,1
|
||||||
|
100: B,2
|
||||||
|
101: B,2
|
||||||
|
110: -> table X (gobble 3 bits)
|
||||||
|
111: -> table Y (gobble 3 bits)
|
||||||
|
|
||||||
|
Each entry is what the bits decode to and how many bits that is, i.e. how
|
||||||
|
many bits to gobble. Or the entry points to another table, with the number of
|
||||||
|
bits to gobble implicit in the size of the table.
|
||||||
|
|
||||||
|
Table X is two bits long since the longest code starting with 110 is five bits
|
||||||
|
long:
|
||||||
|
|
||||||
|
00: C,1
|
||||||
|
01: C,1
|
||||||
|
10: D,2
|
||||||
|
11: E,2
|
||||||
|
|
||||||
|
Table Y is three bits long since the longest code starting with 111 is six
|
||||||
|
bits long:
|
||||||
|
|
||||||
|
000: F,2
|
||||||
|
001: F,2
|
||||||
|
010: G,2
|
||||||
|
011: G,2
|
||||||
|
100: H,2
|
||||||
|
101: H,2
|
||||||
|
110: I,3
|
||||||
|
111: J,3
|
||||||
|
|
||||||
|
So what we have here are three tables with a total of 20 entries that had to
|
||||||
|
be constructed. That's compared to 64 entries for a single table. Or
|
||||||
|
compared to 16 entries for a Huffman tree (six two entry tables and one four
|
||||||
|
entry table). Assuming that the code ideally represents the probability of
|
||||||
|
the symbols, it takes on the average 1.25 lookups per symbol. That's compared
|
||||||
|
to one lookup for the single table, or 1.66 lookups per symbol for the
|
||||||
|
Huffman tree.
|
||||||
|
|
||||||
|
There, I think that gives you a picture of what's going on. For inflate, the
|
||||||
|
meaning of a particular symbol is often more than just a letter. It can be a
|
||||||
|
byte (a "literal"), or it can be either a length or a distance which
|
||||||
|
indicates a base value and a number of bits to fetch after the code that is
|
||||||
|
added to the base value. Or it might be the special end-of-block code. The
|
||||||
|
data structures created in inftrees.c try to encode all that information
|
||||||
|
compactly in the tables.
|
||||||
|
|
||||||
|
|
||||||
Jean-loup Gailly Mark Adler
|
Jean-loup Gailly Mark Adler
|
||||||
gzip@prep.ai.mit.edu madler@alumni.caltech.edu
|
jloup@gzip.org madler@alumni.caltech.edu
|
||||||
|
|
||||||
|
|
||||||
References:
|
References:
|
||||||
66
amiga/Makefile.pup
Normal file
66
amiga/Makefile.pup
Normal file
@@ -0,0 +1,66 @@
|
|||||||
|
# Amiga powerUP (TM) Makefile
|
||||||
|
# makefile for libpng and SAS C V6.58/7.00 PPC compiler
|
||||||
|
# Copyright (C) 1998 by Andreas R. Kleinert
|
||||||
|
|
||||||
|
CC = scppc
|
||||||
|
CFLAGS = NOSTKCHK NOSINT OPTIMIZE OPTGO OPTPEEP OPTINLOCAL OPTINL \
|
||||||
|
OPTLOOP OPTRDEP=8 OPTDEP=8 OPTCOMP=8
|
||||||
|
LIBNAME = libzip.a
|
||||||
|
AR = ppc-amigaos-ar
|
||||||
|
AR_FLAGS = cr
|
||||||
|
RANLIB = ppc-amigaos-ranlib
|
||||||
|
LDFLAGS = -r -o
|
||||||
|
LDLIBS = LIB:scppc.a
|
||||||
|
LN = ppc-amigaos-ld
|
||||||
|
RM = delete quiet
|
||||||
|
|
||||||
|
OBJS = adler32.o compress.o crc32.o gzio.o uncompr.o deflate.o trees.o \
|
||||||
|
zutil.o inflate.o infblock.o inftrees.o infcodes.o infutil.o inffast.o
|
||||||
|
|
||||||
|
TEST_OBJS = example.o minigzip.o
|
||||||
|
|
||||||
|
all: example minigzip
|
||||||
|
|
||||||
|
test: all
|
||||||
|
example
|
||||||
|
echo hello world | minigzip | minigzip -d
|
||||||
|
|
||||||
|
$(LIBNAME): $(OBJS)
|
||||||
|
$(AR) $(AR_FLAGS) $@ $(OBJS)
|
||||||
|
$(RANLIB) $@
|
||||||
|
|
||||||
|
example: example.o $(LIBNAME)
|
||||||
|
$(LN) $(LDFLAGS) example LIB:c_ppc.o example.o $(LIBNAME) $(LDLIBS) LIB:end.o
|
||||||
|
|
||||||
|
minigzip: minigzip.o $(LIBNAME)
|
||||||
|
$(LN) $(LDFLAGS) minigzip LIB:c_ppc.o minigzip.o $(LIBNAME) $(LDLIBS) LIB:end.o
|
||||||
|
|
||||||
|
clean:
|
||||||
|
$(RM) *.o example minigzip $(LIBNAME) foo.gz
|
||||||
|
|
||||||
|
zip:
|
||||||
|
zip -ul9 zlib README ChangeLog Makefile Make????.??? Makefile.?? \
|
||||||
|
descrip.mms *.[ch]
|
||||||
|
|
||||||
|
tgz:
|
||||||
|
cd ..; tar cfz zlib/zlib.tgz zlib/README zlib/ChangeLog zlib/Makefile \
|
||||||
|
zlib/Make????.??? zlib/Makefile.?? zlib/descrip.mms zlib/*.[ch]
|
||||||
|
|
||||||
|
# DO NOT DELETE THIS LINE -- make depend depends on it.
|
||||||
|
|
||||||
|
adler32.o: zutil.h zlib.h zconf.h
|
||||||
|
compress.o: zlib.h zconf.h
|
||||||
|
crc32.o: zutil.h zlib.h zconf.h
|
||||||
|
deflate.o: deflate.h zutil.h zlib.h zconf.h
|
||||||
|
example.o: zlib.h zconf.h
|
||||||
|
gzio.o: zutil.h zlib.h zconf.h
|
||||||
|
infblock.o: zutil.h zlib.h zconf.h infblock.h inftrees.h infcodes.h infutil.h
|
||||||
|
infcodes.o: zutil.h zlib.h zconf.h inftrees.h infutil.h infcodes.h inffast.h
|
||||||
|
inffast.o: zutil.h zlib.h zconf.h inftrees.h infutil.h inffast.h
|
||||||
|
inflate.o: zutil.h zlib.h zconf.h infblock.h
|
||||||
|
inftrees.o: zutil.h zlib.h zconf.h inftrees.h
|
||||||
|
infutil.o: zutil.h zlib.h zconf.h inftrees.h infutil.h
|
||||||
|
minigzip.o: zlib.h zconf.h
|
||||||
|
trees.o: deflate.h zutil.h zlib.h zconf.h
|
||||||
|
uncompr.o: zlib.h zconf.h
|
||||||
|
zutil.o: zutil.h zlib.h zconf.h
|
||||||
39
compress.c
39
compress.c
@@ -1,29 +1,29 @@
|
|||||||
/* compress.c -- compress a memory buffer
|
/* compress.c -- compress a memory buffer
|
||||||
* Copyright (C) 1995-1996 Jean-loup Gailly.
|
* Copyright (C) 1995-1998 Jean-loup Gailly.
|
||||||
* For conditions of distribution and use, see copyright notice in zlib.h
|
* For conditions of distribution and use, see copyright notice in zlib.h
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* $Id: compress.c,v 1.10 1996/05/23 16:51:12 me Exp $ */
|
/* @(#) $Id$ */
|
||||||
|
|
||||||
#include "zlib.h"
|
#include "zlib.h"
|
||||||
|
|
||||||
/* ===========================================================================
|
/* ===========================================================================
|
||||||
Compresses the source buffer into the destination buffer. sourceLen is
|
Compresses the source buffer into the destination buffer. The level
|
||||||
the byte length of the source buffer. Upon entry, destLen is the total
|
parameter has the same meaning as in deflateInit. sourceLen is the byte
|
||||||
size of the destination buffer, which must be at least 0.1% larger than
|
length of the source buffer. Upon entry, destLen is the total size of the
|
||||||
sourceLen plus 8 bytes. Upon exit, destLen is the actual size of the
|
destination buffer, which must be at least 0.1% larger than sourceLen plus
|
||||||
compressed buffer.
|
12 bytes. Upon exit, destLen is the actual size of the compressed buffer.
|
||||||
This function can be used to compress a whole file at once if the
|
|
||||||
input file is mmap'ed.
|
compress2 returns Z_OK if success, Z_MEM_ERROR if there was not enough
|
||||||
compress returns Z_OK if success, Z_MEM_ERROR if there was not
|
memory, Z_BUF_ERROR if there was not enough room in the output buffer,
|
||||||
enough memory, Z_BUF_ERROR if there was not enough room in the output
|
Z_STREAM_ERROR if the level parameter is invalid.
|
||||||
buffer.
|
|
||||||
*/
|
*/
|
||||||
int compress (dest, destLen, source, sourceLen)
|
int ZEXPORT compress2 (dest, destLen, source, sourceLen, level)
|
||||||
Bytef *dest;
|
Bytef *dest;
|
||||||
uLongf *destLen;
|
uLongf *destLen;
|
||||||
const Bytef *source;
|
const Bytef *source;
|
||||||
uLong sourceLen;
|
uLong sourceLen;
|
||||||
|
int level;
|
||||||
{
|
{
|
||||||
z_stream stream;
|
z_stream stream;
|
||||||
int err;
|
int err;
|
||||||
@@ -42,7 +42,7 @@ int compress (dest, destLen, source, sourceLen)
|
|||||||
stream.zfree = (free_func)0;
|
stream.zfree = (free_func)0;
|
||||||
stream.opaque = (voidpf)0;
|
stream.opaque = (voidpf)0;
|
||||||
|
|
||||||
err = deflateInit(&stream, Z_DEFAULT_COMPRESSION);
|
err = deflateInit(&stream, level);
|
||||||
if (err != Z_OK) return err;
|
if (err != Z_OK) return err;
|
||||||
|
|
||||||
err = deflate(&stream, Z_FINISH);
|
err = deflate(&stream, Z_FINISH);
|
||||||
@@ -55,3 +55,14 @@ int compress (dest, destLen, source, sourceLen)
|
|||||||
err = deflateEnd(&stream);
|
err = deflateEnd(&stream);
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* ===========================================================================
|
||||||
|
*/
|
||||||
|
int ZEXPORT compress (dest, destLen, source, sourceLen)
|
||||||
|
Bytef *dest;
|
||||||
|
uLongf *destLen;
|
||||||
|
const Bytef *source;
|
||||||
|
uLong sourceLen;
|
||||||
|
{
|
||||||
|
return compress2(dest, destLen, source, sourceLen, Z_DEFAULT_COMPRESSION);
|
||||||
|
}
|
||||||
|
|||||||
196
configure
vendored
196
configure
vendored
@@ -4,42 +4,96 @@
|
|||||||
# of if you need special compiler, flags or install directory.
|
# of if you need special compiler, flags or install directory.
|
||||||
# Otherwise, you can just use directly "make test; make install"
|
# Otherwise, you can just use directly "make test; make install"
|
||||||
#
|
#
|
||||||
|
# To create a shared library, use "configure --shared"; by default a static
|
||||||
|
# library is created. If the primitive shared library support provided here
|
||||||
|
# does not work, use ftp://prep.ai.mit.edu/pub/gnu/libtool-*.tar.gz
|
||||||
|
#
|
||||||
# To impose specific compiler or flags or install directory, use for example:
|
# To impose specific compiler or flags or install directory, use for example:
|
||||||
# prefix=$HOME CC=cc CFLAGS="-O4" ./configure
|
# prefix=$HOME CC=cc CFLAGS="-O4" ./configure
|
||||||
# or for csh/tcsh users:
|
# or for csh/tcsh users:
|
||||||
# (setenv prefix $HOME; setenv CC cc; setenv CFLAGS "-O4"; ./configure)
|
# (setenv prefix $HOME; setenv CC cc; setenv CFLAGS "-O4"; ./configure)
|
||||||
# LDSHARED is the command to be used to create a shared library
|
# LDSHARED is the command to be used to create a shared library
|
||||||
|
|
||||||
|
# Incorrect settings of CC or CFLAGS may prevent creating a shared library.
|
||||||
|
# If you have problems, try without defining CC and CFLAGS before reporting
|
||||||
|
# an error.
|
||||||
|
|
||||||
LIBS=libz.a
|
LIBS=libz.a
|
||||||
|
SHAREDLIB=libz.so
|
||||||
VER=`sed -n -e '/VERSION "/s/.*"\(.*\)".*/\1/p' < zlib.h`
|
VER=`sed -n -e '/VERSION "/s/.*"\(.*\)".*/\1/p' < zlib.h`
|
||||||
AR=${AR-"ar rc"}
|
AR=${AR-"ar rc"}
|
||||||
RANLIB=${RANLIB-"ranlib"}
|
RANLIB=${RANLIB-"ranlib"}
|
||||||
prefix=${prefix-/usr/local}
|
prefix=${prefix-/usr/local}
|
||||||
exec_prefix=${exec_prefix-$prefix}
|
exec_prefix=${exec_prefix-'${prefix}'}
|
||||||
|
libdir=${libdir-'${exec_prefix}/lib'}
|
||||||
|
includedir=${includedir-'${prefix}/include'}
|
||||||
|
shared_ext='.so'
|
||||||
|
shared=0
|
||||||
|
gcc=0
|
||||||
|
old_cc="$CC"
|
||||||
|
old_cflags="$CFLAGS"
|
||||||
|
|
||||||
|
while test $# -ge 1
|
||||||
|
do
|
||||||
|
case "$1" in
|
||||||
|
-h* | --h*)
|
||||||
|
echo 'usage:'
|
||||||
|
echo ' configure [--shared] [--prefix=PREFIX] [--exec_prefix=EXPREFIX]'
|
||||||
|
echo ' [--libdir=LIBDIR] [--includedir=INCLUDEDIR]'
|
||||||
|
exit 0;;
|
||||||
|
-p*=* | --p*=*) prefix=`echo $1 | sed 's/[-a-z_]*=//'`; shift;;
|
||||||
|
-e*=* | --e*=*) exec_prefix=`echo $1 | sed 's/[-a-z_]*=//'`; shift;;
|
||||||
|
-l*=* | --libdir=*) libdir=`echo $1 | sed 's/[-a-z_]*=//'`; shift;;
|
||||||
|
-i*=* | --includedir=*) includedir=`echo $1 | sed 's/[-a-z_]*=//'`;shift;;
|
||||||
|
-p* | --p*) prefix="$2"; shift; shift;;
|
||||||
|
-e* | --e*) exec_prefix="$2"; shift; shift;;
|
||||||
|
-l* | --l*) libdir="$2"; shift; shift;;
|
||||||
|
-i* | --i*) includedir="$2"; shift; shift;;
|
||||||
|
-s* | --s*) shared=1; shift;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
test -z "$CC" && echo Checking for gcc...
|
|
||||||
test=ztest$$
|
test=ztest$$
|
||||||
cat > $test.c <<EOF
|
cat > $test.c <<EOF
|
||||||
int hello() { printf("hello\n"); }
|
extern int getchar();
|
||||||
|
int hello() {return getchar();}
|
||||||
EOF
|
EOF
|
||||||
if test -z "$CC" && (gcc -c -O3 $test.c) 2>/dev/null; then
|
|
||||||
CC=gcc
|
test -z "$CC" && echo Checking for gcc...
|
||||||
|
cc=${CC-gcc}
|
||||||
|
cflags=${CFLAGS-"-O3"}
|
||||||
|
# to force the asm version use: CFLAGS="-O3 -DASMV" ./configure
|
||||||
|
case "$cc" in
|
||||||
|
*gcc*) gcc=1;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
if test "$gcc" -eq 1 && ($cc -c $cflags $test.c) 2>/dev/null; then
|
||||||
|
CC="$cc"
|
||||||
SFLAGS=${CFLAGS-"-fPIC -O3"}
|
SFLAGS=${CFLAGS-"-fPIC -O3"}
|
||||||
CFLAGS=${CFLAGS-"-O3"}
|
CFLAGS="$cflags"
|
||||||
LDSHARED=${LDSHARED-"gcc -shared"}
|
case `(uname -s || echo unknown) 2>/dev/null` in
|
||||||
|
Linux | linux) LDSHARED=${LDSHARED-"gcc -shared -Wl,-soname,libz.so.1"};;
|
||||||
|
*) LDSHARED=${LDSHARED-"gcc -shared"};;
|
||||||
|
esac
|
||||||
else
|
else
|
||||||
# find system name and corresponding cc options
|
# find system name and corresponding cc options
|
||||||
CC=${CC-cc}
|
CC=${CC-cc}
|
||||||
case `(uname -sr || echo unknown) 2>/dev/null` in
|
case `(uname -sr || echo unknown) 2>/dev/null` in
|
||||||
SunOS\ 5*) SFLAGS=${CFLAGS-"-fast -xcg89 -KPIC -R."}
|
HP-UX*) SFLAGS=${CFLAGS-"-O +z"}
|
||||||
CFLAGS=${CFLAGS-"-fast -xcg89"}
|
CFLAGS=${CFLAGS-"-O"}
|
||||||
LDSHARED=${LDSHARED-"cc -G"};;
|
# LDSHARED=${LDSHARED-"ld -b +vnocompatwarnings"}
|
||||||
SunOS\ 4*) SFLAGS=${CFLAGS-"-O2 -PIC"}
|
LDSHARED=${LDSHARED-"ld -b"}
|
||||||
CFLAGS=${CFLAGS-"-O2"}
|
shared_ext='.sl'
|
||||||
LDSHARED=${LDSHARED-"ld"};;
|
SHAREDLIB='libz.sl';;
|
||||||
IRIX*) SFLAGS=${CFLAGS-"-ansi -O2 -rpath ."}
|
IRIX*) SFLAGS=${CFLAGS-"-ansi -O2 -rpath ."}
|
||||||
CFLAGS=${CFLAGS-"-ansi -O2"}
|
CFLAGS=${CFLAGS-"-ansi -O2"}
|
||||||
LDSHARED=${LDSHARED-"cc -shared"};;
|
LDSHARED=${LDSHARED-"cc -shared"};;
|
||||||
|
OSF1\ V4*) SFLAGS=${CFLAGS-"-O -std1"}
|
||||||
|
CFLAGS=${CFLAGS-"-O -std1"}
|
||||||
|
LDSHARED=${LDSHARED-"cc -shared -Wl,-soname,$SHAREDLIB -Wl,-msym -Wl,-rpath,$(libdir) -Wl,-set_version,${VER}:1.0"};;
|
||||||
|
OSF1*) SFLAGS=${CFLAGS-"-O -std1"}
|
||||||
|
CFLAGS=${CFLAGS-"-O -std1"}
|
||||||
|
LDSHARED=${LDSHARED-"cc -shared"};;
|
||||||
QNX*) SFLAGS=${CFLAGS-"-4 -O"}
|
QNX*) SFLAGS=${CFLAGS-"-4 -O"}
|
||||||
CFLAGS=${CFLAGS-"-4 -O"}
|
CFLAGS=${CFLAGS-"-4 -O"}
|
||||||
LDSHARED=${LDSHARED-"cc"}
|
LDSHARED=${LDSHARED-"cc"}
|
||||||
@@ -48,39 +102,111 @@ else
|
|||||||
SCO_SV\ 3.2*) SFLAGS=${CFLAGS-"-O3 -dy -KPIC "}
|
SCO_SV\ 3.2*) SFLAGS=${CFLAGS-"-O3 -dy -KPIC "}
|
||||||
CFLAGS=${CFLAGS-"-O3"}
|
CFLAGS=${CFLAGS-"-O3"}
|
||||||
LDSHARED=${LDSHARED-"cc -dy -KPIC -G"};;
|
LDSHARED=${LDSHARED-"cc -dy -KPIC -G"};;
|
||||||
HP-UX*) SFLAGS=${CFLAGS-"-O +z"}
|
SunOS\ 5*) SFLAGS=${CFLAGS-"-fast -xcg89 -KPIC -R."}
|
||||||
|
CFLAGS=${CFLAGS-"-fast -xcg89"}
|
||||||
|
LDSHARED=${LDSHARED-"cc -G"};;
|
||||||
|
SunOS\ 4*) SFLAGS=${CFLAGS-"-O2 -PIC"}
|
||||||
|
CFLAGS=${CFLAGS-"-O2"}
|
||||||
|
LDSHARED=${LDSHARED-"ld"};;
|
||||||
|
UNIX_System_V\ 4.2.0)
|
||||||
|
SFLAGS=${CFLAGS-"-KPIC -O"}
|
||||||
CFLAGS=${CFLAGS-"-O"}
|
CFLAGS=${CFLAGS-"-O"}
|
||||||
LDSHARED=${LDSHARED-"ld -b"}
|
LDSHARED=${LDSHARED-"cc -G"};;
|
||||||
SHAREDLIBS='libz.sl';;
|
UNIX_SV\ 4.2MP)
|
||||||
# send working options for other systems to gzip@prep.ai.mit.edu
|
SFLAGS=${CFLAGS-"-Kconform_pic -O"}
|
||||||
|
CFLAGS=${CFLAGS-"-O"}
|
||||||
|
LDSHARED=${LDSHARED-"cc -G"};;
|
||||||
|
# send working options for other systems to support@gzip.org
|
||||||
*) SFLAGS=${CFLAGS-"-O"}
|
*) SFLAGS=${CFLAGS-"-O"}
|
||||||
CFLAGS=${CFLAGS-"-O"}
|
CFLAGS=${CFLAGS-"-O"}
|
||||||
LDSHARED=${LDSHARED-"cc -shared"};;
|
LDSHARED=${LDSHARED-"cc -shared"};;
|
||||||
esac
|
esac
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo Checking for shared library support...
|
if test $shared -eq 1; then
|
||||||
# we must test in two steps (cc then ld), required at least on SunOS 4.x
|
echo Checking for shared library support...
|
||||||
if test "`($CC -c $SFLAGS $test.c) 2>&1`" = "" &&
|
# we must test in two steps (cc then ld), required at least on SunOS 4.x
|
||||||
test "`($LDSHARED -o $test.so $test.o) 2>&1`" = ""; then
|
if test "`($CC -c $SFLAGS $test.c) 2>&1`" = "" &&
|
||||||
CFLAGS="$SFLAGS"
|
test "`($LDSHARED -o $test$shared_ext $test.o) 2>&1`" = ""; then
|
||||||
LIBS='libz.so.$(VER)'
|
CFLAGS="$SFLAGS"
|
||||||
echo Building shared library libz.so.$VER with $CC.
|
LIBS="$SHAREDLIB.$VER"
|
||||||
else
|
echo Building shared library $SHAREDLIB.$VER with $CC.
|
||||||
|
elif test -z "$old_cc" -a -z "$old_cflags"; then
|
||||||
|
echo No shared library suppport.
|
||||||
|
shared=0;
|
||||||
|
else
|
||||||
|
echo 'No shared library suppport; try without defining CC and CFLAGS'
|
||||||
|
shared=0;
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
if test $shared -eq 0; then
|
||||||
LDSHARED="$CC"
|
LDSHARED="$CC"
|
||||||
echo Building static library $LIBS version $VER with $CC.
|
echo Building static library $LIBS version $VER with $CC.
|
||||||
fi
|
fi
|
||||||
rm -f $test.[co] $test.so
|
|
||||||
|
cat > $test.c <<EOF
|
||||||
|
#include <unistd.h>
|
||||||
|
int main() { return 0; }
|
||||||
|
EOF
|
||||||
|
if test "`($CC -c $CFLAGS $test.c) 2>&1`" = ""; then
|
||||||
|
CFLAGS="$CFLAGS -DHAVE_UNISTD_H"
|
||||||
|
echo "Checking for unistd.h... Yes."
|
||||||
|
else
|
||||||
|
echo "Checking for unistd.h... No."
|
||||||
|
fi
|
||||||
|
|
||||||
|
cat > $test.c <<EOF
|
||||||
|
#include <errno.h>
|
||||||
|
int main() { return 0; }
|
||||||
|
EOF
|
||||||
|
if test "`($CC -c $CFLAGS $test.c) 2>&1`" = ""; then
|
||||||
|
echo "Checking for errno.h... Yes."
|
||||||
|
else
|
||||||
|
echo "Checking for errno.h... No."
|
||||||
|
CFLAGS="$CFLAGS -DNO_ERRNO_H"
|
||||||
|
fi
|
||||||
|
|
||||||
|
cat > $test.c <<EOF
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <sys/mman.h>
|
||||||
|
#include <sys/stat.h>
|
||||||
|
caddr_t hello() {
|
||||||
|
return mmap((caddr_t)0, (off_t)0, PROT_READ, MAP_SHARED, 0, (off_t)0);
|
||||||
|
}
|
||||||
|
EOF
|
||||||
|
if test "`($CC -c $CFLAGS $test.c) 2>&1`" = ""; then
|
||||||
|
CFLAGS="$CFLAGS -DUSE_MMAP"
|
||||||
|
echo Checking for mmap support... Yes.
|
||||||
|
else
|
||||||
|
echo Checking for mmap support... No.
|
||||||
|
fi
|
||||||
|
|
||||||
|
CPP=${CPP-"$CC -E"}
|
||||||
|
case $CFLAGS in
|
||||||
|
*ASMV*)
|
||||||
|
if test "`nm $test.o | grep _hello`" = ""; then
|
||||||
|
CPP="$CPP -DNO_UNDERLINE"
|
||||||
|
echo Checking for underline in external names... No.
|
||||||
|
else
|
||||||
|
echo Checking for underline in external names... Yes.
|
||||||
|
fi;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
rm -f $test.[co] $test$shared_ext
|
||||||
|
|
||||||
# udpate Makefile
|
# udpate Makefile
|
||||||
sed < Makefile.in "
|
sed < Makefile.in "
|
||||||
/^CC *=/s/=.*/=$CC/
|
/^CC *=/s%=.*%=$CC%
|
||||||
/^CFLAGS *=/s/=.*/=$CFLAGS/
|
/^CFLAGS *=/s%=.*%=$CFLAGS%
|
||||||
/^LDSHARED *=/s/=.*/=$LDSHARED/
|
/^CPP *=/s%=.*%=$CPP%
|
||||||
/^LIBS *=/s,=.*,=$LIBS,
|
/^LDSHARED *=/s%=.*%=$LDSHARED%
|
||||||
/^AR *=/s/=.*/=$AR/
|
/^LIBS *=/s%=.*%=$LIBS%
|
||||||
/^RANLIB *=/s,=.*,=$RANLIB,
|
/^SHAREDLIB *=/s%=.*%=$SHAREDLIB%
|
||||||
/^VER *=/s/=.*/=$VER/
|
/^AR *=/s%=.*%=$AR%
|
||||||
/^prefix *=/s,=.*,=$prefix,
|
/^RANLIB *=/s%=.*%=$RANLIB%
|
||||||
/^exec_prefix *=/s,=.*,=$exec_prefix,
|
/^VER *=/s%=.*%=$VER%
|
||||||
|
/^prefix *=/s%=.*%=$prefix%
|
||||||
|
/^exec_prefix *=/s%=.*%=$exec_prefix%
|
||||||
|
/^libdir *=/s%=.*%=$libdir%
|
||||||
|
/^includedir *=/s%=.*%=$includedir%
|
||||||
" > Makefile
|
" > Makefile
|
||||||
|
|||||||
34
contrib/README.contrib
Normal file
34
contrib/README.contrib
Normal file
@@ -0,0 +1,34 @@
|
|||||||
|
All files under this contrib directory are UNSUPPORTED. There were
|
||||||
|
provided by users of zlib and were not tested by the authors of zlib.
|
||||||
|
Use at your own risk. Please contact the authors of the contributions
|
||||||
|
for help about these, not the zlib authors. Thanks.
|
||||||
|
|
||||||
|
|
||||||
|
asm386/ by Gilles Vollant <info@winimage.com>
|
||||||
|
386 asm code replacing longest_match(), for Visual C++ 4.2 and ML 6.11c
|
||||||
|
|
||||||
|
asm586/ and asm686/ by Brian Raiter <breadbox@muppetlabs.com>
|
||||||
|
asm code for Pentium and Pentium Pro
|
||||||
|
See http://www.muppetlabs.com/~breadbox/software/assembly.html
|
||||||
|
|
||||||
|
delphi/ by Bob Dellaca <bobdl@xtra.co.nz>
|
||||||
|
Support for Delphi
|
||||||
|
|
||||||
|
delphi2/ by Davide Moretti <dave@rimini.com>
|
||||||
|
Another support for C++Builder and Delphi
|
||||||
|
|
||||||
|
minizip/ by Gilles Vollant <info@winimage.com>
|
||||||
|
Mini zip and unzip based on zlib
|
||||||
|
See http://www.winimage.com/zLibDll/unzip.html
|
||||||
|
|
||||||
|
iostream/ by Kevin Ruland <kevin@rodin.wustl.edu>
|
||||||
|
A C++ I/O streams interface to the zlib gz* functions
|
||||||
|
|
||||||
|
iostream2/ by Tyge L<>vset <Tyge.Lovset@cmr.no>
|
||||||
|
Another C++ I/O streams interface
|
||||||
|
|
||||||
|
untgz/ by "Pedro A. Aranda Guti\irrez" <paag@tid.es>
|
||||||
|
A very simple tar.gz file extractor using zlib
|
||||||
|
|
||||||
|
visual-basic.txt by Carlos Rios <c_rios@sonda.cl>
|
||||||
|
How to use compress(), uncompress() and the gz* functions from VB.
|
||||||
559
contrib/asm386/gvmat32.asm
Normal file
559
contrib/asm386/gvmat32.asm
Normal file
@@ -0,0 +1,559 @@
|
|||||||
|
;
|
||||||
|
; gvmat32.asm -- Asm portion of the optimized longest_match for 32 bits x86
|
||||||
|
; Copyright (C) 1995-1996 Jean-loup Gailly and Gilles Vollant.
|
||||||
|
; File written by Gilles Vollant, by modifiying the longest_match
|
||||||
|
; from Jean-loup Gailly in deflate.c
|
||||||
|
; It need wmask == 0x7fff
|
||||||
|
; (assembly code is faster with a fixed wmask)
|
||||||
|
;
|
||||||
|
; For Visual C++ 4.2 and ML 6.11c (version in directory \MASM611C of Win95 DDK)
|
||||||
|
; I compile with : "ml /coff /Zi /c gvmat32.asm"
|
||||||
|
;
|
||||||
|
|
||||||
|
;uInt longest_match_7fff(s, cur_match)
|
||||||
|
; deflate_state *s;
|
||||||
|
; IPos cur_match; /* current match */
|
||||||
|
|
||||||
|
NbStack equ 76
|
||||||
|
cur_match equ dword ptr[esp+NbStack-0]
|
||||||
|
str_s equ dword ptr[esp+NbStack-4]
|
||||||
|
; 5 dword on top (ret,ebp,esi,edi,ebx)
|
||||||
|
adrret equ dword ptr[esp+NbStack-8]
|
||||||
|
pushebp equ dword ptr[esp+NbStack-12]
|
||||||
|
pushedi equ dword ptr[esp+NbStack-16]
|
||||||
|
pushesi equ dword ptr[esp+NbStack-20]
|
||||||
|
pushebx equ dword ptr[esp+NbStack-24]
|
||||||
|
|
||||||
|
chain_length equ dword ptr [esp+NbStack-28]
|
||||||
|
limit equ dword ptr [esp+NbStack-32]
|
||||||
|
best_len equ dword ptr [esp+NbStack-36]
|
||||||
|
window equ dword ptr [esp+NbStack-40]
|
||||||
|
prev equ dword ptr [esp+NbStack-44]
|
||||||
|
scan_start equ word ptr [esp+NbStack-48]
|
||||||
|
wmask equ dword ptr [esp+NbStack-52]
|
||||||
|
match_start_ptr equ dword ptr [esp+NbStack-56]
|
||||||
|
nice_match equ dword ptr [esp+NbStack-60]
|
||||||
|
scan equ dword ptr [esp+NbStack-64]
|
||||||
|
|
||||||
|
windowlen equ dword ptr [esp+NbStack-68]
|
||||||
|
match_start equ dword ptr [esp+NbStack-72]
|
||||||
|
strend equ dword ptr [esp+NbStack-76]
|
||||||
|
NbStackAdd equ (NbStack-24)
|
||||||
|
|
||||||
|
.386p
|
||||||
|
|
||||||
|
name gvmatch
|
||||||
|
.MODEL FLAT
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
; all the +4 offsets are due to the addition of pending_buf_size (in zlib
|
||||||
|
; in the deflate_state structure since the asm code was first written
|
||||||
|
; (if you compile with zlib 1.0.4 or older, remove the +4).
|
||||||
|
; Note : these value are good with a 8 bytes boundary pack structure
|
||||||
|
dep_chain_length equ 70h+4
|
||||||
|
dep_window equ 2ch+4
|
||||||
|
dep_strstart equ 60h+4
|
||||||
|
dep_prev_length equ 6ch+4
|
||||||
|
dep_nice_match equ 84h+4
|
||||||
|
dep_w_size equ 20h+4
|
||||||
|
dep_prev equ 34h+4
|
||||||
|
dep_w_mask equ 28h+4
|
||||||
|
dep_good_match equ 80h+4
|
||||||
|
dep_match_start equ 64h+4
|
||||||
|
dep_lookahead equ 68h+4
|
||||||
|
|
||||||
|
|
||||||
|
_TEXT segment
|
||||||
|
|
||||||
|
IFDEF NOUNDERLINE
|
||||||
|
public longest_match_7fff
|
||||||
|
; public match_init
|
||||||
|
ELSE
|
||||||
|
public _longest_match_7fff
|
||||||
|
; public _match_init
|
||||||
|
ENDIF
|
||||||
|
|
||||||
|
MAX_MATCH equ 258
|
||||||
|
MIN_MATCH equ 3
|
||||||
|
MIN_LOOKAHEAD equ (MAX_MATCH+MIN_MATCH+1)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
IFDEF NOUNDERLINE
|
||||||
|
;match_init proc near
|
||||||
|
; ret
|
||||||
|
;match_init endp
|
||||||
|
ELSE
|
||||||
|
;_match_init proc near
|
||||||
|
; ret
|
||||||
|
;_match_init endp
|
||||||
|
ENDIF
|
||||||
|
|
||||||
|
|
||||||
|
IFDEF NOUNDERLINE
|
||||||
|
longest_match_7fff proc near
|
||||||
|
ELSE
|
||||||
|
_longest_match_7fff proc near
|
||||||
|
ENDIF
|
||||||
|
|
||||||
|
mov edx,[esp+4]
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
push ebp
|
||||||
|
push edi
|
||||||
|
push esi
|
||||||
|
push ebx
|
||||||
|
|
||||||
|
sub esp,NbStackAdd
|
||||||
|
|
||||||
|
; initialize or check the variables used in match.asm.
|
||||||
|
mov ebp,edx
|
||||||
|
|
||||||
|
; chain_length = s->max_chain_length
|
||||||
|
; if (prev_length>=good_match) chain_length >>= 2
|
||||||
|
mov edx,[ebp+dep_chain_length]
|
||||||
|
mov ebx,[ebp+dep_prev_length]
|
||||||
|
cmp [ebp+dep_good_match],ebx
|
||||||
|
ja noshr
|
||||||
|
shr edx,2
|
||||||
|
noshr:
|
||||||
|
; we increment chain_length because in the asm, the --chain_lenght is in the beginning of the loop
|
||||||
|
inc edx
|
||||||
|
mov edi,[ebp+dep_nice_match]
|
||||||
|
mov chain_length,edx
|
||||||
|
mov eax,[ebp+dep_lookahead]
|
||||||
|
cmp eax,edi
|
||||||
|
; if ((uInt)nice_match > s->lookahead) nice_match = s->lookahead;
|
||||||
|
jae nolookaheadnicematch
|
||||||
|
mov edi,eax
|
||||||
|
nolookaheadnicematch:
|
||||||
|
; best_len = s->prev_length
|
||||||
|
mov best_len,ebx
|
||||||
|
|
||||||
|
; window = s->window
|
||||||
|
mov esi,[ebp+dep_window]
|
||||||
|
mov ecx,[ebp+dep_strstart]
|
||||||
|
mov window,esi
|
||||||
|
|
||||||
|
mov nice_match,edi
|
||||||
|
; scan = window + strstart
|
||||||
|
add esi,ecx
|
||||||
|
mov scan,esi
|
||||||
|
; dx = *window
|
||||||
|
mov dx,word ptr [esi]
|
||||||
|
; bx = *(window+best_len-1)
|
||||||
|
mov bx,word ptr [esi+ebx-1]
|
||||||
|
add esi,MAX_MATCH-1
|
||||||
|
; scan_start = *scan
|
||||||
|
mov scan_start,dx
|
||||||
|
; strend = scan + MAX_MATCH-1
|
||||||
|
mov strend,esi
|
||||||
|
; bx = scan_end = *(window+best_len-1)
|
||||||
|
|
||||||
|
; IPos limit = s->strstart > (IPos)MAX_DIST(s) ?
|
||||||
|
; s->strstart - (IPos)MAX_DIST(s) : NIL;
|
||||||
|
|
||||||
|
mov esi,[ebp+dep_w_size]
|
||||||
|
sub esi,MIN_LOOKAHEAD
|
||||||
|
; here esi = MAX_DIST(s)
|
||||||
|
sub ecx,esi
|
||||||
|
ja nodist
|
||||||
|
xor ecx,ecx
|
||||||
|
nodist:
|
||||||
|
mov limit,ecx
|
||||||
|
|
||||||
|
; prev = s->prev
|
||||||
|
mov edx,[ebp+dep_prev]
|
||||||
|
mov prev,edx
|
||||||
|
|
||||||
|
;
|
||||||
|
mov edx,dword ptr [ebp+dep_match_start]
|
||||||
|
mov bp,scan_start
|
||||||
|
mov eax,cur_match
|
||||||
|
mov match_start,edx
|
||||||
|
|
||||||
|
mov edx,window
|
||||||
|
mov edi,edx
|
||||||
|
add edi,best_len
|
||||||
|
mov esi,prev
|
||||||
|
dec edi
|
||||||
|
; windowlen = window + best_len -1
|
||||||
|
mov windowlen,edi
|
||||||
|
|
||||||
|
jmp beginloop2
|
||||||
|
align 4
|
||||||
|
|
||||||
|
; here, in the loop
|
||||||
|
; eax = ax = cur_match
|
||||||
|
; ecx = limit
|
||||||
|
; bx = scan_end
|
||||||
|
; bp = scan_start
|
||||||
|
; edi = windowlen (window + best_len -1)
|
||||||
|
; esi = prev
|
||||||
|
|
||||||
|
|
||||||
|
;// here; chain_length <=16
|
||||||
|
normalbeg0add16:
|
||||||
|
add chain_length,16
|
||||||
|
jz exitloop
|
||||||
|
normalbeg0:
|
||||||
|
cmp word ptr[edi+eax],bx
|
||||||
|
je normalbeg2noroll
|
||||||
|
rcontlabnoroll:
|
||||||
|
; cur_match = prev[cur_match & wmask]
|
||||||
|
and eax,7fffh
|
||||||
|
mov ax,word ptr[esi+eax*2]
|
||||||
|
; if cur_match > limit, go to exitloop
|
||||||
|
cmp ecx,eax
|
||||||
|
jnb exitloop
|
||||||
|
; if --chain_length != 0, go to exitloop
|
||||||
|
dec chain_length
|
||||||
|
jnz normalbeg0
|
||||||
|
jmp exitloop
|
||||||
|
|
||||||
|
normalbeg2noroll:
|
||||||
|
; if (scan_start==*(cur_match+window)) goto normalbeg2
|
||||||
|
cmp bp,word ptr[edx+eax]
|
||||||
|
jne rcontlabnoroll
|
||||||
|
jmp normalbeg2
|
||||||
|
|
||||||
|
contloop3:
|
||||||
|
mov edi,windowlen
|
||||||
|
|
||||||
|
; cur_match = prev[cur_match & wmask]
|
||||||
|
and eax,7fffh
|
||||||
|
mov ax,word ptr[esi+eax*2]
|
||||||
|
; if cur_match > limit, go to exitloop
|
||||||
|
cmp ecx,eax
|
||||||
|
jnbexitloopshort1:
|
||||||
|
jnb exitloop
|
||||||
|
; if --chain_length != 0, go to exitloop
|
||||||
|
|
||||||
|
|
||||||
|
; begin the main loop
|
||||||
|
beginloop2:
|
||||||
|
sub chain_length,16+1
|
||||||
|
; if chain_length <=16, don't use the unrolled loop
|
||||||
|
jna normalbeg0add16
|
||||||
|
|
||||||
|
do16:
|
||||||
|
cmp word ptr[edi+eax],bx
|
||||||
|
je normalbeg2dc0
|
||||||
|
|
||||||
|
maccn MACRO lab
|
||||||
|
and eax,7fffh
|
||||||
|
mov ax,word ptr[esi+eax*2]
|
||||||
|
cmp ecx,eax
|
||||||
|
jnb exitloop
|
||||||
|
cmp word ptr[edi+eax],bx
|
||||||
|
je lab
|
||||||
|
ENDM
|
||||||
|
|
||||||
|
rcontloop0:
|
||||||
|
maccn normalbeg2dc1
|
||||||
|
|
||||||
|
rcontloop1:
|
||||||
|
maccn normalbeg2dc2
|
||||||
|
|
||||||
|
rcontloop2:
|
||||||
|
maccn normalbeg2dc3
|
||||||
|
|
||||||
|
rcontloop3:
|
||||||
|
maccn normalbeg2dc4
|
||||||
|
|
||||||
|
rcontloop4:
|
||||||
|
maccn normalbeg2dc5
|
||||||
|
|
||||||
|
rcontloop5:
|
||||||
|
maccn normalbeg2dc6
|
||||||
|
|
||||||
|
rcontloop6:
|
||||||
|
maccn normalbeg2dc7
|
||||||
|
|
||||||
|
rcontloop7:
|
||||||
|
maccn normalbeg2dc8
|
||||||
|
|
||||||
|
rcontloop8:
|
||||||
|
maccn normalbeg2dc9
|
||||||
|
|
||||||
|
rcontloop9:
|
||||||
|
maccn normalbeg2dc10
|
||||||
|
|
||||||
|
rcontloop10:
|
||||||
|
maccn short normalbeg2dc11
|
||||||
|
|
||||||
|
rcontloop11:
|
||||||
|
maccn short normalbeg2dc12
|
||||||
|
|
||||||
|
rcontloop12:
|
||||||
|
maccn short normalbeg2dc13
|
||||||
|
|
||||||
|
rcontloop13:
|
||||||
|
maccn short normalbeg2dc14
|
||||||
|
|
||||||
|
rcontloop14:
|
||||||
|
maccn short normalbeg2dc15
|
||||||
|
|
||||||
|
rcontloop15:
|
||||||
|
and eax,7fffh
|
||||||
|
mov ax,word ptr[esi+eax*2]
|
||||||
|
cmp ecx,eax
|
||||||
|
jnb exitloop
|
||||||
|
|
||||||
|
sub chain_length,16
|
||||||
|
ja do16
|
||||||
|
jmp normalbeg0add16
|
||||||
|
|
||||||
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||||
|
|
||||||
|
normbeg MACRO rcontlab,valsub
|
||||||
|
; if we are here, we know that *(match+best_len-1) == scan_end
|
||||||
|
cmp bp,word ptr[edx+eax]
|
||||||
|
; if (match != scan_start) goto rcontlab
|
||||||
|
jne rcontlab
|
||||||
|
; calculate the good chain_length, and we'll compare scan and match string
|
||||||
|
add chain_length,16-valsub
|
||||||
|
jmp iseq
|
||||||
|
ENDM
|
||||||
|
|
||||||
|
|
||||||
|
normalbeg2dc11:
|
||||||
|
normbeg rcontloop11,11
|
||||||
|
|
||||||
|
normalbeg2dc12:
|
||||||
|
normbeg short rcontloop12,12
|
||||||
|
|
||||||
|
normalbeg2dc13:
|
||||||
|
normbeg short rcontloop13,13
|
||||||
|
|
||||||
|
normalbeg2dc14:
|
||||||
|
normbeg short rcontloop14,14
|
||||||
|
|
||||||
|
normalbeg2dc15:
|
||||||
|
normbeg short rcontloop15,15
|
||||||
|
|
||||||
|
normalbeg2dc10:
|
||||||
|
normbeg rcontloop10,10
|
||||||
|
|
||||||
|
normalbeg2dc9:
|
||||||
|
normbeg rcontloop9,9
|
||||||
|
|
||||||
|
normalbeg2dc8:
|
||||||
|
normbeg rcontloop8,8
|
||||||
|
|
||||||
|
normalbeg2dc7:
|
||||||
|
normbeg rcontloop7,7
|
||||||
|
|
||||||
|
normalbeg2dc6:
|
||||||
|
normbeg rcontloop6,6
|
||||||
|
|
||||||
|
normalbeg2dc5:
|
||||||
|
normbeg rcontloop5,5
|
||||||
|
|
||||||
|
normalbeg2dc4:
|
||||||
|
normbeg rcontloop4,4
|
||||||
|
|
||||||
|
normalbeg2dc3:
|
||||||
|
normbeg rcontloop3,3
|
||||||
|
|
||||||
|
normalbeg2dc2:
|
||||||
|
normbeg rcontloop2,2
|
||||||
|
|
||||||
|
normalbeg2dc1:
|
||||||
|
normbeg rcontloop1,1
|
||||||
|
|
||||||
|
normalbeg2dc0:
|
||||||
|
normbeg rcontloop0,0
|
||||||
|
|
||||||
|
|
||||||
|
; we go in normalbeg2 because *(ushf*)(match+best_len-1) == scan_end
|
||||||
|
|
||||||
|
normalbeg2:
|
||||||
|
mov edi,window
|
||||||
|
|
||||||
|
cmp bp,word ptr[edi+eax]
|
||||||
|
jne contloop3 ; if *(ushf*)match != scan_start, continue
|
||||||
|
|
||||||
|
iseq:
|
||||||
|
; if we are here, we know that *(match+best_len-1) == scan_end
|
||||||
|
; and (match == scan_start)
|
||||||
|
|
||||||
|
mov edi,edx
|
||||||
|
mov esi,scan ; esi = scan
|
||||||
|
add edi,eax ; edi = window + cur_match = match
|
||||||
|
|
||||||
|
mov edx,[esi+3] ; compare manually dword at match+3
|
||||||
|
xor edx,[edi+3] ; and scan +3
|
||||||
|
|
||||||
|
jz begincompare ; if equal, go to long compare
|
||||||
|
|
||||||
|
; we will determine the unmatch byte and calculate len (in esi)
|
||||||
|
or dl,dl
|
||||||
|
je eq1rr
|
||||||
|
mov esi,3
|
||||||
|
jmp trfinval
|
||||||
|
eq1rr:
|
||||||
|
or dx,dx
|
||||||
|
je eq1
|
||||||
|
|
||||||
|
mov esi,4
|
||||||
|
jmp trfinval
|
||||||
|
eq1:
|
||||||
|
and edx,0ffffffh
|
||||||
|
jz eq11
|
||||||
|
mov esi,5
|
||||||
|
jmp trfinval
|
||||||
|
eq11:
|
||||||
|
mov esi,6
|
||||||
|
jmp trfinval
|
||||||
|
|
||||||
|
begincompare:
|
||||||
|
; here we now scan and match begin same
|
||||||
|
add edi,6
|
||||||
|
add esi,6
|
||||||
|
mov ecx,(MAX_MATCH-(2+4))/4 ; scan for at most MAX_MATCH bytes
|
||||||
|
repe cmpsd ; loop until mismatch
|
||||||
|
|
||||||
|
je trfin ; go to trfin if not unmatch
|
||||||
|
; we determine the unmatch byte
|
||||||
|
sub esi,4
|
||||||
|
mov edx,[edi-4]
|
||||||
|
xor edx,[esi]
|
||||||
|
|
||||||
|
or dl,dl
|
||||||
|
jnz trfin
|
||||||
|
inc esi
|
||||||
|
|
||||||
|
or dx,dx
|
||||||
|
jnz trfin
|
||||||
|
inc esi
|
||||||
|
|
||||||
|
and edx,0ffffffh
|
||||||
|
jnz trfin
|
||||||
|
inc esi
|
||||||
|
|
||||||
|
trfin:
|
||||||
|
sub esi,scan ; esi = len
|
||||||
|
trfinval:
|
||||||
|
; here we have finised compare, and esi contain len of equal string
|
||||||
|
cmp esi,best_len ; if len > best_len, go newbestlen
|
||||||
|
ja short newbestlen
|
||||||
|
; now we restore edx, ecx and esi, for the big loop
|
||||||
|
mov esi,prev
|
||||||
|
mov ecx,limit
|
||||||
|
mov edx,window
|
||||||
|
jmp contloop3
|
||||||
|
|
||||||
|
newbestlen:
|
||||||
|
mov best_len,esi ; len become best_len
|
||||||
|
|
||||||
|
mov match_start,eax ; save new position as match_start
|
||||||
|
cmp esi,nice_match ; if best_len >= nice_match, exit
|
||||||
|
jae exitloop
|
||||||
|
mov ecx,scan
|
||||||
|
mov edx,window ; restore edx=window
|
||||||
|
add ecx,esi
|
||||||
|
add esi,edx
|
||||||
|
|
||||||
|
dec esi
|
||||||
|
mov windowlen,esi ; windowlen = window + best_len-1
|
||||||
|
mov bx,[ecx-1] ; bx = *(scan+best_len-1) = scan_end
|
||||||
|
|
||||||
|
; now we restore ecx and esi, for the big loop :
|
||||||
|
mov esi,prev
|
||||||
|
mov ecx,limit
|
||||||
|
jmp contloop3
|
||||||
|
|
||||||
|
exitloop:
|
||||||
|
; exit : s->match_start=match_start
|
||||||
|
mov ebx,match_start
|
||||||
|
mov ebp,str_s
|
||||||
|
mov ecx,best_len
|
||||||
|
mov dword ptr [ebp+dep_match_start],ebx
|
||||||
|
mov eax,dword ptr [ebp+dep_lookahead]
|
||||||
|
cmp ecx,eax
|
||||||
|
ja minexlo
|
||||||
|
mov eax,ecx
|
||||||
|
minexlo:
|
||||||
|
; return min(best_len,s->lookahead)
|
||||||
|
|
||||||
|
; restore stack and register ebx,esi,edi,ebp
|
||||||
|
add esp,NbStackAdd
|
||||||
|
|
||||||
|
pop ebx
|
||||||
|
pop esi
|
||||||
|
pop edi
|
||||||
|
pop ebp
|
||||||
|
ret
|
||||||
|
InfoAuthor:
|
||||||
|
; please don't remove this string !
|
||||||
|
; Your are free use gvmat32 in any fre or commercial apps if you don't remove the string in the binary!
|
||||||
|
db 0dh,0ah,"GVMat32 optimised assembly code written 1996-98 by Gilles Vollant",0dh,0ah
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
IFDEF NOUNDERLINE
|
||||||
|
longest_match_7fff endp
|
||||||
|
ELSE
|
||||||
|
_longest_match_7fff endp
|
||||||
|
ENDIF
|
||||||
|
|
||||||
|
|
||||||
|
IFDEF NOUNDERLINE
|
||||||
|
cpudetect32 proc near
|
||||||
|
ELSE
|
||||||
|
_cpudetect32 proc near
|
||||||
|
ENDIF
|
||||||
|
|
||||||
|
|
||||||
|
pushfd ; push original EFLAGS
|
||||||
|
pop eax ; get original EFLAGS
|
||||||
|
mov ecx, eax ; save original EFLAGS
|
||||||
|
xor eax, 40000h ; flip AC bit in EFLAGS
|
||||||
|
push eax ; save new EFLAGS value on stack
|
||||||
|
popfd ; replace current EFLAGS value
|
||||||
|
pushfd ; get new EFLAGS
|
||||||
|
pop eax ; store new EFLAGS in EAX
|
||||||
|
xor eax, ecx ; can<61>t toggle AC bit, processor=80386
|
||||||
|
jz end_cpu_is_386 ; jump if 80386 processor
|
||||||
|
push ecx
|
||||||
|
popfd ; restore AC bit in EFLAGS first
|
||||||
|
|
||||||
|
pushfd
|
||||||
|
pushfd
|
||||||
|
pop ecx
|
||||||
|
|
||||||
|
mov eax, ecx ; get original EFLAGS
|
||||||
|
xor eax, 200000h ; flip ID bit in EFLAGS
|
||||||
|
push eax ; save new EFLAGS value on stack
|
||||||
|
popfd ; replace current EFLAGS value
|
||||||
|
pushfd ; get new EFLAGS
|
||||||
|
pop eax ; store new EFLAGS in EAX
|
||||||
|
popfd ; restore original EFLAGS
|
||||||
|
xor eax, ecx ; can<61>t toggle ID bit,
|
||||||
|
je is_old_486 ; processor=old
|
||||||
|
|
||||||
|
mov eax,1
|
||||||
|
db 0fh,0a2h ;CPUID
|
||||||
|
|
||||||
|
exitcpudetect:
|
||||||
|
ret
|
||||||
|
|
||||||
|
end_cpu_is_386:
|
||||||
|
mov eax,0300h
|
||||||
|
jmp exitcpudetect
|
||||||
|
|
||||||
|
is_old_486:
|
||||||
|
mov eax,0400h
|
||||||
|
jmp exitcpudetect
|
||||||
|
|
||||||
|
IFDEF NOUNDERLINE
|
||||||
|
cpudetect32 endp
|
||||||
|
ELSE
|
||||||
|
_cpudetect32 endp
|
||||||
|
ENDIF
|
||||||
|
|
||||||
|
_TEXT ends
|
||||||
|
end
|
||||||
200
contrib/asm386/gvmat32c.c
Normal file
200
contrib/asm386/gvmat32c.c
Normal file
@@ -0,0 +1,200 @@
|
|||||||
|
/* gvmat32.c -- C portion of the optimized longest_match for 32 bits x86
|
||||||
|
* Copyright (C) 1995-1996 Jean-loup Gailly and Gilles Vollant.
|
||||||
|
* File written by Gilles Vollant, by modifiying the longest_match
|
||||||
|
* from Jean-loup Gailly in deflate.c
|
||||||
|
* it prepare all parameters and call the assembly longest_match_gvasm
|
||||||
|
* longest_match execute standard C code is wmask != 0x7fff
|
||||||
|
* (assembly code is faster with a fixed wmask)
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "deflate.h"
|
||||||
|
|
||||||
|
#undef FAR
|
||||||
|
#include <windows.h>
|
||||||
|
|
||||||
|
#ifdef ASMV
|
||||||
|
#define NIL 0
|
||||||
|
|
||||||
|
#define UNALIGNED_OK
|
||||||
|
|
||||||
|
|
||||||
|
/* if your C compiler don't add underline before function name,
|
||||||
|
define ADD_UNDERLINE_ASMFUNC */
|
||||||
|
#ifdef ADD_UNDERLINE_ASMFUNC
|
||||||
|
#define longest_match_7fff _longest_match_7fff
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
void match_init()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
unsigned long cpudetect32();
|
||||||
|
|
||||||
|
uInt longest_match_c(
|
||||||
|
deflate_state *s,
|
||||||
|
IPos cur_match); /* current match */
|
||||||
|
|
||||||
|
|
||||||
|
uInt longest_match_7fff(
|
||||||
|
deflate_state *s,
|
||||||
|
IPos cur_match); /* current match */
|
||||||
|
|
||||||
|
uInt longest_match(
|
||||||
|
deflate_state *s,
|
||||||
|
IPos cur_match) /* current match */
|
||||||
|
{
|
||||||
|
static uInt iIsPPro=2;
|
||||||
|
|
||||||
|
if ((s->w_mask == 0x7fff) && (iIsPPro==0))
|
||||||
|
return longest_match_7fff(s,cur_match);
|
||||||
|
|
||||||
|
if (iIsPPro==2)
|
||||||
|
iIsPPro = (((cpudetect32()/0x100)&0xf)>=6) ? 1 : 0;
|
||||||
|
|
||||||
|
return longest_match_c(s,cur_match);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
uInt longest_match_c(s, cur_match)
|
||||||
|
deflate_state *s;
|
||||||
|
IPos cur_match; /* current match */
|
||||||
|
{
|
||||||
|
unsigned chain_length = s->max_chain_length;/* max hash chain length */
|
||||||
|
register Bytef *scan = s->window + s->strstart; /* current string */
|
||||||
|
register Bytef *match; /* matched string */
|
||||||
|
register int len; /* length of current match */
|
||||||
|
int best_len = s->prev_length; /* best match length so far */
|
||||||
|
int nice_match = s->nice_match; /* stop if match long enough */
|
||||||
|
IPos limit = s->strstart > (IPos)MAX_DIST(s) ?
|
||||||
|
s->strstart - (IPos)MAX_DIST(s) : NIL;
|
||||||
|
/* Stop when cur_match becomes <= limit. To simplify the code,
|
||||||
|
* we prevent matches with the string of window index 0.
|
||||||
|
*/
|
||||||
|
Posf *prev = s->prev;
|
||||||
|
uInt wmask = s->w_mask;
|
||||||
|
|
||||||
|
#ifdef UNALIGNED_OK
|
||||||
|
/* Compare two bytes at a time. Note: this is not always beneficial.
|
||||||
|
* Try with and without -DUNALIGNED_OK to check.
|
||||||
|
*/
|
||||||
|
register Bytef *strend = s->window + s->strstart + MAX_MATCH - 1;
|
||||||
|
register ush scan_start = *(ushf*)scan;
|
||||||
|
register ush scan_end = *(ushf*)(scan+best_len-1);
|
||||||
|
#else
|
||||||
|
register Bytef *strend = s->window + s->strstart + MAX_MATCH;
|
||||||
|
register Byte scan_end1 = scan[best_len-1];
|
||||||
|
register Byte scan_end = scan[best_len];
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* The code is optimized for HASH_BITS >= 8 and MAX_MATCH-2 multiple of 16.
|
||||||
|
* It is easy to get rid of this optimization if necessary.
|
||||||
|
*/
|
||||||
|
Assert(s->hash_bits >= 8 && MAX_MATCH == 258, "Code too clever");
|
||||||
|
|
||||||
|
/* Do not waste too much time if we already have a good match: */
|
||||||
|
if (s->prev_length >= s->good_match) {
|
||||||
|
chain_length >>= 2;
|
||||||
|
}
|
||||||
|
/* Do not look for matches beyond the end of the input. This is necessary
|
||||||
|
* to make deflate deterministic.
|
||||||
|
*/
|
||||||
|
if ((uInt)nice_match > s->lookahead) nice_match = s->lookahead;
|
||||||
|
|
||||||
|
Assert((ulg)s->strstart <= s->window_size-MIN_LOOKAHEAD, "need lookahead");
|
||||||
|
|
||||||
|
do {
|
||||||
|
Assert(cur_match < s->strstart, "no future");
|
||||||
|
match = s->window + cur_match;
|
||||||
|
|
||||||
|
/* Skip to next match if the match length cannot increase
|
||||||
|
* or if the match length is less than 2:
|
||||||
|
*/
|
||||||
|
#if (defined(UNALIGNED_OK) && MAX_MATCH == 258)
|
||||||
|
/* This code assumes sizeof(unsigned short) == 2. Do not use
|
||||||
|
* UNALIGNED_OK if your compiler uses a different size.
|
||||||
|
*/
|
||||||
|
if (*(ushf*)(match+best_len-1) != scan_end ||
|
||||||
|
*(ushf*)match != scan_start) continue;
|
||||||
|
|
||||||
|
/* It is not necessary to compare scan[2] and match[2] since they are
|
||||||
|
* always equal when the other bytes match, given that the hash keys
|
||||||
|
* are equal and that HASH_BITS >= 8. Compare 2 bytes at a time at
|
||||||
|
* strstart+3, +5, ... up to strstart+257. We check for insufficient
|
||||||
|
* lookahead only every 4th comparison; the 128th check will be made
|
||||||
|
* at strstart+257. If MAX_MATCH-2 is not a multiple of 8, it is
|
||||||
|
* necessary to put more guard bytes at the end of the window, or
|
||||||
|
* to check more often for insufficient lookahead.
|
||||||
|
*/
|
||||||
|
Assert(scan[2] == match[2], "scan[2]?");
|
||||||
|
scan++, match++;
|
||||||
|
do {
|
||||||
|
} while (*(ushf*)(scan+=2) == *(ushf*)(match+=2) &&
|
||||||
|
*(ushf*)(scan+=2) == *(ushf*)(match+=2) &&
|
||||||
|
*(ushf*)(scan+=2) == *(ushf*)(match+=2) &&
|
||||||
|
*(ushf*)(scan+=2) == *(ushf*)(match+=2) &&
|
||||||
|
scan < strend);
|
||||||
|
/* The funny "do {}" generates better code on most compilers */
|
||||||
|
|
||||||
|
/* Here, scan <= window+strstart+257 */
|
||||||
|
Assert(scan <= s->window+(unsigned)(s->window_size-1), "wild scan");
|
||||||
|
if (*scan == *match) scan++;
|
||||||
|
|
||||||
|
len = (MAX_MATCH - 1) - (int)(strend-scan);
|
||||||
|
scan = strend - (MAX_MATCH-1);
|
||||||
|
|
||||||
|
#else /* UNALIGNED_OK */
|
||||||
|
|
||||||
|
if (match[best_len] != scan_end ||
|
||||||
|
match[best_len-1] != scan_end1 ||
|
||||||
|
*match != *scan ||
|
||||||
|
*++match != scan[1]) continue;
|
||||||
|
|
||||||
|
/* The check at best_len-1 can be removed because it will be made
|
||||||
|
* again later. (This heuristic is not always a win.)
|
||||||
|
* It is not necessary to compare scan[2] and match[2] since they
|
||||||
|
* are always equal when the other bytes match, given that
|
||||||
|
* the hash keys are equal and that HASH_BITS >= 8.
|
||||||
|
*/
|
||||||
|
scan += 2, match++;
|
||||||
|
Assert(*scan == *match, "match[2]?");
|
||||||
|
|
||||||
|
/* We check for insufficient lookahead only every 8th comparison;
|
||||||
|
* the 256th check will be made at strstart+258.
|
||||||
|
*/
|
||||||
|
do {
|
||||||
|
} while (*++scan == *++match && *++scan == *++match &&
|
||||||
|
*++scan == *++match && *++scan == *++match &&
|
||||||
|
*++scan == *++match && *++scan == *++match &&
|
||||||
|
*++scan == *++match && *++scan == *++match &&
|
||||||
|
scan < strend);
|
||||||
|
|
||||||
|
Assert(scan <= s->window+(unsigned)(s->window_size-1), "wild scan");
|
||||||
|
|
||||||
|
len = MAX_MATCH - (int)(strend - scan);
|
||||||
|
scan = strend - MAX_MATCH;
|
||||||
|
|
||||||
|
#endif /* UNALIGNED_OK */
|
||||||
|
|
||||||
|
if (len > best_len) {
|
||||||
|
s->match_start = cur_match;
|
||||||
|
best_len = len;
|
||||||
|
if (len >= nice_match) break;
|
||||||
|
#ifdef UNALIGNED_OK
|
||||||
|
scan_end = *(ushf*)(scan+best_len-1);
|
||||||
|
#else
|
||||||
|
scan_end1 = scan[best_len-1];
|
||||||
|
scan_end = scan[best_len];
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
} while ((cur_match = prev[cur_match & wmask]) > limit
|
||||||
|
&& --chain_length != 0);
|
||||||
|
|
||||||
|
if ((uInt)best_len <= s->lookahead) return (uInt)best_len;
|
||||||
|
return s->lookahead;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif /* ASMV */
|
||||||
1
contrib/asm386/mkgvmt32.bat
Normal file
1
contrib/asm386/mkgvmt32.bat
Normal file
@@ -0,0 +1 @@
|
|||||||
|
c:\masm611\bin\ml /coff /Zi /c /Flgvmat32.lst gvmat32.asm
|
||||||
74
contrib/asm386/zlibvc.def
Normal file
74
contrib/asm386/zlibvc.def
Normal file
@@ -0,0 +1,74 @@
|
|||||||
|
LIBRARY "zlib"
|
||||||
|
|
||||||
|
DESCRIPTION '"""zlib data compression library"""'
|
||||||
|
|
||||||
|
|
||||||
|
VERSION 1.11
|
||||||
|
|
||||||
|
|
||||||
|
HEAPSIZE 1048576,8192
|
||||||
|
|
||||||
|
EXPORTS
|
||||||
|
adler32 @1
|
||||||
|
compress @2
|
||||||
|
crc32 @3
|
||||||
|
deflate @4
|
||||||
|
deflateCopy @5
|
||||||
|
deflateEnd @6
|
||||||
|
deflateInit2_ @7
|
||||||
|
deflateInit_ @8
|
||||||
|
deflateParams @9
|
||||||
|
deflateReset @10
|
||||||
|
deflateSetDictionary @11
|
||||||
|
gzclose @12
|
||||||
|
gzdopen @13
|
||||||
|
gzerror @14
|
||||||
|
gzflush @15
|
||||||
|
gzopen @16
|
||||||
|
gzread @17
|
||||||
|
gzwrite @18
|
||||||
|
inflate @19
|
||||||
|
inflateEnd @20
|
||||||
|
inflateInit2_ @21
|
||||||
|
inflateInit_ @22
|
||||||
|
inflateReset @23
|
||||||
|
inflateSetDictionary @24
|
||||||
|
inflateSync @25
|
||||||
|
uncompress @26
|
||||||
|
zlibVersion @27
|
||||||
|
gzprintf @28
|
||||||
|
gzputc @29
|
||||||
|
gzgetc @30
|
||||||
|
gzseek @31
|
||||||
|
gzrewind @32
|
||||||
|
gztell @33
|
||||||
|
gzeof @34
|
||||||
|
gzsetparams @35
|
||||||
|
zError @36
|
||||||
|
inflateSyncPoint @37
|
||||||
|
get_crc_table @38
|
||||||
|
compress2 @39
|
||||||
|
gzputs @40
|
||||||
|
gzgets @41
|
||||||
|
|
||||||
|
unzOpen @61
|
||||||
|
unzClose @62
|
||||||
|
unzGetGlobalInfo @63
|
||||||
|
unzGetCurrentFileInfo @64
|
||||||
|
unzGoToFirstFile @65
|
||||||
|
unzGoToNextFile @66
|
||||||
|
unzOpenCurrentFile @67
|
||||||
|
unzReadCurrentFile @68
|
||||||
|
unztell @70
|
||||||
|
unzeof @71
|
||||||
|
unzCloseCurrentFile @72
|
||||||
|
unzGetGlobalComment @73
|
||||||
|
unzStringFileNameCompare @74
|
||||||
|
unzLocateFile @75
|
||||||
|
unzGetLocalExtrafield @76
|
||||||
|
|
||||||
|
zipOpen @80
|
||||||
|
zipOpenNewFileInZip @81
|
||||||
|
zipWriteInFileInZip @82
|
||||||
|
zipCloseFileInZip @83
|
||||||
|
zipClose @84
|
||||||
651
contrib/asm386/zlibvc.dsp
Normal file
651
contrib/asm386/zlibvc.dsp
Normal file
@@ -0,0 +1,651 @@
|
|||||||
|
# Microsoft Developer Studio Project File - Name="zlibvc" - Package Owner=<4>
|
||||||
|
# Microsoft Developer Studio Generated Build File, Format Version 5.00
|
||||||
|
# ** DO NOT EDIT **
|
||||||
|
|
||||||
|
# TARGTYPE "Win32 (x86) Dynamic-Link Library" 0x0102
|
||||||
|
# TARGTYPE "Win32 (ALPHA) Dynamic-Link Library" 0x0602
|
||||||
|
|
||||||
|
CFG=zlibvc - Win32 Release
|
||||||
|
!MESSAGE This is not a valid makefile. To build this project using NMAKE,
|
||||||
|
!MESSAGE use the Export Makefile command and run
|
||||||
|
!MESSAGE
|
||||||
|
!MESSAGE NMAKE /f "zlibvc.mak".
|
||||||
|
!MESSAGE
|
||||||
|
!MESSAGE You can specify a configuration when running NMAKE
|
||||||
|
!MESSAGE by defining the macro CFG on the command line. For example:
|
||||||
|
!MESSAGE
|
||||||
|
!MESSAGE NMAKE /f "zlibvc.mak" CFG="zlibvc - Win32 Release"
|
||||||
|
!MESSAGE
|
||||||
|
!MESSAGE Possible choices for configuration are:
|
||||||
|
!MESSAGE
|
||||||
|
!MESSAGE "zlibvc - Win32 Release" (based on "Win32 (x86) Dynamic-Link Library")
|
||||||
|
!MESSAGE "zlibvc - Win32 Debug" (based on "Win32 (x86) Dynamic-Link Library")
|
||||||
|
!MESSAGE "zlibvc - Win32 ReleaseAxp" (based on\
|
||||||
|
"Win32 (ALPHA) Dynamic-Link Library")
|
||||||
|
!MESSAGE "zlibvc - Win32 ReleaseWithoutAsm" (based on\
|
||||||
|
"Win32 (x86) Dynamic-Link Library")
|
||||||
|
!MESSAGE "zlibvc - Win32 ReleaseWithoutCrtdll" (based on\
|
||||||
|
"Win32 (x86) Dynamic-Link Library")
|
||||||
|
!MESSAGE
|
||||||
|
|
||||||
|
# Begin Project
|
||||||
|
# PROP Scc_ProjName ""
|
||||||
|
# PROP Scc_LocalPath ""
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
# PROP BASE Use_MFC 0
|
||||||
|
# PROP BASE Use_Debug_Libraries 0
|
||||||
|
# PROP BASE Output_Dir ".\Release"
|
||||||
|
# PROP BASE Intermediate_Dir ".\Release"
|
||||||
|
# PROP BASE Target_Dir ""
|
||||||
|
# PROP Use_MFC 0
|
||||||
|
# PROP Use_Debug_Libraries 0
|
||||||
|
# PROP Output_Dir ".\Release"
|
||||||
|
# PROP Intermediate_Dir ".\Release"
|
||||||
|
# PROP Ignore_Export_Lib 0
|
||||||
|
# PROP Target_Dir ""
|
||||||
|
CPP=cl.exe
|
||||||
|
# ADD BASE CPP /nologo /MT /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_WINDOWS" /YX /c
|
||||||
|
# ADD CPP /nologo /MT /W3 /GX /O2 /D "NDEBUG" /D "WIN32" /D "_WINDOWS" /D "_WINDLL" /D "_WIN32" /D "BUILD_ZLIBDLL" /D "ZLIB_DLL" /D "DYNAMIC_CRC_TABLE" /D "ASMV" /FAcs /FR /FD /c
|
||||||
|
# SUBTRACT CPP /YX
|
||||||
|
MTL=midl.exe
|
||||||
|
# ADD BASE MTL /nologo /D "NDEBUG" /win32
|
||||||
|
# ADD MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
||||||
|
RSC=rc.exe
|
||||||
|
# ADD BASE RSC /l 0x40c /d "NDEBUG"
|
||||||
|
# ADD RSC /l 0x40c /d "NDEBUG"
|
||||||
|
BSC32=bscmake.exe
|
||||||
|
# ADD BASE BSC32 /nologo
|
||||||
|
# ADD BSC32 /nologo
|
||||||
|
LINK32=link.exe
|
||||||
|
# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /subsystem:windows /dll /machine:I386
|
||||||
|
# ADD LINK32 gvmat32.obj kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib crtdll.lib /nologo /subsystem:windows /dll /map /machine:I386 /nodefaultlib /out:".\Release\zlib.dll"
|
||||||
|
# SUBTRACT LINK32 /pdb:none
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
# PROP BASE Use_MFC 0
|
||||||
|
# PROP BASE Use_Debug_Libraries 1
|
||||||
|
# PROP BASE Output_Dir ".\Debug"
|
||||||
|
# PROP BASE Intermediate_Dir ".\Debug"
|
||||||
|
# PROP BASE Target_Dir ""
|
||||||
|
# PROP Use_MFC 0
|
||||||
|
# PROP Use_Debug_Libraries 1
|
||||||
|
# PROP Output_Dir ".\Debug"
|
||||||
|
# PROP Intermediate_Dir ".\Debug"
|
||||||
|
# PROP Target_Dir ""
|
||||||
|
CPP=cl.exe
|
||||||
|
# ADD BASE CPP /nologo /MTd /W3 /Gm /GX /Zi /Od /D "WIN32" /D "_DEBUG" /D "_WINDOWS" /YX /c
|
||||||
|
# ADD CPP /nologo /MTd /W3 /Gm /GX /Zi /Od /D "_DEBUG" /D "WIN32" /D "_WINDOWS" /D "_WINDLL" /D "_WIN32" /D "BUILD_ZLIBDLL" /D "ZLIB_DLL" /FD /c
|
||||||
|
# SUBTRACT CPP /YX
|
||||||
|
MTL=midl.exe
|
||||||
|
# ADD BASE MTL /nologo /D "_DEBUG" /win32
|
||||||
|
# ADD MTL /nologo /D "_DEBUG" /mktyplib203 /win32
|
||||||
|
RSC=rc.exe
|
||||||
|
# ADD BASE RSC /l 0x40c /d "_DEBUG"
|
||||||
|
# ADD RSC /l 0x40c /d "_DEBUG"
|
||||||
|
BSC32=bscmake.exe
|
||||||
|
# ADD BASE BSC32 /nologo
|
||||||
|
# ADD BSC32 /nologo
|
||||||
|
LINK32=link.exe
|
||||||
|
# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /subsystem:windows /dll /debug /machine:I386
|
||||||
|
# ADD LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib /nologo /subsystem:windows /dll /debug /machine:I386 /out:".\Debug\zlib.dll"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
# PROP BASE Use_MFC 0
|
||||||
|
# PROP BASE Use_Debug_Libraries 0
|
||||||
|
# PROP BASE Output_Dir "zlibvc__"
|
||||||
|
# PROP BASE Intermediate_Dir "zlibvc__"
|
||||||
|
# PROP BASE Ignore_Export_Lib 0
|
||||||
|
# PROP BASE Target_Dir ""
|
||||||
|
# PROP Use_MFC 0
|
||||||
|
# PROP Use_Debug_Libraries 0
|
||||||
|
# PROP Output_Dir "zlibvc__"
|
||||||
|
# PROP Intermediate_Dir "zlibvc__"
|
||||||
|
# PROP Ignore_Export_Lib 0
|
||||||
|
# PROP Target_Dir ""
|
||||||
|
MTL=midl.exe
|
||||||
|
# ADD BASE MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
||||||
|
# ADD MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
||||||
|
CPP=cl.exe
|
||||||
|
# ADD BASE CPP /nologo /MT /Gt0 /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_WINDOWS" /D "_WIN32" /D "BUILD_ZLIBDLL" /D "ZLIB_DLL" /D "DYNAMIC_CRC_TABLE" /FAcs /FR /YX /FD /c
|
||||||
|
# ADD CPP /nologo /MT /Gt0 /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_WINDOWS" /D "_WIN32" /D "BUILD_ZLIBDLL" /D "ZLIB_DLL" /D "DYNAMIC_CRC_TABLE" /FAcs /FR /FD /c
|
||||||
|
# SUBTRACT CPP /YX
|
||||||
|
RSC=rc.exe
|
||||||
|
# ADD BASE RSC /l 0x40c /d "NDEBUG"
|
||||||
|
# ADD RSC /l 0x40c /d "NDEBUG"
|
||||||
|
BSC32=bscmake.exe
|
||||||
|
# ADD BASE BSC32 /nologo
|
||||||
|
# ADD BSC32 /nologo
|
||||||
|
LINK32=link.exe
|
||||||
|
# ADD BASE LINK32 crtdll.lib kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib /nologo /subsystem:windows /dll /map /machine:ALPHA /nodefaultlib /out:".\Release\zlib.dll"
|
||||||
|
# SUBTRACT BASE LINK32 /pdb:none
|
||||||
|
# ADD LINK32 crtdll.lib kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib /nologo /subsystem:windows /dll /map /machine:ALPHA /nodefaultlib /out:"zlibvc__\zlib.dll"
|
||||||
|
# SUBTRACT LINK32 /pdb:none
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
# PROP BASE Use_MFC 0
|
||||||
|
# PROP BASE Use_Debug_Libraries 0
|
||||||
|
# PROP BASE Output_Dir "zlibvc_0"
|
||||||
|
# PROP BASE Intermediate_Dir "zlibvc_0"
|
||||||
|
# PROP BASE Ignore_Export_Lib 0
|
||||||
|
# PROP BASE Target_Dir ""
|
||||||
|
# PROP Use_MFC 0
|
||||||
|
# PROP Use_Debug_Libraries 0
|
||||||
|
# PROP Output_Dir "zlibvc_0"
|
||||||
|
# PROP Intermediate_Dir "zlibvc_0"
|
||||||
|
# PROP Ignore_Export_Lib 0
|
||||||
|
# PROP Target_Dir ""
|
||||||
|
CPP=cl.exe
|
||||||
|
# ADD BASE CPP /nologo /MT /W3 /GX /O2 /D "NDEBUG" /D "WIN32" /D "_WINDOWS" /D "_WINDLL" /D "_WIN32" /D "BUILD_ZLIBDLL" /D "ZLIB_DLL" /D "DYNAMIC_CRC_TABLE" /FAcs /FR /YX /FD /c
|
||||||
|
# ADD CPP /nologo /MT /W3 /GX /O2 /D "NDEBUG" /D "WIN32" /D "_WINDOWS" /D "_WINDLL" /D "_WIN32" /D "BUILD_ZLIBDLL" /D "ZLIB_DLL" /D "DYNAMIC_CRC_TABLE" /FAcs /FR /FD /c
|
||||||
|
# SUBTRACT CPP /YX
|
||||||
|
MTL=midl.exe
|
||||||
|
# ADD BASE MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
||||||
|
# ADD MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
||||||
|
RSC=rc.exe
|
||||||
|
# ADD BASE RSC /l 0x40c /d "NDEBUG"
|
||||||
|
# ADD RSC /l 0x40c /d "NDEBUG"
|
||||||
|
BSC32=bscmake.exe
|
||||||
|
# ADD BASE BSC32 /nologo
|
||||||
|
# ADD BSC32 /nologo
|
||||||
|
LINK32=link.exe
|
||||||
|
# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib crtdll.lib /nologo /subsystem:windows /dll /map /machine:I386 /nodefaultlib /out:".\Release\zlib.dll"
|
||||||
|
# SUBTRACT BASE LINK32 /pdb:none
|
||||||
|
# ADD LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib crtdll.lib /nologo /subsystem:windows /dll /map /machine:I386 /nodefaultlib /out:".\zlibvc_0\zlib.dll"
|
||||||
|
# SUBTRACT LINK32 /pdb:none
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
# PROP BASE Use_MFC 0
|
||||||
|
# PROP BASE Use_Debug_Libraries 0
|
||||||
|
# PROP BASE Output_Dir "zlibvc_1"
|
||||||
|
# PROP BASE Intermediate_Dir "zlibvc_1"
|
||||||
|
# PROP BASE Ignore_Export_Lib 0
|
||||||
|
# PROP BASE Target_Dir ""
|
||||||
|
# PROP Use_MFC 0
|
||||||
|
# PROP Use_Debug_Libraries 0
|
||||||
|
# PROP Output_Dir "zlibvc_1"
|
||||||
|
# PROP Intermediate_Dir "zlibvc_1"
|
||||||
|
# PROP Ignore_Export_Lib 0
|
||||||
|
# PROP Target_Dir ""
|
||||||
|
CPP=cl.exe
|
||||||
|
# ADD BASE CPP /nologo /MT /W3 /GX /O2 /D "NDEBUG" /D "WIN32" /D "_WINDOWS" /D "_WINDLL" /D "_WIN32" /D "BUILD_ZLIBDLL" /D "ZLIB_DLL" /D "DYNAMIC_CRC_TABLE" /D "ASMV" /FAcs /FR /YX /FD /c
|
||||||
|
# ADD CPP /nologo /MT /W3 /GX /O2 /D "NDEBUG" /D "WIN32" /D "_WINDOWS" /D "_WINDLL" /D "_WIN32" /D "BUILD_ZLIBDLL" /D "ZLIB_DLL" /D "DYNAMIC_CRC_TABLE" /D "ASMV" /FAcs /FR /FD /c
|
||||||
|
# SUBTRACT CPP /YX
|
||||||
|
MTL=midl.exe
|
||||||
|
# ADD BASE MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
||||||
|
# ADD MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
||||||
|
RSC=rc.exe
|
||||||
|
# ADD BASE RSC /l 0x40c /d "NDEBUG"
|
||||||
|
# ADD RSC /l 0x40c /d "NDEBUG"
|
||||||
|
BSC32=bscmake.exe
|
||||||
|
# ADD BASE BSC32 /nologo
|
||||||
|
# ADD BSC32 /nologo
|
||||||
|
LINK32=link.exe
|
||||||
|
# ADD BASE LINK32 gvmat32.obj kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib crtdll.lib /nologo /subsystem:windows /dll /map /machine:I386 /nodefaultlib /out:".\Release\zlib.dll"
|
||||||
|
# SUBTRACT BASE LINK32 /pdb:none
|
||||||
|
# ADD LINK32 gvmat32.obj kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib crtdll.lib /nologo /subsystem:windows /dll /map /machine:I386 /nodefaultlib /out:".\zlibvc_1\zlib.dll"
|
||||||
|
# SUBTRACT LINK32 /pdb:none
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# Begin Target
|
||||||
|
|
||||||
|
# Name "zlibvc - Win32 Release"
|
||||||
|
# Name "zlibvc - Win32 Debug"
|
||||||
|
# Name "zlibvc - Win32 ReleaseAxp"
|
||||||
|
# Name "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
# Name "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
# Begin Group "Source Files"
|
||||||
|
|
||||||
|
# PROP Default_Filter "cpp;c;cxx;rc;def;r;odl;hpj;bat;for;f90"
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\adler32.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
DEP_CPP_ADLER=\
|
||||||
|
".\zconf.h"\
|
||||||
|
".\zlib.h"\
|
||||||
|
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\compress.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
DEP_CPP_COMPR=\
|
||||||
|
".\zconf.h"\
|
||||||
|
".\zlib.h"\
|
||||||
|
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\crc32.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
DEP_CPP_CRC32=\
|
||||||
|
".\zconf.h"\
|
||||||
|
".\zlib.h"\
|
||||||
|
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\deflate.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
DEP_CPP_DEFLA=\
|
||||||
|
".\deflate.h"\
|
||||||
|
".\zconf.h"\
|
||||||
|
".\zlib.h"\
|
||||||
|
".\zutil.h"\
|
||||||
|
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\gvmat32c.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\gzio.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
DEP_CPP_GZIO_=\
|
||||||
|
".\zconf.h"\
|
||||||
|
".\zlib.h"\
|
||||||
|
".\zutil.h"\
|
||||||
|
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\infblock.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
DEP_CPP_INFBL=\
|
||||||
|
".\infblock.h"\
|
||||||
|
".\infcodes.h"\
|
||||||
|
".\inftrees.h"\
|
||||||
|
".\infutil.h"\
|
||||||
|
".\zconf.h"\
|
||||||
|
".\zlib.h"\
|
||||||
|
".\zutil.h"\
|
||||||
|
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\infcodes.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
DEP_CPP_INFCO=\
|
||||||
|
".\infblock.h"\
|
||||||
|
".\infcodes.h"\
|
||||||
|
".\inffast.h"\
|
||||||
|
".\inftrees.h"\
|
||||||
|
".\infutil.h"\
|
||||||
|
".\zconf.h"\
|
||||||
|
".\zlib.h"\
|
||||||
|
".\zutil.h"\
|
||||||
|
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\inffast.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
DEP_CPP_INFFA=\
|
||||||
|
".\infblock.h"\
|
||||||
|
".\infcodes.h"\
|
||||||
|
".\inffast.h"\
|
||||||
|
".\inftrees.h"\
|
||||||
|
".\infutil.h"\
|
||||||
|
".\zconf.h"\
|
||||||
|
".\zlib.h"\
|
||||||
|
".\zutil.h"\
|
||||||
|
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\inflate.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
DEP_CPP_INFLA=\
|
||||||
|
".\infblock.h"\
|
||||||
|
".\zconf.h"\
|
||||||
|
".\zlib.h"\
|
||||||
|
".\zutil.h"\
|
||||||
|
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\inftrees.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
DEP_CPP_INFTR=\
|
||||||
|
".\inftrees.h"\
|
||||||
|
".\zconf.h"\
|
||||||
|
".\zlib.h"\
|
||||||
|
".\zutil.h"\
|
||||||
|
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\infutil.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
DEP_CPP_INFUT=\
|
||||||
|
".\infblock.h"\
|
||||||
|
".\infcodes.h"\
|
||||||
|
".\inftrees.h"\
|
||||||
|
".\infutil.h"\
|
||||||
|
".\zconf.h"\
|
||||||
|
".\zlib.h"\
|
||||||
|
".\zutil.h"\
|
||||||
|
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\trees.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
DEP_CPP_TREES=\
|
||||||
|
".\deflate.h"\
|
||||||
|
".\zconf.h"\
|
||||||
|
".\zlib.h"\
|
||||||
|
".\zutil.h"\
|
||||||
|
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\uncompr.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
DEP_CPP_UNCOM=\
|
||||||
|
".\zconf.h"\
|
||||||
|
".\zlib.h"\
|
||||||
|
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\unzip.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\zip.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\zlib.rc
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\zlibvc.def
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\zutil.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
DEP_CPP_ZUTIL=\
|
||||||
|
".\zconf.h"\
|
||||||
|
".\zlib.h"\
|
||||||
|
".\zutil.h"\
|
||||||
|
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# End Group
|
||||||
|
# Begin Group "Header Files"
|
||||||
|
|
||||||
|
# PROP Default_Filter "h;hpp;hxx;hm;inl;fi;fd"
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\deflate.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\infblock.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\infcodes.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\inffast.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\inftrees.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\infutil.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\zconf.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\zlib.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\zutil.h
|
||||||
|
# End Source File
|
||||||
|
# End Group
|
||||||
|
# Begin Group "Resource Files"
|
||||||
|
|
||||||
|
# PROP Default_Filter "ico;cur;bmp;dlg;rc2;rct;bin;cnt;rtf;gif;jpg;jpeg;jpe"
|
||||||
|
# End Group
|
||||||
|
# End Target
|
||||||
|
# End Project
|
||||||
41
contrib/asm386/zlibvc.dsw
Normal file
41
contrib/asm386/zlibvc.dsw
Normal file
@@ -0,0 +1,41 @@
|
|||||||
|
Microsoft Developer Studio Workspace File, Format Version 5.00
|
||||||
|
# WARNING: DO NOT EDIT OR DELETE THIS WORKSPACE FILE!
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
|
||||||
|
Project: "zlibstat"=.\zlibstat.dsp - Package Owner=<4>
|
||||||
|
|
||||||
|
Package=<5>
|
||||||
|
{{{
|
||||||
|
}}}
|
||||||
|
|
||||||
|
Package=<4>
|
||||||
|
{{{
|
||||||
|
}}}
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
|
||||||
|
Project: "zlibvc"=.\zlibvc.dsp - Package Owner=<4>
|
||||||
|
|
||||||
|
Package=<5>
|
||||||
|
{{{
|
||||||
|
}}}
|
||||||
|
|
||||||
|
Package=<4>
|
||||||
|
{{{
|
||||||
|
}}}
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
|
||||||
|
Global:
|
||||||
|
|
||||||
|
Package=<5>
|
||||||
|
{{{
|
||||||
|
}}}
|
||||||
|
|
||||||
|
Package=<3>
|
||||||
|
{{{
|
||||||
|
}}}
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
|
||||||
43
contrib/asm586/README.586
Normal file
43
contrib/asm586/README.586
Normal file
@@ -0,0 +1,43 @@
|
|||||||
|
This is a patched version of zlib modified to use
|
||||||
|
Pentium-optimized assembly code in the deflation algorithm. The files
|
||||||
|
changed/added by this patch are:
|
||||||
|
|
||||||
|
README.586
|
||||||
|
match.S
|
||||||
|
|
||||||
|
The effectiveness of these modifications is a bit marginal, as the the
|
||||||
|
program's bottleneck seems to be mostly L1-cache contention, for which
|
||||||
|
there is no real way to work around without rewriting the basic
|
||||||
|
algorithm. The speedup on average is around 5-10% (which is generally
|
||||||
|
less than the amount of variance between subsequent executions).
|
||||||
|
However, when used at level 9 compression, the cache contention can
|
||||||
|
drop enough for the assembly version to achieve 10-20% speedup (and
|
||||||
|
sometimes more, depending on the amount of overall redundancy in the
|
||||||
|
files). Even here, though, cache contention can still be the limiting
|
||||||
|
factor, depending on the nature of the program using the zlib library.
|
||||||
|
This may also mean that better improvements will be seen on a Pentium
|
||||||
|
with MMX, which suffers much less from L1-cache contention, but I have
|
||||||
|
not yet verified this.
|
||||||
|
|
||||||
|
Note that this code has been tailored for the Pentium in particular,
|
||||||
|
and will not perform well on the Pentium Pro (due to the use of a
|
||||||
|
partial register in the inner loop).
|
||||||
|
|
||||||
|
If you are using an assembler other than GNU as, you will have to
|
||||||
|
translate match.S to use your assembler's syntax. (Have fun.)
|
||||||
|
|
||||||
|
Brian Raiter
|
||||||
|
breadbox@muppetlabs.com
|
||||||
|
April, 1998
|
||||||
|
|
||||||
|
|
||||||
|
Added for zlib 1.1.3:
|
||||||
|
|
||||||
|
The patches come from
|
||||||
|
http://www.muppetlabs.com/~breadbox/software/assembly.html
|
||||||
|
|
||||||
|
To compile zlib with this asm file, copy match.S to the zlib directory
|
||||||
|
then do:
|
||||||
|
|
||||||
|
CFLAGS="-O3 -DASMV" ./configure
|
||||||
|
make OBJA=match.o
|
||||||
354
contrib/asm586/match.S
Normal file
354
contrib/asm586/match.S
Normal file
@@ -0,0 +1,354 @@
|
|||||||
|
/* match.s -- Pentium-optimized version of longest_match()
|
||||||
|
* Written for zlib 1.1.2
|
||||||
|
* Copyright (C) 1998 Brian Raiter <breadbox@muppetlabs.com>
|
||||||
|
*
|
||||||
|
* This is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef NO_UNDERLINE
|
||||||
|
#define match_init _match_init
|
||||||
|
#define longest_match _longest_match
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define MAX_MATCH (258)
|
||||||
|
#define MIN_MATCH (3)
|
||||||
|
#define MIN_LOOKAHEAD (MAX_MATCH + MIN_MATCH + 1)
|
||||||
|
#define MAX_MATCH_8 ((MAX_MATCH + 7) & ~7)
|
||||||
|
|
||||||
|
/* stack frame offsets */
|
||||||
|
|
||||||
|
#define wmask 0 /* local copy of s->wmask */
|
||||||
|
#define window 4 /* local copy of s->window */
|
||||||
|
#define windowbestlen 8 /* s->window + bestlen */
|
||||||
|
#define chainlenscanend 12 /* high word: current chain len */
|
||||||
|
/* low word: last bytes sought */
|
||||||
|
#define scanstart 16 /* first two bytes of string */
|
||||||
|
#define scanalign 20 /* dword-misalignment of string */
|
||||||
|
#define nicematch 24 /* a good enough match size */
|
||||||
|
#define bestlen 28 /* size of best match so far */
|
||||||
|
#define scan 32 /* ptr to string wanting match */
|
||||||
|
|
||||||
|
#define LocalVarsSize (36)
|
||||||
|
/* saved ebx 36 */
|
||||||
|
/* saved edi 40 */
|
||||||
|
/* saved esi 44 */
|
||||||
|
/* saved ebp 48 */
|
||||||
|
/* return address 52 */
|
||||||
|
#define deflatestate 56 /* the function arguments */
|
||||||
|
#define curmatch 60
|
||||||
|
|
||||||
|
/* Offsets for fields in the deflate_state structure. These numbers
|
||||||
|
* are calculated from the definition of deflate_state, with the
|
||||||
|
* assumption that the compiler will dword-align the fields. (Thus,
|
||||||
|
* changing the definition of deflate_state could easily cause this
|
||||||
|
* program to crash horribly, without so much as a warning at
|
||||||
|
* compile time. Sigh.)
|
||||||
|
*/
|
||||||
|
#define dsWSize 36
|
||||||
|
#define dsWMask 44
|
||||||
|
#define dsWindow 48
|
||||||
|
#define dsPrev 56
|
||||||
|
#define dsMatchLen 88
|
||||||
|
#define dsPrevMatch 92
|
||||||
|
#define dsStrStart 100
|
||||||
|
#define dsMatchStart 104
|
||||||
|
#define dsLookahead 108
|
||||||
|
#define dsPrevLen 112
|
||||||
|
#define dsMaxChainLen 116
|
||||||
|
#define dsGoodMatch 132
|
||||||
|
#define dsNiceMatch 136
|
||||||
|
|
||||||
|
|
||||||
|
.file "match.S"
|
||||||
|
|
||||||
|
.globl match_init, longest_match
|
||||||
|
|
||||||
|
.text
|
||||||
|
|
||||||
|
/* uInt longest_match(deflate_state *deflatestate, IPos curmatch) */
|
||||||
|
|
||||||
|
longest_match:
|
||||||
|
|
||||||
|
/* Save registers that the compiler may be using, and adjust %esp to */
|
||||||
|
/* make room for our stack frame. */
|
||||||
|
|
||||||
|
pushl %ebp
|
||||||
|
pushl %edi
|
||||||
|
pushl %esi
|
||||||
|
pushl %ebx
|
||||||
|
subl $LocalVarsSize, %esp
|
||||||
|
|
||||||
|
/* Retrieve the function arguments. %ecx will hold cur_match */
|
||||||
|
/* throughout the entire function. %edx will hold the pointer to the */
|
||||||
|
/* deflate_state structure during the function's setup (before */
|
||||||
|
/* entering the main loop). */
|
||||||
|
|
||||||
|
movl deflatestate(%esp), %edx
|
||||||
|
movl curmatch(%esp), %ecx
|
||||||
|
|
||||||
|
/* if ((uInt)nice_match > s->lookahead) nice_match = s->lookahead; */
|
||||||
|
|
||||||
|
movl dsNiceMatch(%edx), %eax
|
||||||
|
movl dsLookahead(%edx), %ebx
|
||||||
|
cmpl %eax, %ebx
|
||||||
|
jl LookaheadLess
|
||||||
|
movl %eax, %ebx
|
||||||
|
LookaheadLess: movl %ebx, nicematch(%esp)
|
||||||
|
|
||||||
|
/* register Bytef *scan = s->window + s->strstart; */
|
||||||
|
|
||||||
|
movl dsWindow(%edx), %esi
|
||||||
|
movl %esi, window(%esp)
|
||||||
|
movl dsStrStart(%edx), %ebp
|
||||||
|
lea (%esi,%ebp), %edi
|
||||||
|
movl %edi, scan(%esp)
|
||||||
|
|
||||||
|
/* Determine how many bytes the scan ptr is off from being */
|
||||||
|
/* dword-aligned. */
|
||||||
|
|
||||||
|
movl %edi, %eax
|
||||||
|
negl %eax
|
||||||
|
andl $3, %eax
|
||||||
|
movl %eax, scanalign(%esp)
|
||||||
|
|
||||||
|
/* IPos limit = s->strstart > (IPos)MAX_DIST(s) ? */
|
||||||
|
/* s->strstart - (IPos)MAX_DIST(s) : NIL; */
|
||||||
|
|
||||||
|
movl dsWSize(%edx), %eax
|
||||||
|
subl $MIN_LOOKAHEAD, %eax
|
||||||
|
subl %eax, %ebp
|
||||||
|
jg LimitPositive
|
||||||
|
xorl %ebp, %ebp
|
||||||
|
LimitPositive:
|
||||||
|
|
||||||
|
/* unsigned chain_length = s->max_chain_length; */
|
||||||
|
/* if (s->prev_length >= s->good_match) { */
|
||||||
|
/* chain_length >>= 2; */
|
||||||
|
/* } */
|
||||||
|
|
||||||
|
movl dsPrevLen(%edx), %eax
|
||||||
|
movl dsGoodMatch(%edx), %ebx
|
||||||
|
cmpl %ebx, %eax
|
||||||
|
movl dsMaxChainLen(%edx), %ebx
|
||||||
|
jl LastMatchGood
|
||||||
|
shrl $2, %ebx
|
||||||
|
LastMatchGood:
|
||||||
|
|
||||||
|
/* chainlen is decremented once beforehand so that the function can */
|
||||||
|
/* use the sign flag instead of the zero flag for the exit test. */
|
||||||
|
/* It is then shifted into the high word, to make room for the scanend */
|
||||||
|
/* scanend value, which it will always accompany. */
|
||||||
|
|
||||||
|
decl %ebx
|
||||||
|
shll $16, %ebx
|
||||||
|
|
||||||
|
/* int best_len = s->prev_length; */
|
||||||
|
|
||||||
|
movl dsPrevLen(%edx), %eax
|
||||||
|
movl %eax, bestlen(%esp)
|
||||||
|
|
||||||
|
/* Store the sum of s->window + best_len in %esi locally, and in %esi. */
|
||||||
|
|
||||||
|
addl %eax, %esi
|
||||||
|
movl %esi, windowbestlen(%esp)
|
||||||
|
|
||||||
|
/* register ush scan_start = *(ushf*)scan; */
|
||||||
|
/* register ush scan_end = *(ushf*)(scan+best_len-1); */
|
||||||
|
|
||||||
|
movw (%edi), %bx
|
||||||
|
movw %bx, scanstart(%esp)
|
||||||
|
movw -1(%edi,%eax), %bx
|
||||||
|
movl %ebx, chainlenscanend(%esp)
|
||||||
|
|
||||||
|
/* Posf *prev = s->prev; */
|
||||||
|
/* uInt wmask = s->w_mask; */
|
||||||
|
|
||||||
|
movl dsPrev(%edx), %edi
|
||||||
|
movl dsWMask(%edx), %edx
|
||||||
|
mov %edx, wmask(%esp)
|
||||||
|
|
||||||
|
/* Jump into the main loop. */
|
||||||
|
|
||||||
|
jmp LoopEntry
|
||||||
|
|
||||||
|
.balign 16
|
||||||
|
|
||||||
|
/* do {
|
||||||
|
* match = s->window + cur_match;
|
||||||
|
* if (*(ushf*)(match+best_len-1) != scan_end ||
|
||||||
|
* *(ushf*)match != scan_start) continue;
|
||||||
|
* [...]
|
||||||
|
* } while ((cur_match = prev[cur_match & wmask]) > limit
|
||||||
|
* && --chain_length != 0);
|
||||||
|
*
|
||||||
|
* Here is the inner loop of the function. The function will spend the
|
||||||
|
* majority of its time in this loop, and majority of that time will
|
||||||
|
* be spent in the first ten instructions.
|
||||||
|
*
|
||||||
|
* Within this loop:
|
||||||
|
* %ebx = chainlenscanend - i.e., ((chainlen << 16) | scanend)
|
||||||
|
* %ecx = curmatch
|
||||||
|
* %edx = curmatch & wmask
|
||||||
|
* %esi = windowbestlen - i.e., (window + bestlen)
|
||||||
|
* %edi = prev
|
||||||
|
* %ebp = limit
|
||||||
|
*
|
||||||
|
* Two optimization notes on the choice of instructions:
|
||||||
|
*
|
||||||
|
* The first instruction uses a 16-bit address, which costs an extra,
|
||||||
|
* unpairable cycle. This is cheaper than doing a 32-bit access and
|
||||||
|
* zeroing the high word, due to the 3-cycle misalignment penalty which
|
||||||
|
* would occur half the time. This also turns out to be cheaper than
|
||||||
|
* doing two separate 8-bit accesses, as the memory is so rarely in the
|
||||||
|
* L1 cache.
|
||||||
|
*
|
||||||
|
* The window buffer, however, apparently spends a lot of time in the
|
||||||
|
* cache, and so it is faster to retrieve the word at the end of the
|
||||||
|
* match string with two 8-bit loads. The instructions that test the
|
||||||
|
* word at the beginning of the match string, however, are executed
|
||||||
|
* much less frequently, and there it was cheaper to use 16-bit
|
||||||
|
* instructions, which avoided the necessity of saving off and
|
||||||
|
* subsequently reloading one of the other registers.
|
||||||
|
*/
|
||||||
|
LookupLoop:
|
||||||
|
/* 1 U & V */
|
||||||
|
movw (%edi,%edx,2), %cx /* 2 U pipe */
|
||||||
|
movl wmask(%esp), %edx /* 2 V pipe */
|
||||||
|
cmpl %ebp, %ecx /* 3 U pipe */
|
||||||
|
jbe LeaveNow /* 3 V pipe */
|
||||||
|
subl $0x00010000, %ebx /* 4 U pipe */
|
||||||
|
js LeaveNow /* 4 V pipe */
|
||||||
|
LoopEntry: movb -1(%esi,%ecx), %al /* 5 U pipe */
|
||||||
|
andl %ecx, %edx /* 5 V pipe */
|
||||||
|
cmpb %bl, %al /* 6 U pipe */
|
||||||
|
jnz LookupLoop /* 6 V pipe */
|
||||||
|
movb (%esi,%ecx), %ah
|
||||||
|
cmpb %bh, %ah
|
||||||
|
jnz LookupLoop
|
||||||
|
movl window(%esp), %eax
|
||||||
|
movw (%eax,%ecx), %ax
|
||||||
|
cmpw scanstart(%esp), %ax
|
||||||
|
jnz LookupLoop
|
||||||
|
|
||||||
|
/* Store the current value of chainlen. */
|
||||||
|
|
||||||
|
movl %ebx, chainlenscanend(%esp)
|
||||||
|
|
||||||
|
/* Point %edi to the string under scrutiny, and %esi to the string we */
|
||||||
|
/* are hoping to match it up with. In actuality, %esi and %edi are */
|
||||||
|
/* both pointed (MAX_MATCH_8 - scanalign) bytes ahead, and %edx is */
|
||||||
|
/* initialized to -(MAX_MATCH_8 - scanalign). */
|
||||||
|
|
||||||
|
movl window(%esp), %esi
|
||||||
|
movl scan(%esp), %edi
|
||||||
|
addl %ecx, %esi
|
||||||
|
movl scanalign(%esp), %eax
|
||||||
|
movl $(-MAX_MATCH_8), %edx
|
||||||
|
lea MAX_MATCH_8(%edi,%eax), %edi
|
||||||
|
lea MAX_MATCH_8(%esi,%eax), %esi
|
||||||
|
|
||||||
|
/* Test the strings for equality, 8 bytes at a time. At the end,
|
||||||
|
* adjust %edx so that it is offset to the exact byte that mismatched.
|
||||||
|
*
|
||||||
|
* We already know at this point that the first three bytes of the
|
||||||
|
* strings match each other, and they can be safely passed over before
|
||||||
|
* starting the compare loop. So what this code does is skip over 0-3
|
||||||
|
* bytes, as much as necessary in order to dword-align the %edi
|
||||||
|
* pointer. (%esi will still be misaligned three times out of four.)
|
||||||
|
*
|
||||||
|
* It should be confessed that this loop usually does not represent
|
||||||
|
* much of the total running time. Replacing it with a more
|
||||||
|
* straightforward "rep cmpsb" would not drastically degrade
|
||||||
|
* performance.
|
||||||
|
*/
|
||||||
|
LoopCmps:
|
||||||
|
movl (%esi,%edx), %eax
|
||||||
|
movl (%edi,%edx), %ebx
|
||||||
|
xorl %ebx, %eax
|
||||||
|
jnz LeaveLoopCmps
|
||||||
|
movl 4(%esi,%edx), %eax
|
||||||
|
movl 4(%edi,%edx), %ebx
|
||||||
|
xorl %ebx, %eax
|
||||||
|
jnz LeaveLoopCmps4
|
||||||
|
addl $8, %edx
|
||||||
|
jnz LoopCmps
|
||||||
|
jmp LenMaximum
|
||||||
|
LeaveLoopCmps4: addl $4, %edx
|
||||||
|
LeaveLoopCmps: testl $0x0000FFFF, %eax
|
||||||
|
jnz LenLower
|
||||||
|
addl $2, %edx
|
||||||
|
shrl $16, %eax
|
||||||
|
LenLower: subb $1, %al
|
||||||
|
adcl $0, %edx
|
||||||
|
|
||||||
|
/* Calculate the length of the match. If it is longer than MAX_MATCH, */
|
||||||
|
/* then automatically accept it as the best possible match and leave. */
|
||||||
|
|
||||||
|
lea (%edi,%edx), %eax
|
||||||
|
movl scan(%esp), %edi
|
||||||
|
subl %edi, %eax
|
||||||
|
cmpl $MAX_MATCH, %eax
|
||||||
|
jge LenMaximum
|
||||||
|
|
||||||
|
/* If the length of the match is not longer than the best match we */
|
||||||
|
/* have so far, then forget it and return to the lookup loop. */
|
||||||
|
|
||||||
|
movl deflatestate(%esp), %edx
|
||||||
|
movl bestlen(%esp), %ebx
|
||||||
|
cmpl %ebx, %eax
|
||||||
|
jg LongerMatch
|
||||||
|
movl chainlenscanend(%esp), %ebx
|
||||||
|
movl windowbestlen(%esp), %esi
|
||||||
|
movl dsPrev(%edx), %edi
|
||||||
|
movl wmask(%esp), %edx
|
||||||
|
andl %ecx, %edx
|
||||||
|
jmp LookupLoop
|
||||||
|
|
||||||
|
/* s->match_start = cur_match; */
|
||||||
|
/* best_len = len; */
|
||||||
|
/* if (len >= nice_match) break; */
|
||||||
|
/* scan_end = *(ushf*)(scan+best_len-1); */
|
||||||
|
|
||||||
|
LongerMatch: movl nicematch(%esp), %ebx
|
||||||
|
movl %eax, bestlen(%esp)
|
||||||
|
movl %ecx, dsMatchStart(%edx)
|
||||||
|
cmpl %ebx, %eax
|
||||||
|
jge LeaveNow
|
||||||
|
movl window(%esp), %esi
|
||||||
|
addl %eax, %esi
|
||||||
|
movl %esi, windowbestlen(%esp)
|
||||||
|
movl chainlenscanend(%esp), %ebx
|
||||||
|
movw -1(%edi,%eax), %bx
|
||||||
|
movl dsPrev(%edx), %edi
|
||||||
|
movl %ebx, chainlenscanend(%esp)
|
||||||
|
movl wmask(%esp), %edx
|
||||||
|
andl %ecx, %edx
|
||||||
|
jmp LookupLoop
|
||||||
|
|
||||||
|
/* Accept the current string, with the maximum possible length. */
|
||||||
|
|
||||||
|
LenMaximum: movl deflatestate(%esp), %edx
|
||||||
|
movl $MAX_MATCH, bestlen(%esp)
|
||||||
|
movl %ecx, dsMatchStart(%edx)
|
||||||
|
|
||||||
|
/* if ((uInt)best_len <= s->lookahead) return (uInt)best_len; */
|
||||||
|
/* return s->lookahead; */
|
||||||
|
|
||||||
|
LeaveNow:
|
||||||
|
movl deflatestate(%esp), %edx
|
||||||
|
movl bestlen(%esp), %ebx
|
||||||
|
movl dsLookahead(%edx), %eax
|
||||||
|
cmpl %eax, %ebx
|
||||||
|
jg LookaheadRet
|
||||||
|
movl %ebx, %eax
|
||||||
|
LookaheadRet:
|
||||||
|
|
||||||
|
/* Restore the stack and return from whence we came. */
|
||||||
|
|
||||||
|
addl $LocalVarsSize, %esp
|
||||||
|
popl %ebx
|
||||||
|
popl %esi
|
||||||
|
popl %edi
|
||||||
|
popl %ebp
|
||||||
|
match_init: ret
|
||||||
34
contrib/asm686/README.686
Normal file
34
contrib/asm686/README.686
Normal file
@@ -0,0 +1,34 @@
|
|||||||
|
This is a patched version of zlib, modified to use
|
||||||
|
Pentium-Pro-optimized assembly code in the deflation algorithm. The
|
||||||
|
files changed/added by this patch are:
|
||||||
|
|
||||||
|
README.686
|
||||||
|
match.S
|
||||||
|
|
||||||
|
The speedup that this patch provides varies, depending on whether the
|
||||||
|
compiler used to build the original version of zlib falls afoul of the
|
||||||
|
PPro's speed traps. My own tests show a speedup of around 10-20% at
|
||||||
|
the default compression level, and 20-30% using -9, against a version
|
||||||
|
compiled using gcc 2.7.2.3. Your mileage may vary.
|
||||||
|
|
||||||
|
Note that this code has been tailored for the PPro/PII in particular,
|
||||||
|
and will not perform particuarly well on a Pentium.
|
||||||
|
|
||||||
|
If you are using an assembler other than GNU as, you will have to
|
||||||
|
translate match.S to use your assembler's syntax. (Have fun.)
|
||||||
|
|
||||||
|
Brian Raiter
|
||||||
|
breadbox@muppetlabs.com
|
||||||
|
April, 1998
|
||||||
|
|
||||||
|
|
||||||
|
Added for zlib 1.1.3:
|
||||||
|
|
||||||
|
The patches come from
|
||||||
|
http://www.muppetlabs.com/~breadbox/software/assembly.html
|
||||||
|
|
||||||
|
To compile zlib with this asm file, copy match.S to the zlib directory
|
||||||
|
then do:
|
||||||
|
|
||||||
|
CFLAGS="-O3 -DASMV" ./configure
|
||||||
|
make OBJA=match.o
|
||||||
327
contrib/asm686/match.S
Normal file
327
contrib/asm686/match.S
Normal file
@@ -0,0 +1,327 @@
|
|||||||
|
/* match.s -- Pentium-Pro-optimized version of longest_match()
|
||||||
|
* Written for zlib 1.1.2
|
||||||
|
* Copyright (C) 1998 Brian Raiter <breadbox@muppetlabs.com>
|
||||||
|
*
|
||||||
|
* This is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef NO_UNDERLINE
|
||||||
|
#define match_init _match_init
|
||||||
|
#define longest_match _longest_match
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define MAX_MATCH (258)
|
||||||
|
#define MIN_MATCH (3)
|
||||||
|
#define MIN_LOOKAHEAD (MAX_MATCH + MIN_MATCH + 1)
|
||||||
|
#define MAX_MATCH_8 ((MAX_MATCH + 7) & ~7)
|
||||||
|
|
||||||
|
/* stack frame offsets */
|
||||||
|
|
||||||
|
#define chainlenwmask 0 /* high word: current chain len */
|
||||||
|
/* low word: s->wmask */
|
||||||
|
#define window 4 /* local copy of s->window */
|
||||||
|
#define windowbestlen 8 /* s->window + bestlen */
|
||||||
|
#define scanstart 16 /* first two bytes of string */
|
||||||
|
#define scanend 12 /* last two bytes of string */
|
||||||
|
#define scanalign 20 /* dword-misalignment of string */
|
||||||
|
#define nicematch 24 /* a good enough match size */
|
||||||
|
#define bestlen 28 /* size of best match so far */
|
||||||
|
#define scan 32 /* ptr to string wanting match */
|
||||||
|
|
||||||
|
#define LocalVarsSize (36)
|
||||||
|
/* saved ebx 36 */
|
||||||
|
/* saved edi 40 */
|
||||||
|
/* saved esi 44 */
|
||||||
|
/* saved ebp 48 */
|
||||||
|
/* return address 52 */
|
||||||
|
#define deflatestate 56 /* the function arguments */
|
||||||
|
#define curmatch 60
|
||||||
|
|
||||||
|
/* Offsets for fields in the deflate_state structure. These numbers
|
||||||
|
* are calculated from the definition of deflate_state, with the
|
||||||
|
* assumption that the compiler will dword-align the fields. (Thus,
|
||||||
|
* changing the definition of deflate_state could easily cause this
|
||||||
|
* program to crash horribly, without so much as a warning at
|
||||||
|
* compile time. Sigh.)
|
||||||
|
*/
|
||||||
|
#define dsWSize 36
|
||||||
|
#define dsWMask 44
|
||||||
|
#define dsWindow 48
|
||||||
|
#define dsPrev 56
|
||||||
|
#define dsMatchLen 88
|
||||||
|
#define dsPrevMatch 92
|
||||||
|
#define dsStrStart 100
|
||||||
|
#define dsMatchStart 104
|
||||||
|
#define dsLookahead 108
|
||||||
|
#define dsPrevLen 112
|
||||||
|
#define dsMaxChainLen 116
|
||||||
|
#define dsGoodMatch 132
|
||||||
|
#define dsNiceMatch 136
|
||||||
|
|
||||||
|
|
||||||
|
.file "match.S"
|
||||||
|
|
||||||
|
.globl match_init, longest_match
|
||||||
|
|
||||||
|
.text
|
||||||
|
|
||||||
|
/* uInt longest_match(deflate_state *deflatestate, IPos curmatch) */
|
||||||
|
|
||||||
|
longest_match:
|
||||||
|
|
||||||
|
/* Save registers that the compiler may be using, and adjust %esp to */
|
||||||
|
/* make room for our stack frame. */
|
||||||
|
|
||||||
|
pushl %ebp
|
||||||
|
pushl %edi
|
||||||
|
pushl %esi
|
||||||
|
pushl %ebx
|
||||||
|
subl $LocalVarsSize, %esp
|
||||||
|
|
||||||
|
/* Retrieve the function arguments. %ecx will hold cur_match */
|
||||||
|
/* throughout the entire function. %edx will hold the pointer to the */
|
||||||
|
/* deflate_state structure during the function's setup (before */
|
||||||
|
/* entering the main loop). */
|
||||||
|
|
||||||
|
movl deflatestate(%esp), %edx
|
||||||
|
movl curmatch(%esp), %ecx
|
||||||
|
|
||||||
|
/* uInt wmask = s->w_mask; */
|
||||||
|
/* unsigned chain_length = s->max_chain_length; */
|
||||||
|
/* if (s->prev_length >= s->good_match) { */
|
||||||
|
/* chain_length >>= 2; */
|
||||||
|
/* } */
|
||||||
|
|
||||||
|
movl dsPrevLen(%edx), %eax
|
||||||
|
movl dsGoodMatch(%edx), %ebx
|
||||||
|
cmpl %ebx, %eax
|
||||||
|
movl dsWMask(%edx), %eax
|
||||||
|
movl dsMaxChainLen(%edx), %ebx
|
||||||
|
jl LastMatchGood
|
||||||
|
shrl $2, %ebx
|
||||||
|
LastMatchGood:
|
||||||
|
|
||||||
|
/* chainlen is decremented once beforehand so that the function can */
|
||||||
|
/* use the sign flag instead of the zero flag for the exit test. */
|
||||||
|
/* It is then shifted into the high word, to make room for the wmask */
|
||||||
|
/* value, which it will always accompany. */
|
||||||
|
|
||||||
|
decl %ebx
|
||||||
|
shll $16, %ebx
|
||||||
|
orl %eax, %ebx
|
||||||
|
movl %ebx, chainlenwmask(%esp)
|
||||||
|
|
||||||
|
/* if ((uInt)nice_match > s->lookahead) nice_match = s->lookahead; */
|
||||||
|
|
||||||
|
movl dsNiceMatch(%edx), %eax
|
||||||
|
movl dsLookahead(%edx), %ebx
|
||||||
|
cmpl %eax, %ebx
|
||||||
|
jl LookaheadLess
|
||||||
|
movl %eax, %ebx
|
||||||
|
LookaheadLess: movl %ebx, nicematch(%esp)
|
||||||
|
|
||||||
|
/* register Bytef *scan = s->window + s->strstart; */
|
||||||
|
|
||||||
|
movl dsWindow(%edx), %esi
|
||||||
|
movl %esi, window(%esp)
|
||||||
|
movl dsStrStart(%edx), %ebp
|
||||||
|
lea (%esi,%ebp), %edi
|
||||||
|
movl %edi, scan(%esp)
|
||||||
|
|
||||||
|
/* Determine how many bytes the scan ptr is off from being */
|
||||||
|
/* dword-aligned. */
|
||||||
|
|
||||||
|
movl %edi, %eax
|
||||||
|
negl %eax
|
||||||
|
andl $3, %eax
|
||||||
|
movl %eax, scanalign(%esp)
|
||||||
|
|
||||||
|
/* IPos limit = s->strstart > (IPos)MAX_DIST(s) ? */
|
||||||
|
/* s->strstart - (IPos)MAX_DIST(s) : NIL; */
|
||||||
|
|
||||||
|
movl dsWSize(%edx), %eax
|
||||||
|
subl $MIN_LOOKAHEAD, %eax
|
||||||
|
subl %eax, %ebp
|
||||||
|
jg LimitPositive
|
||||||
|
xorl %ebp, %ebp
|
||||||
|
LimitPositive:
|
||||||
|
|
||||||
|
/* int best_len = s->prev_length; */
|
||||||
|
|
||||||
|
movl dsPrevLen(%edx), %eax
|
||||||
|
movl %eax, bestlen(%esp)
|
||||||
|
|
||||||
|
/* Store the sum of s->window + best_len in %esi locally, and in %esi. */
|
||||||
|
|
||||||
|
addl %eax, %esi
|
||||||
|
movl %esi, windowbestlen(%esp)
|
||||||
|
|
||||||
|
/* register ush scan_start = *(ushf*)scan; */
|
||||||
|
/* register ush scan_end = *(ushf*)(scan+best_len-1); */
|
||||||
|
/* Posf *prev = s->prev; */
|
||||||
|
|
||||||
|
movzwl (%edi), %ebx
|
||||||
|
movl %ebx, scanstart(%esp)
|
||||||
|
movzwl -1(%edi,%eax), %ebx
|
||||||
|
movl %ebx, scanend(%esp)
|
||||||
|
movl dsPrev(%edx), %edi
|
||||||
|
|
||||||
|
/* Jump into the main loop. */
|
||||||
|
|
||||||
|
movl chainlenwmask(%esp), %edx
|
||||||
|
jmp LoopEntry
|
||||||
|
|
||||||
|
.balign 16
|
||||||
|
|
||||||
|
/* do {
|
||||||
|
* match = s->window + cur_match;
|
||||||
|
* if (*(ushf*)(match+best_len-1) != scan_end ||
|
||||||
|
* *(ushf*)match != scan_start) continue;
|
||||||
|
* [...]
|
||||||
|
* } while ((cur_match = prev[cur_match & wmask]) > limit
|
||||||
|
* && --chain_length != 0);
|
||||||
|
*
|
||||||
|
* Here is the inner loop of the function. The function will spend the
|
||||||
|
* majority of its time in this loop, and majority of that time will
|
||||||
|
* be spent in the first ten instructions.
|
||||||
|
*
|
||||||
|
* Within this loop:
|
||||||
|
* %ebx = scanend
|
||||||
|
* %ecx = curmatch
|
||||||
|
* %edx = chainlenwmask - i.e., ((chainlen << 16) | wmask)
|
||||||
|
* %esi = windowbestlen - i.e., (window + bestlen)
|
||||||
|
* %edi = prev
|
||||||
|
* %ebp = limit
|
||||||
|
*/
|
||||||
|
LookupLoop:
|
||||||
|
andl %edx, %ecx
|
||||||
|
movzwl (%edi,%ecx,2), %ecx
|
||||||
|
cmpl %ebp, %ecx
|
||||||
|
jbe LeaveNow
|
||||||
|
subl $0x00010000, %edx
|
||||||
|
js LeaveNow
|
||||||
|
LoopEntry: movzwl -1(%esi,%ecx), %eax
|
||||||
|
cmpl %ebx, %eax
|
||||||
|
jnz LookupLoop
|
||||||
|
movl window(%esp), %eax
|
||||||
|
movzwl (%eax,%ecx), %eax
|
||||||
|
cmpl scanstart(%esp), %eax
|
||||||
|
jnz LookupLoop
|
||||||
|
|
||||||
|
/* Store the current value of chainlen. */
|
||||||
|
|
||||||
|
movl %edx, chainlenwmask(%esp)
|
||||||
|
|
||||||
|
/* Point %edi to the string under scrutiny, and %esi to the string we */
|
||||||
|
/* are hoping to match it up with. In actuality, %esi and %edi are */
|
||||||
|
/* both pointed (MAX_MATCH_8 - scanalign) bytes ahead, and %edx is */
|
||||||
|
/* initialized to -(MAX_MATCH_8 - scanalign). */
|
||||||
|
|
||||||
|
movl window(%esp), %esi
|
||||||
|
movl scan(%esp), %edi
|
||||||
|
addl %ecx, %esi
|
||||||
|
movl scanalign(%esp), %eax
|
||||||
|
movl $(-MAX_MATCH_8), %edx
|
||||||
|
lea MAX_MATCH_8(%edi,%eax), %edi
|
||||||
|
lea MAX_MATCH_8(%esi,%eax), %esi
|
||||||
|
|
||||||
|
/* Test the strings for equality, 8 bytes at a time. At the end,
|
||||||
|
* adjust %edx so that it is offset to the exact byte that mismatched.
|
||||||
|
*
|
||||||
|
* We already know at this point that the first three bytes of the
|
||||||
|
* strings match each other, and they can be safely passed over before
|
||||||
|
* starting the compare loop. So what this code does is skip over 0-3
|
||||||
|
* bytes, as much as necessary in order to dword-align the %edi
|
||||||
|
* pointer. (%esi will still be misaligned three times out of four.)
|
||||||
|
*
|
||||||
|
* It should be confessed that this loop usually does not represent
|
||||||
|
* much of the total running time. Replacing it with a more
|
||||||
|
* straightforward "rep cmpsb" would not drastically degrade
|
||||||
|
* performance.
|
||||||
|
*/
|
||||||
|
LoopCmps:
|
||||||
|
movl (%esi,%edx), %eax
|
||||||
|
xorl (%edi,%edx), %eax
|
||||||
|
jnz LeaveLoopCmps
|
||||||
|
movl 4(%esi,%edx), %eax
|
||||||
|
xorl 4(%edi,%edx), %eax
|
||||||
|
jnz LeaveLoopCmps4
|
||||||
|
addl $8, %edx
|
||||||
|
jnz LoopCmps
|
||||||
|
jmp LenMaximum
|
||||||
|
LeaveLoopCmps4: addl $4, %edx
|
||||||
|
LeaveLoopCmps: testl $0x0000FFFF, %eax
|
||||||
|
jnz LenLower
|
||||||
|
addl $2, %edx
|
||||||
|
shrl $16, %eax
|
||||||
|
LenLower: subb $1, %al
|
||||||
|
adcl $0, %edx
|
||||||
|
|
||||||
|
/* Calculate the length of the match. If it is longer than MAX_MATCH, */
|
||||||
|
/* then automatically accept it as the best possible match and leave. */
|
||||||
|
|
||||||
|
lea (%edi,%edx), %eax
|
||||||
|
movl scan(%esp), %edi
|
||||||
|
subl %edi, %eax
|
||||||
|
cmpl $MAX_MATCH, %eax
|
||||||
|
jge LenMaximum
|
||||||
|
|
||||||
|
/* If the length of the match is not longer than the best match we */
|
||||||
|
/* have so far, then forget it and return to the lookup loop. */
|
||||||
|
|
||||||
|
movl deflatestate(%esp), %edx
|
||||||
|
movl bestlen(%esp), %ebx
|
||||||
|
cmpl %ebx, %eax
|
||||||
|
jg LongerMatch
|
||||||
|
movl windowbestlen(%esp), %esi
|
||||||
|
movl dsPrev(%edx), %edi
|
||||||
|
movl scanend(%esp), %ebx
|
||||||
|
movl chainlenwmask(%esp), %edx
|
||||||
|
jmp LookupLoop
|
||||||
|
|
||||||
|
/* s->match_start = cur_match; */
|
||||||
|
/* best_len = len; */
|
||||||
|
/* if (len >= nice_match) break; */
|
||||||
|
/* scan_end = *(ushf*)(scan+best_len-1); */
|
||||||
|
|
||||||
|
LongerMatch: movl nicematch(%esp), %ebx
|
||||||
|
movl %eax, bestlen(%esp)
|
||||||
|
movl %ecx, dsMatchStart(%edx)
|
||||||
|
cmpl %ebx, %eax
|
||||||
|
jge LeaveNow
|
||||||
|
movl window(%esp), %esi
|
||||||
|
addl %eax, %esi
|
||||||
|
movl %esi, windowbestlen(%esp)
|
||||||
|
movzwl -1(%edi,%eax), %ebx
|
||||||
|
movl dsPrev(%edx), %edi
|
||||||
|
movl %ebx, scanend(%esp)
|
||||||
|
movl chainlenwmask(%esp), %edx
|
||||||
|
jmp LookupLoop
|
||||||
|
|
||||||
|
/* Accept the current string, with the maximum possible length. */
|
||||||
|
|
||||||
|
LenMaximum: movl deflatestate(%esp), %edx
|
||||||
|
movl $MAX_MATCH, bestlen(%esp)
|
||||||
|
movl %ecx, dsMatchStart(%edx)
|
||||||
|
|
||||||
|
/* if ((uInt)best_len <= s->lookahead) return (uInt)best_len; */
|
||||||
|
/* return s->lookahead; */
|
||||||
|
|
||||||
|
LeaveNow:
|
||||||
|
movl deflatestate(%esp), %edx
|
||||||
|
movl bestlen(%esp), %ebx
|
||||||
|
movl dsLookahead(%edx), %eax
|
||||||
|
cmpl %eax, %ebx
|
||||||
|
jg LookaheadRet
|
||||||
|
movl %ebx, %eax
|
||||||
|
LookaheadRet:
|
||||||
|
|
||||||
|
/* Restore the stack and return from whence we came. */
|
||||||
|
|
||||||
|
addl $LocalVarsSize, %esp
|
||||||
|
popl %ebx
|
||||||
|
popl %esi
|
||||||
|
popl %edi
|
||||||
|
popl %ebp
|
||||||
|
match_init: ret
|
||||||
36
contrib/delphi/zlib.mak
Normal file
36
contrib/delphi/zlib.mak
Normal file
@@ -0,0 +1,36 @@
|
|||||||
|
# Makefile for zlib32bd.lib
|
||||||
|
# ------------- Borland C++ 4.5 -------------
|
||||||
|
|
||||||
|
# The (32-bit) zlib32bd.lib made with this makefile is intended for use
|
||||||
|
# in making the (32-bit) DLL, png32bd.dll. It uses the "stdcall" calling
|
||||||
|
# convention.
|
||||||
|
|
||||||
|
CFLAGS= -ps -O2 -C -K -N- -k- -d -3 -r- -w-par -w-aus -WDE
|
||||||
|
CC=f:\bc45\bin\bcc32
|
||||||
|
LIBFLAGS= /C
|
||||||
|
LIB=f:\bc45\bin\tlib
|
||||||
|
ZLIB=zlib32bd.lib
|
||||||
|
|
||||||
|
.autodepend
|
||||||
|
.c.obj:
|
||||||
|
$(CC) -c $(CFLAGS) $<
|
||||||
|
|
||||||
|
OBJ1=adler32.obj compress.obj crc32.obj deflate.obj gzio.obj infblock.obj
|
||||||
|
OBJ2=infcodes.obj inflate.obj inftrees.obj infutil.obj inffast.obj
|
||||||
|
OBJ3=trees.obj uncompr.obj zutil.obj
|
||||||
|
pOBJ1=+adler32.obj+compress.obj+crc32.obj+deflate.obj+gzio.obj+infblock.obj
|
||||||
|
pOBJ2=+infcodes.obj+inflate.obj+inftrees.obj+infutil.obj+inffast.obj
|
||||||
|
pOBJ3=+trees.obj+uncompr.obj+zutil.obj
|
||||||
|
|
||||||
|
all: $(ZLIB)
|
||||||
|
|
||||||
|
$(ZLIB): $(OBJ1) $(OBJ2) $(OBJ3)
|
||||||
|
@if exist $@ del $@
|
||||||
|
$(LIB) @&&|
|
||||||
|
$@ $(LIBFLAGS) &
|
||||||
|
$(pOBJ1) &
|
||||||
|
$(pOBJ2) &
|
||||||
|
$(pOBJ3)
|
||||||
|
|
|
||||||
|
|
||||||
|
# End of makefile for zlib32bd.lib
|
||||||
169
contrib/delphi/zlibdef.pas
Normal file
169
contrib/delphi/zlibdef.pas
Normal file
@@ -0,0 +1,169 @@
|
|||||||
|
unit zlibdef;
|
||||||
|
|
||||||
|
interface
|
||||||
|
|
||||||
|
uses
|
||||||
|
Windows;
|
||||||
|
|
||||||
|
const
|
||||||
|
ZLIB_VERSION = '1.1.3';
|
||||||
|
|
||||||
|
type
|
||||||
|
voidpf = Pointer;
|
||||||
|
int = Integer;
|
||||||
|
uInt = Cardinal;
|
||||||
|
pBytef = PChar;
|
||||||
|
uLong = Cardinal;
|
||||||
|
|
||||||
|
alloc_func = function(opaque: voidpf; items, size: uInt): voidpf;
|
||||||
|
stdcall;
|
||||||
|
free_func = procedure(opaque, address: voidpf);
|
||||||
|
stdcall;
|
||||||
|
|
||||||
|
internal_state = Pointer;
|
||||||
|
|
||||||
|
z_streamp = ^z_stream;
|
||||||
|
z_stream = packed record
|
||||||
|
next_in: pBytef; // next input byte
|
||||||
|
avail_in: uInt; // number of bytes available at next_in
|
||||||
|
total_in: uLong; // total nb of input bytes read so far
|
||||||
|
|
||||||
|
next_out: pBytef; // next output byte should be put there
|
||||||
|
avail_out: uInt; // remaining free space at next_out
|
||||||
|
total_out: uLong; // total nb of bytes output so far
|
||||||
|
|
||||||
|
msg: PChar; // last error message, NULL if no error
|
||||||
|
state: internal_state; // not visible by applications
|
||||||
|
|
||||||
|
zalloc: alloc_func; // used to allocate the internal state
|
||||||
|
zfree: free_func; // used to free the internal state
|
||||||
|
opaque: voidpf; // private data object passed to zalloc and zfree
|
||||||
|
|
||||||
|
data_type: int; // best guess about the data type: ascii or binary
|
||||||
|
adler: uLong; // adler32 value of the uncompressed data
|
||||||
|
reserved: uLong; // reserved for future use
|
||||||
|
end;
|
||||||
|
|
||||||
|
const
|
||||||
|
Z_NO_FLUSH = 0;
|
||||||
|
Z_SYNC_FLUSH = 2;
|
||||||
|
Z_FULL_FLUSH = 3;
|
||||||
|
Z_FINISH = 4;
|
||||||
|
|
||||||
|
Z_OK = 0;
|
||||||
|
Z_STREAM_END = 1;
|
||||||
|
|
||||||
|
Z_NO_COMPRESSION = 0;
|
||||||
|
Z_BEST_SPEED = 1;
|
||||||
|
Z_BEST_COMPRESSION = 9;
|
||||||
|
Z_DEFAULT_COMPRESSION = -1;
|
||||||
|
|
||||||
|
Z_FILTERED = 1;
|
||||||
|
Z_HUFFMAN_ONLY = 2;
|
||||||
|
Z_DEFAULT_STRATEGY = 0;
|
||||||
|
|
||||||
|
Z_BINARY = 0;
|
||||||
|
Z_ASCII = 1;
|
||||||
|
Z_UNKNOWN = 2;
|
||||||
|
|
||||||
|
Z_DEFLATED = 8;
|
||||||
|
|
||||||
|
MAX_MEM_LEVEL = 9;
|
||||||
|
|
||||||
|
function adler32(adler: uLong; const buf: pBytef; len: uInt): uLong;
|
||||||
|
stdcall;
|
||||||
|
function crc32(crc: uLong; const buf: pBytef; len: uInt): uLong;
|
||||||
|
stdcall;
|
||||||
|
function deflate(strm: z_streamp; flush: int): int;
|
||||||
|
stdcall;
|
||||||
|
function deflateCopy(dest, source: z_streamp): int;
|
||||||
|
stdcall;
|
||||||
|
function deflateEnd(strm: z_streamp): int;
|
||||||
|
stdcall;
|
||||||
|
function deflateInit2_(strm: z_streamp; level, method,
|
||||||
|
windowBits, memLevel, strategy: int;
|
||||||
|
const version: PChar; stream_size: int): int;
|
||||||
|
stdcall;
|
||||||
|
function deflateInit_(strm: z_streamp; level: int;
|
||||||
|
const version: PChar; stream_size: int): int;
|
||||||
|
stdcall;
|
||||||
|
function deflateParams(strm: z_streamp; level, strategy: int): int;
|
||||||
|
stdcall;
|
||||||
|
function deflateReset(strm: z_streamp): int;
|
||||||
|
stdcall;
|
||||||
|
function deflateSetDictionary(strm: z_streamp;
|
||||||
|
const dictionary: pBytef;
|
||||||
|
dictLength: uInt): int;
|
||||||
|
stdcall;
|
||||||
|
function inflate(strm: z_streamp; flush: int): int;
|
||||||
|
stdcall;
|
||||||
|
function inflateEnd(strm: z_streamp): int;
|
||||||
|
stdcall;
|
||||||
|
function inflateInit2_(strm: z_streamp; windowBits: int;
|
||||||
|
const version: PChar; stream_size: int): int;
|
||||||
|
stdcall;
|
||||||
|
function inflateInit_(strm: z_streamp; const version: PChar;
|
||||||
|
stream_size: int): int;
|
||||||
|
stdcall;
|
||||||
|
function inflateReset(strm: z_streamp): int;
|
||||||
|
stdcall;
|
||||||
|
function inflateSetDictionary(strm: z_streamp;
|
||||||
|
const dictionary: pBytef;
|
||||||
|
dictLength: uInt): int;
|
||||||
|
stdcall;
|
||||||
|
function inflateSync(strm: z_streamp): int;
|
||||||
|
stdcall;
|
||||||
|
|
||||||
|
function deflateInit(strm: z_streamp; level: int): int;
|
||||||
|
function deflateInit2(strm: z_streamp; level, method, windowBits,
|
||||||
|
memLevel, strategy: int): int;
|
||||||
|
function inflateInit(strm: z_streamp): int;
|
||||||
|
function inflateInit2(strm: z_streamp; windowBits: int): int;
|
||||||
|
|
||||||
|
implementation
|
||||||
|
|
||||||
|
function deflateInit(strm: z_streamp; level: int): int;
|
||||||
|
begin
|
||||||
|
Result := deflateInit_(strm, level, ZLIB_VERSION, sizeof(z_stream));
|
||||||
|
end;
|
||||||
|
|
||||||
|
function deflateInit2(strm: z_streamp; level, method, windowBits,
|
||||||
|
memLevel, strategy: int): int;
|
||||||
|
begin
|
||||||
|
Result := deflateInit2_(strm, level, method, windowBits, memLevel,
|
||||||
|
strategy, ZLIB_VERSION, sizeof(z_stream));
|
||||||
|
end;
|
||||||
|
|
||||||
|
function inflateInit(strm: z_streamp): int;
|
||||||
|
begin
|
||||||
|
Result := inflateInit_(strm, ZLIB_VERSION, sizeof(z_stream));
|
||||||
|
end;
|
||||||
|
|
||||||
|
function inflateInit2(strm: z_streamp; windowBits: int): int;
|
||||||
|
begin
|
||||||
|
Result := inflateInit2_(strm, windowBits, ZLIB_VERSION,
|
||||||
|
sizeof(z_stream));
|
||||||
|
end;
|
||||||
|
|
||||||
|
const
|
||||||
|
zlibDLL = 'png32bd.dll';
|
||||||
|
|
||||||
|
function adler32; external zlibDLL;
|
||||||
|
function crc32; external zlibDLL;
|
||||||
|
function deflate; external zlibDLL;
|
||||||
|
function deflateCopy; external zlibDLL;
|
||||||
|
function deflateEnd; external zlibDLL;
|
||||||
|
function deflateInit2_; external zlibDLL;
|
||||||
|
function deflateInit_; external zlibDLL;
|
||||||
|
function deflateParams; external zlibDLL;
|
||||||
|
function deflateReset; external zlibDLL;
|
||||||
|
function deflateSetDictionary; external zlibDLL;
|
||||||
|
function inflate; external zlibDLL;
|
||||||
|
function inflateEnd; external zlibDLL;
|
||||||
|
function inflateInit2_; external zlibDLL;
|
||||||
|
function inflateInit_; external zlibDLL;
|
||||||
|
function inflateReset; external zlibDLL;
|
||||||
|
function inflateSetDictionary; external zlibDLL;
|
||||||
|
function inflateSync; external zlibDLL;
|
||||||
|
|
||||||
|
end.
|
||||||
224
contrib/delphi2/d_zlib.bpr
Normal file
224
contrib/delphi2/d_zlib.bpr
Normal file
@@ -0,0 +1,224 @@
|
|||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
!if !$d(BCB)
|
||||||
|
BCB = $(MAKEDIR)\..
|
||||||
|
!endif
|
||||||
|
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
# IDE SECTION
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
# The following section of the project makefile is managed by the BCB IDE.
|
||||||
|
# It is recommended to use the IDE to change any of the values in this
|
||||||
|
# section.
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
VERSION = BCB.03
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
PROJECT = d_zlib.lib
|
||||||
|
OBJFILES = d_zlib.obj adler32.obj deflate.obj infblock.obj infcodes.obj inffast.obj \
|
||||||
|
inflate.obj inftrees.obj infutil.obj trees.obj
|
||||||
|
RESFILES =
|
||||||
|
RESDEPEN = $(RESFILES)
|
||||||
|
LIBFILES =
|
||||||
|
LIBRARIES = VCL35.lib
|
||||||
|
SPARELIBS = VCL35.lib
|
||||||
|
DEFFILE =
|
||||||
|
PACKAGES = VCLX35.bpi VCL35.bpi VCLDB35.bpi VCLDBX35.bpi ibsmp35.bpi bcbsmp35.bpi \
|
||||||
|
dclocx35.bpi QRPT35.bpi TEEUI35.bpi TEEDB35.bpi TEE35.bpi DSS35.bpi \
|
||||||
|
NMFAST35.bpi INETDB35.bpi INET35.bpi VCLMID35.bpi
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
PATHCPP = .;
|
||||||
|
PATHASM = .;
|
||||||
|
PATHPAS = .;
|
||||||
|
PATHRC = .;
|
||||||
|
DEBUGLIBPATH = $(BCB)\lib\debug
|
||||||
|
RELEASELIBPATH = $(BCB)\lib\release
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
CFLAG1 = -O2 -Ve -d -k- -vi
|
||||||
|
CFLAG2 = -I$(BCB)\include;$(BCB)\include\vcl -H=$(BCB)\lib\vcl35.csm
|
||||||
|
CFLAG3 = -ff -pr -5
|
||||||
|
PFLAGS = -U;$(DEBUGLIBPATH) -I$(BCB)\include;$(BCB)\include\vcl -H -W -$I- -v -JPHN -M
|
||||||
|
RFLAGS = -i$(BCB)\include;$(BCB)\include\vcl
|
||||||
|
AFLAGS = /i$(BCB)\include /i$(BCB)\include\vcl /mx /w2 /zn
|
||||||
|
LFLAGS =
|
||||||
|
IFLAGS = -g -Gn
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
ALLOBJ = c0w32.obj $(OBJFILES)
|
||||||
|
ALLRES = $(RESFILES)
|
||||||
|
ALLLIB = $(LIBFILES) $(LIBRARIES) import32.lib cp32mt.lib
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
!!ifdef IDEOPTIONS
|
||||||
|
|
||||||
|
[Version Info]
|
||||||
|
IncludeVerInfo=0
|
||||||
|
AutoIncBuild=0
|
||||||
|
MajorVer=1
|
||||||
|
MinorVer=0
|
||||||
|
Release=0
|
||||||
|
Build=0
|
||||||
|
Debug=0
|
||||||
|
PreRelease=0
|
||||||
|
Special=0
|
||||||
|
Private=0
|
||||||
|
DLL=0
|
||||||
|
Locale=1040
|
||||||
|
CodePage=1252
|
||||||
|
|
||||||
|
[Version Info Keys]
|
||||||
|
CompanyName=
|
||||||
|
FileDescription=
|
||||||
|
FileVersion=1.0.0.0
|
||||||
|
InternalName=
|
||||||
|
LegalCopyright=
|
||||||
|
LegalTrademarks=
|
||||||
|
OriginalFilename=
|
||||||
|
ProductName=
|
||||||
|
ProductVersion=1.0.0.0
|
||||||
|
Comments=
|
||||||
|
|
||||||
|
[HistoryLists\hlIncludePath]
|
||||||
|
Count=2
|
||||||
|
Item0=$(BCB)\include
|
||||||
|
Item1=$(BCB)\include;$(BCB)\include\vcl
|
||||||
|
|
||||||
|
[HistoryLists\hlLibraryPath]
|
||||||
|
Count=1
|
||||||
|
Item0=$(BCB)\lib\obj;$(BCB)\lib
|
||||||
|
|
||||||
|
[HistoryLists\hlDebugSourcePath]
|
||||||
|
Count=1
|
||||||
|
Item0=$(BCB)\source\vcl
|
||||||
|
|
||||||
|
[Debugging]
|
||||||
|
DebugSourceDirs=
|
||||||
|
|
||||||
|
[Parameters]
|
||||||
|
RunParams=
|
||||||
|
HostApplication=
|
||||||
|
|
||||||
|
!endif
|
||||||
|
|
||||||
|
---------------------------------------------------------------------------
|
||||||
|
# MAKE SECTION
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
# This section of the project file is not used by the BCB IDE. It is for
|
||||||
|
# the benefit of building from the command-line using the MAKE utility.
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
.autodepend
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
!if !$d(BCC32)
|
||||||
|
BCC32 = bcc32
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if !$d(DCC32)
|
||||||
|
DCC32 = dcc32
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if !$d(TASM32)
|
||||||
|
TASM32 = tasm32
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if !$d(LINKER)
|
||||||
|
LINKER = TLib
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if !$d(BRCC32)
|
||||||
|
BRCC32 = brcc32
|
||||||
|
!endif
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
!if $d(PATHCPP)
|
||||||
|
.PATH.CPP = $(PATHCPP)
|
||||||
|
.PATH.C = $(PATHCPP)
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if $d(PATHPAS)
|
||||||
|
.PATH.PAS = $(PATHPAS)
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if $d(PATHASM)
|
||||||
|
.PATH.ASM = $(PATHASM)
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if $d(PATHRC)
|
||||||
|
.PATH.RC = $(PATHRC)
|
||||||
|
!endif
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
!ifdef IDEOPTIONS
|
||||||
|
|
||||||
|
[Version Info]
|
||||||
|
IncludeVerInfo=0
|
||||||
|
AutoIncBuild=0
|
||||||
|
MajorVer=1
|
||||||
|
MinorVer=0
|
||||||
|
Release=0
|
||||||
|
Build=0
|
||||||
|
Debug=0
|
||||||
|
PreRelease=0
|
||||||
|
Special=0
|
||||||
|
Private=0
|
||||||
|
DLL=0
|
||||||
|
Locale=1040
|
||||||
|
CodePage=1252
|
||||||
|
|
||||||
|
[Version Info Keys]
|
||||||
|
CompanyName=
|
||||||
|
FileDescription=
|
||||||
|
FileVersion=1.0.0.0
|
||||||
|
InternalName=
|
||||||
|
LegalCopyright=
|
||||||
|
LegalTrademarks=
|
||||||
|
OriginalFilename=
|
||||||
|
ProductName=
|
||||||
|
ProductVersion=1.0.0.0
|
||||||
|
Comments=
|
||||||
|
|
||||||
|
[HistoryLists\hlIncludePath]
|
||||||
|
Count=2
|
||||||
|
Item0=$(BCB)\include;$(BCB)\include\vcl
|
||||||
|
Item1=$(BCB)\include
|
||||||
|
|
||||||
|
[HistoryLists\hlLibraryPath]
|
||||||
|
Count=1
|
||||||
|
Item0=$(BCB)\lib\obj;$(BCB)\lib
|
||||||
|
|
||||||
|
[HistoryLists\hlDebugSourcePath]
|
||||||
|
Count=1
|
||||||
|
Item0=$(BCB)\source\vcl
|
||||||
|
|
||||||
|
[Debugging]
|
||||||
|
DebugSourceDirs=
|
||||||
|
|
||||||
|
[Parameters]
|
||||||
|
RunParams=
|
||||||
|
HostApplication=
|
||||||
|
|
||||||
|
!endif
|
||||||
|
|
||||||
|
$(PROJECT): $(OBJFILES) $(RESDEPEN) $(DEFFILE)
|
||||||
|
$(BCB)\BIN\$(LINKER) @&&!
|
||||||
|
$(LFLAGS) $(IFLAGS) +
|
||||||
|
$(ALLOBJ), +
|
||||||
|
$(PROJECT),, +
|
||||||
|
$(ALLLIB), +
|
||||||
|
$(DEFFILE), +
|
||||||
|
$(ALLRES)
|
||||||
|
!
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
.pas.hpp:
|
||||||
|
$(BCB)\BIN\$(DCC32) $(PFLAGS) {$< }
|
||||||
|
|
||||||
|
.pas.obj:
|
||||||
|
$(BCB)\BIN\$(DCC32) $(PFLAGS) {$< }
|
||||||
|
|
||||||
|
.cpp.obj:
|
||||||
|
$(BCB)\BIN\$(BCC32) $(CFLAG1) $(CFLAG2) $(CFLAG3) -n$(@D) {$< }
|
||||||
|
|
||||||
|
.c.obj:
|
||||||
|
$(BCB)\BIN\$(BCC32) $(CFLAG1) $(CFLAG2) $(CFLAG3) -n$(@D) {$< }
|
||||||
|
|
||||||
|
.asm.obj:
|
||||||
|
$(BCB)\BIN\$(TASM32) $(AFLAGS) $<, $@
|
||||||
|
|
||||||
|
.rc.res:
|
||||||
|
$(BCB)\BIN\$(BRCC32) $(RFLAGS) -fo$@ $<
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
17
contrib/delphi2/d_zlib.cpp
Normal file
17
contrib/delphi2/d_zlib.cpp
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
#include <condefs.h>
|
||||||
|
#pragma hdrstop
|
||||||
|
//---------------------------------------------------------------------------
|
||||||
|
USEUNIT("adler32.c");
|
||||||
|
USEUNIT("deflate.c");
|
||||||
|
USEUNIT("infblock.c");
|
||||||
|
USEUNIT("infcodes.c");
|
||||||
|
USEUNIT("inffast.c");
|
||||||
|
USEUNIT("inflate.c");
|
||||||
|
USEUNIT("inftrees.c");
|
||||||
|
USEUNIT("infutil.c");
|
||||||
|
USEUNIT("trees.c");
|
||||||
|
//---------------------------------------------------------------------------
|
||||||
|
#define Library
|
||||||
|
|
||||||
|
// To add a file to the library use the Project menu 'Add to Project'.
|
||||||
|
|
||||||
17
contrib/delphi2/readme.txt
Normal file
17
contrib/delphi2/readme.txt
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
These are files used to compile zlib under Borland C++ Builder 3.
|
||||||
|
|
||||||
|
zlib.bpg is the main project group that can be loaded in the BCB IDE and
|
||||||
|
loads all other *.bpr projects
|
||||||
|
|
||||||
|
zlib.bpr is a project used to create a static zlib.lib library with C calling
|
||||||
|
convention for functions.
|
||||||
|
|
||||||
|
zlib32.bpr creates a zlib32.dll dynamic link library with Windows standard
|
||||||
|
calling convention.
|
||||||
|
|
||||||
|
d_zlib.bpr creates a set of .obj files with register calling convention.
|
||||||
|
These files are used by zlib.pas to create a Delphi unit containing zlib.
|
||||||
|
The d_zlib.lib file generated isn't useful and can be deleted.
|
||||||
|
|
||||||
|
zlib.cpp, zlib32.cpp and d_zlib.cpp are used by the above projects.
|
||||||
|
|
||||||
26
contrib/delphi2/zlib.bpg
Normal file
26
contrib/delphi2/zlib.bpg
Normal file
@@ -0,0 +1,26 @@
|
|||||||
|
#------------------------------------------------------------------------------
|
||||||
|
VERSION = BWS.01
|
||||||
|
#------------------------------------------------------------------------------
|
||||||
|
!ifndef ROOT
|
||||||
|
ROOT = $(MAKEDIR)\..
|
||||||
|
!endif
|
||||||
|
#------------------------------------------------------------------------------
|
||||||
|
MAKE = $(ROOT)\bin\make.exe -$(MAKEFLAGS) -f$**
|
||||||
|
DCC = $(ROOT)\bin\dcc32.exe $**
|
||||||
|
BRCC = $(ROOT)\bin\brcc32.exe $**
|
||||||
|
#------------------------------------------------------------------------------
|
||||||
|
PROJECTS = zlib zlib32 d_zlib
|
||||||
|
#------------------------------------------------------------------------------
|
||||||
|
default: $(PROJECTS)
|
||||||
|
#------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
zlib: zlib.bpr
|
||||||
|
$(MAKE)
|
||||||
|
|
||||||
|
zlib32: zlib32.bpr
|
||||||
|
$(MAKE)
|
||||||
|
|
||||||
|
d_zlib: d_zlib.bpr
|
||||||
|
$(MAKE)
|
||||||
|
|
||||||
|
|
||||||
225
contrib/delphi2/zlib.bpr
Normal file
225
contrib/delphi2/zlib.bpr
Normal file
@@ -0,0 +1,225 @@
|
|||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
!if !$d(BCB)
|
||||||
|
BCB = $(MAKEDIR)\..
|
||||||
|
!endif
|
||||||
|
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
# IDE SECTION
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
# The following section of the project makefile is managed by the BCB IDE.
|
||||||
|
# It is recommended to use the IDE to change any of the values in this
|
||||||
|
# section.
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
VERSION = BCB.03
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
PROJECT = zlib.lib
|
||||||
|
OBJFILES = zlib.obj adler32.obj compress.obj crc32.obj deflate.obj gzio.obj infblock.obj \
|
||||||
|
infcodes.obj inffast.obj inflate.obj inftrees.obj infutil.obj trees.obj \
|
||||||
|
uncompr.obj zutil.obj
|
||||||
|
RESFILES =
|
||||||
|
RESDEPEN = $(RESFILES)
|
||||||
|
LIBFILES =
|
||||||
|
LIBRARIES = VCL35.lib
|
||||||
|
SPARELIBS = VCL35.lib
|
||||||
|
DEFFILE =
|
||||||
|
PACKAGES = VCLX35.bpi VCL35.bpi VCLDB35.bpi VCLDBX35.bpi ibsmp35.bpi bcbsmp35.bpi \
|
||||||
|
dclocx35.bpi QRPT35.bpi TEEUI35.bpi TEEDB35.bpi TEE35.bpi DSS35.bpi \
|
||||||
|
NMFAST35.bpi INETDB35.bpi INET35.bpi VCLMID35.bpi
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
PATHCPP = .;
|
||||||
|
PATHASM = .;
|
||||||
|
PATHPAS = .;
|
||||||
|
PATHRC = .;
|
||||||
|
DEBUGLIBPATH = $(BCB)\lib\debug
|
||||||
|
RELEASELIBPATH = $(BCB)\lib\release
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
CFLAG1 = -O2 -Ve -d -k- -vi
|
||||||
|
CFLAG2 = -I$(BCB)\include;$(BCB)\include\vcl -H=$(BCB)\lib\vcl35.csm
|
||||||
|
CFLAG3 = -ff -5
|
||||||
|
PFLAGS = -U;$(DEBUGLIBPATH) -I$(BCB)\include;$(BCB)\include\vcl -H -W -$I- -v -JPHN -M
|
||||||
|
RFLAGS = -i$(BCB)\include;$(BCB)\include\vcl
|
||||||
|
AFLAGS = /i$(BCB)\include /i$(BCB)\include\vcl /mx /w2 /zn
|
||||||
|
LFLAGS =
|
||||||
|
IFLAGS = -g -Gn
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
ALLOBJ = c0w32.obj $(OBJFILES)
|
||||||
|
ALLRES = $(RESFILES)
|
||||||
|
ALLLIB = $(LIBFILES) $(LIBRARIES) import32.lib cp32mt.lib
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
!!ifdef IDEOPTIONS
|
||||||
|
|
||||||
|
[Version Info]
|
||||||
|
IncludeVerInfo=0
|
||||||
|
AutoIncBuild=0
|
||||||
|
MajorVer=1
|
||||||
|
MinorVer=0
|
||||||
|
Release=0
|
||||||
|
Build=0
|
||||||
|
Debug=0
|
||||||
|
PreRelease=0
|
||||||
|
Special=0
|
||||||
|
Private=0
|
||||||
|
DLL=0
|
||||||
|
Locale=1040
|
||||||
|
CodePage=1252
|
||||||
|
|
||||||
|
[Version Info Keys]
|
||||||
|
CompanyName=
|
||||||
|
FileDescription=
|
||||||
|
FileVersion=1.0.0.0
|
||||||
|
InternalName=
|
||||||
|
LegalCopyright=
|
||||||
|
LegalTrademarks=
|
||||||
|
OriginalFilename=
|
||||||
|
ProductName=
|
||||||
|
ProductVersion=1.0.0.0
|
||||||
|
Comments=
|
||||||
|
|
||||||
|
[HistoryLists\hlIncludePath]
|
||||||
|
Count=2
|
||||||
|
Item0=$(BCB)\include
|
||||||
|
Item1=$(BCB)\include;$(BCB)\include\vcl
|
||||||
|
|
||||||
|
[HistoryLists\hlLibraryPath]
|
||||||
|
Count=1
|
||||||
|
Item0=$(BCB)\lib\obj;$(BCB)\lib
|
||||||
|
|
||||||
|
[HistoryLists\hlDebugSourcePath]
|
||||||
|
Count=1
|
||||||
|
Item0=$(BCB)\source\vcl
|
||||||
|
|
||||||
|
[Debugging]
|
||||||
|
DebugSourceDirs=
|
||||||
|
|
||||||
|
[Parameters]
|
||||||
|
RunParams=
|
||||||
|
HostApplication=
|
||||||
|
|
||||||
|
!endif
|
||||||
|
|
||||||
|
---------------------------------------------------------------------------
|
||||||
|
# MAKE SECTION
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
# This section of the project file is not used by the BCB IDE. It is for
|
||||||
|
# the benefit of building from the command-line using the MAKE utility.
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
.autodepend
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
!if !$d(BCC32)
|
||||||
|
BCC32 = bcc32
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if !$d(DCC32)
|
||||||
|
DCC32 = dcc32
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if !$d(TASM32)
|
||||||
|
TASM32 = tasm32
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if !$d(LINKER)
|
||||||
|
LINKER = TLib
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if !$d(BRCC32)
|
||||||
|
BRCC32 = brcc32
|
||||||
|
!endif
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
!if $d(PATHCPP)
|
||||||
|
.PATH.CPP = $(PATHCPP)
|
||||||
|
.PATH.C = $(PATHCPP)
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if $d(PATHPAS)
|
||||||
|
.PATH.PAS = $(PATHPAS)
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if $d(PATHASM)
|
||||||
|
.PATH.ASM = $(PATHASM)
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if $d(PATHRC)
|
||||||
|
.PATH.RC = $(PATHRC)
|
||||||
|
!endif
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
!ifdef IDEOPTIONS
|
||||||
|
|
||||||
|
[Version Info]
|
||||||
|
IncludeVerInfo=0
|
||||||
|
AutoIncBuild=0
|
||||||
|
MajorVer=1
|
||||||
|
MinorVer=0
|
||||||
|
Release=0
|
||||||
|
Build=0
|
||||||
|
Debug=0
|
||||||
|
PreRelease=0
|
||||||
|
Special=0
|
||||||
|
Private=0
|
||||||
|
DLL=0
|
||||||
|
Locale=1040
|
||||||
|
CodePage=1252
|
||||||
|
|
||||||
|
[Version Info Keys]
|
||||||
|
CompanyName=
|
||||||
|
FileDescription=
|
||||||
|
FileVersion=1.0.0.0
|
||||||
|
InternalName=
|
||||||
|
LegalCopyright=
|
||||||
|
LegalTrademarks=
|
||||||
|
OriginalFilename=
|
||||||
|
ProductName=
|
||||||
|
ProductVersion=1.0.0.0
|
||||||
|
Comments=
|
||||||
|
|
||||||
|
[HistoryLists\hlIncludePath]
|
||||||
|
Count=2
|
||||||
|
Item0=$(BCB)\include;$(BCB)\include\vcl
|
||||||
|
Item1=$(BCB)\include
|
||||||
|
|
||||||
|
[HistoryLists\hlLibraryPath]
|
||||||
|
Count=1
|
||||||
|
Item0=$(BCB)\lib\obj;$(BCB)\lib
|
||||||
|
|
||||||
|
[HistoryLists\hlDebugSourcePath]
|
||||||
|
Count=1
|
||||||
|
Item0=$(BCB)\source\vcl
|
||||||
|
|
||||||
|
[Debugging]
|
||||||
|
DebugSourceDirs=
|
||||||
|
|
||||||
|
[Parameters]
|
||||||
|
RunParams=
|
||||||
|
HostApplication=
|
||||||
|
|
||||||
|
!endif
|
||||||
|
|
||||||
|
$(PROJECT): $(OBJFILES) $(RESDEPEN) $(DEFFILE)
|
||||||
|
$(BCB)\BIN\$(LINKER) @&&!
|
||||||
|
$(LFLAGS) $(IFLAGS) +
|
||||||
|
$(ALLOBJ), +
|
||||||
|
$(PROJECT),, +
|
||||||
|
$(ALLLIB), +
|
||||||
|
$(DEFFILE), +
|
||||||
|
$(ALLRES)
|
||||||
|
!
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
.pas.hpp:
|
||||||
|
$(BCB)\BIN\$(DCC32) $(PFLAGS) {$< }
|
||||||
|
|
||||||
|
.pas.obj:
|
||||||
|
$(BCB)\BIN\$(DCC32) $(PFLAGS) {$< }
|
||||||
|
|
||||||
|
.cpp.obj:
|
||||||
|
$(BCB)\BIN\$(BCC32) $(CFLAG1) $(CFLAG2) $(CFLAG3) -n$(@D) {$< }
|
||||||
|
|
||||||
|
.c.obj:
|
||||||
|
$(BCB)\BIN\$(BCC32) $(CFLAG1) $(CFLAG2) $(CFLAG3) -n$(@D) {$< }
|
||||||
|
|
||||||
|
.asm.obj:
|
||||||
|
$(BCB)\BIN\$(TASM32) $(AFLAGS) $<, $@
|
||||||
|
|
||||||
|
.rc.res:
|
||||||
|
$(BCB)\BIN\$(BRCC32) $(RFLAGS) -fo$@ $<
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
22
contrib/delphi2/zlib.cpp
Normal file
22
contrib/delphi2/zlib.cpp
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
#include <condefs.h>
|
||||||
|
#pragma hdrstop
|
||||||
|
//---------------------------------------------------------------------------
|
||||||
|
USEUNIT("adler32.c");
|
||||||
|
USEUNIT("compress.c");
|
||||||
|
USEUNIT("crc32.c");
|
||||||
|
USEUNIT("deflate.c");
|
||||||
|
USEUNIT("gzio.c");
|
||||||
|
USEUNIT("infblock.c");
|
||||||
|
USEUNIT("infcodes.c");
|
||||||
|
USEUNIT("inffast.c");
|
||||||
|
USEUNIT("inflate.c");
|
||||||
|
USEUNIT("inftrees.c");
|
||||||
|
USEUNIT("infutil.c");
|
||||||
|
USEUNIT("trees.c");
|
||||||
|
USEUNIT("uncompr.c");
|
||||||
|
USEUNIT("zutil.c");
|
||||||
|
//---------------------------------------------------------------------------
|
||||||
|
#define Library
|
||||||
|
|
||||||
|
// To add a file to the library use the Project menu 'Add to Project'.
|
||||||
|
|
||||||
534
contrib/delphi2/zlib.pas
Normal file
534
contrib/delphi2/zlib.pas
Normal file
@@ -0,0 +1,534 @@
|
|||||||
|
{*******************************************************}
|
||||||
|
{ }
|
||||||
|
{ Delphi Supplemental Components }
|
||||||
|
{ ZLIB Data Compression Interface Unit }
|
||||||
|
{ }
|
||||||
|
{ Copyright (c) 1997 Borland International }
|
||||||
|
{ }
|
||||||
|
{*******************************************************}
|
||||||
|
|
||||||
|
{ Modified for zlib 1.1.3 by Davide Moretti <dave@rimini.com }
|
||||||
|
|
||||||
|
unit zlib;
|
||||||
|
|
||||||
|
interface
|
||||||
|
|
||||||
|
uses Sysutils, Classes;
|
||||||
|
|
||||||
|
type
|
||||||
|
TAlloc = function (AppData: Pointer; Items, Size: Integer): Pointer;
|
||||||
|
TFree = procedure (AppData, Block: Pointer);
|
||||||
|
|
||||||
|
// Internal structure. Ignore.
|
||||||
|
TZStreamRec = packed record
|
||||||
|
next_in: PChar; // next input byte
|
||||||
|
avail_in: Integer; // number of bytes available at next_in
|
||||||
|
total_in: Integer; // total nb of input bytes read so far
|
||||||
|
|
||||||
|
next_out: PChar; // next output byte should be put here
|
||||||
|
avail_out: Integer; // remaining free space at next_out
|
||||||
|
total_out: Integer; // total nb of bytes output so far
|
||||||
|
|
||||||
|
msg: PChar; // last error message, NULL if no error
|
||||||
|
internal: Pointer; // not visible by applications
|
||||||
|
|
||||||
|
zalloc: TAlloc; // used to allocate the internal state
|
||||||
|
zfree: TFree; // used to free the internal state
|
||||||
|
AppData: Pointer; // private data object passed to zalloc and zfree
|
||||||
|
|
||||||
|
data_type: Integer; // best guess about the data type: ascii or binary
|
||||||
|
adler: Integer; // adler32 value of the uncompressed data
|
||||||
|
reserved: Integer; // reserved for future use
|
||||||
|
end;
|
||||||
|
|
||||||
|
// Abstract ancestor class
|
||||||
|
TCustomZlibStream = class(TStream)
|
||||||
|
private
|
||||||
|
FStrm: TStream;
|
||||||
|
FStrmPos: Integer;
|
||||||
|
FOnProgress: TNotifyEvent;
|
||||||
|
FZRec: TZStreamRec;
|
||||||
|
FBuffer: array [Word] of Char;
|
||||||
|
protected
|
||||||
|
procedure Progress(Sender: TObject); dynamic;
|
||||||
|
property OnProgress: TNotifyEvent read FOnProgress write FOnProgress;
|
||||||
|
constructor Create(Strm: TStream);
|
||||||
|
end;
|
||||||
|
|
||||||
|
{ TCompressionStream compresses data on the fly as data is written to it, and
|
||||||
|
stores the compressed data to another stream.
|
||||||
|
|
||||||
|
TCompressionStream is write-only and strictly sequential. Reading from the
|
||||||
|
stream will raise an exception. Using Seek to move the stream pointer
|
||||||
|
will raise an exception.
|
||||||
|
|
||||||
|
Output data is cached internally, written to the output stream only when
|
||||||
|
the internal output buffer is full. All pending output data is flushed
|
||||||
|
when the stream is destroyed.
|
||||||
|
|
||||||
|
The Position property returns the number of uncompressed bytes of
|
||||||
|
data that have been written to the stream so far.
|
||||||
|
|
||||||
|
CompressionRate returns the on-the-fly percentage by which the original
|
||||||
|
data has been compressed: (1 - (CompressedBytes / UncompressedBytes)) * 100
|
||||||
|
If raw data size = 100 and compressed data size = 25, the CompressionRate
|
||||||
|
is 75%
|
||||||
|
|
||||||
|
The OnProgress event is called each time the output buffer is filled and
|
||||||
|
written to the output stream. This is useful for updating a progress
|
||||||
|
indicator when you are writing a large chunk of data to the compression
|
||||||
|
stream in a single call.}
|
||||||
|
|
||||||
|
|
||||||
|
TCompressionLevel = (clNone, clFastest, clDefault, clMax);
|
||||||
|
|
||||||
|
TCompressionStream = class(TCustomZlibStream)
|
||||||
|
private
|
||||||
|
function GetCompressionRate: Single;
|
||||||
|
public
|
||||||
|
constructor Create(CompressionLevel: TCompressionLevel; Dest: TStream);
|
||||||
|
destructor Destroy; override;
|
||||||
|
function Read(var Buffer; Count: Longint): Longint; override;
|
||||||
|
function Write(const Buffer; Count: Longint): Longint; override;
|
||||||
|
function Seek(Offset: Longint; Origin: Word): Longint; override;
|
||||||
|
property CompressionRate: Single read GetCompressionRate;
|
||||||
|
property OnProgress;
|
||||||
|
end;
|
||||||
|
|
||||||
|
{ TDecompressionStream decompresses data on the fly as data is read from it.
|
||||||
|
|
||||||
|
Compressed data comes from a separate source stream. TDecompressionStream
|
||||||
|
is read-only and unidirectional; you can seek forward in the stream, but not
|
||||||
|
backwards. The special case of setting the stream position to zero is
|
||||||
|
allowed. Seeking forward decompresses data until the requested position in
|
||||||
|
the uncompressed data has been reached. Seeking backwards, seeking relative
|
||||||
|
to the end of the stream, requesting the size of the stream, and writing to
|
||||||
|
the stream will raise an exception.
|
||||||
|
|
||||||
|
The Position property returns the number of bytes of uncompressed data that
|
||||||
|
have been read from the stream so far.
|
||||||
|
|
||||||
|
The OnProgress event is called each time the internal input buffer of
|
||||||
|
compressed data is exhausted and the next block is read from the input stream.
|
||||||
|
This is useful for updating a progress indicator when you are reading a
|
||||||
|
large chunk of data from the decompression stream in a single call.}
|
||||||
|
|
||||||
|
TDecompressionStream = class(TCustomZlibStream)
|
||||||
|
public
|
||||||
|
constructor Create(Source: TStream);
|
||||||
|
destructor Destroy; override;
|
||||||
|
function Read(var Buffer; Count: Longint): Longint; override;
|
||||||
|
function Write(const Buffer; Count: Longint): Longint; override;
|
||||||
|
function Seek(Offset: Longint; Origin: Word): Longint; override;
|
||||||
|
property OnProgress;
|
||||||
|
end;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
{ CompressBuf compresses data, buffer to buffer, in one call.
|
||||||
|
In: InBuf = ptr to compressed data
|
||||||
|
InBytes = number of bytes in InBuf
|
||||||
|
Out: OutBuf = ptr to newly allocated buffer containing decompressed data
|
||||||
|
OutBytes = number of bytes in OutBuf }
|
||||||
|
procedure CompressBuf(const InBuf: Pointer; InBytes: Integer;
|
||||||
|
out OutBuf: Pointer; out OutBytes: Integer);
|
||||||
|
|
||||||
|
|
||||||
|
{ DecompressBuf decompresses data, buffer to buffer, in one call.
|
||||||
|
In: InBuf = ptr to compressed data
|
||||||
|
InBytes = number of bytes in InBuf
|
||||||
|
OutEstimate = zero, or est. size of the decompressed data
|
||||||
|
Out: OutBuf = ptr to newly allocated buffer containing decompressed data
|
||||||
|
OutBytes = number of bytes in OutBuf }
|
||||||
|
procedure DecompressBuf(const InBuf: Pointer; InBytes: Integer;
|
||||||
|
OutEstimate: Integer; out OutBuf: Pointer; out OutBytes: Integer);
|
||||||
|
|
||||||
|
const
|
||||||
|
zlib_version = '1.1.3';
|
||||||
|
|
||||||
|
type
|
||||||
|
EZlibError = class(Exception);
|
||||||
|
ECompressionError = class(EZlibError);
|
||||||
|
EDecompressionError = class(EZlibError);
|
||||||
|
|
||||||
|
function adler32(adler: Integer; buf: PChar; len: Integer): Integer;
|
||||||
|
|
||||||
|
implementation
|
||||||
|
|
||||||
|
const
|
||||||
|
Z_NO_FLUSH = 0;
|
||||||
|
Z_PARTIAL_FLUSH = 1;
|
||||||
|
Z_SYNC_FLUSH = 2;
|
||||||
|
Z_FULL_FLUSH = 3;
|
||||||
|
Z_FINISH = 4;
|
||||||
|
|
||||||
|
Z_OK = 0;
|
||||||
|
Z_STREAM_END = 1;
|
||||||
|
Z_NEED_DICT = 2;
|
||||||
|
Z_ERRNO = (-1);
|
||||||
|
Z_STREAM_ERROR = (-2);
|
||||||
|
Z_DATA_ERROR = (-3);
|
||||||
|
Z_MEM_ERROR = (-4);
|
||||||
|
Z_BUF_ERROR = (-5);
|
||||||
|
Z_VERSION_ERROR = (-6);
|
||||||
|
|
||||||
|
Z_NO_COMPRESSION = 0;
|
||||||
|
Z_BEST_SPEED = 1;
|
||||||
|
Z_BEST_COMPRESSION = 9;
|
||||||
|
Z_DEFAULT_COMPRESSION = (-1);
|
||||||
|
|
||||||
|
Z_FILTERED = 1;
|
||||||
|
Z_HUFFMAN_ONLY = 2;
|
||||||
|
Z_DEFAULT_STRATEGY = 0;
|
||||||
|
|
||||||
|
Z_BINARY = 0;
|
||||||
|
Z_ASCII = 1;
|
||||||
|
Z_UNKNOWN = 2;
|
||||||
|
|
||||||
|
Z_DEFLATED = 8;
|
||||||
|
|
||||||
|
_z_errmsg: array[0..9] of PChar = (
|
||||||
|
'need dictionary', // Z_NEED_DICT (2)
|
||||||
|
'stream end', // Z_STREAM_END (1)
|
||||||
|
'', // Z_OK (0)
|
||||||
|
'file error', // Z_ERRNO (-1)
|
||||||
|
'stream error', // Z_STREAM_ERROR (-2)
|
||||||
|
'data error', // Z_DATA_ERROR (-3)
|
||||||
|
'insufficient memory', // Z_MEM_ERROR (-4)
|
||||||
|
'buffer error', // Z_BUF_ERROR (-5)
|
||||||
|
'incompatible version', // Z_VERSION_ERROR (-6)
|
||||||
|
''
|
||||||
|
);
|
||||||
|
|
||||||
|
{$L deflate.obj}
|
||||||
|
{$L inflate.obj}
|
||||||
|
{$L inftrees.obj}
|
||||||
|
{$L trees.obj}
|
||||||
|
{$L adler32.obj}
|
||||||
|
{$L infblock.obj}
|
||||||
|
{$L infcodes.obj}
|
||||||
|
{$L infutil.obj}
|
||||||
|
{$L inffast.obj}
|
||||||
|
|
||||||
|
procedure _tr_init; external;
|
||||||
|
procedure _tr_tally; external;
|
||||||
|
procedure _tr_flush_block; external;
|
||||||
|
procedure _tr_align; external;
|
||||||
|
procedure _tr_stored_block; external;
|
||||||
|
function adler32; external;
|
||||||
|
procedure inflate_blocks_new; external;
|
||||||
|
procedure inflate_blocks; external;
|
||||||
|
procedure inflate_blocks_reset; external;
|
||||||
|
procedure inflate_blocks_free; external;
|
||||||
|
procedure inflate_set_dictionary; external;
|
||||||
|
procedure inflate_trees_bits; external;
|
||||||
|
procedure inflate_trees_dynamic; external;
|
||||||
|
procedure inflate_trees_fixed; external;
|
||||||
|
procedure inflate_codes_new; external;
|
||||||
|
procedure inflate_codes; external;
|
||||||
|
procedure inflate_codes_free; external;
|
||||||
|
procedure _inflate_mask; external;
|
||||||
|
procedure inflate_flush; external;
|
||||||
|
procedure inflate_fast; external;
|
||||||
|
|
||||||
|
procedure _memset(P: Pointer; B: Byte; count: Integer);cdecl;
|
||||||
|
begin
|
||||||
|
FillChar(P^, count, B);
|
||||||
|
end;
|
||||||
|
|
||||||
|
procedure _memcpy(dest, source: Pointer; count: Integer);cdecl;
|
||||||
|
begin
|
||||||
|
Move(source^, dest^, count);
|
||||||
|
end;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// deflate compresses data
|
||||||
|
function deflateInit_(var strm: TZStreamRec; level: Integer; version: PChar;
|
||||||
|
recsize: Integer): Integer; external;
|
||||||
|
function deflate(var strm: TZStreamRec; flush: Integer): Integer; external;
|
||||||
|
function deflateEnd(var strm: TZStreamRec): Integer; external;
|
||||||
|
|
||||||
|
// inflate decompresses data
|
||||||
|
function inflateInit_(var strm: TZStreamRec; version: PChar;
|
||||||
|
recsize: Integer): Integer; external;
|
||||||
|
function inflate(var strm: TZStreamRec; flush: Integer): Integer; external;
|
||||||
|
function inflateEnd(var strm: TZStreamRec): Integer; external;
|
||||||
|
function inflateReset(var strm: TZStreamRec): Integer; external;
|
||||||
|
|
||||||
|
|
||||||
|
function zcalloc(AppData: Pointer; Items, Size: Integer): Pointer;
|
||||||
|
begin
|
||||||
|
GetMem(Result, Items*Size);
|
||||||
|
end;
|
||||||
|
|
||||||
|
procedure zcfree(AppData, Block: Pointer);
|
||||||
|
begin
|
||||||
|
FreeMem(Block);
|
||||||
|
end;
|
||||||
|
|
||||||
|
function zlibCheck(code: Integer): Integer;
|
||||||
|
begin
|
||||||
|
Result := code;
|
||||||
|
if code < 0 then
|
||||||
|
raise EZlibError.Create('error'); //!!
|
||||||
|
end;
|
||||||
|
|
||||||
|
function CCheck(code: Integer): Integer;
|
||||||
|
begin
|
||||||
|
Result := code;
|
||||||
|
if code < 0 then
|
||||||
|
raise ECompressionError.Create('error'); //!!
|
||||||
|
end;
|
||||||
|
|
||||||
|
function DCheck(code: Integer): Integer;
|
||||||
|
begin
|
||||||
|
Result := code;
|
||||||
|
if code < 0 then
|
||||||
|
raise EDecompressionError.Create('error'); //!!
|
||||||
|
end;
|
||||||
|
|
||||||
|
procedure CompressBuf(const InBuf: Pointer; InBytes: Integer;
|
||||||
|
out OutBuf: Pointer; out OutBytes: Integer);
|
||||||
|
var
|
||||||
|
strm: TZStreamRec;
|
||||||
|
P: Pointer;
|
||||||
|
begin
|
||||||
|
FillChar(strm, sizeof(strm), 0);
|
||||||
|
OutBytes := ((InBytes + (InBytes div 10) + 12) + 255) and not 255;
|
||||||
|
GetMem(OutBuf, OutBytes);
|
||||||
|
try
|
||||||
|
strm.next_in := InBuf;
|
||||||
|
strm.avail_in := InBytes;
|
||||||
|
strm.next_out := OutBuf;
|
||||||
|
strm.avail_out := OutBytes;
|
||||||
|
CCheck(deflateInit_(strm, Z_BEST_COMPRESSION, zlib_version, sizeof(strm)));
|
||||||
|
try
|
||||||
|
while CCheck(deflate(strm, Z_FINISH)) <> Z_STREAM_END do
|
||||||
|
begin
|
||||||
|
P := OutBuf;
|
||||||
|
Inc(OutBytes, 256);
|
||||||
|
ReallocMem(OutBuf, OutBytes);
|
||||||
|
strm.next_out := PChar(Integer(OutBuf) + (Integer(strm.next_out) - Integer(P)));
|
||||||
|
strm.avail_out := 256;
|
||||||
|
end;
|
||||||
|
finally
|
||||||
|
CCheck(deflateEnd(strm));
|
||||||
|
end;
|
||||||
|
ReallocMem(OutBuf, strm.total_out);
|
||||||
|
OutBytes := strm.total_out;
|
||||||
|
except
|
||||||
|
FreeMem(OutBuf);
|
||||||
|
raise
|
||||||
|
end;
|
||||||
|
end;
|
||||||
|
|
||||||
|
|
||||||
|
procedure DecompressBuf(const InBuf: Pointer; InBytes: Integer;
|
||||||
|
OutEstimate: Integer; out OutBuf: Pointer; out OutBytes: Integer);
|
||||||
|
var
|
||||||
|
strm: TZStreamRec;
|
||||||
|
P: Pointer;
|
||||||
|
BufInc: Integer;
|
||||||
|
begin
|
||||||
|
FillChar(strm, sizeof(strm), 0);
|
||||||
|
BufInc := (InBytes + 255) and not 255;
|
||||||
|
if OutEstimate = 0 then
|
||||||
|
OutBytes := BufInc
|
||||||
|
else
|
||||||
|
OutBytes := OutEstimate;
|
||||||
|
GetMem(OutBuf, OutBytes);
|
||||||
|
try
|
||||||
|
strm.next_in := InBuf;
|
||||||
|
strm.avail_in := InBytes;
|
||||||
|
strm.next_out := OutBuf;
|
||||||
|
strm.avail_out := OutBytes;
|
||||||
|
DCheck(inflateInit_(strm, zlib_version, sizeof(strm)));
|
||||||
|
try
|
||||||
|
while DCheck(inflate(strm, Z_FINISH)) <> Z_STREAM_END do
|
||||||
|
begin
|
||||||
|
P := OutBuf;
|
||||||
|
Inc(OutBytes, BufInc);
|
||||||
|
ReallocMem(OutBuf, OutBytes);
|
||||||
|
strm.next_out := PChar(Integer(OutBuf) + (Integer(strm.next_out) - Integer(P)));
|
||||||
|
strm.avail_out := BufInc;
|
||||||
|
end;
|
||||||
|
finally
|
||||||
|
DCheck(inflateEnd(strm));
|
||||||
|
end;
|
||||||
|
ReallocMem(OutBuf, strm.total_out);
|
||||||
|
OutBytes := strm.total_out;
|
||||||
|
except
|
||||||
|
FreeMem(OutBuf);
|
||||||
|
raise
|
||||||
|
end;
|
||||||
|
end;
|
||||||
|
|
||||||
|
|
||||||
|
// TCustomZlibStream
|
||||||
|
|
||||||
|
constructor TCustomZLibStream.Create(Strm: TStream);
|
||||||
|
begin
|
||||||
|
inherited Create;
|
||||||
|
FStrm := Strm;
|
||||||
|
FStrmPos := Strm.Position;
|
||||||
|
end;
|
||||||
|
|
||||||
|
procedure TCustomZLibStream.Progress(Sender: TObject);
|
||||||
|
begin
|
||||||
|
if Assigned(FOnProgress) then FOnProgress(Sender);
|
||||||
|
end;
|
||||||
|
|
||||||
|
|
||||||
|
// TCompressionStream
|
||||||
|
|
||||||
|
constructor TCompressionStream.Create(CompressionLevel: TCompressionLevel;
|
||||||
|
Dest: TStream);
|
||||||
|
const
|
||||||
|
Levels: array [TCompressionLevel] of ShortInt =
|
||||||
|
(Z_NO_COMPRESSION, Z_BEST_SPEED, Z_DEFAULT_COMPRESSION, Z_BEST_COMPRESSION);
|
||||||
|
begin
|
||||||
|
inherited Create(Dest);
|
||||||
|
FZRec.next_out := FBuffer;
|
||||||
|
FZRec.avail_out := sizeof(FBuffer);
|
||||||
|
CCheck(deflateInit_(FZRec, Levels[CompressionLevel], zlib_version, sizeof(FZRec)));
|
||||||
|
end;
|
||||||
|
|
||||||
|
destructor TCompressionStream.Destroy;
|
||||||
|
begin
|
||||||
|
FZRec.next_in := nil;
|
||||||
|
FZRec.avail_in := 0;
|
||||||
|
try
|
||||||
|
if FStrm.Position <> FStrmPos then FStrm.Position := FStrmPos;
|
||||||
|
while (CCheck(deflate(FZRec, Z_FINISH)) <> Z_STREAM_END)
|
||||||
|
and (FZRec.avail_out = 0) do
|
||||||
|
begin
|
||||||
|
FStrm.WriteBuffer(FBuffer, sizeof(FBuffer));
|
||||||
|
FZRec.next_out := FBuffer;
|
||||||
|
FZRec.avail_out := sizeof(FBuffer);
|
||||||
|
end;
|
||||||
|
if FZRec.avail_out < sizeof(FBuffer) then
|
||||||
|
FStrm.WriteBuffer(FBuffer, sizeof(FBuffer) - FZRec.avail_out);
|
||||||
|
finally
|
||||||
|
deflateEnd(FZRec);
|
||||||
|
end;
|
||||||
|
inherited Destroy;
|
||||||
|
end;
|
||||||
|
|
||||||
|
function TCompressionStream.Read(var Buffer; Count: Longint): Longint;
|
||||||
|
begin
|
||||||
|
raise ECompressionError.Create('Invalid stream operation');
|
||||||
|
end;
|
||||||
|
|
||||||
|
function TCompressionStream.Write(const Buffer; Count: Longint): Longint;
|
||||||
|
begin
|
||||||
|
FZRec.next_in := @Buffer;
|
||||||
|
FZRec.avail_in := Count;
|
||||||
|
if FStrm.Position <> FStrmPos then FStrm.Position := FStrmPos;
|
||||||
|
while (FZRec.avail_in > 0) do
|
||||||
|
begin
|
||||||
|
CCheck(deflate(FZRec, 0));
|
||||||
|
if FZRec.avail_out = 0 then
|
||||||
|
begin
|
||||||
|
FStrm.WriteBuffer(FBuffer, sizeof(FBuffer));
|
||||||
|
FZRec.next_out := FBuffer;
|
||||||
|
FZRec.avail_out := sizeof(FBuffer);
|
||||||
|
FStrmPos := FStrm.Position;
|
||||||
|
Progress(Self);
|
||||||
|
end;
|
||||||
|
end;
|
||||||
|
Result := Count;
|
||||||
|
end;
|
||||||
|
|
||||||
|
function TCompressionStream.Seek(Offset: Longint; Origin: Word): Longint;
|
||||||
|
begin
|
||||||
|
if (Offset = 0) and (Origin = soFromCurrent) then
|
||||||
|
Result := FZRec.total_in
|
||||||
|
else
|
||||||
|
raise ECompressionError.Create('Invalid stream operation');
|
||||||
|
end;
|
||||||
|
|
||||||
|
function TCompressionStream.GetCompressionRate: Single;
|
||||||
|
begin
|
||||||
|
if FZRec.total_in = 0 then
|
||||||
|
Result := 0
|
||||||
|
else
|
||||||
|
Result := (1.0 - (FZRec.total_out / FZRec.total_in)) * 100.0;
|
||||||
|
end;
|
||||||
|
|
||||||
|
|
||||||
|
// TDecompressionStream
|
||||||
|
|
||||||
|
constructor TDecompressionStream.Create(Source: TStream);
|
||||||
|
begin
|
||||||
|
inherited Create(Source);
|
||||||
|
FZRec.next_in := FBuffer;
|
||||||
|
FZRec.avail_in := 0;
|
||||||
|
DCheck(inflateInit_(FZRec, zlib_version, sizeof(FZRec)));
|
||||||
|
end;
|
||||||
|
|
||||||
|
destructor TDecompressionStream.Destroy;
|
||||||
|
begin
|
||||||
|
inflateEnd(FZRec);
|
||||||
|
inherited Destroy;
|
||||||
|
end;
|
||||||
|
|
||||||
|
function TDecompressionStream.Read(var Buffer; Count: Longint): Longint;
|
||||||
|
begin
|
||||||
|
FZRec.next_out := @Buffer;
|
||||||
|
FZRec.avail_out := Count;
|
||||||
|
if FStrm.Position <> FStrmPos then FStrm.Position := FStrmPos;
|
||||||
|
while (FZRec.avail_out > 0) do
|
||||||
|
begin
|
||||||
|
if FZRec.avail_in = 0 then
|
||||||
|
begin
|
||||||
|
FZRec.avail_in := FStrm.Read(FBuffer, sizeof(FBuffer));
|
||||||
|
if FZRec.avail_in = 0 then
|
||||||
|
begin
|
||||||
|
Result := Count - FZRec.avail_out;
|
||||||
|
Exit;
|
||||||
|
end;
|
||||||
|
FZRec.next_in := FBuffer;
|
||||||
|
FStrmPos := FStrm.Position;
|
||||||
|
Progress(Self);
|
||||||
|
end;
|
||||||
|
DCheck(inflate(FZRec, 0));
|
||||||
|
end;
|
||||||
|
Result := Count;
|
||||||
|
end;
|
||||||
|
|
||||||
|
function TDecompressionStream.Write(const Buffer; Count: Longint): Longint;
|
||||||
|
begin
|
||||||
|
raise EDecompressionError.Create('Invalid stream operation');
|
||||||
|
end;
|
||||||
|
|
||||||
|
function TDecompressionStream.Seek(Offset: Longint; Origin: Word): Longint;
|
||||||
|
var
|
||||||
|
I: Integer;
|
||||||
|
Buf: array [0..4095] of Char;
|
||||||
|
begin
|
||||||
|
if (Offset = 0) and (Origin = soFromBeginning) then
|
||||||
|
begin
|
||||||
|
DCheck(inflateReset(FZRec));
|
||||||
|
FZRec.next_in := FBuffer;
|
||||||
|
FZRec.avail_in := 0;
|
||||||
|
FStrm.Position := 0;
|
||||||
|
FStrmPos := 0;
|
||||||
|
end
|
||||||
|
else if ( (Offset >= 0) and (Origin = soFromCurrent)) or
|
||||||
|
( ((Offset - FZRec.total_out) > 0) and (Origin = soFromBeginning)) then
|
||||||
|
begin
|
||||||
|
if Origin = soFromBeginning then Dec(Offset, FZRec.total_out);
|
||||||
|
if Offset > 0 then
|
||||||
|
begin
|
||||||
|
for I := 1 to Offset div sizeof(Buf) do
|
||||||
|
ReadBuffer(Buf, sizeof(Buf));
|
||||||
|
ReadBuffer(Buf, Offset mod sizeof(Buf));
|
||||||
|
end;
|
||||||
|
end
|
||||||
|
else
|
||||||
|
raise EDecompressionError.Create('Invalid stream operation');
|
||||||
|
Result := FZRec.total_out;
|
||||||
|
end;
|
||||||
|
|
||||||
|
end.
|
||||||
174
contrib/delphi2/zlib32.bpr
Normal file
174
contrib/delphi2/zlib32.bpr
Normal file
@@ -0,0 +1,174 @@
|
|||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
!if !$d(BCB)
|
||||||
|
BCB = $(MAKEDIR)\..
|
||||||
|
!endif
|
||||||
|
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
# IDE SECTION
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
# The following section of the project makefile is managed by the BCB IDE.
|
||||||
|
# It is recommended to use the IDE to change any of the values in this
|
||||||
|
# section.
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
VERSION = BCB.03
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
PROJECT = zlib32.dll
|
||||||
|
OBJFILES = zlib32.obj adler32.obj compress.obj crc32.obj deflate.obj gzio.obj infblock.obj \
|
||||||
|
infcodes.obj inffast.obj inflate.obj inftrees.obj infutil.obj trees.obj \
|
||||||
|
uncompr.obj zutil.obj
|
||||||
|
RESFILES =
|
||||||
|
RESDEPEN = $(RESFILES)
|
||||||
|
LIBFILES =
|
||||||
|
LIBRARIES =
|
||||||
|
SPARELIBS =
|
||||||
|
DEFFILE =
|
||||||
|
PACKAGES = VCLX35.bpi VCL35.bpi VCLDB35.bpi VCLDBX35.bpi ibsmp35.bpi bcbsmp35.bpi \
|
||||||
|
dclocx35.bpi QRPT35.bpi TEEUI35.bpi TEEDB35.bpi TEE35.bpi DSS35.bpi \
|
||||||
|
NMFAST35.bpi INETDB35.bpi INET35.bpi VCLMID35.bpi
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
PATHCPP = .;
|
||||||
|
PATHASM = .;
|
||||||
|
PATHPAS = .;
|
||||||
|
PATHRC = .;
|
||||||
|
DEBUGLIBPATH = $(BCB)\lib\debug
|
||||||
|
RELEASELIBPATH = $(BCB)\lib\release
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
CFLAG1 = -WD -O2 -Ve -d -k- -vi -c -tWD
|
||||||
|
CFLAG2 = -D_NO_VCL;ZLIB_DLL -I$(BCB)\include
|
||||||
|
CFLAG3 = -ff -5
|
||||||
|
PFLAGS = -D_NO_VCL;ZLIB_DLL -U$(BCB)\lib;$(RELEASELIBPATH) -I$(BCB)\include -$I- -v \
|
||||||
|
-JPHN -M
|
||||||
|
RFLAGS = -D_NO_VCL;ZLIB_DLL -i$(BCB)\include
|
||||||
|
AFLAGS = /i$(BCB)\include /d_NO_VCL /dZLIB_DLL /mx /w2 /zn
|
||||||
|
LFLAGS = -L$(BCB)\lib;$(RELEASELIBPATH) -aa -Tpd -x -Gi
|
||||||
|
IFLAGS = -Gn -g
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
ALLOBJ = c0d32.obj $(OBJFILES)
|
||||||
|
ALLRES = $(RESFILES)
|
||||||
|
ALLLIB = $(LIBFILES) import32.lib cw32mt.lib
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
!ifdef IDEOPTIONS
|
||||||
|
|
||||||
|
[Version Info]
|
||||||
|
IncludeVerInfo=0
|
||||||
|
AutoIncBuild=0
|
||||||
|
MajorVer=1
|
||||||
|
MinorVer=0
|
||||||
|
Release=0
|
||||||
|
Build=0
|
||||||
|
Debug=0
|
||||||
|
PreRelease=0
|
||||||
|
Special=0
|
||||||
|
Private=0
|
||||||
|
DLL=1
|
||||||
|
Locale=1040
|
||||||
|
CodePage=1252
|
||||||
|
|
||||||
|
[Version Info Keys]
|
||||||
|
CompanyName=
|
||||||
|
FileDescription=DLL (GUI)
|
||||||
|
FileVersion=1.0.0.0
|
||||||
|
InternalName=
|
||||||
|
LegalCopyright=
|
||||||
|
LegalTrademarks=
|
||||||
|
OriginalFilename=
|
||||||
|
ProductName=
|
||||||
|
ProductVersion=1.0.0.0
|
||||||
|
Comments=
|
||||||
|
|
||||||
|
[HistoryLists\hlIncludePath]
|
||||||
|
Count=1
|
||||||
|
Item0=$(BCB)\include
|
||||||
|
|
||||||
|
[HistoryLists\hlLibraryPath]
|
||||||
|
Count=1
|
||||||
|
Item0=$(BCB)\lib
|
||||||
|
|
||||||
|
[HistoryLists\hlConditionals]
|
||||||
|
Count=1
|
||||||
|
Item0=_NO_VCL;ZLIB_DLL
|
||||||
|
|
||||||
|
[Debugging]
|
||||||
|
DebugSourceDirs=
|
||||||
|
|
||||||
|
[Parameters]
|
||||||
|
RunParams=
|
||||||
|
HostApplication=
|
||||||
|
|
||||||
|
!endif
|
||||||
|
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
# MAKE SECTION
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
# This section of the project file is not used by the BCB IDE. It is for
|
||||||
|
# the benefit of building from the command-line using the MAKE utility.
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
.autodepend
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
!if !$d(BCC32)
|
||||||
|
BCC32 = bcc32
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if !$d(DCC32)
|
||||||
|
DCC32 = dcc32
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if !$d(TASM32)
|
||||||
|
TASM32 = tasm32
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if !$d(LINKER)
|
||||||
|
LINKER = ilink32
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if !$d(BRCC32)
|
||||||
|
BRCC32 = brcc32
|
||||||
|
!endif
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
!if $d(PATHCPP)
|
||||||
|
.PATH.CPP = $(PATHCPP)
|
||||||
|
.PATH.C = $(PATHCPP)
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if $d(PATHPAS)
|
||||||
|
.PATH.PAS = $(PATHPAS)
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if $d(PATHASM)
|
||||||
|
.PATH.ASM = $(PATHASM)
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if $d(PATHRC)
|
||||||
|
.PATH.RC = $(PATHRC)
|
||||||
|
!endif
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
$(PROJECT): $(OBJFILES) $(RESDEPEN) $(DEFFILE)
|
||||||
|
$(BCB)\BIN\$(LINKER) @&&!
|
||||||
|
$(LFLAGS) $(IFLAGS) +
|
||||||
|
$(ALLOBJ), +
|
||||||
|
$(PROJECT),, +
|
||||||
|
$(ALLLIB), +
|
||||||
|
$(DEFFILE), +
|
||||||
|
$(ALLRES)
|
||||||
|
!
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
.pas.hpp:
|
||||||
|
$(BCB)\BIN\$(DCC32) $(PFLAGS) {$< }
|
||||||
|
|
||||||
|
.pas.obj:
|
||||||
|
$(BCB)\BIN\$(DCC32) $(PFLAGS) {$< }
|
||||||
|
|
||||||
|
.cpp.obj:
|
||||||
|
$(BCB)\BIN\$(BCC32) $(CFLAG1) $(CFLAG2) $(CFLAG3) -n$(@D) {$< }
|
||||||
|
|
||||||
|
.c.obj:
|
||||||
|
$(BCB)\BIN\$(BCC32) $(CFLAG1) $(CFLAG2) $(CFLAG3) -n$(@D) {$< }
|
||||||
|
|
||||||
|
.asm.obj:
|
||||||
|
$(BCB)\BIN\$(TASM32) $(AFLAGS) $<, $@
|
||||||
|
|
||||||
|
.rc.res:
|
||||||
|
$(BCB)\BIN\$(BRCC32) $(RFLAGS) -fo$@ $<
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
42
contrib/delphi2/zlib32.cpp
Normal file
42
contrib/delphi2/zlib32.cpp
Normal file
@@ -0,0 +1,42 @@
|
|||||||
|
|
||||||
|
#include <windows.h>
|
||||||
|
#pragma hdrstop
|
||||||
|
#include <condefs.h>
|
||||||
|
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------
|
||||||
|
// Important note about DLL memory management in a VCL DLL:
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//
|
||||||
|
// If your DLL uses VCL and exports any functions that pass VCL String objects
|
||||||
|
// (or structs/classes containing nested Strings) as parameter or function
|
||||||
|
// results, you will need to build both your DLL project and any EXE projects
|
||||||
|
// that use your DLL with the dynamic RTL (the RTL DLL). This will change your
|
||||||
|
// DLL and its calling EXE's to use BORLNDMM.DLL as their memory manager. In
|
||||||
|
// these cases, the file BORLNDMM.DLL should be deployed along with your DLL
|
||||||
|
// and the RTL DLL (CP3240MT.DLL). To avoid the requiring BORLNDMM.DLL in
|
||||||
|
// these situations, pass string information using "char *" or ShortString
|
||||||
|
// parameters and then link with the static RTL.
|
||||||
|
//
|
||||||
|
//---------------------------------------------------------------------------
|
||||||
|
USEUNIT("adler32.c");
|
||||||
|
USEUNIT("compress.c");
|
||||||
|
USEUNIT("crc32.c");
|
||||||
|
USEUNIT("deflate.c");
|
||||||
|
USEUNIT("gzio.c");
|
||||||
|
USEUNIT("infblock.c");
|
||||||
|
USEUNIT("infcodes.c");
|
||||||
|
USEUNIT("inffast.c");
|
||||||
|
USEUNIT("inflate.c");
|
||||||
|
USEUNIT("inftrees.c");
|
||||||
|
USEUNIT("infutil.c");
|
||||||
|
USEUNIT("trees.c");
|
||||||
|
USEUNIT("uncompr.c");
|
||||||
|
USEUNIT("zutil.c");
|
||||||
|
//---------------------------------------------------------------------------
|
||||||
|
#pragma argsused
|
||||||
|
int WINAPI DllEntryPoint(HINSTANCE hinst, unsigned long reason, void*)
|
||||||
|
{
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
24
contrib/iostream/test.cpp
Normal file
24
contrib/iostream/test.cpp
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
|
||||||
|
#include "zfstream.h"
|
||||||
|
|
||||||
|
int main() {
|
||||||
|
|
||||||
|
// Construct a stream object with this filebuffer. Anything sent
|
||||||
|
// to this stream will go to standard out.
|
||||||
|
gzofstream os( 1, ios::out );
|
||||||
|
|
||||||
|
// This text is getting compressed and sent to stdout.
|
||||||
|
// To prove this, run 'test | zcat'.
|
||||||
|
os << "Hello, Mommy" << endl;
|
||||||
|
|
||||||
|
os << setcompressionlevel( Z_NO_COMPRESSION );
|
||||||
|
os << "hello, hello, hi, ho!" << endl;
|
||||||
|
|
||||||
|
setcompressionlevel( os, Z_DEFAULT_COMPRESSION )
|
||||||
|
<< "I'm compressing again" << endl;
|
||||||
|
|
||||||
|
os.close();
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
}
|
||||||
329
contrib/iostream/zfstream.cpp
Normal file
329
contrib/iostream/zfstream.cpp
Normal file
@@ -0,0 +1,329 @@
|
|||||||
|
|
||||||
|
#include <memory.h>
|
||||||
|
#include "zfstream.h"
|
||||||
|
|
||||||
|
gzfilebuf::gzfilebuf() :
|
||||||
|
file(NULL),
|
||||||
|
mode(0),
|
||||||
|
own_file_descriptor(0)
|
||||||
|
{ }
|
||||||
|
|
||||||
|
gzfilebuf::~gzfilebuf() {
|
||||||
|
|
||||||
|
sync();
|
||||||
|
if ( own_file_descriptor )
|
||||||
|
close();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
gzfilebuf *gzfilebuf::open( const char *name,
|
||||||
|
int io_mode ) {
|
||||||
|
|
||||||
|
if ( is_open() )
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
char char_mode[10];
|
||||||
|
char *p;
|
||||||
|
memset(char_mode,'\0',10);
|
||||||
|
p = char_mode;
|
||||||
|
|
||||||
|
if ( io_mode & ios::in ) {
|
||||||
|
mode = ios::in;
|
||||||
|
*p++ = 'r';
|
||||||
|
} else if ( io_mode & ios::app ) {
|
||||||
|
mode = ios::app;
|
||||||
|
*p++ = 'a';
|
||||||
|
} else {
|
||||||
|
mode = ios::out;
|
||||||
|
*p++ = 'w';
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( io_mode & ios::binary ) {
|
||||||
|
mode |= ios::binary;
|
||||||
|
*p++ = 'b';
|
||||||
|
}
|
||||||
|
|
||||||
|
// Hard code the compression level
|
||||||
|
if ( io_mode & (ios::out|ios::app )) {
|
||||||
|
*p++ = '9';
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( (file = gzopen(name, char_mode)) == NULL )
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
own_file_descriptor = 1;
|
||||||
|
|
||||||
|
return this;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
gzfilebuf *gzfilebuf::attach( int file_descriptor,
|
||||||
|
int io_mode ) {
|
||||||
|
|
||||||
|
if ( is_open() )
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
char char_mode[10];
|
||||||
|
char *p;
|
||||||
|
memset(char_mode,'\0',10);
|
||||||
|
p = char_mode;
|
||||||
|
|
||||||
|
if ( io_mode & ios::in ) {
|
||||||
|
mode = ios::in;
|
||||||
|
*p++ = 'r';
|
||||||
|
} else if ( io_mode & ios::app ) {
|
||||||
|
mode = ios::app;
|
||||||
|
*p++ = 'a';
|
||||||
|
} else {
|
||||||
|
mode = ios::out;
|
||||||
|
*p++ = 'w';
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( io_mode & ios::binary ) {
|
||||||
|
mode |= ios::binary;
|
||||||
|
*p++ = 'b';
|
||||||
|
}
|
||||||
|
|
||||||
|
// Hard code the compression level
|
||||||
|
if ( io_mode & (ios::out|ios::app )) {
|
||||||
|
*p++ = '9';
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( (file = gzdopen(file_descriptor, char_mode)) == NULL )
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
own_file_descriptor = 0;
|
||||||
|
|
||||||
|
return this;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
gzfilebuf *gzfilebuf::close() {
|
||||||
|
|
||||||
|
if ( is_open() ) {
|
||||||
|
|
||||||
|
sync();
|
||||||
|
gzclose( file );
|
||||||
|
file = NULL;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
return this;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
int gzfilebuf::setcompressionlevel( short comp_level ) {
|
||||||
|
|
||||||
|
return gzsetparams(file, comp_level, -2);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
int gzfilebuf::setcompressionstrategy( short comp_strategy ) {
|
||||||
|
|
||||||
|
return gzsetparams(file, -2, comp_strategy);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
streampos gzfilebuf::seekoff( streamoff off, ios::seek_dir dir, int which ) {
|
||||||
|
|
||||||
|
return streampos(EOF);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
int gzfilebuf::underflow() {
|
||||||
|
|
||||||
|
// If the file hasn't been opened for reading, error.
|
||||||
|
if ( !is_open() || !(mode & ios::in) )
|
||||||
|
return EOF;
|
||||||
|
|
||||||
|
// if a buffer doesn't exists, allocate one.
|
||||||
|
if ( !base() ) {
|
||||||
|
|
||||||
|
if ( (allocate()) == EOF )
|
||||||
|
return EOF;
|
||||||
|
setp(0,0);
|
||||||
|
|
||||||
|
} else {
|
||||||
|
|
||||||
|
if ( in_avail() )
|
||||||
|
return (unsigned char) *gptr();
|
||||||
|
|
||||||
|
if ( out_waiting() ) {
|
||||||
|
if ( flushbuf() == EOF )
|
||||||
|
return EOF;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Attempt to fill the buffer.
|
||||||
|
|
||||||
|
int result = fillbuf();
|
||||||
|
if ( result == EOF ) {
|
||||||
|
// disable get area
|
||||||
|
setg(0,0,0);
|
||||||
|
return EOF;
|
||||||
|
}
|
||||||
|
|
||||||
|
return (unsigned char) *gptr();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
int gzfilebuf::overflow( int c ) {
|
||||||
|
|
||||||
|
if ( !is_open() || !(mode & ios::out) )
|
||||||
|
return EOF;
|
||||||
|
|
||||||
|
if ( !base() ) {
|
||||||
|
if ( allocate() == EOF )
|
||||||
|
return EOF;
|
||||||
|
setg(0,0,0);
|
||||||
|
} else {
|
||||||
|
if (in_avail()) {
|
||||||
|
return EOF;
|
||||||
|
}
|
||||||
|
if (out_waiting()) {
|
||||||
|
if (flushbuf() == EOF)
|
||||||
|
return EOF;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int bl = blen();
|
||||||
|
setp( base(), base() + bl);
|
||||||
|
|
||||||
|
if ( c != EOF ) {
|
||||||
|
|
||||||
|
*pptr() = c;
|
||||||
|
pbump(1);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
int gzfilebuf::sync() {
|
||||||
|
|
||||||
|
if ( !is_open() )
|
||||||
|
return EOF;
|
||||||
|
|
||||||
|
if ( out_waiting() )
|
||||||
|
return flushbuf();
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
int gzfilebuf::flushbuf() {
|
||||||
|
|
||||||
|
int n;
|
||||||
|
char *q;
|
||||||
|
|
||||||
|
q = pbase();
|
||||||
|
n = pptr() - q;
|
||||||
|
|
||||||
|
if ( gzwrite( file, q, n) < n )
|
||||||
|
return EOF;
|
||||||
|
|
||||||
|
setp(0,0);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
int gzfilebuf::fillbuf() {
|
||||||
|
|
||||||
|
int required;
|
||||||
|
char *p;
|
||||||
|
|
||||||
|
p = base();
|
||||||
|
|
||||||
|
required = blen();
|
||||||
|
|
||||||
|
int t = gzread( file, p, required );
|
||||||
|
|
||||||
|
if ( t <= 0) return EOF;
|
||||||
|
|
||||||
|
setg( base(), base(), base()+t);
|
||||||
|
|
||||||
|
return t;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
gzfilestream_common::gzfilestream_common() :
|
||||||
|
ios( gzfilestream_common::rdbuf() )
|
||||||
|
{ }
|
||||||
|
|
||||||
|
gzfilestream_common::~gzfilestream_common()
|
||||||
|
{ }
|
||||||
|
|
||||||
|
void gzfilestream_common::attach( int fd, int io_mode ) {
|
||||||
|
|
||||||
|
if ( !buffer.attach( fd, io_mode) )
|
||||||
|
clear( ios::failbit | ios::badbit );
|
||||||
|
else
|
||||||
|
clear();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void gzfilestream_common::open( const char *name, int io_mode ) {
|
||||||
|
|
||||||
|
if ( !buffer.open( name, io_mode ) )
|
||||||
|
clear( ios::failbit | ios::badbit );
|
||||||
|
else
|
||||||
|
clear();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void gzfilestream_common::close() {
|
||||||
|
|
||||||
|
if ( !buffer.close() )
|
||||||
|
clear( ios::failbit | ios::badbit );
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
gzfilebuf *gzfilestream_common::rdbuf() {
|
||||||
|
|
||||||
|
return &buffer;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
gzifstream::gzifstream() :
|
||||||
|
ios( gzfilestream_common::rdbuf() )
|
||||||
|
{
|
||||||
|
clear( ios::badbit );
|
||||||
|
}
|
||||||
|
|
||||||
|
gzifstream::gzifstream( const char *name, int io_mode ) :
|
||||||
|
ios( gzfilestream_common::rdbuf() )
|
||||||
|
{
|
||||||
|
gzfilestream_common::open( name, io_mode );
|
||||||
|
}
|
||||||
|
|
||||||
|
gzifstream::gzifstream( int fd, int io_mode ) :
|
||||||
|
ios( gzfilestream_common::rdbuf() )
|
||||||
|
{
|
||||||
|
gzfilestream_common::attach( fd, io_mode );
|
||||||
|
}
|
||||||
|
|
||||||
|
gzifstream::~gzifstream() { }
|
||||||
|
|
||||||
|
gzofstream::gzofstream() :
|
||||||
|
ios( gzfilestream_common::rdbuf() )
|
||||||
|
{
|
||||||
|
clear( ios::badbit );
|
||||||
|
}
|
||||||
|
|
||||||
|
gzofstream::gzofstream( const char *name, int io_mode ) :
|
||||||
|
ios( gzfilestream_common::rdbuf() )
|
||||||
|
{
|
||||||
|
gzfilestream_common::open( name, io_mode );
|
||||||
|
}
|
||||||
|
|
||||||
|
gzofstream::gzofstream( int fd, int io_mode ) :
|
||||||
|
ios( gzfilestream_common::rdbuf() )
|
||||||
|
{
|
||||||
|
gzfilestream_common::attach( fd, io_mode );
|
||||||
|
}
|
||||||
|
|
||||||
|
gzofstream::~gzofstream() { }
|
||||||
142
contrib/iostream/zfstream.h
Normal file
142
contrib/iostream/zfstream.h
Normal file
@@ -0,0 +1,142 @@
|
|||||||
|
|
||||||
|
#ifndef _zfstream_h
|
||||||
|
#define _zfstream_h
|
||||||
|
|
||||||
|
#include <fstream.h>
|
||||||
|
#include "zlib.h"
|
||||||
|
|
||||||
|
class gzfilebuf : public streambuf {
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
gzfilebuf( );
|
||||||
|
virtual ~gzfilebuf();
|
||||||
|
|
||||||
|
gzfilebuf *open( const char *name, int io_mode );
|
||||||
|
gzfilebuf *attach( int file_descriptor, int io_mode );
|
||||||
|
gzfilebuf *close();
|
||||||
|
|
||||||
|
int setcompressionlevel( short comp_level );
|
||||||
|
int setcompressionstrategy( short comp_strategy );
|
||||||
|
|
||||||
|
inline int is_open() const { return (file !=NULL); }
|
||||||
|
|
||||||
|
virtual streampos seekoff( streamoff, ios::seek_dir, int );
|
||||||
|
|
||||||
|
virtual int sync();
|
||||||
|
|
||||||
|
protected:
|
||||||
|
|
||||||
|
virtual int underflow();
|
||||||
|
virtual int overflow( int = EOF );
|
||||||
|
|
||||||
|
private:
|
||||||
|
|
||||||
|
gzFile file;
|
||||||
|
short mode;
|
||||||
|
short own_file_descriptor;
|
||||||
|
|
||||||
|
int flushbuf();
|
||||||
|
int fillbuf();
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
class gzfilestream_common : virtual public ios {
|
||||||
|
|
||||||
|
friend class gzifstream;
|
||||||
|
friend class gzofstream;
|
||||||
|
friend gzofstream &setcompressionlevel( gzofstream &, int );
|
||||||
|
friend gzofstream &setcompressionstrategy( gzofstream &, int );
|
||||||
|
|
||||||
|
public:
|
||||||
|
virtual ~gzfilestream_common();
|
||||||
|
|
||||||
|
void attach( int fd, int io_mode );
|
||||||
|
void open( const char *name, int io_mode );
|
||||||
|
void close();
|
||||||
|
|
||||||
|
protected:
|
||||||
|
gzfilestream_common();
|
||||||
|
|
||||||
|
private:
|
||||||
|
gzfilebuf *rdbuf();
|
||||||
|
|
||||||
|
gzfilebuf buffer;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
class gzifstream : public gzfilestream_common, public istream {
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
gzifstream();
|
||||||
|
gzifstream( const char *name, int io_mode = ios::in );
|
||||||
|
gzifstream( int fd, int io_mode = ios::in );
|
||||||
|
|
||||||
|
virtual ~gzifstream();
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
class gzofstream : public gzfilestream_common, public ostream {
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
gzofstream();
|
||||||
|
gzofstream( const char *name, int io_mode = ios::out );
|
||||||
|
gzofstream( int fd, int io_mode = ios::out );
|
||||||
|
|
||||||
|
virtual ~gzofstream();
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
template<class T> class gzomanip {
|
||||||
|
friend gzofstream &operator<<(gzofstream &, const gzomanip<T> &);
|
||||||
|
public:
|
||||||
|
gzomanip(gzofstream &(*f)(gzofstream &, T), T v) : func(f), val(v) { }
|
||||||
|
private:
|
||||||
|
gzofstream &(*func)(gzofstream &, T);
|
||||||
|
T val;
|
||||||
|
};
|
||||||
|
|
||||||
|
template<class T> gzofstream &operator<<(gzofstream &s,
|
||||||
|
const gzomanip<T> &m) {
|
||||||
|
return (*m.func)(s, m.val);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
inline gzofstream &setcompressionlevel( gzofstream &s, int l ) {
|
||||||
|
(s.rdbuf())->setcompressionlevel(l);
|
||||||
|
return s;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline gzofstream &setcompressionstrategy( gzofstream &s, int l ) {
|
||||||
|
(s.rdbuf())->setcompressionstrategy(l);
|
||||||
|
return s;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline gzomanip<int> setcompressionlevel(int l)
|
||||||
|
{
|
||||||
|
return gzomanip<int>(&setcompressionlevel,l);
|
||||||
|
}
|
||||||
|
|
||||||
|
inline gzomanip<int> setcompressionstrategy(int l)
|
||||||
|
{
|
||||||
|
return gzomanip<int>(&setcompressionstrategy,l);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
307
contrib/iostream2/zstream.h
Normal file
307
contrib/iostream2/zstream.h
Normal file
@@ -0,0 +1,307 @@
|
|||||||
|
/*
|
||||||
|
*
|
||||||
|
* Copyright (c) 1997
|
||||||
|
* Christian Michelsen Research AS
|
||||||
|
* Advanced Computing
|
||||||
|
* Fantoftvegen 38, 5036 BERGEN, Norway
|
||||||
|
* http://www.cmr.no
|
||||||
|
*
|
||||||
|
* Permission to use, copy, modify, distribute and sell this software
|
||||||
|
* and its documentation for any purpose is hereby granted without fee,
|
||||||
|
* provided that the above copyright notice appear in all copies and
|
||||||
|
* that both that copyright notice and this permission notice appear
|
||||||
|
* in supporting documentation. Christian Michelsen Research AS makes no
|
||||||
|
* representations about the suitability of this software for any
|
||||||
|
* purpose. It is provided "as is" without express or implied warranty.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef ZSTREAM__H
|
||||||
|
#define ZSTREAM__H
|
||||||
|
|
||||||
|
/*
|
||||||
|
* zstream.h - C++ interface to the 'zlib' general purpose compression library
|
||||||
|
* $Id: zstream.h 1.1 1997-06-25 12:00:56+02 tyge Exp tyge $
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <strstream.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include "zlib.h"
|
||||||
|
|
||||||
|
#if defined(_WIN32)
|
||||||
|
# include <fcntl.h>
|
||||||
|
# include <io.h>
|
||||||
|
# define SET_BINARY_MODE(file) setmode(fileno(file), O_BINARY)
|
||||||
|
#else
|
||||||
|
# define SET_BINARY_MODE(file)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
class zstringlen {
|
||||||
|
public:
|
||||||
|
zstringlen(class izstream&);
|
||||||
|
zstringlen(class ozstream&, const char*);
|
||||||
|
size_t value() const { return val.word; }
|
||||||
|
private:
|
||||||
|
struct Val { unsigned char byte; size_t word; } val;
|
||||||
|
};
|
||||||
|
|
||||||
|
// ----------------------------- izstream -----------------------------
|
||||||
|
|
||||||
|
class izstream
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
izstream() : m_fp(0) {}
|
||||||
|
izstream(FILE* fp) : m_fp(0) { open(fp); }
|
||||||
|
izstream(const char* name) : m_fp(0) { open(name); }
|
||||||
|
~izstream() { close(); }
|
||||||
|
|
||||||
|
/* Opens a gzip (.gz) file for reading.
|
||||||
|
* open() can be used to read a file which is not in gzip format;
|
||||||
|
* in this case read() will directly read from the file without
|
||||||
|
* decompression. errno can be checked to distinguish two error
|
||||||
|
* cases (if errno is zero, the zlib error is Z_MEM_ERROR).
|
||||||
|
*/
|
||||||
|
void open(const char* name) {
|
||||||
|
if (m_fp) close();
|
||||||
|
m_fp = ::gzopen(name, "rb");
|
||||||
|
}
|
||||||
|
|
||||||
|
void open(FILE* fp) {
|
||||||
|
SET_BINARY_MODE(fp);
|
||||||
|
if (m_fp) close();
|
||||||
|
m_fp = ::gzdopen(fileno(fp), "rb");
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Flushes all pending input if necessary, closes the compressed file
|
||||||
|
* and deallocates all the (de)compression state. The return value is
|
||||||
|
* the zlib error number (see function error() below).
|
||||||
|
*/
|
||||||
|
int close() {
|
||||||
|
int r = ::gzclose(m_fp);
|
||||||
|
m_fp = 0; return r;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Binary read the given number of bytes from the compressed file.
|
||||||
|
*/
|
||||||
|
int read(void* buf, size_t len) {
|
||||||
|
return ::gzread(m_fp, buf, len);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Returns the error message for the last error which occurred on the
|
||||||
|
* given compressed file. errnum is set to zlib error number. If an
|
||||||
|
* error occurred in the file system and not in the compression library,
|
||||||
|
* errnum is set to Z_ERRNO and the application may consult errno
|
||||||
|
* to get the exact error code.
|
||||||
|
*/
|
||||||
|
const char* error(int* errnum) {
|
||||||
|
return ::gzerror(m_fp, errnum);
|
||||||
|
}
|
||||||
|
|
||||||
|
gzFile fp() { return m_fp; }
|
||||||
|
|
||||||
|
private:
|
||||||
|
gzFile m_fp;
|
||||||
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Binary read the given (array of) object(s) from the compressed file.
|
||||||
|
* If the input file was not in gzip format, read() copies the objects number
|
||||||
|
* of bytes into the buffer.
|
||||||
|
* returns the number of uncompressed bytes actually read
|
||||||
|
* (0 for end of file, -1 for error).
|
||||||
|
*/
|
||||||
|
template <class T, class Items>
|
||||||
|
inline int read(izstream& zs, T* x, Items items) {
|
||||||
|
return ::gzread(zs.fp(), x, items*sizeof(T));
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Binary input with the '>' operator.
|
||||||
|
*/
|
||||||
|
template <class T>
|
||||||
|
inline izstream& operator>(izstream& zs, T& x) {
|
||||||
|
::gzread(zs.fp(), &x, sizeof(T));
|
||||||
|
return zs;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
inline zstringlen::zstringlen(izstream& zs) {
|
||||||
|
zs > val.byte;
|
||||||
|
if (val.byte == 255) zs > val.word;
|
||||||
|
else val.word = val.byte;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Read length of string + the string with the '>' operator.
|
||||||
|
*/
|
||||||
|
inline izstream& operator>(izstream& zs, char* x) {
|
||||||
|
zstringlen len(zs);
|
||||||
|
::gzread(zs.fp(), x, len.value());
|
||||||
|
x[len.value()] = '\0';
|
||||||
|
return zs;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline char* read_string(izstream& zs) {
|
||||||
|
zstringlen len(zs);
|
||||||
|
char* x = new char[len.value()+1];
|
||||||
|
::gzread(zs.fp(), x, len.value());
|
||||||
|
x[len.value()] = '\0';
|
||||||
|
return x;
|
||||||
|
}
|
||||||
|
|
||||||
|
// ----------------------------- ozstream -----------------------------
|
||||||
|
|
||||||
|
class ozstream
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
ozstream() : m_fp(0), m_os(0) {
|
||||||
|
}
|
||||||
|
ozstream(FILE* fp, int level = Z_DEFAULT_COMPRESSION)
|
||||||
|
: m_fp(0), m_os(0) {
|
||||||
|
open(fp, level);
|
||||||
|
}
|
||||||
|
ozstream(const char* name, int level = Z_DEFAULT_COMPRESSION)
|
||||||
|
: m_fp(0), m_os(0) {
|
||||||
|
open(name, level);
|
||||||
|
}
|
||||||
|
~ozstream() {
|
||||||
|
close();
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Opens a gzip (.gz) file for writing.
|
||||||
|
* The compression level parameter should be in 0..9
|
||||||
|
* errno can be checked to distinguish two error cases
|
||||||
|
* (if errno is zero, the zlib error is Z_MEM_ERROR).
|
||||||
|
*/
|
||||||
|
void open(const char* name, int level = Z_DEFAULT_COMPRESSION) {
|
||||||
|
char mode[4] = "wb\0";
|
||||||
|
if (level != Z_DEFAULT_COMPRESSION) mode[2] = '0'+level;
|
||||||
|
if (m_fp) close();
|
||||||
|
m_fp = ::gzopen(name, mode);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* open from a FILE pointer.
|
||||||
|
*/
|
||||||
|
void open(FILE* fp, int level = Z_DEFAULT_COMPRESSION) {
|
||||||
|
SET_BINARY_MODE(fp);
|
||||||
|
char mode[4] = "wb\0";
|
||||||
|
if (level != Z_DEFAULT_COMPRESSION) mode[2] = '0'+level;
|
||||||
|
if (m_fp) close();
|
||||||
|
m_fp = ::gzdopen(fileno(fp), mode);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Flushes all pending output if necessary, closes the compressed file
|
||||||
|
* and deallocates all the (de)compression state. The return value is
|
||||||
|
* the zlib error number (see function error() below).
|
||||||
|
*/
|
||||||
|
int close() {
|
||||||
|
if (m_os) {
|
||||||
|
::gzwrite(m_fp, m_os->str(), m_os->pcount());
|
||||||
|
delete[] m_os->str(); delete m_os; m_os = 0;
|
||||||
|
}
|
||||||
|
int r = ::gzclose(m_fp); m_fp = 0; return r;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Binary write the given number of bytes into the compressed file.
|
||||||
|
*/
|
||||||
|
int write(const void* buf, size_t len) {
|
||||||
|
return ::gzwrite(m_fp, (voidp) buf, len);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Flushes all pending output into the compressed file. The parameter
|
||||||
|
* _flush is as in the deflate() function. The return value is the zlib
|
||||||
|
* error number (see function gzerror below). flush() returns Z_OK if
|
||||||
|
* the flush_ parameter is Z_FINISH and all output could be flushed.
|
||||||
|
* flush() should be called only when strictly necessary because it can
|
||||||
|
* degrade compression.
|
||||||
|
*/
|
||||||
|
int flush(int _flush) {
|
||||||
|
os_flush();
|
||||||
|
return ::gzflush(m_fp, _flush);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Returns the error message for the last error which occurred on the
|
||||||
|
* given compressed file. errnum is set to zlib error number. If an
|
||||||
|
* error occurred in the file system and not in the compression library,
|
||||||
|
* errnum is set to Z_ERRNO and the application may consult errno
|
||||||
|
* to get the exact error code.
|
||||||
|
*/
|
||||||
|
const char* error(int* errnum) {
|
||||||
|
return ::gzerror(m_fp, errnum);
|
||||||
|
}
|
||||||
|
|
||||||
|
gzFile fp() { return m_fp; }
|
||||||
|
|
||||||
|
ostream& os() {
|
||||||
|
if (m_os == 0) m_os = new ostrstream;
|
||||||
|
return *m_os;
|
||||||
|
}
|
||||||
|
|
||||||
|
void os_flush() {
|
||||||
|
if (m_os && m_os->pcount()>0) {
|
||||||
|
ostrstream* oss = new ostrstream;
|
||||||
|
oss->fill(m_os->fill());
|
||||||
|
oss->flags(m_os->flags());
|
||||||
|
oss->precision(m_os->precision());
|
||||||
|
oss->width(m_os->width());
|
||||||
|
::gzwrite(m_fp, m_os->str(), m_os->pcount());
|
||||||
|
delete[] m_os->str(); delete m_os; m_os = oss;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
gzFile m_fp;
|
||||||
|
ostrstream* m_os;
|
||||||
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Binary write the given (array of) object(s) into the compressed file.
|
||||||
|
* returns the number of uncompressed bytes actually written
|
||||||
|
* (0 in case of error).
|
||||||
|
*/
|
||||||
|
template <class T, class Items>
|
||||||
|
inline int write(ozstream& zs, const T* x, Items items) {
|
||||||
|
return ::gzwrite(zs.fp(), (voidp) x, items*sizeof(T));
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Binary output with the '<' operator.
|
||||||
|
*/
|
||||||
|
template <class T>
|
||||||
|
inline ozstream& operator<(ozstream& zs, const T& x) {
|
||||||
|
::gzwrite(zs.fp(), (voidp) &x, sizeof(T));
|
||||||
|
return zs;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline zstringlen::zstringlen(ozstream& zs, const char* x) {
|
||||||
|
val.byte = 255; val.word = ::strlen(x);
|
||||||
|
if (val.word < 255) zs < (val.byte = val.word);
|
||||||
|
else zs < val;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Write length of string + the string with the '<' operator.
|
||||||
|
*/
|
||||||
|
inline ozstream& operator<(ozstream& zs, const char* x) {
|
||||||
|
zstringlen len(zs, x);
|
||||||
|
::gzwrite(zs.fp(), (voidp) x, len.value());
|
||||||
|
return zs;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef _MSC_VER
|
||||||
|
inline ozstream& operator<(ozstream& zs, char* const& x) {
|
||||||
|
return zs < (const char*) x;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Ascii write with the << operator;
|
||||||
|
*/
|
||||||
|
template <class T>
|
||||||
|
inline ostream& operator<<(ozstream& zs, const T& x) {
|
||||||
|
zs.os_flush();
|
||||||
|
return zs.os() << x;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
25
contrib/iostream2/zstream_test.cpp
Normal file
25
contrib/iostream2/zstream_test.cpp
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
#include "zstream.h"
|
||||||
|
#include <math.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <iomanip.h>
|
||||||
|
|
||||||
|
void main() {
|
||||||
|
char h[256] = "Hello";
|
||||||
|
char* g = "Goodbye";
|
||||||
|
ozstream out("temp.gz");
|
||||||
|
out < "This works well" < h < g;
|
||||||
|
out.close();
|
||||||
|
|
||||||
|
izstream in("temp.gz"); // read it back
|
||||||
|
char *x = read_string(in), *y = new char[256], z[256];
|
||||||
|
in > y > z;
|
||||||
|
in.close();
|
||||||
|
cout << x << endl << y << endl << z << endl;
|
||||||
|
|
||||||
|
out.open("temp.gz"); // try ascii output; zcat temp.gz to see the results
|
||||||
|
out << setw(50) << setfill('#') << setprecision(20) << x << endl << y << endl << z << endl;
|
||||||
|
out << z << endl << y << endl << x << endl;
|
||||||
|
out << 1.1234567890123456789 << endl;
|
||||||
|
|
||||||
|
delete[] x; delete[] y;
|
||||||
|
}
|
||||||
38
contrib/minizip/ChangeLogUnzip
Normal file
38
contrib/minizip/ChangeLogUnzip
Normal file
@@ -0,0 +1,38 @@
|
|||||||
|
Change in 0.15: (19 Mar 98)
|
||||||
|
- fix memory leak in minizip.c
|
||||||
|
|
||||||
|
Change in 0.14: (10 Mar 98)
|
||||||
|
- fix bugs in minizip.c sample for zipping big file
|
||||||
|
- fix problem in month in date handling
|
||||||
|
- fix bug in unzlocal_GetCurrentFileInfoInternal in unzip.c for
|
||||||
|
comment handling
|
||||||
|
|
||||||
|
Change in 0.13: (6 Mar 98)
|
||||||
|
- fix bugs in zip.c
|
||||||
|
- add real minizip sample
|
||||||
|
|
||||||
|
Change in 0.12: (4 Mar 98)
|
||||||
|
- add zip.c and zip.h for creates .zip file
|
||||||
|
- fix change_file_date in miniunz.c for Unix (Jean-loup Gailly)
|
||||||
|
- fix miniunz.c for file without specific record for directory
|
||||||
|
|
||||||
|
Change in 0.11: (3 Mar 98)
|
||||||
|
- fix bug in unzGetCurrentFileInfo for get extra field and comment
|
||||||
|
- enhance miniunz sample, remove the bad unztst.c sample
|
||||||
|
|
||||||
|
Change in 0.10: (2 Mar 98)
|
||||||
|
- fix bug in unzReadCurrentFile
|
||||||
|
- rename unzip* to unz* function and structure
|
||||||
|
- remove Windows-like hungary notation variable name
|
||||||
|
- modify some structure in unzip.h
|
||||||
|
- add somes comment in source
|
||||||
|
- remove unzipGetcCurrentFile function
|
||||||
|
- replace ZUNZEXPORT by ZEXPORT
|
||||||
|
- add unzGetLocalExtrafield for get the local extrafield info
|
||||||
|
- add a new sample, miniunz.c
|
||||||
|
|
||||||
|
Change in 0.4: (25 Feb 98)
|
||||||
|
- suppress the type unzipFileInZip.
|
||||||
|
Only on file in the zipfile can be open at the same time
|
||||||
|
- fix somes typo in code
|
||||||
|
- added tm_unz structure in unzip_file_info (date/time in readable format)
|
||||||
25
contrib/minizip/Makefile
Normal file
25
contrib/minizip/Makefile
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
CC=cc
|
||||||
|
CFLAGS=-O -I../..
|
||||||
|
|
||||||
|
UNZ_OBJS = miniunz.o unzip.o ../../libz.a
|
||||||
|
ZIP_OBJS = minizip.o zip.o ../../libz.a
|
||||||
|
|
||||||
|
.c.o:
|
||||||
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
all: miniunz minizip
|
||||||
|
|
||||||
|
miniunz: $(UNZ_OBJS)
|
||||||
|
$(CC) $(CFLAGS) -o $@ $(UNZ_OBJS)
|
||||||
|
|
||||||
|
minizip: $(ZIP_OBJS)
|
||||||
|
$(CC) $(CFLAGS) -o $@ $(ZIP_OBJS)
|
||||||
|
|
||||||
|
test: miniunz minizip
|
||||||
|
./minizip test readme.txt
|
||||||
|
./miniunz -l test.zip
|
||||||
|
mv readme.txt readme.old
|
||||||
|
./miniunz test.zip
|
||||||
|
|
||||||
|
clean:
|
||||||
|
/bin/rm -f *.o *~ minizip miniunz
|
||||||
508
contrib/minizip/miniunz.c
Normal file
508
contrib/minizip/miniunz.c
Normal file
@@ -0,0 +1,508 @@
|
|||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <time.h>
|
||||||
|
#include <errno.h>
|
||||||
|
#include <fcntl.h>
|
||||||
|
|
||||||
|
#ifdef unix
|
||||||
|
# include <unistd.h>
|
||||||
|
# include <utime.h>
|
||||||
|
#else
|
||||||
|
# include <direct.h>
|
||||||
|
# include <io.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "unzip.h"
|
||||||
|
|
||||||
|
#define CASESENSITIVITY (0)
|
||||||
|
#define WRITEBUFFERSIZE (8192)
|
||||||
|
|
||||||
|
/*
|
||||||
|
mini unzip, demo of unzip package
|
||||||
|
|
||||||
|
usage :
|
||||||
|
Usage : miniunz [-exvlo] file.zip [file_to_extract]
|
||||||
|
|
||||||
|
list the file in the zipfile, and print the content of FILE_ID.ZIP or README.TXT
|
||||||
|
if it exists
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/* change_file_date : change the date/time of a file
|
||||||
|
filename : the filename of the file where date/time must be modified
|
||||||
|
dosdate : the new date at the MSDos format (4 bytes)
|
||||||
|
tmu_date : the SAME new date at the tm_unz format */
|
||||||
|
void change_file_date(filename,dosdate,tmu_date)
|
||||||
|
const char *filename;
|
||||||
|
uLong dosdate;
|
||||||
|
tm_unz tmu_date;
|
||||||
|
{
|
||||||
|
#ifdef WIN32
|
||||||
|
HANDLE hFile;
|
||||||
|
FILETIME ftm,ftLocal,ftCreate,ftLastAcc,ftLastWrite;
|
||||||
|
|
||||||
|
hFile = CreateFile(filename,GENERIC_READ | GENERIC_WRITE,
|
||||||
|
0,NULL,OPEN_EXISTING,0,NULL);
|
||||||
|
GetFileTime(hFile,&ftCreate,&ftLastAcc,&ftLastWrite);
|
||||||
|
DosDateTimeToFileTime((WORD)(dosdate>>16),(WORD)dosdate,&ftLocal);
|
||||||
|
LocalFileTimeToFileTime(&ftLocal,&ftm);
|
||||||
|
SetFileTime(hFile,&ftm,&ftLastAcc,&ftm);
|
||||||
|
CloseHandle(hFile);
|
||||||
|
#else
|
||||||
|
#ifdef unix
|
||||||
|
struct utimbuf ut;
|
||||||
|
struct tm newdate;
|
||||||
|
newdate.tm_sec = tmu_date.tm_sec;
|
||||||
|
newdate.tm_min=tmu_date.tm_min;
|
||||||
|
newdate.tm_hour=tmu_date.tm_hour;
|
||||||
|
newdate.tm_mday=tmu_date.tm_mday;
|
||||||
|
newdate.tm_mon=tmu_date.tm_mon;
|
||||||
|
if (tmu_date.tm_year > 1900)
|
||||||
|
newdate.tm_year=tmu_date.tm_year - 1900;
|
||||||
|
else
|
||||||
|
newdate.tm_year=tmu_date.tm_year ;
|
||||||
|
newdate.tm_isdst=-1;
|
||||||
|
|
||||||
|
ut.actime=ut.modtime=mktime(&newdate);
|
||||||
|
utime(filename,&ut);
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* mymkdir and change_file_date are not 100 % portable
|
||||||
|
As I don't know well Unix, I wait feedback for the unix portion */
|
||||||
|
|
||||||
|
int mymkdir(dirname)
|
||||||
|
const char* dirname;
|
||||||
|
{
|
||||||
|
int ret=0;
|
||||||
|
#ifdef WIN32
|
||||||
|
ret = mkdir(dirname);
|
||||||
|
#else
|
||||||
|
#ifdef unix
|
||||||
|
ret = mkdir (dirname,0775);
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
int makedir (newdir)
|
||||||
|
char *newdir;
|
||||||
|
{
|
||||||
|
char *buffer ;
|
||||||
|
char *p;
|
||||||
|
int len = strlen(newdir);
|
||||||
|
|
||||||
|
if (len <= 0)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
buffer = (char*)malloc(len+1);
|
||||||
|
strcpy(buffer,newdir);
|
||||||
|
|
||||||
|
if (buffer[len-1] == '/') {
|
||||||
|
buffer[len-1] = '\0';
|
||||||
|
}
|
||||||
|
if (mymkdir(buffer) == 0)
|
||||||
|
{
|
||||||
|
free(buffer);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
p = buffer+1;
|
||||||
|
while (1)
|
||||||
|
{
|
||||||
|
char hold;
|
||||||
|
|
||||||
|
while(*p && *p != '\\' && *p != '/')
|
||||||
|
p++;
|
||||||
|
hold = *p;
|
||||||
|
*p = 0;
|
||||||
|
if ((mymkdir(buffer) == -1) && (errno == ENOENT))
|
||||||
|
{
|
||||||
|
printf("couldn't create directory %s\n",buffer);
|
||||||
|
free(buffer);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
if (hold == 0)
|
||||||
|
break;
|
||||||
|
*p++ = hold;
|
||||||
|
}
|
||||||
|
free(buffer);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
void do_banner()
|
||||||
|
{
|
||||||
|
printf("MiniUnz 0.15, demo of zLib + Unz package written by Gilles Vollant\n");
|
||||||
|
printf("more info at http://wwww.winimage/zLibDll/unzip.htm\n\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
void do_help()
|
||||||
|
{
|
||||||
|
printf("Usage : miniunz [-exvlo] file.zip [file_to_extract]\n\n") ;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int do_list(uf)
|
||||||
|
unzFile uf;
|
||||||
|
{
|
||||||
|
uLong i;
|
||||||
|
unz_global_info gi;
|
||||||
|
int err;
|
||||||
|
|
||||||
|
err = unzGetGlobalInfo (uf,&gi);
|
||||||
|
if (err!=UNZ_OK)
|
||||||
|
printf("error %d with zipfile in unzGetGlobalInfo \n",err);
|
||||||
|
printf(" Length Method Size Ratio Date Time CRC-32 Name\n");
|
||||||
|
printf(" ------ ------ ---- ----- ---- ---- ------ ----\n");
|
||||||
|
for (i=0;i<gi.number_entry;i++)
|
||||||
|
{
|
||||||
|
char filename_inzip[256];
|
||||||
|
unz_file_info file_info;
|
||||||
|
uLong ratio=0;
|
||||||
|
const char *string_method;
|
||||||
|
err = unzGetCurrentFileInfo(uf,&file_info,filename_inzip,sizeof(filename_inzip),NULL,0,NULL,0);
|
||||||
|
if (err!=UNZ_OK)
|
||||||
|
{
|
||||||
|
printf("error %d with zipfile in unzGetCurrentFileInfo\n",err);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (file_info.uncompressed_size>0)
|
||||||
|
ratio = (file_info.compressed_size*100)/file_info.uncompressed_size;
|
||||||
|
|
||||||
|
if (file_info.compression_method==0)
|
||||||
|
string_method="Stored";
|
||||||
|
else
|
||||||
|
if (file_info.compression_method==Z_DEFLATED)
|
||||||
|
{
|
||||||
|
uInt iLevel=(uInt)((file_info.flag & 0x6)/2);
|
||||||
|
if (iLevel==0)
|
||||||
|
string_method="Defl:N";
|
||||||
|
else if (iLevel==1)
|
||||||
|
string_method="Defl:X";
|
||||||
|
else if ((iLevel==2) || (iLevel==3))
|
||||||
|
string_method="Defl:F"; /* 2:fast , 3 : extra fast*/
|
||||||
|
}
|
||||||
|
else
|
||||||
|
string_method="Unkn. ";
|
||||||
|
|
||||||
|
printf("%7lu %6s %7lu %3lu%% %2.2lu-%2.2lu-%2.2lu %2.2lu:%2.2lu %8.8lx %s\n",
|
||||||
|
file_info.uncompressed_size,string_method,file_info.compressed_size,
|
||||||
|
ratio,
|
||||||
|
(uLong)file_info.tmu_date.tm_mon + 1,
|
||||||
|
(uLong)file_info.tmu_date.tm_mday,
|
||||||
|
(uLong)file_info.tmu_date.tm_year % 100,
|
||||||
|
(uLong)file_info.tmu_date.tm_hour,(uLong)file_info.tmu_date.tm_min,
|
||||||
|
(uLong)file_info.crc,filename_inzip);
|
||||||
|
if ((i+1)<gi.number_entry)
|
||||||
|
{
|
||||||
|
err = unzGoToNextFile(uf);
|
||||||
|
if (err!=UNZ_OK)
|
||||||
|
{
|
||||||
|
printf("error %d with zipfile in unzGoToNextFile\n",err);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int do_extract_currentfile(uf,popt_extract_without_path,popt_overwrite)
|
||||||
|
unzFile uf;
|
||||||
|
const int* popt_extract_without_path;
|
||||||
|
int* popt_overwrite;
|
||||||
|
{
|
||||||
|
char filename_inzip[256];
|
||||||
|
char* filename_withoutpath;
|
||||||
|
char* p;
|
||||||
|
int err=UNZ_OK;
|
||||||
|
FILE *fout=NULL;
|
||||||
|
void* buf;
|
||||||
|
uInt size_buf;
|
||||||
|
|
||||||
|
unz_file_info file_info;
|
||||||
|
uLong ratio=0;
|
||||||
|
err = unzGetCurrentFileInfo(uf,&file_info,filename_inzip,sizeof(filename_inzip),NULL,0,NULL,0);
|
||||||
|
|
||||||
|
if (err!=UNZ_OK)
|
||||||
|
{
|
||||||
|
printf("error %d with zipfile in unzGetCurrentFileInfo\n",err);
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
|
||||||
|
size_buf = WRITEBUFFERSIZE;
|
||||||
|
buf = (void*)malloc(size_buf);
|
||||||
|
if (buf==NULL)
|
||||||
|
{
|
||||||
|
printf("Error allocating memory\n");
|
||||||
|
return UNZ_INTERNALERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
p = filename_withoutpath = filename_inzip;
|
||||||
|
while ((*p) != '\0')
|
||||||
|
{
|
||||||
|
if (((*p)=='/') || ((*p)=='\\'))
|
||||||
|
filename_withoutpath = p+1;
|
||||||
|
p++;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((*filename_withoutpath)=='\0')
|
||||||
|
{
|
||||||
|
if ((*popt_extract_without_path)==0)
|
||||||
|
{
|
||||||
|
printf("creating directory: %s\n",filename_inzip);
|
||||||
|
mymkdir(filename_inzip);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
const char* write_filename;
|
||||||
|
int skip=0;
|
||||||
|
|
||||||
|
if ((*popt_extract_without_path)==0)
|
||||||
|
write_filename = filename_inzip;
|
||||||
|
else
|
||||||
|
write_filename = filename_withoutpath;
|
||||||
|
|
||||||
|
err = unzOpenCurrentFile(uf);
|
||||||
|
if (err!=UNZ_OK)
|
||||||
|
{
|
||||||
|
printf("error %d with zipfile in unzOpenCurrentFile\n",err);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (((*popt_overwrite)==0) && (err==UNZ_OK))
|
||||||
|
{
|
||||||
|
char rep;
|
||||||
|
FILE* ftestexist;
|
||||||
|
ftestexist = fopen(write_filename,"rb");
|
||||||
|
if (ftestexist!=NULL)
|
||||||
|
{
|
||||||
|
fclose(ftestexist);
|
||||||
|
do
|
||||||
|
{
|
||||||
|
char answer[128];
|
||||||
|
printf("The file %s exist. Overwrite ? [y]es, [n]o, [A]ll: ",write_filename);
|
||||||
|
scanf("%1s",answer);
|
||||||
|
rep = answer[0] ;
|
||||||
|
if ((rep>='a') && (rep<='z'))
|
||||||
|
rep -= 0x20;
|
||||||
|
}
|
||||||
|
while ((rep!='Y') && (rep!='N') && (rep!='A'));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (rep == 'N')
|
||||||
|
skip = 1;
|
||||||
|
|
||||||
|
if (rep == 'A')
|
||||||
|
*popt_overwrite=1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((skip==0) && (err==UNZ_OK))
|
||||||
|
{
|
||||||
|
fout=fopen(write_filename,"wb");
|
||||||
|
|
||||||
|
/* some zipfile don't contain directory alone before file */
|
||||||
|
if ((fout==NULL) && ((*popt_extract_without_path)==0) &&
|
||||||
|
(filename_withoutpath!=(char*)filename_inzip))
|
||||||
|
{
|
||||||
|
char c=*(filename_withoutpath-1);
|
||||||
|
*(filename_withoutpath-1)='\0';
|
||||||
|
makedir(write_filename);
|
||||||
|
*(filename_withoutpath-1)=c;
|
||||||
|
fout=fopen(write_filename,"wb");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (fout==NULL)
|
||||||
|
{
|
||||||
|
printf("error opening %s\n",write_filename);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (fout!=NULL)
|
||||||
|
{
|
||||||
|
printf(" extracting: %s\n",write_filename);
|
||||||
|
|
||||||
|
do
|
||||||
|
{
|
||||||
|
err = unzReadCurrentFile(uf,buf,size_buf);
|
||||||
|
if (err<0)
|
||||||
|
{
|
||||||
|
printf("error %d with zipfile in unzReadCurrentFile\n",err);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (err>0)
|
||||||
|
if (fwrite(buf,err,1,fout)!=1)
|
||||||
|
{
|
||||||
|
printf("error in writing extracted file\n");
|
||||||
|
err=UNZ_ERRNO;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
while (err>0);
|
||||||
|
fclose(fout);
|
||||||
|
if (err==0)
|
||||||
|
change_file_date(write_filename,file_info.dosDate,
|
||||||
|
file_info.tmu_date);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (err==UNZ_OK)
|
||||||
|
{
|
||||||
|
err = unzCloseCurrentFile (uf);
|
||||||
|
if (err!=UNZ_OK)
|
||||||
|
{
|
||||||
|
printf("error %d with zipfile in unzCloseCurrentFile\n",err);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
unzCloseCurrentFile(uf); /* don't lose the error */
|
||||||
|
}
|
||||||
|
|
||||||
|
free(buf);
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int do_extract(uf,opt_extract_without_path,opt_overwrite)
|
||||||
|
unzFile uf;
|
||||||
|
int opt_extract_without_path;
|
||||||
|
int opt_overwrite;
|
||||||
|
{
|
||||||
|
uLong i;
|
||||||
|
unz_global_info gi;
|
||||||
|
int err;
|
||||||
|
FILE* fout=NULL;
|
||||||
|
|
||||||
|
err = unzGetGlobalInfo (uf,&gi);
|
||||||
|
if (err!=UNZ_OK)
|
||||||
|
printf("error %d with zipfile in unzGetGlobalInfo \n",err);
|
||||||
|
|
||||||
|
for (i=0;i<gi.number_entry;i++)
|
||||||
|
{
|
||||||
|
if (do_extract_currentfile(uf,&opt_extract_without_path,
|
||||||
|
&opt_overwrite) != UNZ_OK)
|
||||||
|
break;
|
||||||
|
|
||||||
|
if ((i+1)<gi.number_entry)
|
||||||
|
{
|
||||||
|
err = unzGoToNextFile(uf);
|
||||||
|
if (err!=UNZ_OK)
|
||||||
|
{
|
||||||
|
printf("error %d with zipfile in unzGoToNextFile\n",err);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int do_extract_onefile(uf,filename,opt_extract_without_path,opt_overwrite)
|
||||||
|
unzFile uf;
|
||||||
|
const char* filename;
|
||||||
|
int opt_extract_without_path;
|
||||||
|
int opt_overwrite;
|
||||||
|
{
|
||||||
|
int err = UNZ_OK;
|
||||||
|
if (unzLocateFile(uf,filename,CASESENSITIVITY)!=UNZ_OK)
|
||||||
|
{
|
||||||
|
printf("file %s not found in the zipfile\n",filename);
|
||||||
|
return 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (do_extract_currentfile(uf,&opt_extract_without_path,
|
||||||
|
&opt_overwrite) == UNZ_OK)
|
||||||
|
return 0;
|
||||||
|
else
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int main(argc,argv)
|
||||||
|
int argc;
|
||||||
|
char *argv[];
|
||||||
|
{
|
||||||
|
const char *zipfilename=NULL;
|
||||||
|
const char *filename_to_extract=NULL;
|
||||||
|
int i;
|
||||||
|
int opt_do_list=0;
|
||||||
|
int opt_do_extract=1;
|
||||||
|
int opt_do_extract_withoutpath=0;
|
||||||
|
int opt_overwrite=0;
|
||||||
|
char filename_try[512];
|
||||||
|
unzFile uf=NULL;
|
||||||
|
|
||||||
|
do_banner();
|
||||||
|
if (argc==1)
|
||||||
|
{
|
||||||
|
do_help();
|
||||||
|
exit(0);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
for (i=1;i<argc;i++)
|
||||||
|
{
|
||||||
|
if ((*argv[i])=='-')
|
||||||
|
{
|
||||||
|
const char *p=argv[i]+1;
|
||||||
|
|
||||||
|
while ((*p)!='\0')
|
||||||
|
{
|
||||||
|
char c=*(p++);;
|
||||||
|
if ((c=='l') || (c=='L'))
|
||||||
|
opt_do_list = 1;
|
||||||
|
if ((c=='v') || (c=='V'))
|
||||||
|
opt_do_list = 1;
|
||||||
|
if ((c=='x') || (c=='X'))
|
||||||
|
opt_do_extract = 1;
|
||||||
|
if ((c=='e') || (c=='E'))
|
||||||
|
opt_do_extract = opt_do_extract_withoutpath = 1;
|
||||||
|
if ((c=='o') || (c=='O'))
|
||||||
|
opt_overwrite=1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (zipfilename == NULL)
|
||||||
|
zipfilename = argv[i];
|
||||||
|
else if (filename_to_extract==NULL)
|
||||||
|
filename_to_extract = argv[i] ;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (zipfilename!=NULL)
|
||||||
|
{
|
||||||
|
strcpy(filename_try,zipfilename);
|
||||||
|
uf = unzOpen(zipfilename);
|
||||||
|
if (uf==NULL)
|
||||||
|
{
|
||||||
|
strcat(filename_try,".zip");
|
||||||
|
uf = unzOpen(filename_try);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (uf==NULL)
|
||||||
|
{
|
||||||
|
printf("Cannot open %s or %s.zip\n",zipfilename,zipfilename);
|
||||||
|
exit (1);
|
||||||
|
}
|
||||||
|
printf("%s opened\n",filename_try);
|
||||||
|
|
||||||
|
if (opt_do_list==1)
|
||||||
|
return do_list(uf);
|
||||||
|
else if (opt_do_extract==1)
|
||||||
|
{
|
||||||
|
if (filename_to_extract == NULL)
|
||||||
|
return do_extract(uf,opt_do_extract_withoutpath,opt_overwrite);
|
||||||
|
else
|
||||||
|
return do_extract_onefile(uf,filename_to_extract,
|
||||||
|
opt_do_extract_withoutpath,opt_overwrite);
|
||||||
|
}
|
||||||
|
unzCloseCurrentFile(uf);
|
||||||
|
|
||||||
|
return 0; /* to avoid warning */
|
||||||
|
}
|
||||||
302
contrib/minizip/minizip.c
Normal file
302
contrib/minizip/minizip.c
Normal file
@@ -0,0 +1,302 @@
|
|||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <time.h>
|
||||||
|
#include <errno.h>
|
||||||
|
#include <fcntl.h>
|
||||||
|
|
||||||
|
#ifdef unix
|
||||||
|
# include <unistd.h>
|
||||||
|
# include <utime.h>
|
||||||
|
# include <sys/types.h>
|
||||||
|
# include <sys/stat.h>
|
||||||
|
#else
|
||||||
|
# include <direct.h>
|
||||||
|
# include <io.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "zip.h"
|
||||||
|
|
||||||
|
|
||||||
|
#define WRITEBUFFERSIZE (16384)
|
||||||
|
#define MAXFILENAME (256)
|
||||||
|
|
||||||
|
#ifdef WIN32
|
||||||
|
uLong filetime(f, tmzip, dt)
|
||||||
|
char *f; /* name of file to get info on */
|
||||||
|
tm_zip *tmzip; /* return value: access, modific. and creation times */
|
||||||
|
uLong *dt; /* dostime */
|
||||||
|
{
|
||||||
|
int ret = 0;
|
||||||
|
{
|
||||||
|
FILETIME ftLocal;
|
||||||
|
HANDLE hFind;
|
||||||
|
WIN32_FIND_DATA ff32;
|
||||||
|
|
||||||
|
hFind = FindFirstFile(f,&ff32);
|
||||||
|
if (hFind != INVALID_HANDLE_VALUE)
|
||||||
|
{
|
||||||
|
FileTimeToLocalFileTime(&(ff32.ftLastWriteTime),&ftLocal);
|
||||||
|
FileTimeToDosDateTime(&ftLocal,((LPWORD)dt)+1,((LPWORD)dt)+0);
|
||||||
|
FindClose(hFind);
|
||||||
|
ret = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
#ifdef unix
|
||||||
|
uLong filetime(f, tmzip, dt)
|
||||||
|
char *f; /* name of file to get info on */
|
||||||
|
tm_zip *tmzip; /* return value: access, modific. and creation times */
|
||||||
|
uLong *dt; /* dostime */
|
||||||
|
{
|
||||||
|
int ret=0;
|
||||||
|
struct stat s; /* results of stat() */
|
||||||
|
struct tm* filedate;
|
||||||
|
time_t tm_t=0;
|
||||||
|
|
||||||
|
if (strcmp(f,"-")!=0)
|
||||||
|
{
|
||||||
|
char name[MAXFILENAME];
|
||||||
|
int len = strlen(f);
|
||||||
|
strcpy(name, f);
|
||||||
|
if (name[len - 1] == '/')
|
||||||
|
name[len - 1] = '\0';
|
||||||
|
/* not all systems allow stat'ing a file with / appended */
|
||||||
|
if (stat(name,&s)==0)
|
||||||
|
{
|
||||||
|
tm_t = s.st_mtime;
|
||||||
|
ret = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
filedate = localtime(&tm_t);
|
||||||
|
|
||||||
|
tmzip->tm_sec = filedate->tm_sec;
|
||||||
|
tmzip->tm_min = filedate->tm_min;
|
||||||
|
tmzip->tm_hour = filedate->tm_hour;
|
||||||
|
tmzip->tm_mday = filedate->tm_mday;
|
||||||
|
tmzip->tm_mon = filedate->tm_mon ;
|
||||||
|
tmzip->tm_year = filedate->tm_year;
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
uLong filetime(f, tmzip, dt)
|
||||||
|
char *f; /* name of file to get info on */
|
||||||
|
tm_zip *tmzip; /* return value: access, modific. and creation times */
|
||||||
|
uLong *dt; /* dostime */
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
int check_exist_file(filename)
|
||||||
|
const char* filename;
|
||||||
|
{
|
||||||
|
FILE* ftestexist;
|
||||||
|
int ret = 1;
|
||||||
|
ftestexist = fopen(filename,"rb");
|
||||||
|
if (ftestexist==NULL)
|
||||||
|
ret = 0;
|
||||||
|
else
|
||||||
|
fclose(ftestexist);
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
void do_banner()
|
||||||
|
{
|
||||||
|
printf("MiniZip 0.15, demo of zLib + Zip package written by Gilles Vollant\n");
|
||||||
|
printf("more info at http://wwww.winimage/zLibDll/unzip.htm\n\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
void do_help()
|
||||||
|
{
|
||||||
|
printf("Usage : minizip [-o] file.zip [files_to_add]\n\n") ;
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(argc,argv)
|
||||||
|
int argc;
|
||||||
|
char *argv[];
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
int opt_overwrite=0;
|
||||||
|
int opt_compress_level=Z_DEFAULT_COMPRESSION;
|
||||||
|
int zipfilenamearg = 0;
|
||||||
|
char filename_try[MAXFILENAME];
|
||||||
|
int zipok;
|
||||||
|
int err=0;
|
||||||
|
int size_buf=0;
|
||||||
|
void* buf=NULL,
|
||||||
|
|
||||||
|
|
||||||
|
do_banner();
|
||||||
|
if (argc==1)
|
||||||
|
{
|
||||||
|
do_help();
|
||||||
|
exit(0);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
for (i=1;i<argc;i++)
|
||||||
|
{
|
||||||
|
if ((*argv[i])=='-')
|
||||||
|
{
|
||||||
|
const char *p=argv[i]+1;
|
||||||
|
|
||||||
|
while ((*p)!='\0')
|
||||||
|
{
|
||||||
|
char c=*(p++);;
|
||||||
|
if ((c=='o') || (c=='O'))
|
||||||
|
opt_overwrite = 1;
|
||||||
|
if ((c>='0') && (c<='9'))
|
||||||
|
opt_compress_level = c-'0';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
if (zipfilenamearg == 0)
|
||||||
|
zipfilenamearg = i ;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
size_buf = WRITEBUFFERSIZE;
|
||||||
|
buf = (void*)malloc(size_buf);
|
||||||
|
if (buf==NULL)
|
||||||
|
{
|
||||||
|
printf("Error allocating memory\n");
|
||||||
|
return ZIP_INTERNALERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (zipfilenamearg==0)
|
||||||
|
zipok=0;
|
||||||
|
else
|
||||||
|
{
|
||||||
|
int i,len;
|
||||||
|
int dot_found=0;
|
||||||
|
|
||||||
|
zipok = 1 ;
|
||||||
|
strcpy(filename_try,argv[zipfilenamearg]);
|
||||||
|
len=strlen(filename_try);
|
||||||
|
for (i=0;i<len;i++)
|
||||||
|
if (filename_try[i]=='.')
|
||||||
|
dot_found=1;
|
||||||
|
|
||||||
|
if (dot_found==0)
|
||||||
|
strcat(filename_try,".zip");
|
||||||
|
|
||||||
|
if (opt_overwrite==0)
|
||||||
|
if (check_exist_file(filename_try)!=0)
|
||||||
|
{
|
||||||
|
char rep;
|
||||||
|
do
|
||||||
|
{
|
||||||
|
char answer[128];
|
||||||
|
printf("The file %s exist. Overwrite ? [y]es, [n]o : ",filename_try);
|
||||||
|
scanf("%1s",answer);
|
||||||
|
rep = answer[0] ;
|
||||||
|
if ((rep>='a') && (rep<='z'))
|
||||||
|
rep -= 0x20;
|
||||||
|
}
|
||||||
|
while ((rep!='Y') && (rep!='N'));
|
||||||
|
if (rep=='N')
|
||||||
|
zipok = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (zipok==1)
|
||||||
|
{
|
||||||
|
zipFile zf;
|
||||||
|
int errclose;
|
||||||
|
zf = zipOpen(filename_try,0);
|
||||||
|
if (zf == NULL)
|
||||||
|
{
|
||||||
|
printf("error opening %s\n",filename_try);
|
||||||
|
err= ZIP_ERRNO;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
printf("creating %s\n",filename_try);
|
||||||
|
|
||||||
|
for (i=zipfilenamearg+1;(i<argc) && (err==ZIP_OK);i++)
|
||||||
|
{
|
||||||
|
if (((*(argv[i]))!='-') && ((*(argv[i]))!='/'))
|
||||||
|
{
|
||||||
|
FILE * fin;
|
||||||
|
int size_read;
|
||||||
|
const char* filenameinzip = argv[i];
|
||||||
|
zip_fileinfo zi;
|
||||||
|
|
||||||
|
zi.tmz_date.tm_sec = zi.tmz_date.tm_min = zi.tmz_date.tm_hour =
|
||||||
|
zi.tmz_date.tm_mday = zi.tmz_date.tm_min = zi.tmz_date.tm_year = 0;
|
||||||
|
zi.dosDate = 0;
|
||||||
|
zi.internal_fa = 0;
|
||||||
|
zi.external_fa = 0;
|
||||||
|
filetime(filenameinzip,&zi.tmz_date,&zi.dosDate);
|
||||||
|
|
||||||
|
|
||||||
|
err = zipOpenNewFileInZip(zf,filenameinzip,&zi,
|
||||||
|
NULL,0,NULL,0,NULL /* comment*/,
|
||||||
|
(opt_compress_level != 0) ? Z_DEFLATED : 0,
|
||||||
|
opt_compress_level);
|
||||||
|
|
||||||
|
if (err != ZIP_OK)
|
||||||
|
printf("error in opening %s in zipfile\n",filenameinzip);
|
||||||
|
else
|
||||||
|
{
|
||||||
|
fin = fopen(filenameinzip,"rb");
|
||||||
|
if (fin==NULL)
|
||||||
|
{
|
||||||
|
err=ZIP_ERRNO;
|
||||||
|
printf("error in opening %s for reading\n",filenameinzip);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (err == ZIP_OK)
|
||||||
|
do
|
||||||
|
{
|
||||||
|
err = ZIP_OK;
|
||||||
|
size_read = fread(buf,1,size_buf,fin);
|
||||||
|
if (size_read < size_buf)
|
||||||
|
if (feof(fin)==0)
|
||||||
|
{
|
||||||
|
printf("error in reading %s\n",filenameinzip);
|
||||||
|
err = ZIP_ERRNO;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (size_read>0)
|
||||||
|
{
|
||||||
|
err = zipWriteInFileInZip (zf,buf,size_read);
|
||||||
|
if (err<0)
|
||||||
|
{
|
||||||
|
printf("error in writing %s in the zipfile\n",
|
||||||
|
filenameinzip);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
} while ((err == ZIP_OK) && (size_read>0));
|
||||||
|
|
||||||
|
fclose(fin);
|
||||||
|
if (err<0)
|
||||||
|
err=ZIP_ERRNO;
|
||||||
|
else
|
||||||
|
{
|
||||||
|
err = zipCloseFileInZip(zf);
|
||||||
|
if (err!=ZIP_OK)
|
||||||
|
printf("error in closing %s in the zipfile\n",
|
||||||
|
filenameinzip);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
errclose = zipClose(zf,NULL);
|
||||||
|
if (errclose != ZIP_OK)
|
||||||
|
printf("error in closing %s\n",filename_try);
|
||||||
|
}
|
||||||
|
|
||||||
|
free(buf);
|
||||||
|
exit(0);
|
||||||
|
return 0; /* to avoid warning */
|
||||||
|
}
|
||||||
37
contrib/minizip/readme.txt
Normal file
37
contrib/minizip/readme.txt
Normal file
@@ -0,0 +1,37 @@
|
|||||||
|
|
||||||
|
UnZip 0.15 additionnal library
|
||||||
|
|
||||||
|
|
||||||
|
This unzip package allow extract file from .ZIP file, compatible with
|
||||||
|
PKZip 2.04g, WinZip, InfoZip tools and compatible.
|
||||||
|
|
||||||
|
Multi volume ZipFile (span) are not supported, and old compression used by old
|
||||||
|
PKZip 1.x are not supported.
|
||||||
|
|
||||||
|
See probdesc.zip from PKWare for specification of .ZIP format.
|
||||||
|
|
||||||
|
What is Unzip
|
||||||
|
The Zlib library support the deflate compression and the creation of gzip (.gz)
|
||||||
|
file. Zlib is free and small.
|
||||||
|
The .Zip format, which can contain several compressed files (.gz can containt
|
||||||
|
only one file) is a very popular format. This is why I've written a package for reading file compressed in Zipfile.
|
||||||
|
|
||||||
|
Using Unzip package
|
||||||
|
|
||||||
|
You need source of Zlib (get zlib111.zip and read zlib.h).
|
||||||
|
Get unzlb015.zip and read unzip.h (whith documentation of unzip functions)
|
||||||
|
|
||||||
|
The Unzip package is only two file : unzip.h and unzip.c. But it use the Zlib
|
||||||
|
files.
|
||||||
|
unztst.c is a simple sample program, which list file in a zipfile and display
|
||||||
|
README.TXT or FILE_ID.DIZ (if these files are found).
|
||||||
|
miniunz.c is a mini unzip program.
|
||||||
|
|
||||||
|
I'm also currenlyt writing a zipping portion (zip.h, zip.c and test with minizip.c)
|
||||||
|
|
||||||
|
Please email me for feedback.
|
||||||
|
I hope my source is compatible with Unix system, but I need your help for be sure
|
||||||
|
|
||||||
|
Latest revision : Mar 04th, 1998
|
||||||
|
|
||||||
|
Check http://www.winimage.com/zLibDll/unzip.html for up to date info.
|
||||||
1294
contrib/minizip/unzip.c
Normal file
1294
contrib/minizip/unzip.c
Normal file
File diff suppressed because it is too large
Load Diff
15
contrib/minizip/unzip.def
Normal file
15
contrib/minizip/unzip.def
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
unzOpen @61
|
||||||
|
unzClose @62
|
||||||
|
unzGetGlobalInfo @63
|
||||||
|
unzGetCurrentFileInfo @64
|
||||||
|
unzGoToFirstFile @65
|
||||||
|
unzGoToNextFile @66
|
||||||
|
unzOpenCurrentFile @67
|
||||||
|
unzReadCurrentFile @68
|
||||||
|
unztell @70
|
||||||
|
unzeof @71
|
||||||
|
unzCloseCurrentFile @72
|
||||||
|
unzGetGlobalComment @73
|
||||||
|
unzStringFileNameCompare @74
|
||||||
|
unzLocateFile @75
|
||||||
|
unzGetLocalExtrafield @76
|
||||||
275
contrib/minizip/unzip.h
Normal file
275
contrib/minizip/unzip.h
Normal file
@@ -0,0 +1,275 @@
|
|||||||
|
/* unzip.h -- IO for uncompress .zip files using zlib
|
||||||
|
Version 0.15 beta, Mar 19th, 1998,
|
||||||
|
|
||||||
|
Copyright (C) 1998 Gilles Vollant
|
||||||
|
|
||||||
|
This unzip package allow extract file from .ZIP file, compatible with PKZip 2.04g
|
||||||
|
WinZip, InfoZip tools and compatible.
|
||||||
|
Encryption and multi volume ZipFile (span) are not supported.
|
||||||
|
Old compressions used by old PKZip 1.x are not supported
|
||||||
|
|
||||||
|
THIS IS AN ALPHA VERSION. AT THIS STAGE OF DEVELOPPEMENT, SOMES API OR STRUCTURE
|
||||||
|
CAN CHANGE IN FUTURE VERSION !!
|
||||||
|
I WAIT FEEDBACK at mail info@winimage.com
|
||||||
|
Visit also http://www.winimage.com/zLibDll/unzip.htm for evolution
|
||||||
|
|
||||||
|
Condition of use and distribution are the same than zlib :
|
||||||
|
|
||||||
|
This software is provided 'as-is', without any express or implied
|
||||||
|
warranty. In no event will the authors 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.
|
||||||
|
|
||||||
|
|
||||||
|
*/
|
||||||
|
/* for more info about .ZIP format, see
|
||||||
|
ftp://ftp.cdrom.com/pub/infozip/doc/appnote-970311-iz.zip
|
||||||
|
PkWare has also a specification at :
|
||||||
|
ftp://ftp.pkware.com/probdesc.zip */
|
||||||
|
|
||||||
|
#ifndef _unz_H
|
||||||
|
#define _unz_H
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef _ZLIB_H
|
||||||
|
#include "zlib.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(STRICTUNZIP) || defined(STRICTZIPUNZIP)
|
||||||
|
/* like the STRICT of WIN32, we define a pointer that cannot be converted
|
||||||
|
from (void*) without cast */
|
||||||
|
typedef struct TagunzFile__ { int unused; } unzFile__;
|
||||||
|
typedef unzFile__ *unzFile;
|
||||||
|
#else
|
||||||
|
typedef voidp unzFile;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#define UNZ_OK (0)
|
||||||
|
#define UNZ_END_OF_LIST_OF_FILE (-100)
|
||||||
|
#define UNZ_ERRNO (Z_ERRNO)
|
||||||
|
#define UNZ_EOF (0)
|
||||||
|
#define UNZ_PARAMERROR (-102)
|
||||||
|
#define UNZ_BADZIPFILE (-103)
|
||||||
|
#define UNZ_INTERNALERROR (-104)
|
||||||
|
#define UNZ_CRCERROR (-105)
|
||||||
|
|
||||||
|
/* tm_unz contain date/time info */
|
||||||
|
typedef struct tm_unz_s
|
||||||
|
{
|
||||||
|
uInt tm_sec; /* seconds after the minute - [0,59] */
|
||||||
|
uInt tm_min; /* minutes after the hour - [0,59] */
|
||||||
|
uInt tm_hour; /* hours since midnight - [0,23] */
|
||||||
|
uInt tm_mday; /* day of the month - [1,31] */
|
||||||
|
uInt tm_mon; /* months since January - [0,11] */
|
||||||
|
uInt tm_year; /* years - [1980..2044] */
|
||||||
|
} tm_unz;
|
||||||
|
|
||||||
|
/* unz_global_info structure contain global data about the ZIPfile
|
||||||
|
These data comes from the end of central dir */
|
||||||
|
typedef struct unz_global_info_s
|
||||||
|
{
|
||||||
|
uLong number_entry; /* total number of entries in
|
||||||
|
the central dir on this disk */
|
||||||
|
uLong size_comment; /* size of the global comment of the zipfile */
|
||||||
|
} unz_global_info;
|
||||||
|
|
||||||
|
|
||||||
|
/* unz_file_info contain information about a file in the zipfile */
|
||||||
|
typedef struct unz_file_info_s
|
||||||
|
{
|
||||||
|
uLong version; /* version made by 2 bytes */
|
||||||
|
uLong version_needed; /* version needed to extract 2 bytes */
|
||||||
|
uLong flag; /* general purpose bit flag 2 bytes */
|
||||||
|
uLong compression_method; /* compression method 2 bytes */
|
||||||
|
uLong dosDate; /* last mod file date in Dos fmt 4 bytes */
|
||||||
|
uLong crc; /* crc-32 4 bytes */
|
||||||
|
uLong compressed_size; /* compressed size 4 bytes */
|
||||||
|
uLong uncompressed_size; /* uncompressed size 4 bytes */
|
||||||
|
uLong size_filename; /* filename length 2 bytes */
|
||||||
|
uLong size_file_extra; /* extra field length 2 bytes */
|
||||||
|
uLong size_file_comment; /* file comment length 2 bytes */
|
||||||
|
|
||||||
|
uLong disk_num_start; /* disk number start 2 bytes */
|
||||||
|
uLong internal_fa; /* internal file attributes 2 bytes */
|
||||||
|
uLong external_fa; /* external file attributes 4 bytes */
|
||||||
|
|
||||||
|
tm_unz tmu_date;
|
||||||
|
} unz_file_info;
|
||||||
|
|
||||||
|
extern int ZEXPORT unzStringFileNameCompare OF ((const char* fileName1,
|
||||||
|
const char* fileName2,
|
||||||
|
int iCaseSensitivity));
|
||||||
|
/*
|
||||||
|
Compare two filename (fileName1,fileName2).
|
||||||
|
If iCaseSenisivity = 1, comparision is case sensitivity (like strcmp)
|
||||||
|
If iCaseSenisivity = 2, comparision is not case sensitivity (like strcmpi
|
||||||
|
or strcasecmp)
|
||||||
|
If iCaseSenisivity = 0, case sensitivity is defaut of your operating system
|
||||||
|
(like 1 on Unix, 2 on Windows)
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
extern unzFile ZEXPORT unzOpen OF((const char *path));
|
||||||
|
/*
|
||||||
|
Open a Zip file. path contain the full pathname (by example,
|
||||||
|
on a Windows NT computer "c:\\zlib\\zlib111.zip" or on an Unix computer
|
||||||
|
"zlib/zlib111.zip".
|
||||||
|
If the zipfile cannot be opened (file don't exist or in not valid), the
|
||||||
|
return value is NULL.
|
||||||
|
Else, the return value is a unzFile Handle, usable with other function
|
||||||
|
of this unzip package.
|
||||||
|
*/
|
||||||
|
|
||||||
|
extern int ZEXPORT unzClose OF((unzFile file));
|
||||||
|
/*
|
||||||
|
Close a ZipFile opened with unzipOpen.
|
||||||
|
If there is files inside the .Zip opened with unzOpenCurrentFile (see later),
|
||||||
|
these files MUST be closed with unzipCloseCurrentFile before call unzipClose.
|
||||||
|
return UNZ_OK if there is no problem. */
|
||||||
|
|
||||||
|
extern int ZEXPORT unzGetGlobalInfo OF((unzFile file,
|
||||||
|
unz_global_info *pglobal_info));
|
||||||
|
/*
|
||||||
|
Write info about the ZipFile in the *pglobal_info structure.
|
||||||
|
No preparation of the structure is needed
|
||||||
|
return UNZ_OK if there is no problem. */
|
||||||
|
|
||||||
|
|
||||||
|
extern int ZEXPORT unzGetGlobalComment OF((unzFile file,
|
||||||
|
char *szComment,
|
||||||
|
uLong uSizeBuf));
|
||||||
|
/*
|
||||||
|
Get the global comment string of the ZipFile, in the szComment buffer.
|
||||||
|
uSizeBuf is the size of the szComment buffer.
|
||||||
|
return the number of byte copied or an error code <0
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/***************************************************************************/
|
||||||
|
/* Unzip package allow you browse the directory of the zipfile */
|
||||||
|
|
||||||
|
extern int ZEXPORT unzGoToFirstFile OF((unzFile file));
|
||||||
|
/*
|
||||||
|
Set the current file of the zipfile to the first file.
|
||||||
|
return UNZ_OK if there is no problem
|
||||||
|
*/
|
||||||
|
|
||||||
|
extern int ZEXPORT unzGoToNextFile OF((unzFile file));
|
||||||
|
/*
|
||||||
|
Set the current file of the zipfile to the next file.
|
||||||
|
return UNZ_OK if there is no problem
|
||||||
|
return UNZ_END_OF_LIST_OF_FILE if the actual file was the latest.
|
||||||
|
*/
|
||||||
|
|
||||||
|
extern int ZEXPORT unzLocateFile OF((unzFile file,
|
||||||
|
const char *szFileName,
|
||||||
|
int iCaseSensitivity));
|
||||||
|
/*
|
||||||
|
Try locate the file szFileName in the zipfile.
|
||||||
|
For the iCaseSensitivity signification, see unzStringFileNameCompare
|
||||||
|
|
||||||
|
return value :
|
||||||
|
UNZ_OK if the file is found. It becomes the current file.
|
||||||
|
UNZ_END_OF_LIST_OF_FILE if the file is not found
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
extern int ZEXPORT unzGetCurrentFileInfo OF((unzFile file,
|
||||||
|
unz_file_info *pfile_info,
|
||||||
|
char *szFileName,
|
||||||
|
uLong fileNameBufferSize,
|
||||||
|
void *extraField,
|
||||||
|
uLong extraFieldBufferSize,
|
||||||
|
char *szComment,
|
||||||
|
uLong commentBufferSize));
|
||||||
|
/*
|
||||||
|
Get Info about the current file
|
||||||
|
if pfile_info!=NULL, the *pfile_info structure will contain somes info about
|
||||||
|
the current file
|
||||||
|
if szFileName!=NULL, the filemane string will be copied in szFileName
|
||||||
|
(fileNameBufferSize is the size of the buffer)
|
||||||
|
if extraField!=NULL, the extra field information will be copied in extraField
|
||||||
|
(extraFieldBufferSize is the size of the buffer).
|
||||||
|
This is the Central-header version of the extra field
|
||||||
|
if szComment!=NULL, the comment string of the file will be copied in szComment
|
||||||
|
(commentBufferSize is the size of the buffer)
|
||||||
|
*/
|
||||||
|
|
||||||
|
/***************************************************************************/
|
||||||
|
/* for reading the content of the current zipfile, you can open it, read data
|
||||||
|
from it, and close it (you can close it before reading all the file)
|
||||||
|
*/
|
||||||
|
|
||||||
|
extern int ZEXPORT unzOpenCurrentFile OF((unzFile file));
|
||||||
|
/*
|
||||||
|
Open for reading data the current file in the zipfile.
|
||||||
|
If there is no error, the return value is UNZ_OK.
|
||||||
|
*/
|
||||||
|
|
||||||
|
extern int ZEXPORT unzCloseCurrentFile OF((unzFile file));
|
||||||
|
/*
|
||||||
|
Close the file in zip opened with unzOpenCurrentFile
|
||||||
|
Return UNZ_CRCERROR if all the file was read but the CRC is not good
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
extern int ZEXPORT unzReadCurrentFile OF((unzFile file,
|
||||||
|
voidp buf,
|
||||||
|
unsigned len));
|
||||||
|
/*
|
||||||
|
Read bytes from the current file (opened by unzOpenCurrentFile)
|
||||||
|
buf contain buffer where data must be copied
|
||||||
|
len the size of buf.
|
||||||
|
|
||||||
|
return the number of byte copied if somes bytes are copied
|
||||||
|
return 0 if the end of file was reached
|
||||||
|
return <0 with error code if there is an error
|
||||||
|
(UNZ_ERRNO for IO error, or zLib error for uncompress error)
|
||||||
|
*/
|
||||||
|
|
||||||
|
extern z_off_t ZEXPORT unztell OF((unzFile file));
|
||||||
|
/*
|
||||||
|
Give the current position in uncompressed data
|
||||||
|
*/
|
||||||
|
|
||||||
|
extern int ZEXPORT unzeof OF((unzFile file));
|
||||||
|
/*
|
||||||
|
return 1 if the end of file was reached, 0 elsewhere
|
||||||
|
*/
|
||||||
|
|
||||||
|
extern int ZEXPORT unzGetLocalExtrafield OF((unzFile file,
|
||||||
|
voidp buf,
|
||||||
|
unsigned len));
|
||||||
|
/*
|
||||||
|
Read extra field from the current file (opened by unzOpenCurrentFile)
|
||||||
|
This is the local-header version of the extra field (sometimes, there is
|
||||||
|
more info in the local-header version than in the central-header)
|
||||||
|
|
||||||
|
if buf==NULL, it return the size of the local extra field
|
||||||
|
|
||||||
|
if buf!=NULL, len is the size of the buffer, the extra header is copied in
|
||||||
|
buf.
|
||||||
|
the return value is the number of bytes copied in buf, or (if <0)
|
||||||
|
the error code
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* _unz_H */
|
||||||
718
contrib/minizip/zip.c
Normal file
718
contrib/minizip/zip.c
Normal file
@@ -0,0 +1,718 @@
|
|||||||
|
/* zip.c -- IO on .zip files using zlib
|
||||||
|
Version 0.15 beta, Mar 19th, 1998,
|
||||||
|
|
||||||
|
Read zip.h for more info
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include "zlib.h"
|
||||||
|
#include "zip.h"
|
||||||
|
|
||||||
|
#ifdef STDC
|
||||||
|
# include <stddef.h>
|
||||||
|
# include <string.h>
|
||||||
|
# include <stdlib.h>
|
||||||
|
#endif
|
||||||
|
#ifdef NO_ERRNO_H
|
||||||
|
extern int errno;
|
||||||
|
#else
|
||||||
|
# include <errno.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef local
|
||||||
|
# define local static
|
||||||
|
#endif
|
||||||
|
/* compile with -Dlocal if your debugger can't find static symbols */
|
||||||
|
|
||||||
|
#ifndef VERSIONMADEBY
|
||||||
|
# define VERSIONMADEBY (0x0) /* platform depedent */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef Z_BUFSIZE
|
||||||
|
#define Z_BUFSIZE (16384)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef Z_MAXFILENAMEINZIP
|
||||||
|
#define Z_MAXFILENAMEINZIP (256)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef ALLOC
|
||||||
|
# define ALLOC(size) (malloc(size))
|
||||||
|
#endif
|
||||||
|
#ifndef TRYFREE
|
||||||
|
# define TRYFREE(p) {if (p) free(p);}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
#define SIZECENTRALDIRITEM (0x2e)
|
||||||
|
#define SIZEZIPLOCALHEADER (0x1e)
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* I've found an old Unix (a SunOS 4.1.3_U1) without all SEEK_* defined.... */
|
||||||
|
|
||||||
|
#ifndef SEEK_CUR
|
||||||
|
#define SEEK_CUR 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef SEEK_END
|
||||||
|
#define SEEK_END 2
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef SEEK_SET
|
||||||
|
#define SEEK_SET 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
const char zip_copyright[] =
|
||||||
|
" zip 0.15 Copyright 1998 Gilles Vollant ";
|
||||||
|
|
||||||
|
|
||||||
|
#define SIZEDATA_INDATABLOCK (4096-(4*4))
|
||||||
|
|
||||||
|
#define LOCALHEADERMAGIC (0x04034b50)
|
||||||
|
#define CENTRALHEADERMAGIC (0x02014b50)
|
||||||
|
#define ENDHEADERMAGIC (0x06054b50)
|
||||||
|
|
||||||
|
#define FLAG_LOCALHEADER_OFFSET (0x06)
|
||||||
|
#define CRC_LOCALHEADER_OFFSET (0x0e)
|
||||||
|
|
||||||
|
#define SIZECENTRALHEADER (0x2e) /* 46 */
|
||||||
|
|
||||||
|
typedef struct linkedlist_datablock_internal_s
|
||||||
|
{
|
||||||
|
struct linkedlist_datablock_internal_s* next_datablock;
|
||||||
|
uLong avail_in_this_block;
|
||||||
|
uLong filled_in_this_block;
|
||||||
|
uLong unused; /* for future use and alignement */
|
||||||
|
unsigned char data[SIZEDATA_INDATABLOCK];
|
||||||
|
} linkedlist_datablock_internal;
|
||||||
|
|
||||||
|
typedef struct linkedlist_data_s
|
||||||
|
{
|
||||||
|
linkedlist_datablock_internal* first_block;
|
||||||
|
linkedlist_datablock_internal* last_block;
|
||||||
|
} linkedlist_data;
|
||||||
|
|
||||||
|
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
z_stream stream; /* zLib stream structure for inflate */
|
||||||
|
int stream_initialised; /* 1 is stream is initialised */
|
||||||
|
uInt pos_in_buffered_data; /* last written byte in buffered_data */
|
||||||
|
|
||||||
|
uLong pos_local_header; /* offset of the local header of the file
|
||||||
|
currenty writing */
|
||||||
|
char* central_header; /* central header data for the current file */
|
||||||
|
uLong size_centralheader; /* size of the central header for cur file */
|
||||||
|
uLong flag; /* flag of the file currently writing */
|
||||||
|
|
||||||
|
int method; /* compression method of file currenty wr.*/
|
||||||
|
Byte buffered_data[Z_BUFSIZE];/* buffer contain compressed data to be writ*/
|
||||||
|
uLong dosDate;
|
||||||
|
uLong crc32;
|
||||||
|
} curfile_info;
|
||||||
|
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
FILE * filezip;
|
||||||
|
linkedlist_data central_dir;/* datablock with central dir in construction*/
|
||||||
|
int in_opened_file_inzip; /* 1 if a file in the zip is currently writ.*/
|
||||||
|
curfile_info ci; /* info on the file curretly writing */
|
||||||
|
|
||||||
|
uLong begin_pos; /* position of the beginning of the zipfile */
|
||||||
|
uLong number_entry;
|
||||||
|
} zip_internal;
|
||||||
|
|
||||||
|
local linkedlist_datablock_internal* allocate_new_datablock()
|
||||||
|
{
|
||||||
|
linkedlist_datablock_internal* ldi;
|
||||||
|
ldi = (linkedlist_datablock_internal*)
|
||||||
|
ALLOC(sizeof(linkedlist_datablock_internal));
|
||||||
|
if (ldi!=NULL)
|
||||||
|
{
|
||||||
|
ldi->next_datablock = NULL ;
|
||||||
|
ldi->filled_in_this_block = 0 ;
|
||||||
|
ldi->avail_in_this_block = SIZEDATA_INDATABLOCK ;
|
||||||
|
}
|
||||||
|
return ldi;
|
||||||
|
}
|
||||||
|
|
||||||
|
local void free_datablock(ldi)
|
||||||
|
linkedlist_datablock_internal* ldi;
|
||||||
|
{
|
||||||
|
while (ldi!=NULL)
|
||||||
|
{
|
||||||
|
linkedlist_datablock_internal* ldinext = ldi->next_datablock;
|
||||||
|
TRYFREE(ldi);
|
||||||
|
ldi = ldinext;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
local void init_linkedlist(ll)
|
||||||
|
linkedlist_data* ll;
|
||||||
|
{
|
||||||
|
ll->first_block = ll->last_block = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
local void free_linkedlist(ll)
|
||||||
|
linkedlist_data* ll;
|
||||||
|
{
|
||||||
|
free_datablock(ll->first_block);
|
||||||
|
ll->first_block = ll->last_block = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
local int add_data_in_datablock(ll,buf,len)
|
||||||
|
linkedlist_data* ll;
|
||||||
|
const void* buf;
|
||||||
|
uLong len;
|
||||||
|
{
|
||||||
|
linkedlist_datablock_internal* ldi;
|
||||||
|
const unsigned char* from_copy;
|
||||||
|
|
||||||
|
if (ll==NULL)
|
||||||
|
return ZIP_INTERNALERROR;
|
||||||
|
|
||||||
|
if (ll->last_block == NULL)
|
||||||
|
{
|
||||||
|
ll->first_block = ll->last_block = allocate_new_datablock();
|
||||||
|
if (ll->first_block == NULL)
|
||||||
|
return ZIP_INTERNALERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
ldi = ll->last_block;
|
||||||
|
from_copy = (unsigned char*)buf;
|
||||||
|
|
||||||
|
while (len>0)
|
||||||
|
{
|
||||||
|
uInt copy_this;
|
||||||
|
uInt i;
|
||||||
|
unsigned char* to_copy;
|
||||||
|
|
||||||
|
if (ldi->avail_in_this_block==0)
|
||||||
|
{
|
||||||
|
ldi->next_datablock = allocate_new_datablock();
|
||||||
|
if (ldi->next_datablock == NULL)
|
||||||
|
return ZIP_INTERNALERROR;
|
||||||
|
ldi = ldi->next_datablock ;
|
||||||
|
ll->last_block = ldi;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ldi->avail_in_this_block < len)
|
||||||
|
copy_this = (uInt)ldi->avail_in_this_block;
|
||||||
|
else
|
||||||
|
copy_this = (uInt)len;
|
||||||
|
|
||||||
|
to_copy = &(ldi->data[ldi->filled_in_this_block]);
|
||||||
|
|
||||||
|
for (i=0;i<copy_this;i++)
|
||||||
|
*(to_copy+i)=*(from_copy+i);
|
||||||
|
|
||||||
|
ldi->filled_in_this_block += copy_this;
|
||||||
|
ldi->avail_in_this_block -= copy_this;
|
||||||
|
from_copy += copy_this ;
|
||||||
|
len -= copy_this;
|
||||||
|
}
|
||||||
|
return ZIP_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
local int write_datablock(fout,ll)
|
||||||
|
FILE * fout;
|
||||||
|
linkedlist_data* ll;
|
||||||
|
{
|
||||||
|
linkedlist_datablock_internal* ldi;
|
||||||
|
ldi = ll->first_block;
|
||||||
|
while (ldi!=NULL)
|
||||||
|
{
|
||||||
|
if (ldi->filled_in_this_block > 0)
|
||||||
|
if (fwrite(ldi->data,(uInt)ldi->filled_in_this_block,1,fout)!=1)
|
||||||
|
return ZIP_ERRNO;
|
||||||
|
ldi = ldi->next_datablock;
|
||||||
|
}
|
||||||
|
return ZIP_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
/****************************************************************************/
|
||||||
|
|
||||||
|
/* ===========================================================================
|
||||||
|
Outputs a long in LSB order to the given file
|
||||||
|
nbByte == 1, 2 or 4 (byte, short or long)
|
||||||
|
*/
|
||||||
|
|
||||||
|
local int ziplocal_putValue OF((FILE *file, uLong x, int nbByte));
|
||||||
|
local int ziplocal_putValue (file, x, nbByte)
|
||||||
|
FILE *file;
|
||||||
|
uLong x;
|
||||||
|
int nbByte;
|
||||||
|
{
|
||||||
|
unsigned char buf[4];
|
||||||
|
int n;
|
||||||
|
for (n = 0; n < nbByte; n++) {
|
||||||
|
buf[n] = (unsigned char)(x & 0xff);
|
||||||
|
x >>= 8;
|
||||||
|
}
|
||||||
|
if (fwrite(buf,nbByte,1,file)!=1)
|
||||||
|
return ZIP_ERRNO;
|
||||||
|
else
|
||||||
|
return ZIP_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
local void ziplocal_putValue_inmemory OF((void* dest, uLong x, int nbByte));
|
||||||
|
local void ziplocal_putValue_inmemory (dest, x, nbByte)
|
||||||
|
void* dest;
|
||||||
|
uLong x;
|
||||||
|
int nbByte;
|
||||||
|
{
|
||||||
|
unsigned char* buf=(unsigned char*)dest;
|
||||||
|
int n;
|
||||||
|
for (n = 0; n < nbByte; n++) {
|
||||||
|
buf[n] = (unsigned char)(x & 0xff);
|
||||||
|
x >>= 8;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/****************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
|
local uLong ziplocal_TmzDateToDosDate(ptm,dosDate)
|
||||||
|
tm_zip* ptm;
|
||||||
|
uLong dosDate;
|
||||||
|
{
|
||||||
|
uLong year = (uLong)ptm->tm_year;
|
||||||
|
if (year>1980)
|
||||||
|
year-=1980;
|
||||||
|
else if (year>80)
|
||||||
|
year-=80;
|
||||||
|
return
|
||||||
|
(uLong) (((ptm->tm_mday) + (32 * (ptm->tm_mon+1)) + (512 * year)) << 16) |
|
||||||
|
((ptm->tm_sec/2) + (32* ptm->tm_min) + (2048 * (uLong)ptm->tm_hour));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/****************************************************************************/
|
||||||
|
|
||||||
|
extern zipFile ZEXPORT zipOpen (pathname, append)
|
||||||
|
const char *pathname;
|
||||||
|
int append;
|
||||||
|
{
|
||||||
|
zip_internal ziinit;
|
||||||
|
zip_internal* zi;
|
||||||
|
|
||||||
|
ziinit.filezip = fopen(pathname,(append == 0) ? "wb" : "ab");
|
||||||
|
if (ziinit.filezip == NULL)
|
||||||
|
return NULL;
|
||||||
|
ziinit.begin_pos = ftell(ziinit.filezip);
|
||||||
|
ziinit.in_opened_file_inzip = 0;
|
||||||
|
ziinit.ci.stream_initialised = 0;
|
||||||
|
ziinit.number_entry = 0;
|
||||||
|
init_linkedlist(&(ziinit.central_dir));
|
||||||
|
|
||||||
|
|
||||||
|
zi = (zip_internal*)ALLOC(sizeof(zip_internal));
|
||||||
|
if (zi==NULL)
|
||||||
|
{
|
||||||
|
fclose(ziinit.filezip);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
*zi = ziinit;
|
||||||
|
return (zipFile)zi;
|
||||||
|
}
|
||||||
|
|
||||||
|
extern int ZEXPORT zipOpenNewFileInZip (file, filename, zipfi,
|
||||||
|
extrafield_local, size_extrafield_local,
|
||||||
|
extrafield_global, size_extrafield_global,
|
||||||
|
comment, method, level)
|
||||||
|
zipFile file;
|
||||||
|
const char* filename;
|
||||||
|
const zip_fileinfo* zipfi;
|
||||||
|
const void* extrafield_local;
|
||||||
|
uInt size_extrafield_local;
|
||||||
|
const void* extrafield_global;
|
||||||
|
uInt size_extrafield_global;
|
||||||
|
const char* comment;
|
||||||
|
int method;
|
||||||
|
int level;
|
||||||
|
{
|
||||||
|
zip_internal* zi;
|
||||||
|
uInt size_filename;
|
||||||
|
uInt size_comment;
|
||||||
|
uInt i;
|
||||||
|
int err = ZIP_OK;
|
||||||
|
|
||||||
|
if (file == NULL)
|
||||||
|
return ZIP_PARAMERROR;
|
||||||
|
if ((method!=0) && (method!=Z_DEFLATED))
|
||||||
|
return ZIP_PARAMERROR;
|
||||||
|
|
||||||
|
zi = (zip_internal*)file;
|
||||||
|
|
||||||
|
if (zi->in_opened_file_inzip == 1)
|
||||||
|
{
|
||||||
|
err = zipCloseFileInZip (file);
|
||||||
|
if (err != ZIP_OK)
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if (filename==NULL)
|
||||||
|
filename="-";
|
||||||
|
|
||||||
|
if (comment==NULL)
|
||||||
|
size_comment = 0;
|
||||||
|
else
|
||||||
|
size_comment = strlen(comment);
|
||||||
|
|
||||||
|
size_filename = strlen(filename);
|
||||||
|
|
||||||
|
if (zipfi == NULL)
|
||||||
|
zi->ci.dosDate = 0;
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (zipfi->dosDate != 0)
|
||||||
|
zi->ci.dosDate = zipfi->dosDate;
|
||||||
|
else zi->ci.dosDate = ziplocal_TmzDateToDosDate(&zipfi->tmz_date,zipfi->dosDate);
|
||||||
|
}
|
||||||
|
|
||||||
|
zi->ci.flag = 0;
|
||||||
|
if ((level==8) || (level==9))
|
||||||
|
zi->ci.flag |= 2;
|
||||||
|
if ((level==2))
|
||||||
|
zi->ci.flag |= 4;
|
||||||
|
if ((level==1))
|
||||||
|
zi->ci.flag |= 6;
|
||||||
|
|
||||||
|
zi->ci.crc32 = 0;
|
||||||
|
zi->ci.method = method;
|
||||||
|
zi->ci.stream_initialised = 0;
|
||||||
|
zi->ci.pos_in_buffered_data = 0;
|
||||||
|
zi->ci.pos_local_header = ftell(zi->filezip);
|
||||||
|
zi->ci.size_centralheader = SIZECENTRALHEADER + size_filename +
|
||||||
|
size_extrafield_global + size_comment;
|
||||||
|
zi->ci.central_header = (char*)ALLOC((uInt)zi->ci.size_centralheader);
|
||||||
|
|
||||||
|
ziplocal_putValue_inmemory(zi->ci.central_header,(uLong)CENTRALHEADERMAGIC,4);
|
||||||
|
/* version info */
|
||||||
|
ziplocal_putValue_inmemory(zi->ci.central_header+4,(uLong)VERSIONMADEBY,2);
|
||||||
|
ziplocal_putValue_inmemory(zi->ci.central_header+6,(uLong)20,2);
|
||||||
|
ziplocal_putValue_inmemory(zi->ci.central_header+8,(uLong)zi->ci.flag,2);
|
||||||
|
ziplocal_putValue_inmemory(zi->ci.central_header+10,(uLong)zi->ci.method,2);
|
||||||
|
ziplocal_putValue_inmemory(zi->ci.central_header+12,(uLong)zi->ci.dosDate,4);
|
||||||
|
ziplocal_putValue_inmemory(zi->ci.central_header+16,(uLong)0,4); /*crc*/
|
||||||
|
ziplocal_putValue_inmemory(zi->ci.central_header+20,(uLong)0,4); /*compr size*/
|
||||||
|
ziplocal_putValue_inmemory(zi->ci.central_header+24,(uLong)0,4); /*uncompr size*/
|
||||||
|
ziplocal_putValue_inmemory(zi->ci.central_header+28,(uLong)size_filename,2);
|
||||||
|
ziplocal_putValue_inmemory(zi->ci.central_header+30,(uLong)size_extrafield_global,2);
|
||||||
|
ziplocal_putValue_inmemory(zi->ci.central_header+32,(uLong)size_comment,2);
|
||||||
|
ziplocal_putValue_inmemory(zi->ci.central_header+34,(uLong)0,2); /*disk nm start*/
|
||||||
|
|
||||||
|
if (zipfi==NULL)
|
||||||
|
ziplocal_putValue_inmemory(zi->ci.central_header+36,(uLong)0,2);
|
||||||
|
else
|
||||||
|
ziplocal_putValue_inmemory(zi->ci.central_header+36,(uLong)zipfi->internal_fa,2);
|
||||||
|
|
||||||
|
if (zipfi==NULL)
|
||||||
|
ziplocal_putValue_inmemory(zi->ci.central_header+38,(uLong)0,4);
|
||||||
|
else
|
||||||
|
ziplocal_putValue_inmemory(zi->ci.central_header+38,(uLong)zipfi->external_fa,4);
|
||||||
|
|
||||||
|
ziplocal_putValue_inmemory(zi->ci.central_header+42,(uLong)zi->ci.pos_local_header,4);
|
||||||
|
|
||||||
|
for (i=0;i<size_filename;i++)
|
||||||
|
*(zi->ci.central_header+SIZECENTRALHEADER+i) = *(filename+i);
|
||||||
|
|
||||||
|
for (i=0;i<size_extrafield_global;i++)
|
||||||
|
*(zi->ci.central_header+SIZECENTRALHEADER+size_filename+i) =
|
||||||
|
*(((const char*)extrafield_global)+i);
|
||||||
|
|
||||||
|
for (i=0;i<size_comment;i++)
|
||||||
|
*(zi->ci.central_header+SIZECENTRALHEADER+size_filename+
|
||||||
|
size_extrafield_global+i) = *(filename+i);
|
||||||
|
if (zi->ci.central_header == NULL)
|
||||||
|
return ZIP_INTERNALERROR;
|
||||||
|
|
||||||
|
/* write the local header */
|
||||||
|
err = ziplocal_putValue(zi->filezip,(uLong)LOCALHEADERMAGIC,4);
|
||||||
|
|
||||||
|
if (err==ZIP_OK)
|
||||||
|
err = ziplocal_putValue(zi->filezip,(uLong)20,2);/* version needed to extract */
|
||||||
|
if (err==ZIP_OK)
|
||||||
|
err = ziplocal_putValue(zi->filezip,(uLong)zi->ci.flag,2);
|
||||||
|
|
||||||
|
if (err==ZIP_OK)
|
||||||
|
err = ziplocal_putValue(zi->filezip,(uLong)zi->ci.method,2);
|
||||||
|
|
||||||
|
if (err==ZIP_OK)
|
||||||
|
err = ziplocal_putValue(zi->filezip,(uLong)zi->ci.dosDate,4);
|
||||||
|
|
||||||
|
if (err==ZIP_OK)
|
||||||
|
err = ziplocal_putValue(zi->filezip,(uLong)0,4); /* crc 32, unknown */
|
||||||
|
if (err==ZIP_OK)
|
||||||
|
err = ziplocal_putValue(zi->filezip,(uLong)0,4); /* compressed size, unknown */
|
||||||
|
if (err==ZIP_OK)
|
||||||
|
err = ziplocal_putValue(zi->filezip,(uLong)0,4); /* uncompressed size, unknown */
|
||||||
|
|
||||||
|
if (err==ZIP_OK)
|
||||||
|
err = ziplocal_putValue(zi->filezip,(uLong)size_filename,2);
|
||||||
|
|
||||||
|
if (err==ZIP_OK)
|
||||||
|
err = ziplocal_putValue(zi->filezip,(uLong)size_extrafield_local,2);
|
||||||
|
|
||||||
|
if ((err==ZIP_OK) && (size_filename>0))
|
||||||
|
if (fwrite(filename,(uInt)size_filename,1,zi->filezip)!=1)
|
||||||
|
err = ZIP_ERRNO;
|
||||||
|
|
||||||
|
if ((err==ZIP_OK) && (size_extrafield_local>0))
|
||||||
|
if (fwrite(extrafield_local,(uInt)size_extrafield_local,1,zi->filezip)
|
||||||
|
!=1)
|
||||||
|
err = ZIP_ERRNO;
|
||||||
|
|
||||||
|
zi->ci.stream.avail_in = (uInt)0;
|
||||||
|
zi->ci.stream.avail_out = (uInt)Z_BUFSIZE;
|
||||||
|
zi->ci.stream.next_out = zi->ci.buffered_data;
|
||||||
|
zi->ci.stream.total_in = 0;
|
||||||
|
zi->ci.stream.total_out = 0;
|
||||||
|
|
||||||
|
if ((err==ZIP_OK) && (zi->ci.method == Z_DEFLATED))
|
||||||
|
{
|
||||||
|
zi->ci.stream.zalloc = (alloc_func)0;
|
||||||
|
zi->ci.stream.zfree = (free_func)0;
|
||||||
|
zi->ci.stream.opaque = (voidpf)0;
|
||||||
|
|
||||||
|
err = deflateInit2(&zi->ci.stream, level,
|
||||||
|
Z_DEFLATED, -MAX_WBITS, DEF_MEM_LEVEL, 0);
|
||||||
|
|
||||||
|
if (err==Z_OK)
|
||||||
|
zi->ci.stream_initialised = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if (err==Z_OK)
|
||||||
|
zi->in_opened_file_inzip = 1;
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
|
||||||
|
extern int ZEXPORT zipWriteInFileInZip (file, buf, len)
|
||||||
|
zipFile file;
|
||||||
|
const voidp buf;
|
||||||
|
unsigned len;
|
||||||
|
{
|
||||||
|
zip_internal* zi;
|
||||||
|
int err=ZIP_OK;
|
||||||
|
|
||||||
|
if (file == NULL)
|
||||||
|
return ZIP_PARAMERROR;
|
||||||
|
zi = (zip_internal*)file;
|
||||||
|
|
||||||
|
if (zi->in_opened_file_inzip == 0)
|
||||||
|
return ZIP_PARAMERROR;
|
||||||
|
|
||||||
|
zi->ci.stream.next_in = buf;
|
||||||
|
zi->ci.stream.avail_in = len;
|
||||||
|
zi->ci.crc32 = crc32(zi->ci.crc32,buf,len);
|
||||||
|
|
||||||
|
while ((err==ZIP_OK) && (zi->ci.stream.avail_in>0))
|
||||||
|
{
|
||||||
|
if (zi->ci.stream.avail_out == 0)
|
||||||
|
{
|
||||||
|
if (fwrite(zi->ci.buffered_data,(uInt)zi->ci.pos_in_buffered_data,1,zi->filezip)
|
||||||
|
!=1)
|
||||||
|
err = ZIP_ERRNO;
|
||||||
|
zi->ci.pos_in_buffered_data = 0;
|
||||||
|
zi->ci.stream.avail_out = (uInt)Z_BUFSIZE;
|
||||||
|
zi->ci.stream.next_out = zi->ci.buffered_data;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (zi->ci.method == Z_DEFLATED)
|
||||||
|
{
|
||||||
|
uLong uTotalOutBefore = zi->ci.stream.total_out;
|
||||||
|
err=deflate(&zi->ci.stream, Z_NO_FLUSH);
|
||||||
|
zi->ci.pos_in_buffered_data += (uInt)(zi->ci.stream.total_out - uTotalOutBefore) ;
|
||||||
|
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
uInt copy_this,i;
|
||||||
|
if (zi->ci.stream.avail_in < zi->ci.stream.avail_out)
|
||||||
|
copy_this = zi->ci.stream.avail_in;
|
||||||
|
else
|
||||||
|
copy_this = zi->ci.stream.avail_out;
|
||||||
|
for (i=0;i<copy_this;i++)
|
||||||
|
*(((char*)zi->ci.stream.next_out)+i) =
|
||||||
|
*(((const char*)zi->ci.stream.next_in)+i);
|
||||||
|
{
|
||||||
|
zi->ci.stream.avail_in -= copy_this;
|
||||||
|
zi->ci.stream.avail_out-= copy_this;
|
||||||
|
zi->ci.stream.next_in+= copy_this;
|
||||||
|
zi->ci.stream.next_out+= copy_this;
|
||||||
|
zi->ci.stream.total_in+= copy_this;
|
||||||
|
zi->ci.stream.total_out+= copy_this;
|
||||||
|
zi->ci.pos_in_buffered_data += copy_this;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
extern int ZEXPORT zipCloseFileInZip (file)
|
||||||
|
zipFile file;
|
||||||
|
{
|
||||||
|
zip_internal* zi;
|
||||||
|
int err=ZIP_OK;
|
||||||
|
|
||||||
|
if (file == NULL)
|
||||||
|
return ZIP_PARAMERROR;
|
||||||
|
zi = (zip_internal*)file;
|
||||||
|
|
||||||
|
if (zi->in_opened_file_inzip == 0)
|
||||||
|
return ZIP_PARAMERROR;
|
||||||
|
zi->ci.stream.avail_in = 0;
|
||||||
|
|
||||||
|
if (zi->ci.method == Z_DEFLATED)
|
||||||
|
while (err==ZIP_OK)
|
||||||
|
{
|
||||||
|
uLong uTotalOutBefore;
|
||||||
|
if (zi->ci.stream.avail_out == 0)
|
||||||
|
{
|
||||||
|
if (fwrite(zi->ci.buffered_data,(uInt)zi->ci.pos_in_buffered_data,1,zi->filezip)
|
||||||
|
!=1)
|
||||||
|
err = ZIP_ERRNO;
|
||||||
|
zi->ci.pos_in_buffered_data = 0;
|
||||||
|
zi->ci.stream.avail_out = (uInt)Z_BUFSIZE;
|
||||||
|
zi->ci.stream.next_out = zi->ci.buffered_data;
|
||||||
|
}
|
||||||
|
uTotalOutBefore = zi->ci.stream.total_out;
|
||||||
|
err=deflate(&zi->ci.stream, Z_FINISH);
|
||||||
|
zi->ci.pos_in_buffered_data += (uInt)(zi->ci.stream.total_out - uTotalOutBefore) ;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (err==Z_STREAM_END)
|
||||||
|
err=ZIP_OK; /* this is normal */
|
||||||
|
|
||||||
|
if ((zi->ci.pos_in_buffered_data>0) && (err==ZIP_OK))
|
||||||
|
if (fwrite(zi->ci.buffered_data,(uInt)zi->ci.pos_in_buffered_data,1,zi->filezip)
|
||||||
|
!=1)
|
||||||
|
err = ZIP_ERRNO;
|
||||||
|
|
||||||
|
if ((zi->ci.method == Z_DEFLATED) && (err==ZIP_OK))
|
||||||
|
{
|
||||||
|
err=deflateEnd(&zi->ci.stream);
|
||||||
|
zi->ci.stream_initialised = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
ziplocal_putValue_inmemory(zi->ci.central_header+16,(uLong)zi->ci.crc32,4); /*crc*/
|
||||||
|
ziplocal_putValue_inmemory(zi->ci.central_header+20,
|
||||||
|
(uLong)zi->ci.stream.total_out,4); /*compr size*/
|
||||||
|
ziplocal_putValue_inmemory(zi->ci.central_header+24,
|
||||||
|
(uLong)zi->ci.stream.total_in,4); /*uncompr size*/
|
||||||
|
|
||||||
|
if (err==ZIP_OK)
|
||||||
|
err = add_data_in_datablock(&zi->central_dir,zi->ci.central_header,
|
||||||
|
(uLong)zi->ci.size_centralheader);
|
||||||
|
free(zi->ci.central_header);
|
||||||
|
|
||||||
|
if (err==ZIP_OK)
|
||||||
|
{
|
||||||
|
long cur_pos_inzip = ftell(zi->filezip);
|
||||||
|
if (fseek(zi->filezip,
|
||||||
|
zi->ci.pos_local_header + 14,SEEK_SET)!=0)
|
||||||
|
err = ZIP_ERRNO;
|
||||||
|
|
||||||
|
if (err==ZIP_OK)
|
||||||
|
err = ziplocal_putValue(zi->filezip,(uLong)zi->ci.crc32,4); /* crc 32, unknown */
|
||||||
|
|
||||||
|
if (err==ZIP_OK) /* compressed size, unknown */
|
||||||
|
err = ziplocal_putValue(zi->filezip,(uLong)zi->ci.stream.total_out,4);
|
||||||
|
|
||||||
|
if (err==ZIP_OK) /* uncompressed size, unknown */
|
||||||
|
err = ziplocal_putValue(zi->filezip,(uLong)zi->ci.stream.total_in,4);
|
||||||
|
|
||||||
|
if (fseek(zi->filezip,
|
||||||
|
cur_pos_inzip,SEEK_SET)!=0)
|
||||||
|
err = ZIP_ERRNO;
|
||||||
|
}
|
||||||
|
|
||||||
|
zi->number_entry ++;
|
||||||
|
zi->in_opened_file_inzip = 0;
|
||||||
|
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
|
||||||
|
extern int ZEXPORT zipClose (file, global_comment)
|
||||||
|
zipFile file;
|
||||||
|
const char* global_comment;
|
||||||
|
{
|
||||||
|
zip_internal* zi;
|
||||||
|
int err = 0;
|
||||||
|
uLong size_centraldir = 0;
|
||||||
|
uLong centraldir_pos_inzip ;
|
||||||
|
uInt size_global_comment;
|
||||||
|
if (file == NULL)
|
||||||
|
return ZIP_PARAMERROR;
|
||||||
|
zi = (zip_internal*)file;
|
||||||
|
|
||||||
|
if (zi->in_opened_file_inzip == 1)
|
||||||
|
{
|
||||||
|
err = zipCloseFileInZip (file);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (global_comment==NULL)
|
||||||
|
size_global_comment = 0;
|
||||||
|
else
|
||||||
|
size_global_comment = strlen(global_comment);
|
||||||
|
|
||||||
|
|
||||||
|
centraldir_pos_inzip = ftell(zi->filezip);
|
||||||
|
if (err==ZIP_OK)
|
||||||
|
{
|
||||||
|
linkedlist_datablock_internal* ldi = zi->central_dir.first_block ;
|
||||||
|
while (ldi!=NULL)
|
||||||
|
{
|
||||||
|
if ((err==ZIP_OK) && (ldi->filled_in_this_block>0))
|
||||||
|
if (fwrite(ldi->data,(uInt)ldi->filled_in_this_block,
|
||||||
|
1,zi->filezip) !=1 )
|
||||||
|
err = ZIP_ERRNO;
|
||||||
|
|
||||||
|
size_centraldir += ldi->filled_in_this_block;
|
||||||
|
ldi = ldi->next_datablock;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
free_datablock(zi->central_dir.first_block);
|
||||||
|
|
||||||
|
if (err==ZIP_OK) /* Magic End */
|
||||||
|
err = ziplocal_putValue(zi->filezip,(uLong)ENDHEADERMAGIC,4);
|
||||||
|
|
||||||
|
if (err==ZIP_OK) /* number of this disk */
|
||||||
|
err = ziplocal_putValue(zi->filezip,(uLong)0,2);
|
||||||
|
|
||||||
|
if (err==ZIP_OK) /* number of the disk with the start of the central directory */
|
||||||
|
err = ziplocal_putValue(zi->filezip,(uLong)0,2);
|
||||||
|
|
||||||
|
if (err==ZIP_OK) /* total number of entries in the central dir on this disk */
|
||||||
|
err = ziplocal_putValue(zi->filezip,(uLong)zi->number_entry,2);
|
||||||
|
|
||||||
|
if (err==ZIP_OK) /* total number of entries in the central dir */
|
||||||
|
err = ziplocal_putValue(zi->filezip,(uLong)zi->number_entry,2);
|
||||||
|
|
||||||
|
if (err==ZIP_OK) /* size of the central directory */
|
||||||
|
err = ziplocal_putValue(zi->filezip,(uLong)size_centraldir,4);
|
||||||
|
|
||||||
|
if (err==ZIP_OK) /* offset of start of central directory with respect to the
|
||||||
|
starting disk number */
|
||||||
|
err = ziplocal_putValue(zi->filezip,(uLong)centraldir_pos_inzip ,4);
|
||||||
|
|
||||||
|
if (err==ZIP_OK) /* zipfile comment length */
|
||||||
|
err = ziplocal_putValue(zi->filezip,(uLong)size_global_comment,2);
|
||||||
|
|
||||||
|
if ((err==ZIP_OK) && (size_global_comment>0))
|
||||||
|
if (fwrite(global_comment,(uInt)size_global_comment,1,zi->filezip) !=1 )
|
||||||
|
err = ZIP_ERRNO;
|
||||||
|
fclose(zi->filezip);
|
||||||
|
TRYFREE(zi);
|
||||||
|
|
||||||
|
return err;
|
||||||
|
}
|
||||||
5
contrib/minizip/zip.def
Normal file
5
contrib/minizip/zip.def
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
zipOpen @80
|
||||||
|
zipOpenNewFileInZip @81
|
||||||
|
zipWriteInFileInZip @82
|
||||||
|
zipCloseFileInZip @83
|
||||||
|
zipClose @84
|
||||||
150
contrib/minizip/zip.h
Normal file
150
contrib/minizip/zip.h
Normal file
@@ -0,0 +1,150 @@
|
|||||||
|
/* zip.h -- IO for compress .zip files using zlib
|
||||||
|
Version 0.15 alpha, Mar 19th, 1998,
|
||||||
|
|
||||||
|
Copyright (C) 1998 Gilles Vollant
|
||||||
|
|
||||||
|
This unzip package allow creates .ZIP file, compatible with PKZip 2.04g
|
||||||
|
WinZip, InfoZip tools and compatible.
|
||||||
|
Encryption and multi volume ZipFile (span) are not supported.
|
||||||
|
Old compressions used by old PKZip 1.x are not supported
|
||||||
|
|
||||||
|
For uncompress .zip file, look at unzip.h
|
||||||
|
|
||||||
|
THIS IS AN ALPHA VERSION. AT THIS STAGE OF DEVELOPPEMENT, SOMES API OR STRUCTURE
|
||||||
|
CAN CHANGE IN FUTURE VERSION !!
|
||||||
|
I WAIT FEEDBACK at mail info@winimage.com
|
||||||
|
Visit also http://www.winimage.com/zLibDll/zip.htm for evolution
|
||||||
|
|
||||||
|
Condition of use and distribution are the same than zlib :
|
||||||
|
|
||||||
|
This software is provided 'as-is', without any express or implied
|
||||||
|
warranty. In no event will the authors 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.
|
||||||
|
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* for more info about .ZIP format, see
|
||||||
|
ftp://ftp.cdrom.com/pub/infozip/doc/appnote-970311-iz.zip
|
||||||
|
PkWare has also a specification at :
|
||||||
|
ftp://ftp.pkware.com/probdesc.zip
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _zip_H
|
||||||
|
#define _zip_H
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef _ZLIB_H
|
||||||
|
#include "zlib.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(STRICTZIP) || defined(STRICTZIPUNZIP)
|
||||||
|
/* like the STRICT of WIN32, we define a pointer that cannot be converted
|
||||||
|
from (void*) without cast */
|
||||||
|
typedef struct TagzipFile__ { int unused; } zipFile__;
|
||||||
|
typedef zipFile__ *zipFile;
|
||||||
|
#else
|
||||||
|
typedef voidp zipFile;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define ZIP_OK (0)
|
||||||
|
#define ZIP_ERRNO (Z_ERRNO)
|
||||||
|
#define ZIP_PARAMERROR (-102)
|
||||||
|
#define ZIP_INTERNALERROR (-104)
|
||||||
|
|
||||||
|
/* tm_zip contain date/time info */
|
||||||
|
typedef struct tm_zip_s
|
||||||
|
{
|
||||||
|
uInt tm_sec; /* seconds after the minute - [0,59] */
|
||||||
|
uInt tm_min; /* minutes after the hour - [0,59] */
|
||||||
|
uInt tm_hour; /* hours since midnight - [0,23] */
|
||||||
|
uInt tm_mday; /* day of the month - [1,31] */
|
||||||
|
uInt tm_mon; /* months since January - [0,11] */
|
||||||
|
uInt tm_year; /* years - [1980..2044] */
|
||||||
|
} tm_zip;
|
||||||
|
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
tm_zip tmz_date; /* date in understandable format */
|
||||||
|
uLong dosDate; /* if dos_date == 0, tmu_date is used */
|
||||||
|
/* uLong flag; */ /* general purpose bit flag 2 bytes */
|
||||||
|
|
||||||
|
uLong internal_fa; /* internal file attributes 2 bytes */
|
||||||
|
uLong external_fa; /* external file attributes 4 bytes */
|
||||||
|
} zip_fileinfo;
|
||||||
|
|
||||||
|
extern zipFile ZEXPORT zipOpen OF((const char *pathname, int append));
|
||||||
|
/*
|
||||||
|
Create a zipfile.
|
||||||
|
pathname contain on Windows NT a filename like "c:\\zlib\\zlib111.zip" or on
|
||||||
|
an Unix computer "zlib/zlib111.zip".
|
||||||
|
if the file pathname exist and append=1, the zip will be created at the end
|
||||||
|
of the file. (useful if the file contain a self extractor code)
|
||||||
|
If the zipfile cannot be opened, the return value is NULL.
|
||||||
|
Else, the return value is a zipFile Handle, usable with other function
|
||||||
|
of this zip package.
|
||||||
|
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
|
extern int ZEXPORT zipOpenNewFileInZip OF((zipFile file,
|
||||||
|
const char* filename,
|
||||||
|
const zip_fileinfo* zipfi,
|
||||||
|
const void* extrafield_local,
|
||||||
|
uInt size_extrafield_local,
|
||||||
|
const void* extrafield_global,
|
||||||
|
uInt size_extrafield_global,
|
||||||
|
const char* comment,
|
||||||
|
int method,
|
||||||
|
int level));
|
||||||
|
/*
|
||||||
|
Open a file in the ZIP for writing.
|
||||||
|
filename : the filename in zip (if NULL, '-' without quote will be used
|
||||||
|
*zipfi contain supplemental information
|
||||||
|
if extrafield_local!=NULL and size_extrafield_local>0, extrafield_local
|
||||||
|
contains the extrafield data the the local header
|
||||||
|
if extrafield_global!=NULL and size_extrafield_global>0, extrafield_global
|
||||||
|
contains the extrafield data the the local header
|
||||||
|
if comment != NULL, comment contain the comment string
|
||||||
|
method contain the compression method (0 for store, Z_DEFLATED for deflate)
|
||||||
|
level contain the level of compression (can be Z_DEFAULT_COMPRESSION)
|
||||||
|
*/
|
||||||
|
|
||||||
|
extern int ZEXPORT zipWriteInFileInZip OF((zipFile file,
|
||||||
|
const voidp buf,
|
||||||
|
unsigned len));
|
||||||
|
/*
|
||||||
|
Write data in the zipfile
|
||||||
|
*/
|
||||||
|
|
||||||
|
extern int ZEXPORT zipCloseFileInZip OF((zipFile file));
|
||||||
|
/*
|
||||||
|
Close the current file in the zipfile
|
||||||
|
*/
|
||||||
|
|
||||||
|
extern int ZEXPORT zipClose OF((zipFile file,
|
||||||
|
const char* global_comment));
|
||||||
|
/*
|
||||||
|
Close the zipfile
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* _zip_H */
|
||||||
74
contrib/minizip/zlibvc.def
Normal file
74
contrib/minizip/zlibvc.def
Normal file
@@ -0,0 +1,74 @@
|
|||||||
|
LIBRARY "zlib"
|
||||||
|
|
||||||
|
DESCRIPTION '"""zlib data compression library"""'
|
||||||
|
|
||||||
|
|
||||||
|
VERSION 1.11
|
||||||
|
|
||||||
|
|
||||||
|
HEAPSIZE 1048576,8192
|
||||||
|
|
||||||
|
EXPORTS
|
||||||
|
adler32 @1
|
||||||
|
compress @2
|
||||||
|
crc32 @3
|
||||||
|
deflate @4
|
||||||
|
deflateCopy @5
|
||||||
|
deflateEnd @6
|
||||||
|
deflateInit2_ @7
|
||||||
|
deflateInit_ @8
|
||||||
|
deflateParams @9
|
||||||
|
deflateReset @10
|
||||||
|
deflateSetDictionary @11
|
||||||
|
gzclose @12
|
||||||
|
gzdopen @13
|
||||||
|
gzerror @14
|
||||||
|
gzflush @15
|
||||||
|
gzopen @16
|
||||||
|
gzread @17
|
||||||
|
gzwrite @18
|
||||||
|
inflate @19
|
||||||
|
inflateEnd @20
|
||||||
|
inflateInit2_ @21
|
||||||
|
inflateInit_ @22
|
||||||
|
inflateReset @23
|
||||||
|
inflateSetDictionary @24
|
||||||
|
inflateSync @25
|
||||||
|
uncompress @26
|
||||||
|
zlibVersion @27
|
||||||
|
gzprintf @28
|
||||||
|
gzputc @29
|
||||||
|
gzgetc @30
|
||||||
|
gzseek @31
|
||||||
|
gzrewind @32
|
||||||
|
gztell @33
|
||||||
|
gzeof @34
|
||||||
|
gzsetparams @35
|
||||||
|
zError @36
|
||||||
|
inflateSyncPoint @37
|
||||||
|
get_crc_table @38
|
||||||
|
compress2 @39
|
||||||
|
gzputs @40
|
||||||
|
gzgets @41
|
||||||
|
|
||||||
|
unzOpen @61
|
||||||
|
unzClose @62
|
||||||
|
unzGetGlobalInfo @63
|
||||||
|
unzGetCurrentFileInfo @64
|
||||||
|
unzGoToFirstFile @65
|
||||||
|
unzGoToNextFile @66
|
||||||
|
unzOpenCurrentFile @67
|
||||||
|
unzReadCurrentFile @68
|
||||||
|
unztell @70
|
||||||
|
unzeof @71
|
||||||
|
unzCloseCurrentFile @72
|
||||||
|
unzGetGlobalComment @73
|
||||||
|
unzStringFileNameCompare @74
|
||||||
|
unzLocateFile @75
|
||||||
|
unzGetLocalExtrafield @76
|
||||||
|
|
||||||
|
zipOpen @80
|
||||||
|
zipOpenNewFileInZip @81
|
||||||
|
zipWriteInFileInZip @82
|
||||||
|
zipCloseFileInZip @83
|
||||||
|
zipClose @84
|
||||||
651
contrib/minizip/zlibvc.dsp
Normal file
651
contrib/minizip/zlibvc.dsp
Normal file
@@ -0,0 +1,651 @@
|
|||||||
|
# Microsoft Developer Studio Project File - Name="zlibvc" - Package Owner=<4>
|
||||||
|
# Microsoft Developer Studio Generated Build File, Format Version 5.00
|
||||||
|
# ** DO NOT EDIT **
|
||||||
|
|
||||||
|
# TARGTYPE "Win32 (x86) Dynamic-Link Library" 0x0102
|
||||||
|
# TARGTYPE "Win32 (ALPHA) Dynamic-Link Library" 0x0602
|
||||||
|
|
||||||
|
CFG=zlibvc - Win32 Release
|
||||||
|
!MESSAGE This is not a valid makefile. To build this project using NMAKE,
|
||||||
|
!MESSAGE use the Export Makefile command and run
|
||||||
|
!MESSAGE
|
||||||
|
!MESSAGE NMAKE /f "zlibvc.mak".
|
||||||
|
!MESSAGE
|
||||||
|
!MESSAGE You can specify a configuration when running NMAKE
|
||||||
|
!MESSAGE by defining the macro CFG on the command line. For example:
|
||||||
|
!MESSAGE
|
||||||
|
!MESSAGE NMAKE /f "zlibvc.mak" CFG="zlibvc - Win32 Release"
|
||||||
|
!MESSAGE
|
||||||
|
!MESSAGE Possible choices for configuration are:
|
||||||
|
!MESSAGE
|
||||||
|
!MESSAGE "zlibvc - Win32 Release" (based on "Win32 (x86) Dynamic-Link Library")
|
||||||
|
!MESSAGE "zlibvc - Win32 Debug" (based on "Win32 (x86) Dynamic-Link Library")
|
||||||
|
!MESSAGE "zlibvc - Win32 ReleaseAxp" (based on\
|
||||||
|
"Win32 (ALPHA) Dynamic-Link Library")
|
||||||
|
!MESSAGE "zlibvc - Win32 ReleaseWithoutAsm" (based on\
|
||||||
|
"Win32 (x86) Dynamic-Link Library")
|
||||||
|
!MESSAGE "zlibvc - Win32 ReleaseWithoutCrtdll" (based on\
|
||||||
|
"Win32 (x86) Dynamic-Link Library")
|
||||||
|
!MESSAGE
|
||||||
|
|
||||||
|
# Begin Project
|
||||||
|
# PROP Scc_ProjName ""
|
||||||
|
# PROP Scc_LocalPath ""
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
# PROP BASE Use_MFC 0
|
||||||
|
# PROP BASE Use_Debug_Libraries 0
|
||||||
|
# PROP BASE Output_Dir ".\Release"
|
||||||
|
# PROP BASE Intermediate_Dir ".\Release"
|
||||||
|
# PROP BASE Target_Dir ""
|
||||||
|
# PROP Use_MFC 0
|
||||||
|
# PROP Use_Debug_Libraries 0
|
||||||
|
# PROP Output_Dir ".\Release"
|
||||||
|
# PROP Intermediate_Dir ".\Release"
|
||||||
|
# PROP Ignore_Export_Lib 0
|
||||||
|
# PROP Target_Dir ""
|
||||||
|
CPP=cl.exe
|
||||||
|
# ADD BASE CPP /nologo /MT /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_WINDOWS" /YX /c
|
||||||
|
# ADD CPP /nologo /MT /W3 /GX /O2 /D "NDEBUG" /D "WIN32" /D "_WINDOWS" /D "_WINDLL" /D "_WIN32" /D "BUILD_ZLIBDLL" /D "ZLIB_DLL" /D "DYNAMIC_CRC_TABLE" /D "ASMV" /FAcs /FR /FD /c
|
||||||
|
# SUBTRACT CPP /YX
|
||||||
|
MTL=midl.exe
|
||||||
|
# ADD BASE MTL /nologo /D "NDEBUG" /win32
|
||||||
|
# ADD MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
||||||
|
RSC=rc.exe
|
||||||
|
# ADD BASE RSC /l 0x40c /d "NDEBUG"
|
||||||
|
# ADD RSC /l 0x40c /d "NDEBUG"
|
||||||
|
BSC32=bscmake.exe
|
||||||
|
# ADD BASE BSC32 /nologo
|
||||||
|
# ADD BSC32 /nologo
|
||||||
|
LINK32=link.exe
|
||||||
|
# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /subsystem:windows /dll /machine:I386
|
||||||
|
# ADD LINK32 gvmat32.obj kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib crtdll.lib /nologo /subsystem:windows /dll /map /machine:I386 /nodefaultlib /out:".\Release\zlib.dll"
|
||||||
|
# SUBTRACT LINK32 /pdb:none
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
# PROP BASE Use_MFC 0
|
||||||
|
# PROP BASE Use_Debug_Libraries 1
|
||||||
|
# PROP BASE Output_Dir ".\Debug"
|
||||||
|
# PROP BASE Intermediate_Dir ".\Debug"
|
||||||
|
# PROP BASE Target_Dir ""
|
||||||
|
# PROP Use_MFC 0
|
||||||
|
# PROP Use_Debug_Libraries 1
|
||||||
|
# PROP Output_Dir ".\Debug"
|
||||||
|
# PROP Intermediate_Dir ".\Debug"
|
||||||
|
# PROP Target_Dir ""
|
||||||
|
CPP=cl.exe
|
||||||
|
# ADD BASE CPP /nologo /MTd /W3 /Gm /GX /Zi /Od /D "WIN32" /D "_DEBUG" /D "_WINDOWS" /YX /c
|
||||||
|
# ADD CPP /nologo /MTd /W3 /Gm /GX /Zi /Od /D "_DEBUG" /D "WIN32" /D "_WINDOWS" /D "_WINDLL" /D "_WIN32" /D "BUILD_ZLIBDLL" /D "ZLIB_DLL" /FD /c
|
||||||
|
# SUBTRACT CPP /YX
|
||||||
|
MTL=midl.exe
|
||||||
|
# ADD BASE MTL /nologo /D "_DEBUG" /win32
|
||||||
|
# ADD MTL /nologo /D "_DEBUG" /mktyplib203 /win32
|
||||||
|
RSC=rc.exe
|
||||||
|
# ADD BASE RSC /l 0x40c /d "_DEBUG"
|
||||||
|
# ADD RSC /l 0x40c /d "_DEBUG"
|
||||||
|
BSC32=bscmake.exe
|
||||||
|
# ADD BASE BSC32 /nologo
|
||||||
|
# ADD BSC32 /nologo
|
||||||
|
LINK32=link.exe
|
||||||
|
# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /subsystem:windows /dll /debug /machine:I386
|
||||||
|
# ADD LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib /nologo /subsystem:windows /dll /debug /machine:I386 /out:".\Debug\zlib.dll"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
# PROP BASE Use_MFC 0
|
||||||
|
# PROP BASE Use_Debug_Libraries 0
|
||||||
|
# PROP BASE Output_Dir "zlibvc__"
|
||||||
|
# PROP BASE Intermediate_Dir "zlibvc__"
|
||||||
|
# PROP BASE Ignore_Export_Lib 0
|
||||||
|
# PROP BASE Target_Dir ""
|
||||||
|
# PROP Use_MFC 0
|
||||||
|
# PROP Use_Debug_Libraries 0
|
||||||
|
# PROP Output_Dir "zlibvc__"
|
||||||
|
# PROP Intermediate_Dir "zlibvc__"
|
||||||
|
# PROP Ignore_Export_Lib 0
|
||||||
|
# PROP Target_Dir ""
|
||||||
|
MTL=midl.exe
|
||||||
|
# ADD BASE MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
||||||
|
# ADD MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
||||||
|
CPP=cl.exe
|
||||||
|
# ADD BASE CPP /nologo /MT /Gt0 /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_WINDOWS" /D "_WIN32" /D "BUILD_ZLIBDLL" /D "ZLIB_DLL" /D "DYNAMIC_CRC_TABLE" /FAcs /FR /YX /FD /c
|
||||||
|
# ADD CPP /nologo /MT /Gt0 /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_WINDOWS" /D "_WIN32" /D "BUILD_ZLIBDLL" /D "ZLIB_DLL" /D "DYNAMIC_CRC_TABLE" /FAcs /FR /FD /c
|
||||||
|
# SUBTRACT CPP /YX
|
||||||
|
RSC=rc.exe
|
||||||
|
# ADD BASE RSC /l 0x40c /d "NDEBUG"
|
||||||
|
# ADD RSC /l 0x40c /d "NDEBUG"
|
||||||
|
BSC32=bscmake.exe
|
||||||
|
# ADD BASE BSC32 /nologo
|
||||||
|
# ADD BSC32 /nologo
|
||||||
|
LINK32=link.exe
|
||||||
|
# ADD BASE LINK32 crtdll.lib kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib /nologo /subsystem:windows /dll /map /machine:ALPHA /nodefaultlib /out:".\Release\zlib.dll"
|
||||||
|
# SUBTRACT BASE LINK32 /pdb:none
|
||||||
|
# ADD LINK32 crtdll.lib kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib /nologo /subsystem:windows /dll /map /machine:ALPHA /nodefaultlib /out:"zlibvc__\zlib.dll"
|
||||||
|
# SUBTRACT LINK32 /pdb:none
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
# PROP BASE Use_MFC 0
|
||||||
|
# PROP BASE Use_Debug_Libraries 0
|
||||||
|
# PROP BASE Output_Dir "zlibvc_0"
|
||||||
|
# PROP BASE Intermediate_Dir "zlibvc_0"
|
||||||
|
# PROP BASE Ignore_Export_Lib 0
|
||||||
|
# PROP BASE Target_Dir ""
|
||||||
|
# PROP Use_MFC 0
|
||||||
|
# PROP Use_Debug_Libraries 0
|
||||||
|
# PROP Output_Dir "zlibvc_0"
|
||||||
|
# PROP Intermediate_Dir "zlibvc_0"
|
||||||
|
# PROP Ignore_Export_Lib 0
|
||||||
|
# PROP Target_Dir ""
|
||||||
|
CPP=cl.exe
|
||||||
|
# ADD BASE CPP /nologo /MT /W3 /GX /O2 /D "NDEBUG" /D "WIN32" /D "_WINDOWS" /D "_WINDLL" /D "_WIN32" /D "BUILD_ZLIBDLL" /D "ZLIB_DLL" /D "DYNAMIC_CRC_TABLE" /FAcs /FR /YX /FD /c
|
||||||
|
# ADD CPP /nologo /MT /W3 /GX /O2 /D "NDEBUG" /D "WIN32" /D "_WINDOWS" /D "_WINDLL" /D "_WIN32" /D "BUILD_ZLIBDLL" /D "ZLIB_DLL" /D "DYNAMIC_CRC_TABLE" /FAcs /FR /FD /c
|
||||||
|
# SUBTRACT CPP /YX
|
||||||
|
MTL=midl.exe
|
||||||
|
# ADD BASE MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
||||||
|
# ADD MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
||||||
|
RSC=rc.exe
|
||||||
|
# ADD BASE RSC /l 0x40c /d "NDEBUG"
|
||||||
|
# ADD RSC /l 0x40c /d "NDEBUG"
|
||||||
|
BSC32=bscmake.exe
|
||||||
|
# ADD BASE BSC32 /nologo
|
||||||
|
# ADD BSC32 /nologo
|
||||||
|
LINK32=link.exe
|
||||||
|
# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib crtdll.lib /nologo /subsystem:windows /dll /map /machine:I386 /nodefaultlib /out:".\Release\zlib.dll"
|
||||||
|
# SUBTRACT BASE LINK32 /pdb:none
|
||||||
|
# ADD LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib crtdll.lib /nologo /subsystem:windows /dll /map /machine:I386 /nodefaultlib /out:".\zlibvc_0\zlib.dll"
|
||||||
|
# SUBTRACT LINK32 /pdb:none
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
# PROP BASE Use_MFC 0
|
||||||
|
# PROP BASE Use_Debug_Libraries 0
|
||||||
|
# PROP BASE Output_Dir "zlibvc_1"
|
||||||
|
# PROP BASE Intermediate_Dir "zlibvc_1"
|
||||||
|
# PROP BASE Ignore_Export_Lib 0
|
||||||
|
# PROP BASE Target_Dir ""
|
||||||
|
# PROP Use_MFC 0
|
||||||
|
# PROP Use_Debug_Libraries 0
|
||||||
|
# PROP Output_Dir "zlibvc_1"
|
||||||
|
# PROP Intermediate_Dir "zlibvc_1"
|
||||||
|
# PROP Ignore_Export_Lib 0
|
||||||
|
# PROP Target_Dir ""
|
||||||
|
CPP=cl.exe
|
||||||
|
# ADD BASE CPP /nologo /MT /W3 /GX /O2 /D "NDEBUG" /D "WIN32" /D "_WINDOWS" /D "_WINDLL" /D "_WIN32" /D "BUILD_ZLIBDLL" /D "ZLIB_DLL" /D "DYNAMIC_CRC_TABLE" /D "ASMV" /FAcs /FR /YX /FD /c
|
||||||
|
# ADD CPP /nologo /MT /W3 /GX /O2 /D "NDEBUG" /D "WIN32" /D "_WINDOWS" /D "_WINDLL" /D "_WIN32" /D "BUILD_ZLIBDLL" /D "ZLIB_DLL" /D "DYNAMIC_CRC_TABLE" /D "ASMV" /FAcs /FR /FD /c
|
||||||
|
# SUBTRACT CPP /YX
|
||||||
|
MTL=midl.exe
|
||||||
|
# ADD BASE MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
||||||
|
# ADD MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
||||||
|
RSC=rc.exe
|
||||||
|
# ADD BASE RSC /l 0x40c /d "NDEBUG"
|
||||||
|
# ADD RSC /l 0x40c /d "NDEBUG"
|
||||||
|
BSC32=bscmake.exe
|
||||||
|
# ADD BASE BSC32 /nologo
|
||||||
|
# ADD BSC32 /nologo
|
||||||
|
LINK32=link.exe
|
||||||
|
# ADD BASE LINK32 gvmat32.obj kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib crtdll.lib /nologo /subsystem:windows /dll /map /machine:I386 /nodefaultlib /out:".\Release\zlib.dll"
|
||||||
|
# SUBTRACT BASE LINK32 /pdb:none
|
||||||
|
# ADD LINK32 gvmat32.obj kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib crtdll.lib /nologo /subsystem:windows /dll /map /machine:I386 /nodefaultlib /out:".\zlibvc_1\zlib.dll"
|
||||||
|
# SUBTRACT LINK32 /pdb:none
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# Begin Target
|
||||||
|
|
||||||
|
# Name "zlibvc - Win32 Release"
|
||||||
|
# Name "zlibvc - Win32 Debug"
|
||||||
|
# Name "zlibvc - Win32 ReleaseAxp"
|
||||||
|
# Name "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
# Name "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
# Begin Group "Source Files"
|
||||||
|
|
||||||
|
# PROP Default_Filter "cpp;c;cxx;rc;def;r;odl;hpj;bat;for;f90"
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\adler32.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
DEP_CPP_ADLER=\
|
||||||
|
".\zconf.h"\
|
||||||
|
".\zlib.h"\
|
||||||
|
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\compress.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
DEP_CPP_COMPR=\
|
||||||
|
".\zconf.h"\
|
||||||
|
".\zlib.h"\
|
||||||
|
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\crc32.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
DEP_CPP_CRC32=\
|
||||||
|
".\zconf.h"\
|
||||||
|
".\zlib.h"\
|
||||||
|
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\deflate.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
DEP_CPP_DEFLA=\
|
||||||
|
".\deflate.h"\
|
||||||
|
".\zconf.h"\
|
||||||
|
".\zlib.h"\
|
||||||
|
".\zutil.h"\
|
||||||
|
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\gvmat32c.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\gzio.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
DEP_CPP_GZIO_=\
|
||||||
|
".\zconf.h"\
|
||||||
|
".\zlib.h"\
|
||||||
|
".\zutil.h"\
|
||||||
|
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\infblock.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
DEP_CPP_INFBL=\
|
||||||
|
".\infblock.h"\
|
||||||
|
".\infcodes.h"\
|
||||||
|
".\inftrees.h"\
|
||||||
|
".\infutil.h"\
|
||||||
|
".\zconf.h"\
|
||||||
|
".\zlib.h"\
|
||||||
|
".\zutil.h"\
|
||||||
|
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\infcodes.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
DEP_CPP_INFCO=\
|
||||||
|
".\infblock.h"\
|
||||||
|
".\infcodes.h"\
|
||||||
|
".\inffast.h"\
|
||||||
|
".\inftrees.h"\
|
||||||
|
".\infutil.h"\
|
||||||
|
".\zconf.h"\
|
||||||
|
".\zlib.h"\
|
||||||
|
".\zutil.h"\
|
||||||
|
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\inffast.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
DEP_CPP_INFFA=\
|
||||||
|
".\infblock.h"\
|
||||||
|
".\infcodes.h"\
|
||||||
|
".\inffast.h"\
|
||||||
|
".\inftrees.h"\
|
||||||
|
".\infutil.h"\
|
||||||
|
".\zconf.h"\
|
||||||
|
".\zlib.h"\
|
||||||
|
".\zutil.h"\
|
||||||
|
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\inflate.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
DEP_CPP_INFLA=\
|
||||||
|
".\infblock.h"\
|
||||||
|
".\zconf.h"\
|
||||||
|
".\zlib.h"\
|
||||||
|
".\zutil.h"\
|
||||||
|
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\inftrees.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
DEP_CPP_INFTR=\
|
||||||
|
".\inftrees.h"\
|
||||||
|
".\zconf.h"\
|
||||||
|
".\zlib.h"\
|
||||||
|
".\zutil.h"\
|
||||||
|
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\infutil.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
DEP_CPP_INFUT=\
|
||||||
|
".\infblock.h"\
|
||||||
|
".\infcodes.h"\
|
||||||
|
".\inftrees.h"\
|
||||||
|
".\infutil.h"\
|
||||||
|
".\zconf.h"\
|
||||||
|
".\zlib.h"\
|
||||||
|
".\zutil.h"\
|
||||||
|
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\trees.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
DEP_CPP_TREES=\
|
||||||
|
".\deflate.h"\
|
||||||
|
".\zconf.h"\
|
||||||
|
".\zlib.h"\
|
||||||
|
".\zutil.h"\
|
||||||
|
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\uncompr.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
DEP_CPP_UNCOM=\
|
||||||
|
".\zconf.h"\
|
||||||
|
".\zlib.h"\
|
||||||
|
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\unzip.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\zip.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\zlib.rc
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\zlibvc.def
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\zutil.c
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "zlibvc - Win32 Release"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 Debug"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseAxp"
|
||||||
|
|
||||||
|
DEP_CPP_ZUTIL=\
|
||||||
|
".\zconf.h"\
|
||||||
|
".\zlib.h"\
|
||||||
|
".\zutil.h"\
|
||||||
|
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutAsm"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "zlibvc - Win32 ReleaseWithoutCrtdll"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# End Source File
|
||||||
|
# End Group
|
||||||
|
# Begin Group "Header Files"
|
||||||
|
|
||||||
|
# PROP Default_Filter "h;hpp;hxx;hm;inl;fi;fd"
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\deflate.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\infblock.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\infcodes.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\inffast.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\inftrees.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\infutil.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\zconf.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\zlib.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\zutil.h
|
||||||
|
# End Source File
|
||||||
|
# End Group
|
||||||
|
# Begin Group "Resource Files"
|
||||||
|
|
||||||
|
# PROP Default_Filter "ico;cur;bmp;dlg;rc2;rct;bin;cnt;rtf;gif;jpg;jpeg;jpe"
|
||||||
|
# End Group
|
||||||
|
# End Target
|
||||||
|
# End Project
|
||||||
41
contrib/minizip/zlibvc.dsw
Normal file
41
contrib/minizip/zlibvc.dsw
Normal file
@@ -0,0 +1,41 @@
|
|||||||
|
Microsoft Developer Studio Workspace File, Format Version 5.00
|
||||||
|
# WARNING: DO NOT EDIT OR DELETE THIS WORKSPACE FILE!
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
|
||||||
|
Project: "zlibstat"=.\zlibstat.dsp - Package Owner=<4>
|
||||||
|
|
||||||
|
Package=<5>
|
||||||
|
{{{
|
||||||
|
}}}
|
||||||
|
|
||||||
|
Package=<4>
|
||||||
|
{{{
|
||||||
|
}}}
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
|
||||||
|
Project: "zlibvc"=.\zlibvc.dsp - Package Owner=<4>
|
||||||
|
|
||||||
|
Package=<5>
|
||||||
|
{{{
|
||||||
|
}}}
|
||||||
|
|
||||||
|
Package=<4>
|
||||||
|
{{{
|
||||||
|
}}}
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
|
||||||
|
Global:
|
||||||
|
|
||||||
|
Package=<5>
|
||||||
|
{{{
|
||||||
|
}}}
|
||||||
|
|
||||||
|
Package=<3>
|
||||||
|
{{{
|
||||||
|
}}}
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
|
||||||
14
contrib/untgz/Makefile
Normal file
14
contrib/untgz/Makefile
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
CC=cc
|
||||||
|
CFLAGS=-g
|
||||||
|
|
||||||
|
untgz: untgz.o ../../libz.a
|
||||||
|
$(CC) $(CFLAGS) -o untgz untgz.o -L../.. -lz
|
||||||
|
|
||||||
|
untgz.o: untgz.c ../../zlib.h
|
||||||
|
$(CC) $(CFLAGS) -c -I../.. untgz.c
|
||||||
|
|
||||||
|
../../libz.a:
|
||||||
|
cd ../..; make
|
||||||
|
|
||||||
|
clean:
|
||||||
|
rm -f untgz untgz.o *~
|
||||||
63
contrib/untgz/makefile.w32
Normal file
63
contrib/untgz/makefile.w32
Normal file
@@ -0,0 +1,63 @@
|
|||||||
|
# Makefile for zlib. Modified for mingw32
|
||||||
|
# For conditions of distribution and use, see copyright notice in zlib.h
|
||||||
|
|
||||||
|
# To compile,
|
||||||
|
#
|
||||||
|
# make -fmakefile.w32
|
||||||
|
#
|
||||||
|
|
||||||
|
CC=gcc
|
||||||
|
|
||||||
|
# Generate dependencies (see end of the file)
|
||||||
|
|
||||||
|
CPPFLAGS=-MMD
|
||||||
|
|
||||||
|
#CFLAGS=-MMD -O
|
||||||
|
#CFLAGS=-O -DMAX_WBITS=14 -DMAX_MEM_LEVEL=7
|
||||||
|
#CFLAGS=-MMD -g -DDEBUG
|
||||||
|
CFLAGS=-O3 $(BUTT) -Wall -Wwrite-strings -Wpointer-arith -Wconversion \
|
||||||
|
-Wstrict-prototypes -Wmissing-prototypes
|
||||||
|
|
||||||
|
# If cp.exe is not found, replace with copy /Y .
|
||||||
|
CP=cp -f
|
||||||
|
|
||||||
|
# The default value of RM is "rm -f."
|
||||||
|
# If "rm.exe" is not found, uncomment:
|
||||||
|
# RM=del
|
||||||
|
|
||||||
|
LD=gcc
|
||||||
|
LDLIBS=-L. -lz
|
||||||
|
LDFLAGS=-s
|
||||||
|
|
||||||
|
|
||||||
|
INCL=zlib.h zconf.h
|
||||||
|
LIBS=libz.a
|
||||||
|
|
||||||
|
AR=ar rcs
|
||||||
|
|
||||||
|
OBJS = adler32.o compress.o crc32.o gzio.o uncompr.o deflate.o trees.o \
|
||||||
|
zutil.o inflate.o infblock.o inftrees.o infcodes.o infutil.o \
|
||||||
|
inffast.o
|
||||||
|
|
||||||
|
TEST_OBJS = minigzip.o untgz.o
|
||||||
|
|
||||||
|
all: minigzip.exe untgz.exe
|
||||||
|
|
||||||
|
rebuild: clean all
|
||||||
|
|
||||||
|
libz.a: $(OBJS)
|
||||||
|
$(AR) $@ $(OBJS)
|
||||||
|
|
||||||
|
%.exe : %.o $(LIBS)
|
||||||
|
$(LD) $(LDFLAGS) -o $@ $< $(LDLIBS)
|
||||||
|
|
||||||
|
.PHONY : clean
|
||||||
|
|
||||||
|
clean:
|
||||||
|
$(RM) *.d *.o *.exe libz.a foo.gz
|
||||||
|
|
||||||
|
DEPS := $(wildcard *.d)
|
||||||
|
ifneq ($(DEPS),)
|
||||||
|
include $(DEPS)
|
||||||
|
endif
|
||||||
|
|
||||||
522
contrib/untgz/untgz.c
Normal file
522
contrib/untgz/untgz.c
Normal file
@@ -0,0 +1,522 @@
|
|||||||
|
/*
|
||||||
|
* untgz.c -- Display contents and/or extract file from
|
||||||
|
* a gzip'd TAR file
|
||||||
|
* written by "Pedro A. Aranda Guti\irrez" <paag@tid.es>
|
||||||
|
* adaptation to Unix by Jean-loup Gailly <jloup@gzip.org>
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <time.h>
|
||||||
|
#include <errno.h>
|
||||||
|
#include <fcntl.h>
|
||||||
|
#ifdef unix
|
||||||
|
# include <unistd.h>
|
||||||
|
#else
|
||||||
|
# include <direct.h>
|
||||||
|
# include <io.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "zlib.h"
|
||||||
|
|
||||||
|
#ifdef WIN32
|
||||||
|
# ifndef F_OK
|
||||||
|
# define F_OK (0)
|
||||||
|
# endif
|
||||||
|
# ifdef _MSC_VER
|
||||||
|
# define mkdir(dirname,mode) _mkdir(dirname)
|
||||||
|
# define strdup(str) _strdup(str)
|
||||||
|
# define unlink(fn) _unlink(fn)
|
||||||
|
# define access(path,mode) _access(path,mode)
|
||||||
|
# else
|
||||||
|
# define mkdir(dirname,mode) _mkdir(dirname)
|
||||||
|
# endif
|
||||||
|
#else
|
||||||
|
# include <utime.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/* Values used in typeflag field. */
|
||||||
|
|
||||||
|
#define REGTYPE '0' /* regular file */
|
||||||
|
#define AREGTYPE '\0' /* regular file */
|
||||||
|
#define LNKTYPE '1' /* link */
|
||||||
|
#define SYMTYPE '2' /* reserved */
|
||||||
|
#define CHRTYPE '3' /* character special */
|
||||||
|
#define BLKTYPE '4' /* block special */
|
||||||
|
#define DIRTYPE '5' /* directory */
|
||||||
|
#define FIFOTYPE '6' /* FIFO special */
|
||||||
|
#define CONTTYPE '7' /* reserved */
|
||||||
|
|
||||||
|
#define BLOCKSIZE 512
|
||||||
|
|
||||||
|
struct tar_header
|
||||||
|
{ /* byte offset */
|
||||||
|
char name[100]; /* 0 */
|
||||||
|
char mode[8]; /* 100 */
|
||||||
|
char uid[8]; /* 108 */
|
||||||
|
char gid[8]; /* 116 */
|
||||||
|
char size[12]; /* 124 */
|
||||||
|
char mtime[12]; /* 136 */
|
||||||
|
char chksum[8]; /* 148 */
|
||||||
|
char typeflag; /* 156 */
|
||||||
|
char linkname[100]; /* 157 */
|
||||||
|
char magic[6]; /* 257 */
|
||||||
|
char version[2]; /* 263 */
|
||||||
|
char uname[32]; /* 265 */
|
||||||
|
char gname[32]; /* 297 */
|
||||||
|
char devmajor[8]; /* 329 */
|
||||||
|
char devminor[8]; /* 337 */
|
||||||
|
char prefix[155]; /* 345 */
|
||||||
|
/* 500 */
|
||||||
|
};
|
||||||
|
|
||||||
|
union tar_buffer {
|
||||||
|
char buffer[BLOCKSIZE];
|
||||||
|
struct tar_header header;
|
||||||
|
};
|
||||||
|
|
||||||
|
enum { TGZ_EXTRACT = 0, TGZ_LIST };
|
||||||
|
|
||||||
|
static char *TGZfname OF((const char *));
|
||||||
|
void TGZnotfound OF((const char *));
|
||||||
|
|
||||||
|
int getoct OF((char *, int));
|
||||||
|
char *strtime OF((time_t *));
|
||||||
|
int ExprMatch OF((char *,char *));
|
||||||
|
|
||||||
|
int makedir OF((char *));
|
||||||
|
int matchname OF((int,int,char **,char *));
|
||||||
|
|
||||||
|
void error OF((const char *));
|
||||||
|
int tar OF((gzFile, int, int, int, char **));
|
||||||
|
|
||||||
|
void help OF((int));
|
||||||
|
int main OF((int, char **));
|
||||||
|
|
||||||
|
char *prog;
|
||||||
|
|
||||||
|
/* This will give a benign warning */
|
||||||
|
|
||||||
|
static char *TGZprefix[] = { "\0", ".tgz", ".tar.gz", ".tar", NULL };
|
||||||
|
|
||||||
|
/* Return the real name of the TGZ archive */
|
||||||
|
/* or NULL if it does not exist. */
|
||||||
|
|
||||||
|
static char *TGZfname OF((const char *fname))
|
||||||
|
{
|
||||||
|
static char buffer[1024];
|
||||||
|
int origlen,i;
|
||||||
|
|
||||||
|
strcpy(buffer,fname);
|
||||||
|
origlen = strlen(buffer);
|
||||||
|
|
||||||
|
for (i=0; TGZprefix[i]; i++)
|
||||||
|
{
|
||||||
|
strcpy(buffer+origlen,TGZprefix[i]);
|
||||||
|
if (access(buffer,F_OK) == 0)
|
||||||
|
return buffer;
|
||||||
|
}
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* error message for the filename */
|
||||||
|
|
||||||
|
void TGZnotfound OF((const char *fname))
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
fprintf(stderr,"%s : couldn't find ",prog);
|
||||||
|
for (i=0;TGZprefix[i];i++)
|
||||||
|
fprintf(stderr,(TGZprefix[i+1]) ? "%s%s, " : "or %s%s\n",
|
||||||
|
fname,
|
||||||
|
TGZprefix[i]);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* help functions */
|
||||||
|
|
||||||
|
int getoct(char *p,int width)
|
||||||
|
{
|
||||||
|
int result = 0;
|
||||||
|
char c;
|
||||||
|
|
||||||
|
while (width --)
|
||||||
|
{
|
||||||
|
c = *p++;
|
||||||
|
if (c == ' ')
|
||||||
|
continue;
|
||||||
|
if (c == 0)
|
||||||
|
break;
|
||||||
|
result = result * 8 + (c - '0');
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
char *strtime (time_t *t)
|
||||||
|
{
|
||||||
|
struct tm *local;
|
||||||
|
static char result[32];
|
||||||
|
|
||||||
|
local = localtime(t);
|
||||||
|
sprintf(result,"%2d/%02d/%4d %02d:%02d:%02d",
|
||||||
|
local->tm_mday, local->tm_mon+1, local->tm_year+1900,
|
||||||
|
local->tm_hour, local->tm_min, local->tm_sec);
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* regular expression matching */
|
||||||
|
|
||||||
|
#define ISSPECIAL(c) (((c) == '*') || ((c) == '/'))
|
||||||
|
|
||||||
|
int ExprMatch(char *string,char *expr)
|
||||||
|
{
|
||||||
|
while (1)
|
||||||
|
{
|
||||||
|
if (ISSPECIAL(*expr))
|
||||||
|
{
|
||||||
|
if (*expr == '/')
|
||||||
|
{
|
||||||
|
if (*string != '\\' && *string != '/')
|
||||||
|
return 0;
|
||||||
|
string ++; expr++;
|
||||||
|
}
|
||||||
|
else if (*expr == '*')
|
||||||
|
{
|
||||||
|
if (*expr ++ == 0)
|
||||||
|
return 1;
|
||||||
|
while (*++string != *expr)
|
||||||
|
if (*string == 0)
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (*string != *expr)
|
||||||
|
return 0;
|
||||||
|
if (*expr++ == 0)
|
||||||
|
return 1;
|
||||||
|
string++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* recursive make directory */
|
||||||
|
/* abort if you get an ENOENT errno somewhere in the middle */
|
||||||
|
/* e.g. ignore error "mkdir on existing directory" */
|
||||||
|
/* */
|
||||||
|
/* return 1 if OK */
|
||||||
|
/* 0 on error */
|
||||||
|
|
||||||
|
int makedir (char *newdir)
|
||||||
|
{
|
||||||
|
char *buffer = strdup(newdir);
|
||||||
|
char *p;
|
||||||
|
int len = strlen(buffer);
|
||||||
|
|
||||||
|
if (len <= 0) {
|
||||||
|
free(buffer);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
if (buffer[len-1] == '/') {
|
||||||
|
buffer[len-1] = '\0';
|
||||||
|
}
|
||||||
|
if (mkdir(buffer, 0775) == 0)
|
||||||
|
{
|
||||||
|
free(buffer);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
p = buffer+1;
|
||||||
|
while (1)
|
||||||
|
{
|
||||||
|
char hold;
|
||||||
|
|
||||||
|
while(*p && *p != '\\' && *p != '/')
|
||||||
|
p++;
|
||||||
|
hold = *p;
|
||||||
|
*p = 0;
|
||||||
|
if ((mkdir(buffer, 0775) == -1) && (errno == ENOENT))
|
||||||
|
{
|
||||||
|
fprintf(stderr,"%s: couldn't create directory %s\n",prog,buffer);
|
||||||
|
free(buffer);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
if (hold == 0)
|
||||||
|
break;
|
||||||
|
*p++ = hold;
|
||||||
|
}
|
||||||
|
free(buffer);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
int matchname (int arg,int argc,char **argv,char *fname)
|
||||||
|
{
|
||||||
|
if (arg == argc) /* no arguments given (untgz tgzarchive) */
|
||||||
|
return 1;
|
||||||
|
|
||||||
|
while (arg < argc)
|
||||||
|
if (ExprMatch(fname,argv[arg++]))
|
||||||
|
return 1;
|
||||||
|
|
||||||
|
return 0; /* ignore this for the moment being */
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* Tar file list or extract */
|
||||||
|
|
||||||
|
int tar (gzFile in,int action,int arg,int argc,char **argv)
|
||||||
|
{
|
||||||
|
union tar_buffer buffer;
|
||||||
|
int len;
|
||||||
|
int err;
|
||||||
|
int getheader = 1;
|
||||||
|
int remaining = 0;
|
||||||
|
FILE *outfile = NULL;
|
||||||
|
char fname[BLOCKSIZE];
|
||||||
|
time_t tartime;
|
||||||
|
|
||||||
|
if (action == TGZ_LIST)
|
||||||
|
printf(" day time size file\n"
|
||||||
|
" ---------- -------- --------- -------------------------------------\n");
|
||||||
|
while (1)
|
||||||
|
{
|
||||||
|
len = gzread(in, &buffer, BLOCKSIZE);
|
||||||
|
if (len < 0)
|
||||||
|
error (gzerror(in, &err));
|
||||||
|
/*
|
||||||
|
* Always expect complete blocks to process
|
||||||
|
* the tar information.
|
||||||
|
*/
|
||||||
|
if (len != BLOCKSIZE)
|
||||||
|
error("gzread: incomplete block read");
|
||||||
|
|
||||||
|
/*
|
||||||
|
* If we have to get a tar header
|
||||||
|
*/
|
||||||
|
if (getheader == 1)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
* if we met the end of the tar
|
||||||
|
* or the end-of-tar block,
|
||||||
|
* we are done
|
||||||
|
*/
|
||||||
|
if ((len == 0) || (buffer.header.name[0]== 0)) break;
|
||||||
|
|
||||||
|
tartime = (time_t)getoct(buffer.header.mtime,12);
|
||||||
|
strcpy(fname,buffer.header.name);
|
||||||
|
|
||||||
|
switch (buffer.header.typeflag)
|
||||||
|
{
|
||||||
|
case DIRTYPE:
|
||||||
|
if (action == TGZ_LIST)
|
||||||
|
printf(" %s <dir> %s\n",strtime(&tartime),fname);
|
||||||
|
if (action == TGZ_EXTRACT)
|
||||||
|
makedir(fname);
|
||||||
|
break;
|
||||||
|
case REGTYPE:
|
||||||
|
case AREGTYPE:
|
||||||
|
remaining = getoct(buffer.header.size,12);
|
||||||
|
if (action == TGZ_LIST)
|
||||||
|
printf(" %s %9d %s\n",strtime(&tartime),remaining,fname);
|
||||||
|
if (action == TGZ_EXTRACT)
|
||||||
|
{
|
||||||
|
if ((remaining) && (matchname(arg,argc,argv,fname)))
|
||||||
|
{
|
||||||
|
outfile = fopen(fname,"wb");
|
||||||
|
if (outfile == NULL) {
|
||||||
|
/* try creating directory */
|
||||||
|
char *p = strrchr(fname, '/');
|
||||||
|
if (p != NULL) {
|
||||||
|
*p = '\0';
|
||||||
|
makedir(fname);
|
||||||
|
*p = '/';
|
||||||
|
outfile = fopen(fname,"wb");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
fprintf(stderr,
|
||||||
|
"%s %s\n",
|
||||||
|
(outfile) ? "Extracting" : "Couldn't create",
|
||||||
|
fname);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
outfile = NULL;
|
||||||
|
}
|
||||||
|
/*
|
||||||
|
* could have no contents
|
||||||
|
*/
|
||||||
|
getheader = (remaining) ? 0 : 1;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
if (action == TGZ_LIST)
|
||||||
|
printf(" %s <---> %s\n",strtime(&tartime),fname);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
unsigned int bytes = (remaining > BLOCKSIZE) ? BLOCKSIZE : remaining;
|
||||||
|
|
||||||
|
if ((action == TGZ_EXTRACT) && (outfile != NULL))
|
||||||
|
{
|
||||||
|
if (fwrite(&buffer,sizeof(char),bytes,outfile) != bytes)
|
||||||
|
{
|
||||||
|
fprintf(stderr,"%s : error writing %s skipping...\n",prog,fname);
|
||||||
|
fclose(outfile);
|
||||||
|
unlink(fname);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
remaining -= bytes;
|
||||||
|
if (remaining == 0)
|
||||||
|
{
|
||||||
|
getheader = 1;
|
||||||
|
if ((action == TGZ_EXTRACT) && (outfile != NULL))
|
||||||
|
{
|
||||||
|
#ifdef WIN32
|
||||||
|
HANDLE hFile;
|
||||||
|
FILETIME ftm,ftLocal;
|
||||||
|
SYSTEMTIME st;
|
||||||
|
struct tm localt;
|
||||||
|
|
||||||
|
fclose(outfile);
|
||||||
|
|
||||||
|
localt = *localtime(&tartime);
|
||||||
|
|
||||||
|
hFile = CreateFile(fname, GENERIC_READ | GENERIC_WRITE,
|
||||||
|
0, NULL, OPEN_EXISTING, 0, NULL);
|
||||||
|
|
||||||
|
st.wYear = (WORD)localt.tm_year+1900;
|
||||||
|
st.wMonth = (WORD)localt.tm_mon;
|
||||||
|
st.wDayOfWeek = (WORD)localt.tm_wday;
|
||||||
|
st.wDay = (WORD)localt.tm_mday;
|
||||||
|
st.wHour = (WORD)localt.tm_hour;
|
||||||
|
st.wMinute = (WORD)localt.tm_min;
|
||||||
|
st.wSecond = (WORD)localt.tm_sec;
|
||||||
|
st.wMilliseconds = 0;
|
||||||
|
SystemTimeToFileTime(&st,&ftLocal);
|
||||||
|
LocalFileTimeToFileTime(&ftLocal,&ftm);
|
||||||
|
SetFileTime(hFile,&ftm,NULL,&ftm);
|
||||||
|
CloseHandle(hFile);
|
||||||
|
|
||||||
|
outfile = NULL;
|
||||||
|
#else
|
||||||
|
struct utimbuf settime;
|
||||||
|
|
||||||
|
settime.actime = settime.modtime = tartime;
|
||||||
|
|
||||||
|
fclose(outfile);
|
||||||
|
outfile = NULL;
|
||||||
|
utime(fname,&settime);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gzclose(in) != Z_OK)
|
||||||
|
error("failed gzclose");
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* =========================================================== */
|
||||||
|
|
||||||
|
void help(int exitval)
|
||||||
|
{
|
||||||
|
fprintf(stderr,
|
||||||
|
"untgz v 0.1\n"
|
||||||
|
" an sample application of zlib 1.0.4\n\n"
|
||||||
|
"Usage : untgz TGZfile to extract all files\n"
|
||||||
|
" untgz TGZfile fname ... to extract selected files\n"
|
||||||
|
" untgz -l TGZfile to list archive contents\n"
|
||||||
|
" untgz -h to display this help\n\n");
|
||||||
|
exit(exitval);
|
||||||
|
}
|
||||||
|
|
||||||
|
void error(const char *msg)
|
||||||
|
{
|
||||||
|
fprintf(stderr, "%s: %s\n", prog, msg);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* ====================================================================== */
|
||||||
|
|
||||||
|
int _CRT_glob = 0; /* disable globbing of the arguments */
|
||||||
|
|
||||||
|
int main(int argc,char **argv)
|
||||||
|
{
|
||||||
|
int action = TGZ_EXTRACT;
|
||||||
|
int arg = 1;
|
||||||
|
char *TGZfile;
|
||||||
|
gzFile *f;
|
||||||
|
|
||||||
|
|
||||||
|
prog = strrchr(argv[0],'\\');
|
||||||
|
if (prog == NULL)
|
||||||
|
{
|
||||||
|
prog = strrchr(argv[0],'/');
|
||||||
|
if (prog == NULL)
|
||||||
|
{
|
||||||
|
prog = strrchr(argv[0],':');
|
||||||
|
if (prog == NULL)
|
||||||
|
prog = argv[0];
|
||||||
|
else
|
||||||
|
prog++;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
prog++;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
prog++;
|
||||||
|
|
||||||
|
if (argc == 1)
|
||||||
|
help(0);
|
||||||
|
|
||||||
|
if (strcmp(argv[arg],"-l") == 0)
|
||||||
|
{
|
||||||
|
action = TGZ_LIST;
|
||||||
|
if (argc == ++arg)
|
||||||
|
help(0);
|
||||||
|
}
|
||||||
|
else if (strcmp(argv[arg],"-h") == 0)
|
||||||
|
{
|
||||||
|
help(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((TGZfile = TGZfname(argv[arg])) == NULL)
|
||||||
|
TGZnotfound(argv[arg]);
|
||||||
|
|
||||||
|
++arg;
|
||||||
|
if ((action == TGZ_LIST) && (arg != argc))
|
||||||
|
help(1);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Process the TGZ file
|
||||||
|
*/
|
||||||
|
switch(action)
|
||||||
|
{
|
||||||
|
case TGZ_LIST:
|
||||||
|
case TGZ_EXTRACT:
|
||||||
|
f = gzopen(TGZfile,"rb");
|
||||||
|
if (f == NULL)
|
||||||
|
{
|
||||||
|
fprintf(stderr,"%s: Couldn't gzopen %s\n",
|
||||||
|
prog,
|
||||||
|
TGZfile);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
exit(tar(f, action, arg, argc, argv));
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
error("Unknown option!");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
69
contrib/visual-basic.txt
Normal file
69
contrib/visual-basic.txt
Normal file
@@ -0,0 +1,69 @@
|
|||||||
|
See below some functions declarations for Visual Basic.
|
||||||
|
|
||||||
|
Frequently Asked Question:
|
||||||
|
|
||||||
|
Q: Each time I use the compress function I get the -5 error (not enough
|
||||||
|
room in the output buffer).
|
||||||
|
|
||||||
|
A: Make sure that the length of the compressed buffer is passed by
|
||||||
|
reference ("as any"), not by value ("as long"). Also check that
|
||||||
|
before the call of compress this length is equal to the total size of
|
||||||
|
the compressed buffer and not zero.
|
||||||
|
|
||||||
|
|
||||||
|
From: "Jon Caruana" <jon-net@usa.net>
|
||||||
|
Subject: Re: How to port zlib declares to vb?
|
||||||
|
Date: Mon, 28 Oct 1996 18:33:03 -0600
|
||||||
|
|
||||||
|
Got the answer! (I haven't had time to check this but it's what I got, and
|
||||||
|
looks correct):
|
||||||
|
|
||||||
|
He has the following routines working:
|
||||||
|
compress
|
||||||
|
uncompress
|
||||||
|
gzopen
|
||||||
|
gzwrite
|
||||||
|
gzread
|
||||||
|
gzclose
|
||||||
|
|
||||||
|
Declares follow: (Quoted from Carlos Rios <c_rios@sonda.cl>, in Vb4 form)
|
||||||
|
|
||||||
|
#If Win16 Then 'Use Win16 calls.
|
||||||
|
Declare Function compress Lib "ZLIB.DLL" (ByVal compr As
|
||||||
|
String, comprLen As Any, ByVal buf As String, ByVal buflen
|
||||||
|
As Long) As Integer
|
||||||
|
Declare Function uncompress Lib "ZLIB.DLL" (ByVal uncompr
|
||||||
|
As String, uncomprLen As Any, ByVal compr As String, ByVal
|
||||||
|
lcompr As Long) As Integer
|
||||||
|
Declare Function gzopen Lib "ZLIB.DLL" (ByVal filePath As
|
||||||
|
String, ByVal mode As String) As Long
|
||||||
|
Declare Function gzread Lib "ZLIB.DLL" (ByVal file As
|
||||||
|
Long, ByVal uncompr As String, ByVal uncomprLen As Integer)
|
||||||
|
As Integer
|
||||||
|
Declare Function gzwrite Lib "ZLIB.DLL" (ByVal file As
|
||||||
|
Long, ByVal uncompr As String, ByVal uncomprLen As Integer)
|
||||||
|
As Integer
|
||||||
|
Declare Function gzclose Lib "ZLIB.DLL" (ByVal file As
|
||||||
|
Long) As Integer
|
||||||
|
#Else
|
||||||
|
Declare Function compress Lib "ZLIB32.DLL"
|
||||||
|
(ByVal compr As String, comprLen As Any, ByVal buf As
|
||||||
|
String, ByVal buflen As Long) As Integer
|
||||||
|
Declare Function uncompress Lib "ZLIB32.DLL"
|
||||||
|
(ByVal uncompr As String, uncomprLen As Any, ByVal compr As
|
||||||
|
String, ByVal lcompr As Long) As Long
|
||||||
|
Declare Function gzopen Lib "ZLIB32.DLL"
|
||||||
|
(ByVal file As String, ByVal mode As String) As Long
|
||||||
|
Declare Function gzread Lib "ZLIB32.DLL"
|
||||||
|
(ByVal file As Long, ByVal uncompr As String, ByVal
|
||||||
|
uncomprLen As Long) As Long
|
||||||
|
Declare Function gzwrite Lib "ZLIB32.DLL"
|
||||||
|
(ByVal file As Long, ByVal uncompr As String, ByVal
|
||||||
|
uncomprLen As Long) As Long
|
||||||
|
Declare Function gzclose Lib "ZLIB32.DLL"
|
||||||
|
(ByVal file As Long) As Long
|
||||||
|
#End If
|
||||||
|
|
||||||
|
-Jon Caruana
|
||||||
|
jon-net@usa.net
|
||||||
|
Microsoft Sitebuilder Network Level 1 Member - HTML Writer's Guild Member
|
||||||
14
crc32.c
14
crc32.c
@@ -1,9 +1,9 @@
|
|||||||
/* crc32.c -- compute the CRC-32 of a data stream
|
/* crc32.c -- compute the CRC-32 of a data stream
|
||||||
* Copyright (C) 1995-1996 Mark Adler
|
* Copyright (C) 1995-1998 Mark Adler
|
||||||
* For conditions of distribution and use, see copyright notice in zlib.h
|
* For conditions of distribution and use, see copyright notice in zlib.h
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* $Id: crc32.c,v 1.8 1996/01/30 21:59:10 me Exp $ */
|
/* @(#) $Id$ */
|
||||||
|
|
||||||
#include "zlib.h"
|
#include "zlib.h"
|
||||||
|
|
||||||
@@ -45,7 +45,7 @@ local void make_crc_table()
|
|||||||
int n, k;
|
int n, k;
|
||||||
uLong poly; /* polynomial exclusive-or pattern */
|
uLong poly; /* polynomial exclusive-or pattern */
|
||||||
/* terms of polynomial defining this crc (except x^32): */
|
/* terms of polynomial defining this crc (except x^32): */
|
||||||
static Byte p[] = {0,1,2,4,5,7,8,10,11,12,16,22,23,26};
|
static const Byte p[] = {0,1,2,4,5,7,8,10,11,12,16,22,23,26};
|
||||||
|
|
||||||
/* make exclusive-or pattern from polynomial (0xedb88320L) */
|
/* make exclusive-or pattern from polynomial (0xedb88320L) */
|
||||||
poly = 0L;
|
poly = 0L;
|
||||||
@@ -65,7 +65,7 @@ local void make_crc_table()
|
|||||||
/* ========================================================================
|
/* ========================================================================
|
||||||
* Table of CRC-32's of all single-byte values (made by make_crc_table)
|
* Table of CRC-32's of all single-byte values (made by make_crc_table)
|
||||||
*/
|
*/
|
||||||
local uLongf crc_table[256] = {
|
local const uLongf crc_table[256] = {
|
||||||
0x00000000L, 0x77073096L, 0xee0e612cL, 0x990951baL, 0x076dc419L,
|
0x00000000L, 0x77073096L, 0xee0e612cL, 0x990951baL, 0x076dc419L,
|
||||||
0x706af48fL, 0xe963a535L, 0x9e6495a3L, 0x0edb8832L, 0x79dcb8a4L,
|
0x706af48fL, 0xe963a535L, 0x9e6495a3L, 0x0edb8832L, 0x79dcb8a4L,
|
||||||
0xe0d5e91eL, 0x97d2d988L, 0x09b64c2bL, 0x7eb17cbdL, 0xe7b82d07L,
|
0xe0d5e91eL, 0x97d2d988L, 0x09b64c2bL, 0x7eb17cbdL, 0xe7b82d07L,
|
||||||
@@ -124,12 +124,12 @@ local uLongf crc_table[256] = {
|
|||||||
/* =========================================================================
|
/* =========================================================================
|
||||||
* This function can be used by asm versions of crc32()
|
* This function can be used by asm versions of crc32()
|
||||||
*/
|
*/
|
||||||
uLongf *get_crc_table()
|
const uLongf * ZEXPORT get_crc_table()
|
||||||
{
|
{
|
||||||
#ifdef DYNAMIC_CRC_TABLE
|
#ifdef DYNAMIC_CRC_TABLE
|
||||||
if (crc_table_empty) make_crc_table();
|
if (crc_table_empty) make_crc_table();
|
||||||
#endif
|
#endif
|
||||||
return (uLongf *)crc_table;
|
return (const uLongf *)crc_table;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ========================================================================= */
|
/* ========================================================================= */
|
||||||
@@ -139,7 +139,7 @@ uLongf *get_crc_table()
|
|||||||
#define DO8(buf) DO4(buf); DO4(buf);
|
#define DO8(buf) DO4(buf); DO4(buf);
|
||||||
|
|
||||||
/* ========================================================================= */
|
/* ========================================================================= */
|
||||||
uLong crc32(crc, buf, len)
|
uLong ZEXPORT crc32(crc, buf, len)
|
||||||
uLong crc;
|
uLong crc;
|
||||||
const Bytef *buf;
|
const Bytef *buf;
|
||||||
uInt len;
|
uInt len;
|
||||||
|
|||||||
285
deflate.c
285
deflate.c
@@ -1,5 +1,5 @@
|
|||||||
/* deflate.c -- compress data using the deflation algorithm
|
/* deflate.c -- compress data using the deflation algorithm
|
||||||
* Copyright (C) 1995-1996 Jean-loup Gailly.
|
* Copyright (C) 1995-1998 Jean-loup Gailly.
|
||||||
* For conditions of distribution and use, see copyright notice in zlib.h
|
* For conditions of distribution and use, see copyright notice in zlib.h
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@@ -36,8 +36,8 @@
|
|||||||
*
|
*
|
||||||
* REFERENCES
|
* REFERENCES
|
||||||
*
|
*
|
||||||
* Deutsch, L.P.,"'Deflate' Compressed Data Format Specification".
|
* Deutsch, L.P.,"DEFLATE Compressed Data Format Specification".
|
||||||
* Available in ftp.uu.net:/pub/archiving/zip/doc/deflate-1.1.doc
|
* Available in ftp://ds.internic.net/rfc/rfc1951.txt
|
||||||
*
|
*
|
||||||
* A description of the Rabin and Karp algorithm is given in the book
|
* A description of the Rabin and Karp algorithm is given in the book
|
||||||
* "Algorithms" by R. Sedgewick, Addison-Wesley, p252.
|
* "Algorithms" by R. Sedgewick, Addison-Wesley, p252.
|
||||||
@@ -47,11 +47,12 @@
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* $Id: deflate.c,v 1.15 1996/07/24 13:40:58 me Exp $ */
|
/* @(#) $Id$ */
|
||||||
|
|
||||||
#include "deflate.h"
|
#include "deflate.h"
|
||||||
|
|
||||||
char deflate_copyright[] = " deflate 1.0.4 Copyright 1995-1996 Jean-loup Gailly ";
|
const char deflate_copyright[] =
|
||||||
|
" deflate 1.1.3 Copyright 1995-1998 Jean-loup Gailly ";
|
||||||
/*
|
/*
|
||||||
If you use the zlib library in a product, an acknowledgment is welcome
|
If you use the zlib library in a product, an acknowledgment is welcome
|
||||||
in the documentation of your product. If for some reason you cannot
|
in the documentation of your product. If for some reason you cannot
|
||||||
@@ -77,12 +78,14 @@ local block_state deflate_stored OF((deflate_state *s, int flush));
|
|||||||
local block_state deflate_fast OF((deflate_state *s, int flush));
|
local block_state deflate_fast OF((deflate_state *s, int flush));
|
||||||
local block_state deflate_slow OF((deflate_state *s, int flush));
|
local block_state deflate_slow OF((deflate_state *s, int flush));
|
||||||
local void lm_init OF((deflate_state *s));
|
local void lm_init OF((deflate_state *s));
|
||||||
local uInt longest_match OF((deflate_state *s, IPos cur_match));
|
|
||||||
local void putShortMSB OF((deflate_state *s, uInt b));
|
local void putShortMSB OF((deflate_state *s, uInt b));
|
||||||
local void flush_pending OF((z_streamp strm));
|
local void flush_pending OF((z_streamp strm));
|
||||||
local int read_buf OF((z_streamp strm, charf *buf, unsigned size));
|
local int read_buf OF((z_streamp strm, Bytef *buf, unsigned size));
|
||||||
#ifdef ASMV
|
#ifdef ASMV
|
||||||
void match_init OF((void)); /* asm code initialization */
|
void match_init OF((void)); /* asm code initialization */
|
||||||
|
uInt longest_match OF((deflate_state *s, IPos cur_match));
|
||||||
|
#else
|
||||||
|
local uInt longest_match OF((deflate_state *s, IPos cur_match));
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
@@ -120,7 +123,7 @@ typedef struct config_s {
|
|||||||
compress_func func;
|
compress_func func;
|
||||||
} config;
|
} config;
|
||||||
|
|
||||||
local config configuration_table[10] = {
|
local const config configuration_table[10] = {
|
||||||
/* good lazy nice chain */
|
/* good lazy nice chain */
|
||||||
/* 0 */ {0, 0, 0, 0, deflate_stored}, /* store only */
|
/* 0 */ {0, 0, 0, 0, deflate_stored}, /* store only */
|
||||||
/* 1 */ {4, 4, 8, 4, deflate_fast}, /* maximum speed, no lazy matches */
|
/* 1 */ {4, 4, 8, 4, deflate_fast}, /* maximum speed, no lazy matches */
|
||||||
@@ -157,14 +160,23 @@ struct static_tree_desc_s {int dummy;}; /* for buggy compilers */
|
|||||||
* Insert string str in the dictionary and set match_head to the previous head
|
* Insert string str in the dictionary and set match_head to the previous head
|
||||||
* of the hash chain (the most recent string with same hash key). Return
|
* of the hash chain (the most recent string with same hash key). Return
|
||||||
* the previous length of the hash chain.
|
* the previous length of the hash chain.
|
||||||
|
* If this file is compiled with -DFASTEST, the compression level is forced
|
||||||
|
* to 1, and no hash chains are maintained.
|
||||||
* IN assertion: all calls to to INSERT_STRING are made with consecutive
|
* IN assertion: all calls to to INSERT_STRING are made with consecutive
|
||||||
* input characters and the first MIN_MATCH bytes of str are valid
|
* input characters and the first MIN_MATCH bytes of str are valid
|
||||||
* (except for the last MIN_MATCH-1 bytes of the input file).
|
* (except for the last MIN_MATCH-1 bytes of the input file).
|
||||||
*/
|
*/
|
||||||
|
#ifdef FASTEST
|
||||||
|
#define INSERT_STRING(s, str, match_head) \
|
||||||
|
(UPDATE_HASH(s, s->ins_h, s->window[(str) + (MIN_MATCH-1)]), \
|
||||||
|
match_head = s->head[s->ins_h], \
|
||||||
|
s->head[s->ins_h] = (Pos)(str))
|
||||||
|
#else
|
||||||
#define INSERT_STRING(s, str, match_head) \
|
#define INSERT_STRING(s, str, match_head) \
|
||||||
(UPDATE_HASH(s, s->ins_h, s->window[(str) + (MIN_MATCH-1)]), \
|
(UPDATE_HASH(s, s->ins_h, s->window[(str) + (MIN_MATCH-1)]), \
|
||||||
s->prev[(str) & s->w_mask] = match_head = s->head[s->ins_h], \
|
s->prev[(str) & s->w_mask] = match_head = s->head[s->ins_h], \
|
||||||
s->head[s->ins_h] = (Pos)(str))
|
s->head[s->ins_h] = (Pos)(str))
|
||||||
|
#endif
|
||||||
|
|
||||||
/* ===========================================================================
|
/* ===========================================================================
|
||||||
* Initialize the hash table (avoiding 64K overflow for 16 bit systems).
|
* Initialize the hash table (avoiding 64K overflow for 16 bit systems).
|
||||||
@@ -172,10 +184,10 @@ struct static_tree_desc_s {int dummy;}; /* for buggy compilers */
|
|||||||
*/
|
*/
|
||||||
#define CLEAR_HASH(s) \
|
#define CLEAR_HASH(s) \
|
||||||
s->head[s->hash_size-1] = NIL; \
|
s->head[s->hash_size-1] = NIL; \
|
||||||
zmemzero((charf *)s->head, (unsigned)(s->hash_size-1)*sizeof(*s->head));
|
zmemzero((Bytef *)s->head, (unsigned)(s->hash_size-1)*sizeof(*s->head));
|
||||||
|
|
||||||
/* ========================================================================= */
|
/* ========================================================================= */
|
||||||
int deflateInit_(strm, level, version, stream_size)
|
int ZEXPORT deflateInit_(strm, level, version, stream_size)
|
||||||
z_streamp strm;
|
z_streamp strm;
|
||||||
int level;
|
int level;
|
||||||
const char *version;
|
const char *version;
|
||||||
@@ -187,7 +199,7 @@ int deflateInit_(strm, level, version, stream_size)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* ========================================================================= */
|
/* ========================================================================= */
|
||||||
int deflateInit2_(strm, level, method, windowBits, memLevel, strategy,
|
int ZEXPORT deflateInit2_(strm, level, method, windowBits, memLevel, strategy,
|
||||||
version, stream_size)
|
version, stream_size)
|
||||||
z_streamp strm;
|
z_streamp strm;
|
||||||
int level;
|
int level;
|
||||||
@@ -200,13 +212,14 @@ int deflateInit2_(strm, level, method, windowBits, memLevel, strategy,
|
|||||||
{
|
{
|
||||||
deflate_state *s;
|
deflate_state *s;
|
||||||
int noheader = 0;
|
int noheader = 0;
|
||||||
|
static const char* my_version = ZLIB_VERSION;
|
||||||
|
|
||||||
ushf *overlay;
|
ushf *overlay;
|
||||||
/* We overlay pending_buf and d_buf+l_buf. This works since the average
|
/* We overlay pending_buf and d_buf+l_buf. This works since the average
|
||||||
* output size for (length,distance) codes is <= 24 bits.
|
* output size for (length,distance) codes is <= 24 bits.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if (version == Z_NULL || version[0] != ZLIB_VERSION[0] ||
|
if (version == Z_NULL || version[0] != my_version[0] ||
|
||||||
stream_size != sizeof(z_stream)) {
|
stream_size != sizeof(z_stream)) {
|
||||||
return Z_VERSION_ERROR;
|
return Z_VERSION_ERROR;
|
||||||
}
|
}
|
||||||
@@ -220,6 +233,9 @@ int deflateInit2_(strm, level, method, windowBits, memLevel, strategy,
|
|||||||
if (strm->zfree == Z_NULL) strm->zfree = zcfree;
|
if (strm->zfree == Z_NULL) strm->zfree = zcfree;
|
||||||
|
|
||||||
if (level == Z_DEFAULT_COMPRESSION) level = 6;
|
if (level == Z_DEFAULT_COMPRESSION) level = 6;
|
||||||
|
#ifdef FASTEST
|
||||||
|
level = 1;
|
||||||
|
#endif
|
||||||
|
|
||||||
if (windowBits < 0) { /* undocumented feature: suppress zlib header */
|
if (windowBits < 0) { /* undocumented feature: suppress zlib header */
|
||||||
noheader = 1;
|
noheader = 1;
|
||||||
@@ -253,6 +269,7 @@ int deflateInit2_(strm, level, method, windowBits, memLevel, strategy,
|
|||||||
|
|
||||||
overlay = (ushf *) ZALLOC(strm, s->lit_bufsize, sizeof(ush)+2);
|
overlay = (ushf *) ZALLOC(strm, s->lit_bufsize, sizeof(ush)+2);
|
||||||
s->pending_buf = (uchf *) overlay;
|
s->pending_buf = (uchf *) overlay;
|
||||||
|
s->pending_buf_size = (ulg)s->lit_bufsize * (sizeof(ush)+2L);
|
||||||
|
|
||||||
if (s->window == Z_NULL || s->prev == Z_NULL || s->head == Z_NULL ||
|
if (s->window == Z_NULL || s->prev == Z_NULL || s->head == Z_NULL ||
|
||||||
s->pending_buf == Z_NULL) {
|
s->pending_buf == Z_NULL) {
|
||||||
@@ -271,7 +288,7 @@ int deflateInit2_(strm, level, method, windowBits, memLevel, strategy,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* ========================================================================= */
|
/* ========================================================================= */
|
||||||
int deflateSetDictionary (strm, dictionary, dictLength)
|
int ZEXPORT deflateSetDictionary (strm, dictionary, dictLength)
|
||||||
z_streamp strm;
|
z_streamp strm;
|
||||||
const Bytef *dictionary;
|
const Bytef *dictionary;
|
||||||
uInt dictLength;
|
uInt dictLength;
|
||||||
@@ -290,9 +307,11 @@ int deflateSetDictionary (strm, dictionary, dictLength)
|
|||||||
if (length < MIN_MATCH) return Z_OK;
|
if (length < MIN_MATCH) return Z_OK;
|
||||||
if (length > MAX_DIST(s)) {
|
if (length > MAX_DIST(s)) {
|
||||||
length = MAX_DIST(s);
|
length = MAX_DIST(s);
|
||||||
dictionary += dictLength - length;
|
#ifndef USE_DICT_HEAD
|
||||||
|
dictionary += dictLength - length; /* use the tail of the dictionary */
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
zmemcpy((charf *)s->window, dictionary, length);
|
zmemcpy(s->window, dictionary, length);
|
||||||
s->strstart = length;
|
s->strstart = length;
|
||||||
s->block_start = (long)length;
|
s->block_start = (long)length;
|
||||||
|
|
||||||
@@ -310,7 +329,7 @@ int deflateSetDictionary (strm, dictionary, dictLength)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* ========================================================================= */
|
/* ========================================================================= */
|
||||||
int deflateReset (strm)
|
int ZEXPORT deflateReset (strm)
|
||||||
z_streamp strm;
|
z_streamp strm;
|
||||||
{
|
{
|
||||||
deflate_state *s;
|
deflate_state *s;
|
||||||
@@ -340,7 +359,7 @@ int deflateReset (strm)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* ========================================================================= */
|
/* ========================================================================= */
|
||||||
int deflateParams(strm, level, strategy)
|
int ZEXPORT deflateParams(strm, level, strategy)
|
||||||
z_streamp strm;
|
z_streamp strm;
|
||||||
int level;
|
int level;
|
||||||
int strategy;
|
int strategy;
|
||||||
@@ -414,7 +433,7 @@ local void flush_pending(strm)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* ========================================================================= */
|
/* ========================================================================= */
|
||||||
int deflate (strm, flush)
|
int ZEXPORT deflate (strm, flush)
|
||||||
z_streamp strm;
|
z_streamp strm;
|
||||||
int flush;
|
int flush;
|
||||||
{
|
{
|
||||||
@@ -548,42 +567,87 @@ int deflate (strm, flush)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* ========================================================================= */
|
/* ========================================================================= */
|
||||||
int deflateEnd (strm)
|
int ZEXPORT deflateEnd (strm)
|
||||||
z_streamp strm;
|
z_streamp strm;
|
||||||
{
|
{
|
||||||
int status;
|
int status;
|
||||||
|
|
||||||
if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR;
|
if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR;
|
||||||
|
|
||||||
|
status = strm->state->status;
|
||||||
|
if (status != INIT_STATE && status != BUSY_STATE &&
|
||||||
|
status != FINISH_STATE) {
|
||||||
|
return Z_STREAM_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
/* Deallocate in reverse order of allocations: */
|
/* Deallocate in reverse order of allocations: */
|
||||||
TRY_FREE(strm, strm->state->pending_buf);
|
TRY_FREE(strm, strm->state->pending_buf);
|
||||||
TRY_FREE(strm, strm->state->head);
|
TRY_FREE(strm, strm->state->head);
|
||||||
TRY_FREE(strm, strm->state->prev);
|
TRY_FREE(strm, strm->state->prev);
|
||||||
TRY_FREE(strm, strm->state->window);
|
TRY_FREE(strm, strm->state->window);
|
||||||
|
|
||||||
status = strm->state->status;
|
|
||||||
ZFREE(strm, strm->state);
|
ZFREE(strm, strm->state);
|
||||||
strm->state = Z_NULL;
|
strm->state = Z_NULL;
|
||||||
|
|
||||||
return status == BUSY_STATE ? Z_DATA_ERROR : Z_OK;
|
return status == BUSY_STATE ? Z_DATA_ERROR : Z_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ========================================================================= */
|
/* =========================================================================
|
||||||
int deflateCopy (dest, source)
|
* Copy the source state to the destination state.
|
||||||
|
* To simplify the source, this is not supported for 16-bit MSDOS (which
|
||||||
|
* doesn't have enough memory anyway to duplicate compression states).
|
||||||
|
*/
|
||||||
|
int ZEXPORT deflateCopy (dest, source)
|
||||||
z_streamp dest;
|
z_streamp dest;
|
||||||
z_streamp source;
|
z_streamp source;
|
||||||
{
|
{
|
||||||
|
#ifdef MAXSEG_64K
|
||||||
|
return Z_STREAM_ERROR;
|
||||||
|
#else
|
||||||
|
deflate_state *ds;
|
||||||
|
deflate_state *ss;
|
||||||
|
ushf *overlay;
|
||||||
|
|
||||||
|
|
||||||
if (source == Z_NULL || dest == Z_NULL || source->state == Z_NULL) {
|
if (source == Z_NULL || dest == Z_NULL || source->state == Z_NULL) {
|
||||||
return Z_STREAM_ERROR;
|
return Z_STREAM_ERROR;
|
||||||
}
|
}
|
||||||
*dest = *source;
|
|
||||||
return Z_STREAM_ERROR; /* to be implemented */
|
|
||||||
#if 0
|
|
||||||
dest->state = (struct internal_state FAR *)
|
|
||||||
(*dest->zalloc)(1, sizeof(deflate_state));
|
|
||||||
if (dest->state == Z_NULL) return Z_MEM_ERROR;
|
|
||||||
|
|
||||||
*(dest->state) = *(source->state);
|
ss = source->state;
|
||||||
|
|
||||||
|
*dest = *source;
|
||||||
|
|
||||||
|
ds = (deflate_state *) ZALLOC(dest, 1, sizeof(deflate_state));
|
||||||
|
if (ds == Z_NULL) return Z_MEM_ERROR;
|
||||||
|
dest->state = (struct internal_state FAR *) ds;
|
||||||
|
*ds = *ss;
|
||||||
|
ds->strm = dest;
|
||||||
|
|
||||||
|
ds->window = (Bytef *) ZALLOC(dest, ds->w_size, 2*sizeof(Byte));
|
||||||
|
ds->prev = (Posf *) ZALLOC(dest, ds->w_size, sizeof(Pos));
|
||||||
|
ds->head = (Posf *) ZALLOC(dest, ds->hash_size, sizeof(Pos));
|
||||||
|
overlay = (ushf *) ZALLOC(dest, ds->lit_bufsize, sizeof(ush)+2);
|
||||||
|
ds->pending_buf = (uchf *) overlay;
|
||||||
|
|
||||||
|
if (ds->window == Z_NULL || ds->prev == Z_NULL || ds->head == Z_NULL ||
|
||||||
|
ds->pending_buf == Z_NULL) {
|
||||||
|
deflateEnd (dest);
|
||||||
|
return Z_MEM_ERROR;
|
||||||
|
}
|
||||||
|
/* following zmemcpy do not work for 16-bit MSDOS */
|
||||||
|
zmemcpy(ds->window, ss->window, ds->w_size * 2 * sizeof(Byte));
|
||||||
|
zmemcpy(ds->prev, ss->prev, ds->w_size * sizeof(Pos));
|
||||||
|
zmemcpy(ds->head, ss->head, ds->hash_size * sizeof(Pos));
|
||||||
|
zmemcpy(ds->pending_buf, ss->pending_buf, (uInt)ds->pending_buf_size);
|
||||||
|
|
||||||
|
ds->pending_out = ds->pending_buf + (ss->pending_out - ss->pending_buf);
|
||||||
|
ds->d_buf = overlay + ds->lit_bufsize/sizeof(ush);
|
||||||
|
ds->l_buf = ds->pending_buf + (1+sizeof(ush))*ds->lit_bufsize;
|
||||||
|
|
||||||
|
ds->l_desc.dyn_tree = ds->dyn_ltree;
|
||||||
|
ds->d_desc.dyn_tree = ds->dyn_dtree;
|
||||||
|
ds->bl_desc.dyn_tree = ds->bl_tree;
|
||||||
|
|
||||||
return Z_OK;
|
return Z_OK;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
@@ -597,7 +661,7 @@ int deflateCopy (dest, source)
|
|||||||
*/
|
*/
|
||||||
local int read_buf(strm, buf, size)
|
local int read_buf(strm, buf, size)
|
||||||
z_streamp strm;
|
z_streamp strm;
|
||||||
charf *buf;
|
Bytef *buf;
|
||||||
unsigned size;
|
unsigned size;
|
||||||
{
|
{
|
||||||
unsigned len = strm->avail_in;
|
unsigned len = strm->avail_in;
|
||||||
@@ -658,6 +722,7 @@ local void lm_init (s)
|
|||||||
/* For 80x86 and 680x0, an optimized version will be provided in match.asm or
|
/* For 80x86 and 680x0, an optimized version will be provided in match.asm or
|
||||||
* match.S. The code will be functionally equivalent.
|
* match.S. The code will be functionally equivalent.
|
||||||
*/
|
*/
|
||||||
|
#ifndef FASTEST
|
||||||
local uInt longest_match(s, cur_match)
|
local uInt longest_match(s, cur_match)
|
||||||
deflate_state *s;
|
deflate_state *s;
|
||||||
IPos cur_match; /* current match */
|
IPos cur_match; /* current match */
|
||||||
@@ -792,9 +857,67 @@ local uInt longest_match(s, cur_match)
|
|||||||
} while ((cur_match = prev[cur_match & wmask]) > limit
|
} while ((cur_match = prev[cur_match & wmask]) > limit
|
||||||
&& --chain_length != 0);
|
&& --chain_length != 0);
|
||||||
|
|
||||||
if ((uInt)best_len <= s->lookahead) return best_len;
|
if ((uInt)best_len <= s->lookahead) return (uInt)best_len;
|
||||||
return s->lookahead;
|
return s->lookahead;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#else /* FASTEST */
|
||||||
|
/* ---------------------------------------------------------------------------
|
||||||
|
* Optimized version for level == 1 only
|
||||||
|
*/
|
||||||
|
local uInt longest_match(s, cur_match)
|
||||||
|
deflate_state *s;
|
||||||
|
IPos cur_match; /* current match */
|
||||||
|
{
|
||||||
|
register Bytef *scan = s->window + s->strstart; /* current string */
|
||||||
|
register Bytef *match; /* matched string */
|
||||||
|
register int len; /* length of current match */
|
||||||
|
register Bytef *strend = s->window + s->strstart + MAX_MATCH;
|
||||||
|
|
||||||
|
/* The code is optimized for HASH_BITS >= 8 and MAX_MATCH-2 multiple of 16.
|
||||||
|
* It is easy to get rid of this optimization if necessary.
|
||||||
|
*/
|
||||||
|
Assert(s->hash_bits >= 8 && MAX_MATCH == 258, "Code too clever");
|
||||||
|
|
||||||
|
Assert((ulg)s->strstart <= s->window_size-MIN_LOOKAHEAD, "need lookahead");
|
||||||
|
|
||||||
|
Assert(cur_match < s->strstart, "no future");
|
||||||
|
|
||||||
|
match = s->window + cur_match;
|
||||||
|
|
||||||
|
/* Return failure if the match length is less than 2:
|
||||||
|
*/
|
||||||
|
if (match[0] != scan[0] || match[1] != scan[1]) return MIN_MATCH-1;
|
||||||
|
|
||||||
|
/* The check at best_len-1 can be removed because it will be made
|
||||||
|
* again later. (This heuristic is not always a win.)
|
||||||
|
* It is not necessary to compare scan[2] and match[2] since they
|
||||||
|
* are always equal when the other bytes match, given that
|
||||||
|
* the hash keys are equal and that HASH_BITS >= 8.
|
||||||
|
*/
|
||||||
|
scan += 2, match += 2;
|
||||||
|
Assert(*scan == *match, "match[2]?");
|
||||||
|
|
||||||
|
/* We check for insufficient lookahead only every 8th comparison;
|
||||||
|
* the 256th check will be made at strstart+258.
|
||||||
|
*/
|
||||||
|
do {
|
||||||
|
} while (*++scan == *++match && *++scan == *++match &&
|
||||||
|
*++scan == *++match && *++scan == *++match &&
|
||||||
|
*++scan == *++match && *++scan == *++match &&
|
||||||
|
*++scan == *++match && *++scan == *++match &&
|
||||||
|
scan < strend);
|
||||||
|
|
||||||
|
Assert(scan <= s->window+(unsigned)(s->window_size-1), "wild scan");
|
||||||
|
|
||||||
|
len = MAX_MATCH - (int)(strend - scan);
|
||||||
|
|
||||||
|
if (len < MIN_MATCH) return MIN_MATCH - 1;
|
||||||
|
|
||||||
|
s->match_start = cur_match;
|
||||||
|
return len <= s->lookahead ? len : s->lookahead;
|
||||||
|
}
|
||||||
|
#endif /* FASTEST */
|
||||||
#endif /* ASMV */
|
#endif /* ASMV */
|
||||||
|
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
@@ -807,8 +930,8 @@ local void check_match(s, start, match, length)
|
|||||||
int length;
|
int length;
|
||||||
{
|
{
|
||||||
/* check that the match is indeed a match */
|
/* check that the match is indeed a match */
|
||||||
if (zmemcmp((charf *)s->window + match,
|
if (zmemcmp(s->window + match,
|
||||||
(charf *)s->window + start, length) != EQUAL) {
|
s->window + start, length) != EQUAL) {
|
||||||
fprintf(stderr, " start %u, match %u, length %d\n",
|
fprintf(stderr, " start %u, match %u, length %d\n",
|
||||||
start, match, length);
|
start, match, length);
|
||||||
do {
|
do {
|
||||||
@@ -816,7 +939,7 @@ local void check_match(s, start, match, length)
|
|||||||
} while (--length != 0);
|
} while (--length != 0);
|
||||||
z_error("invalid match");
|
z_error("invalid match");
|
||||||
}
|
}
|
||||||
if (verbose > 1) {
|
if (z_verbose > 1) {
|
||||||
fprintf(stderr,"\\[%d,%d]", start-match, length);
|
fprintf(stderr,"\\[%d,%d]", start-match, length);
|
||||||
do { putc(s->window[start++], stderr); } while (--length != 0);
|
do { putc(s->window[start++], stderr); } while (--length != 0);
|
||||||
}
|
}
|
||||||
@@ -861,33 +984,35 @@ local void fill_window(s)
|
|||||||
*/
|
*/
|
||||||
} else if (s->strstart >= wsize+MAX_DIST(s)) {
|
} else if (s->strstart >= wsize+MAX_DIST(s)) {
|
||||||
|
|
||||||
zmemcpy((charf *)s->window, (charf *)s->window+wsize,
|
zmemcpy(s->window, s->window+wsize, (unsigned)wsize);
|
||||||
(unsigned)wsize);
|
|
||||||
s->match_start -= wsize;
|
s->match_start -= wsize;
|
||||||
s->strstart -= wsize; /* we now have strstart >= MAX_DIST */
|
s->strstart -= wsize; /* we now have strstart >= MAX_DIST */
|
||||||
|
|
||||||
s->block_start -= (long) wsize;
|
s->block_start -= (long) wsize;
|
||||||
|
|
||||||
/* Slide the hash table (could be avoided with 32 bit values
|
/* Slide the hash table (could be avoided with 32 bit values
|
||||||
at the expense of memory usage):
|
at the expense of memory usage). We slide even when level == 0
|
||||||
|
to keep the hash table consistent if we switch back to level > 0
|
||||||
|
later. (Using level 0 permanently is not an optimal usage of
|
||||||
|
zlib, so we don't care about this pathological case.)
|
||||||
*/
|
*/
|
||||||
n = s->hash_size;
|
n = s->hash_size;
|
||||||
p = &s->head[n];
|
p = &s->head[n];
|
||||||
do {
|
do {
|
||||||
m = *--p;
|
m = *--p;
|
||||||
*p = (Pos)(m >= wsize ? m-wsize : NIL);
|
*p = (Pos)(m >= wsize ? m-wsize : NIL);
|
||||||
} while (--n);
|
} while (--n);
|
||||||
|
|
||||||
n = wsize;
|
|
||||||
p = &s->prev[n];
|
|
||||||
do {
|
|
||||||
m = *--p;
|
|
||||||
*p = (Pos)(m >= wsize ? m-wsize : NIL);
|
|
||||||
/* If n is not on any hash chain, prev[n] is garbage but
|
|
||||||
* its value will never be used.
|
|
||||||
*/
|
|
||||||
} while (--n);
|
|
||||||
|
|
||||||
|
n = wsize;
|
||||||
|
#ifndef FASTEST
|
||||||
|
p = &s->prev[n];
|
||||||
|
do {
|
||||||
|
m = *--p;
|
||||||
|
*p = (Pos)(m >= wsize ? m-wsize : NIL);
|
||||||
|
/* If n is not on any hash chain, prev[n] is garbage but
|
||||||
|
* its value will never be used.
|
||||||
|
*/
|
||||||
|
} while (--n);
|
||||||
|
#endif
|
||||||
more += wsize;
|
more += wsize;
|
||||||
}
|
}
|
||||||
if (s->strm->avail_in == 0) return;
|
if (s->strm->avail_in == 0) return;
|
||||||
@@ -905,8 +1030,7 @@ local void fill_window(s)
|
|||||||
*/
|
*/
|
||||||
Assert(more >= 2, "more < 2");
|
Assert(more >= 2, "more < 2");
|
||||||
|
|
||||||
n = read_buf(s->strm, (charf *)s->window + s->strstart + s->lookahead,
|
n = read_buf(s->strm, s->window + s->strstart + s->lookahead, more);
|
||||||
more);
|
|
||||||
s->lookahead += n;
|
s->lookahead += n;
|
||||||
|
|
||||||
/* Initialize the hash value now that we have some input: */
|
/* Initialize the hash value now that we have some input: */
|
||||||
@@ -951,12 +1075,24 @@ local void fill_window(s)
|
|||||||
* This function does not insert new strings in the dictionary since
|
* This function does not insert new strings in the dictionary since
|
||||||
* uncompressible data is probably not useful. This function is used
|
* uncompressible data is probably not useful. This function is used
|
||||||
* only for the level=0 compression option.
|
* only for the level=0 compression option.
|
||||||
* NOTE: this function should be optimized to avoid extra copying.
|
* NOTE: this function should be optimized to avoid extra copying from
|
||||||
|
* window to pending_buf.
|
||||||
*/
|
*/
|
||||||
local block_state deflate_stored(s, flush)
|
local block_state deflate_stored(s, flush)
|
||||||
deflate_state *s;
|
deflate_state *s;
|
||||||
int flush;
|
int flush;
|
||||||
{
|
{
|
||||||
|
/* Stored blocks are limited to 0xffff bytes, pending_buf is limited
|
||||||
|
* to pending_buf_size, and each stored block has a 5 byte header:
|
||||||
|
*/
|
||||||
|
ulg max_block_size = 0xffff;
|
||||||
|
ulg max_start;
|
||||||
|
|
||||||
|
if (max_block_size > s->pending_buf_size - 5) {
|
||||||
|
max_block_size = s->pending_buf_size - 5;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Copy as much as possible from input to output: */
|
||||||
for (;;) {
|
for (;;) {
|
||||||
/* Fill the window as much as possible: */
|
/* Fill the window as much as possible: */
|
||||||
if (s->lookahead <= 1) {
|
if (s->lookahead <= 1) {
|
||||||
@@ -974,14 +1110,17 @@ local block_state deflate_stored(s, flush)
|
|||||||
s->strstart += s->lookahead;
|
s->strstart += s->lookahead;
|
||||||
s->lookahead = 0;
|
s->lookahead = 0;
|
||||||
|
|
||||||
/* Stored blocks are limited to 0xffff bytes: */
|
/* Emit a stored block if pending_buf will be full: */
|
||||||
if (s->strstart == 0 || s->strstart > 0xfffe) {
|
max_start = s->block_start + max_block_size;
|
||||||
|
if (s->strstart == 0 || (ulg)s->strstart >= max_start) {
|
||||||
/* strstart == 0 is possible when wraparound on 16-bit machine */
|
/* strstart == 0 is possible when wraparound on 16-bit machine */
|
||||||
s->lookahead = s->strstart - 0xffff;
|
s->lookahead = (uInt)(s->strstart - max_start);
|
||||||
s->strstart = 0xffff;
|
s->strstart = (uInt)max_start;
|
||||||
|
FLUSH_BLOCK(s, 0);
|
||||||
}
|
}
|
||||||
|
/* Flush if we may have to slide, otherwise block_start may become
|
||||||
/* Emit a stored block if it is large enough: */
|
* negative and the data will be gone:
|
||||||
|
*/
|
||||||
if (s->strstart - (uInt)s->block_start >= MAX_DIST(s)) {
|
if (s->strstart - (uInt)s->block_start >= MAX_DIST(s)) {
|
||||||
FLUSH_BLOCK(s, 0);
|
FLUSH_BLOCK(s, 0);
|
||||||
}
|
}
|
||||||
@@ -1041,14 +1180,15 @@ local block_state deflate_fast(s, flush)
|
|||||||
if (s->match_length >= MIN_MATCH) {
|
if (s->match_length >= MIN_MATCH) {
|
||||||
check_match(s, s->strstart, s->match_start, s->match_length);
|
check_match(s, s->strstart, s->match_start, s->match_length);
|
||||||
|
|
||||||
bflush = _tr_tally(s, s->strstart - s->match_start,
|
_tr_tally_dist(s, s->strstart - s->match_start,
|
||||||
s->match_length - MIN_MATCH);
|
s->match_length - MIN_MATCH, bflush);
|
||||||
|
|
||||||
s->lookahead -= s->match_length;
|
s->lookahead -= s->match_length;
|
||||||
|
|
||||||
/* Insert new strings in the hash table only if the match length
|
/* Insert new strings in the hash table only if the match length
|
||||||
* is not too large. This saves time but degrades compression.
|
* is not too large. This saves time but degrades compression.
|
||||||
*/
|
*/
|
||||||
|
#ifndef FASTEST
|
||||||
if (s->match_length <= s->max_insert_length &&
|
if (s->match_length <= s->max_insert_length &&
|
||||||
s->lookahead >= MIN_MATCH) {
|
s->lookahead >= MIN_MATCH) {
|
||||||
s->match_length--; /* string at strstart already in hash table */
|
s->match_length--; /* string at strstart already in hash table */
|
||||||
@@ -1060,7 +1200,9 @@ local block_state deflate_fast(s, flush)
|
|||||||
*/
|
*/
|
||||||
} while (--s->match_length != 0);
|
} while (--s->match_length != 0);
|
||||||
s->strstart++;
|
s->strstart++;
|
||||||
} else {
|
} else
|
||||||
|
#endif
|
||||||
|
{
|
||||||
s->strstart += s->match_length;
|
s->strstart += s->match_length;
|
||||||
s->match_length = 0;
|
s->match_length = 0;
|
||||||
s->ins_h = s->window[s->strstart];
|
s->ins_h = s->window[s->strstart];
|
||||||
@@ -1075,7 +1217,7 @@ local block_state deflate_fast(s, flush)
|
|||||||
} else {
|
} else {
|
||||||
/* No match, output a literal byte */
|
/* No match, output a literal byte */
|
||||||
Tracevv((stderr,"%c", s->window[s->strstart]));
|
Tracevv((stderr,"%c", s->window[s->strstart]));
|
||||||
bflush = _tr_tally (s, 0, s->window[s->strstart]);
|
_tr_tally_lit (s, s->window[s->strstart], bflush);
|
||||||
s->lookahead--;
|
s->lookahead--;
|
||||||
s->strstart++;
|
s->strstart++;
|
||||||
}
|
}
|
||||||
@@ -1154,8 +1296,8 @@ local block_state deflate_slow(s, flush)
|
|||||||
|
|
||||||
check_match(s, s->strstart-1, s->prev_match, s->prev_length);
|
check_match(s, s->strstart-1, s->prev_match, s->prev_length);
|
||||||
|
|
||||||
bflush = _tr_tally(s, s->strstart -1 - s->prev_match,
|
_tr_tally_dist(s, s->strstart -1 - s->prev_match,
|
||||||
s->prev_length - MIN_MATCH);
|
s->prev_length - MIN_MATCH, bflush);
|
||||||
|
|
||||||
/* Insert in hash table all strings up to the end of the match.
|
/* Insert in hash table all strings up to the end of the match.
|
||||||
* strstart-1 and strstart are already inserted. If there is not
|
* strstart-1 and strstart are already inserted. If there is not
|
||||||
@@ -1181,7 +1323,8 @@ local block_state deflate_slow(s, flush)
|
|||||||
* is longer, truncate the previous match to a single literal.
|
* is longer, truncate the previous match to a single literal.
|
||||||
*/
|
*/
|
||||||
Tracevv((stderr,"%c", s->window[s->strstart-1]));
|
Tracevv((stderr,"%c", s->window[s->strstart-1]));
|
||||||
if (_tr_tally (s, 0, s->window[s->strstart-1])) {
|
_tr_tally_lit(s, s->window[s->strstart-1], bflush);
|
||||||
|
if (bflush) {
|
||||||
FLUSH_BLOCK_ONLY(s, 0);
|
FLUSH_BLOCK_ONLY(s, 0);
|
||||||
}
|
}
|
||||||
s->strstart++;
|
s->strstart++;
|
||||||
@@ -1199,7 +1342,7 @@ local block_state deflate_slow(s, flush)
|
|||||||
Assert (flush != Z_NO_FLUSH, "no flush?");
|
Assert (flush != Z_NO_FLUSH, "no flush?");
|
||||||
if (s->match_available) {
|
if (s->match_available) {
|
||||||
Tracevv((stderr,"%c", s->window[s->strstart-1]));
|
Tracevv((stderr,"%c", s->window[s->strstart-1]));
|
||||||
_tr_tally (s, 0, s->window[s->strstart-1]);
|
_tr_tally_lit(s, s->window[s->strstart-1], bflush);
|
||||||
s->match_available = 0;
|
s->match_available = 0;
|
||||||
}
|
}
|
||||||
FLUSH_BLOCK(s, flush == Z_FINISH);
|
FLUSH_BLOCK(s, flush == Z_FINISH);
|
||||||
|
|||||||
53
deflate.h
53
deflate.h
@@ -1,5 +1,5 @@
|
|||||||
/* deflate.h -- internal compression state
|
/* deflate.h -- internal compression state
|
||||||
* Copyright (C) 1995-1996 Jean-loup Gailly
|
* Copyright (C) 1995-1998 Jean-loup Gailly
|
||||||
* For conditions of distribution and use, see copyright notice in zlib.h
|
* For conditions of distribution and use, see copyright notice in zlib.h
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@@ -8,7 +8,7 @@
|
|||||||
subject to change. Applications should only use zlib.h.
|
subject to change. Applications should only use zlib.h.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* $Id: deflate.h,v 1.10 1996/07/02 12:41:00 me Exp $ */
|
/* @(#) $Id$ */
|
||||||
|
|
||||||
#ifndef _DEFLATE_H
|
#ifndef _DEFLATE_H
|
||||||
#define _DEFLATE_H
|
#define _DEFLATE_H
|
||||||
@@ -83,6 +83,7 @@ typedef struct internal_state {
|
|||||||
z_streamp strm; /* pointer back to this zlib stream */
|
z_streamp strm; /* pointer back to this zlib stream */
|
||||||
int status; /* as the name implies */
|
int status; /* as the name implies */
|
||||||
Bytef *pending_buf; /* output still pending */
|
Bytef *pending_buf; /* output still pending */
|
||||||
|
ulg pending_buf_size; /* size of pending_buf */
|
||||||
Bytef *pending_out; /* next pending byte to output to the stream */
|
Bytef *pending_out; /* next pending byte to output to the stream */
|
||||||
int pending; /* nb of bytes in the pending buffer */
|
int pending; /* nb of bytes in the pending buffer */
|
||||||
int noheader; /* suppress zlib header and adler32 */
|
int noheader; /* suppress zlib header and adler32 */
|
||||||
@@ -229,12 +230,12 @@ typedef struct internal_state {
|
|||||||
|
|
||||||
ulg opt_len; /* bit length of current block with optimal trees */
|
ulg opt_len; /* bit length of current block with optimal trees */
|
||||||
ulg static_len; /* bit length of current block with static trees */
|
ulg static_len; /* bit length of current block with static trees */
|
||||||
ulg compressed_len; /* total bit length of compressed file */
|
|
||||||
uInt matches; /* number of string matches in current block */
|
uInt matches; /* number of string matches in current block */
|
||||||
int last_eob_len; /* bit length of EOB code for last block */
|
int last_eob_len; /* bit length of EOB code for last block */
|
||||||
|
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
ulg bits_sent; /* bit length of the compressed data */
|
ulg compressed_len; /* total bit length of compressed file mod 2^32 */
|
||||||
|
ulg bits_sent; /* bit length of compressed data sent mod 2^32 */
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
ush bi_buf;
|
ush bi_buf;
|
||||||
@@ -267,9 +268,51 @@ typedef struct internal_state {
|
|||||||
/* in trees.c */
|
/* in trees.c */
|
||||||
void _tr_init OF((deflate_state *s));
|
void _tr_init OF((deflate_state *s));
|
||||||
int _tr_tally OF((deflate_state *s, unsigned dist, unsigned lc));
|
int _tr_tally OF((deflate_state *s, unsigned dist, unsigned lc));
|
||||||
ulg _tr_flush_block OF((deflate_state *s, charf *buf, ulg stored_len,
|
void _tr_flush_block OF((deflate_state *s, charf *buf, ulg stored_len,
|
||||||
int eof));
|
int eof));
|
||||||
void _tr_align OF((deflate_state *s));
|
void _tr_align OF((deflate_state *s));
|
||||||
void _tr_stored_block OF((deflate_state *s, charf *buf, ulg stored_len,
|
void _tr_stored_block OF((deflate_state *s, charf *buf, ulg stored_len,
|
||||||
int eof));
|
int eof));
|
||||||
|
|
||||||
|
#define d_code(dist) \
|
||||||
|
((dist) < 256 ? _dist_code[dist] : _dist_code[256+((dist)>>7)])
|
||||||
|
/* Mapping from a distance to a distance code. dist is the distance - 1 and
|
||||||
|
* must not have side effects. _dist_code[256] and _dist_code[257] are never
|
||||||
|
* used.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef DEBUG
|
||||||
|
/* Inline versions of _tr_tally for speed: */
|
||||||
|
|
||||||
|
#if defined(GEN_TREES_H) || !defined(STDC)
|
||||||
|
extern uch _length_code[];
|
||||||
|
extern uch _dist_code[];
|
||||||
|
#else
|
||||||
|
extern const uch _length_code[];
|
||||||
|
extern const uch _dist_code[];
|
||||||
|
#endif
|
||||||
|
|
||||||
|
# define _tr_tally_lit(s, c, flush) \
|
||||||
|
{ uch cc = (c); \
|
||||||
|
s->d_buf[s->last_lit] = 0; \
|
||||||
|
s->l_buf[s->last_lit++] = cc; \
|
||||||
|
s->dyn_ltree[cc].Freq++; \
|
||||||
|
flush = (s->last_lit == s->lit_bufsize-1); \
|
||||||
|
}
|
||||||
|
# define _tr_tally_dist(s, distance, length, flush) \
|
||||||
|
{ uch len = (length); \
|
||||||
|
ush dist = (distance); \
|
||||||
|
s->d_buf[s->last_lit] = dist; \
|
||||||
|
s->l_buf[s->last_lit++] = len; \
|
||||||
|
dist--; \
|
||||||
|
s->dyn_ltree[_length_code[len]+LITERALS+1].Freq++; \
|
||||||
|
s->dyn_dtree[d_code(dist)].Freq++; \
|
||||||
|
flush = (s->last_lit == s->lit_bufsize-1); \
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
# define _tr_tally_lit(s, c, flush) flush = _tr_tally(s, 0, c)
|
||||||
|
# define _tr_tally_dist(s, distance, length, flush) \
|
||||||
|
flush = _tr_tally(s, distance, length)
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
121
example.c
121
example.c
@@ -1,9 +1,9 @@
|
|||||||
/* example.c -- usage example of the zlib compression library
|
/* example.c -- usage example of the zlib compression library
|
||||||
* Copyright (C) 1995-1996 Jean-loup Gailly.
|
* Copyright (C) 1995-1998 Jean-loup Gailly.
|
||||||
* For conditions of distribution and use, see copyright notice in zlib.h
|
* For conditions of distribution and use, see copyright notice in zlib.h
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* $Id: example.c,v 1.16 1996/05/23 17:11:28 me Exp $ */
|
/* @(#) $Id$ */
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include "zlib.h"
|
#include "zlib.h"
|
||||||
@@ -15,6 +15,12 @@
|
|||||||
extern void exit OF((int));
|
extern void exit OF((int));
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if defined(VMS) || defined(RISCOS)
|
||||||
|
# define TESTFILE "foo-gz"
|
||||||
|
#else
|
||||||
|
# define TESTFILE "foo.gz"
|
||||||
|
#endif
|
||||||
|
|
||||||
#define CHECK_ERR(err, msg) { \
|
#define CHECK_ERR(err, msg) { \
|
||||||
if (err != Z_OK) { \
|
if (err != Z_OK) { \
|
||||||
fprintf(stderr, "%s error: %d\n", msg, err); \
|
fprintf(stderr, "%s error: %d\n", msg, err); \
|
||||||
@@ -41,7 +47,7 @@ void test_large_deflate OF((Byte *compr, uLong comprLen,
|
|||||||
Byte *uncompr, uLong uncomprLen));
|
Byte *uncompr, uLong uncomprLen));
|
||||||
void test_large_inflate OF((Byte *compr, uLong comprLen,
|
void test_large_inflate OF((Byte *compr, uLong comprLen,
|
||||||
Byte *uncompr, uLong uncomprLen));
|
Byte *uncompr, uLong uncomprLen));
|
||||||
void test_flush OF((Byte *compr, uLong comprLen));
|
void test_flush OF((Byte *compr, uLong *comprLen));
|
||||||
void test_sync OF((Byte *compr, uLong comprLen,
|
void test_sync OF((Byte *compr, uLong comprLen,
|
||||||
Byte *uncompr, uLong uncomprLen));
|
Byte *uncompr, uLong uncomprLen));
|
||||||
void test_dict_deflate OF((Byte *compr, uLong comprLen));
|
void test_dict_deflate OF((Byte *compr, uLong comprLen));
|
||||||
@@ -69,8 +75,9 @@ void test_compress(compr, comprLen, uncompr, uncomprLen)
|
|||||||
|
|
||||||
if (strcmp((char*)uncompr, hello)) {
|
if (strcmp((char*)uncompr, hello)) {
|
||||||
fprintf(stderr, "bad uncompress\n");
|
fprintf(stderr, "bad uncompress\n");
|
||||||
|
exit(1);
|
||||||
} else {
|
} else {
|
||||||
printf("uncompress(): %s\n", uncompr);
|
printf("uncompress(): %s\n", (char *)uncompr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -78,24 +85,31 @@ void test_compress(compr, comprLen, uncompr, uncomprLen)
|
|||||||
* Test read/write of .gz files
|
* Test read/write of .gz files
|
||||||
*/
|
*/
|
||||||
void test_gzio(out, in, uncompr, uncomprLen)
|
void test_gzio(out, in, uncompr, uncomprLen)
|
||||||
const char *out; /* output file */
|
const char *out; /* compressed output file */
|
||||||
const char *in; /* input file */
|
const char *in; /* compressed input file */
|
||||||
Byte *uncompr;
|
Byte *uncompr;
|
||||||
int uncomprLen;
|
int uncomprLen;
|
||||||
{
|
{
|
||||||
int err;
|
int err;
|
||||||
int len = strlen(hello)+1;
|
int len = strlen(hello)+1;
|
||||||
gzFile file;
|
gzFile file;
|
||||||
|
z_off_t pos;
|
||||||
|
|
||||||
file = gzopen(out, "wb");
|
file = gzopen(out, "wb");
|
||||||
if (file == NULL) {
|
if (file == NULL) {
|
||||||
fprintf(stderr, "gzopen error\n");
|
fprintf(stderr, "gzopen error\n");
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
gzputc(file, 'h');
|
||||||
if (gzwrite(file, (const voidp)hello, (unsigned)len) != len) {
|
if (gzputs(file, "ello") != 4) {
|
||||||
fprintf(stderr, "gzwrite err: %s\n", gzerror(file, &err));
|
fprintf(stderr, "gzputs err: %s\n", gzerror(file, &err));
|
||||||
|
exit(1);
|
||||||
}
|
}
|
||||||
|
if (gzprintf(file, ", %s!", "hello") != 8) {
|
||||||
|
fprintf(stderr, "gzprintf err: %s\n", gzerror(file, &err));
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
gzseek(file, 1L, SEEK_CUR); /* add one zero byte */
|
||||||
gzclose(file);
|
gzclose(file);
|
||||||
|
|
||||||
file = gzopen(in, "rb");
|
file = gzopen(in, "rb");
|
||||||
@@ -107,14 +121,41 @@ void test_gzio(out, in, uncompr, uncomprLen)
|
|||||||
uncomprLen = gzread(file, uncompr, (unsigned)uncomprLen);
|
uncomprLen = gzread(file, uncompr, (unsigned)uncomprLen);
|
||||||
if (uncomprLen != len) {
|
if (uncomprLen != len) {
|
||||||
fprintf(stderr, "gzread err: %s\n", gzerror(file, &err));
|
fprintf(stderr, "gzread err: %s\n", gzerror(file, &err));
|
||||||
|
exit(1);
|
||||||
}
|
}
|
||||||
gzclose(file);
|
|
||||||
|
|
||||||
if (strcmp((char*)uncompr, hello)) {
|
if (strcmp((char*)uncompr, hello)) {
|
||||||
fprintf(stderr, "bad gzread\n");
|
fprintf(stderr, "bad gzread: %s\n", (char*)uncompr);
|
||||||
|
exit(1);
|
||||||
} else {
|
} else {
|
||||||
printf("gzread(): %s\n", uncompr);
|
printf("gzread(): %s\n", (char *)uncompr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pos = gzseek(file, -8L, SEEK_CUR);
|
||||||
|
if (pos != 6 || gztell(file) != pos) {
|
||||||
|
fprintf(stderr, "gzseek error, pos=%ld, gztell=%ld\n",
|
||||||
|
(long)pos, (long)gztell(file));
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gzgetc(file) != ' ') {
|
||||||
|
fprintf(stderr, "gzgetc error\n");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
gzgets(file, (char*)uncompr, uncomprLen);
|
||||||
|
uncomprLen = strlen((char*)uncompr);
|
||||||
|
if (uncomprLen != 6) { /* "hello!" */
|
||||||
|
fprintf(stderr, "gzgets err after gzseek: %s\n", gzerror(file, &err));
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
if (strcmp((char*)uncompr, hello+7)) {
|
||||||
|
fprintf(stderr, "bad gzgets after gzseek\n");
|
||||||
|
exit(1);
|
||||||
|
} else {
|
||||||
|
printf("gzgets() after gzseek: %s\n", (char *)uncompr);
|
||||||
|
}
|
||||||
|
|
||||||
|
gzclose(file);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ===========================================================================
|
/* ===========================================================================
|
||||||
@@ -171,12 +212,13 @@ void test_inflate(compr, comprLen, uncompr, uncomprLen)
|
|||||||
d_stream.zfree = (free_func)0;
|
d_stream.zfree = (free_func)0;
|
||||||
d_stream.opaque = (voidpf)0;
|
d_stream.opaque = (voidpf)0;
|
||||||
|
|
||||||
|
d_stream.next_in = compr;
|
||||||
|
d_stream.avail_in = 0;
|
||||||
|
d_stream.next_out = uncompr;
|
||||||
|
|
||||||
err = inflateInit(&d_stream);
|
err = inflateInit(&d_stream);
|
||||||
CHECK_ERR(err, "inflateInit");
|
CHECK_ERR(err, "inflateInit");
|
||||||
|
|
||||||
d_stream.next_in = compr;
|
|
||||||
d_stream.next_out = uncompr;
|
|
||||||
|
|
||||||
while (d_stream.total_out < uncomprLen && d_stream.total_in < comprLen) {
|
while (d_stream.total_out < uncomprLen && d_stream.total_in < comprLen) {
|
||||||
d_stream.avail_in = d_stream.avail_out = 1; /* force small buffers */
|
d_stream.avail_in = d_stream.avail_out = 1; /* force small buffers */
|
||||||
err = inflate(&d_stream, Z_NO_FLUSH);
|
err = inflate(&d_stream, Z_NO_FLUSH);
|
||||||
@@ -189,8 +231,9 @@ void test_inflate(compr, comprLen, uncompr, uncomprLen)
|
|||||||
|
|
||||||
if (strcmp((char*)uncompr, hello)) {
|
if (strcmp((char*)uncompr, hello)) {
|
||||||
fprintf(stderr, "bad inflate\n");
|
fprintf(stderr, "bad inflate\n");
|
||||||
|
exit(1);
|
||||||
} else {
|
} else {
|
||||||
printf("inflate(): %s\n", uncompr);
|
printf("inflate(): %s\n", (char *)uncompr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -223,6 +266,7 @@ void test_large_deflate(compr, comprLen, uncompr, uncomprLen)
|
|||||||
CHECK_ERR(err, "deflate");
|
CHECK_ERR(err, "deflate");
|
||||||
if (c_stream.avail_in != 0) {
|
if (c_stream.avail_in != 0) {
|
||||||
fprintf(stderr, "deflate not greedy\n");
|
fprintf(stderr, "deflate not greedy\n");
|
||||||
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Feed in already compressed data and switch to no compression: */
|
/* Feed in already compressed data and switch to no compression: */
|
||||||
@@ -242,6 +286,7 @@ void test_large_deflate(compr, comprLen, uncompr, uncomprLen)
|
|||||||
err = deflate(&c_stream, Z_FINISH);
|
err = deflate(&c_stream, Z_FINISH);
|
||||||
if (err != Z_STREAM_END) {
|
if (err != Z_STREAM_END) {
|
||||||
fprintf(stderr, "deflate should report Z_STREAM_END\n");
|
fprintf(stderr, "deflate should report Z_STREAM_END\n");
|
||||||
|
exit(1);
|
||||||
}
|
}
|
||||||
err = deflateEnd(&c_stream);
|
err = deflateEnd(&c_stream);
|
||||||
CHECK_ERR(err, "deflateEnd");
|
CHECK_ERR(err, "deflateEnd");
|
||||||
@@ -263,12 +308,12 @@ void test_large_inflate(compr, comprLen, uncompr, uncomprLen)
|
|||||||
d_stream.zfree = (free_func)0;
|
d_stream.zfree = (free_func)0;
|
||||||
d_stream.opaque = (voidpf)0;
|
d_stream.opaque = (voidpf)0;
|
||||||
|
|
||||||
err = inflateInit(&d_stream);
|
|
||||||
CHECK_ERR(err, "inflateInit");
|
|
||||||
|
|
||||||
d_stream.next_in = compr;
|
d_stream.next_in = compr;
|
||||||
d_stream.avail_in = (uInt)comprLen;
|
d_stream.avail_in = (uInt)comprLen;
|
||||||
|
|
||||||
|
err = inflateInit(&d_stream);
|
||||||
|
CHECK_ERR(err, "inflateInit");
|
||||||
|
|
||||||
for (;;) {
|
for (;;) {
|
||||||
d_stream.next_out = uncompr; /* discard the output */
|
d_stream.next_out = uncompr; /* discard the output */
|
||||||
d_stream.avail_out = (uInt)uncomprLen;
|
d_stream.avail_out = (uInt)uncomprLen;
|
||||||
@@ -282,6 +327,7 @@ void test_large_inflate(compr, comprLen, uncompr, uncomprLen)
|
|||||||
|
|
||||||
if (d_stream.total_out != 2*uncomprLen + comprLen/2) {
|
if (d_stream.total_out != 2*uncomprLen + comprLen/2) {
|
||||||
fprintf(stderr, "bad large inflate: %ld\n", d_stream.total_out);
|
fprintf(stderr, "bad large inflate: %ld\n", d_stream.total_out);
|
||||||
|
exit(1);
|
||||||
} else {
|
} else {
|
||||||
printf("large_inflate(): OK\n");
|
printf("large_inflate(): OK\n");
|
||||||
}
|
}
|
||||||
@@ -292,7 +338,7 @@ void test_large_inflate(compr, comprLen, uncompr, uncomprLen)
|
|||||||
*/
|
*/
|
||||||
void test_flush(compr, comprLen)
|
void test_flush(compr, comprLen)
|
||||||
Byte *compr;
|
Byte *compr;
|
||||||
uLong comprLen;
|
uLong *comprLen;
|
||||||
{
|
{
|
||||||
z_stream c_stream; /* compression stream */
|
z_stream c_stream; /* compression stream */
|
||||||
int err;
|
int err;
|
||||||
@@ -308,7 +354,7 @@ void test_flush(compr, comprLen)
|
|||||||
c_stream.next_in = (Bytef*)hello;
|
c_stream.next_in = (Bytef*)hello;
|
||||||
c_stream.next_out = compr;
|
c_stream.next_out = compr;
|
||||||
c_stream.avail_in = 3;
|
c_stream.avail_in = 3;
|
||||||
c_stream.avail_out = (uInt)comprLen;
|
c_stream.avail_out = (uInt)*comprLen;
|
||||||
err = deflate(&c_stream, Z_FULL_FLUSH);
|
err = deflate(&c_stream, Z_FULL_FLUSH);
|
||||||
CHECK_ERR(err, "deflate");
|
CHECK_ERR(err, "deflate");
|
||||||
|
|
||||||
@@ -321,6 +367,8 @@ void test_flush(compr, comprLen)
|
|||||||
}
|
}
|
||||||
err = deflateEnd(&c_stream);
|
err = deflateEnd(&c_stream);
|
||||||
CHECK_ERR(err, "deflateEnd");
|
CHECK_ERR(err, "deflateEnd");
|
||||||
|
|
||||||
|
*comprLen = c_stream.total_out;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ===========================================================================
|
/* ===========================================================================
|
||||||
@@ -339,12 +387,13 @@ void test_sync(compr, comprLen, uncompr, uncomprLen)
|
|||||||
d_stream.zfree = (free_func)0;
|
d_stream.zfree = (free_func)0;
|
||||||
d_stream.opaque = (voidpf)0;
|
d_stream.opaque = (voidpf)0;
|
||||||
|
|
||||||
|
d_stream.next_in = compr;
|
||||||
|
d_stream.avail_in = 2; /* just read the zlib header */
|
||||||
|
|
||||||
err = inflateInit(&d_stream);
|
err = inflateInit(&d_stream);
|
||||||
CHECK_ERR(err, "inflateInit");
|
CHECK_ERR(err, "inflateInit");
|
||||||
|
|
||||||
d_stream.next_in = compr;
|
|
||||||
d_stream.next_out = uncompr;
|
d_stream.next_out = uncompr;
|
||||||
d_stream.avail_in = 2; /* just read the zlib header */
|
|
||||||
d_stream.avail_out = (uInt)uncomprLen;
|
d_stream.avail_out = (uInt)uncomprLen;
|
||||||
|
|
||||||
inflate(&d_stream, Z_NO_FLUSH);
|
inflate(&d_stream, Z_NO_FLUSH);
|
||||||
@@ -358,11 +407,12 @@ void test_sync(compr, comprLen, uncompr, uncomprLen)
|
|||||||
if (err != Z_DATA_ERROR) {
|
if (err != Z_DATA_ERROR) {
|
||||||
fprintf(stderr, "inflate should report DATA_ERROR\n");
|
fprintf(stderr, "inflate should report DATA_ERROR\n");
|
||||||
/* Because of incorrect adler32 */
|
/* Because of incorrect adler32 */
|
||||||
|
exit(1);
|
||||||
}
|
}
|
||||||
err = inflateEnd(&d_stream);
|
err = inflateEnd(&d_stream);
|
||||||
CHECK_ERR(err, "inflateEnd");
|
CHECK_ERR(err, "inflateEnd");
|
||||||
|
|
||||||
printf("after inflateSync(): hel%s\n", uncompr);
|
printf("after inflateSync(): hel%s\n", (char *)uncompr);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ===========================================================================
|
/* ===========================================================================
|
||||||
@@ -396,6 +446,7 @@ void test_dict_deflate(compr, comprLen)
|
|||||||
err = deflate(&c_stream, Z_FINISH);
|
err = deflate(&c_stream, Z_FINISH);
|
||||||
if (err != Z_STREAM_END) {
|
if (err != Z_STREAM_END) {
|
||||||
fprintf(stderr, "deflate should report Z_STREAM_END\n");
|
fprintf(stderr, "deflate should report Z_STREAM_END\n");
|
||||||
|
exit(1);
|
||||||
}
|
}
|
||||||
err = deflateEnd(&c_stream);
|
err = deflateEnd(&c_stream);
|
||||||
CHECK_ERR(err, "deflateEnd");
|
CHECK_ERR(err, "deflateEnd");
|
||||||
@@ -417,12 +468,12 @@ void test_dict_inflate(compr, comprLen, uncompr, uncomprLen)
|
|||||||
d_stream.zfree = (free_func)0;
|
d_stream.zfree = (free_func)0;
|
||||||
d_stream.opaque = (voidpf)0;
|
d_stream.opaque = (voidpf)0;
|
||||||
|
|
||||||
err = inflateInit(&d_stream);
|
|
||||||
CHECK_ERR(err, "inflateInit");
|
|
||||||
|
|
||||||
d_stream.next_in = compr;
|
d_stream.next_in = compr;
|
||||||
d_stream.avail_in = (uInt)comprLen;
|
d_stream.avail_in = (uInt)comprLen;
|
||||||
|
|
||||||
|
err = inflateInit(&d_stream);
|
||||||
|
CHECK_ERR(err, "inflateInit");
|
||||||
|
|
||||||
d_stream.next_out = uncompr;
|
d_stream.next_out = uncompr;
|
||||||
d_stream.avail_out = (uInt)uncomprLen;
|
d_stream.avail_out = (uInt)uncomprLen;
|
||||||
|
|
||||||
@@ -445,8 +496,9 @@ void test_dict_inflate(compr, comprLen, uncompr, uncomprLen)
|
|||||||
|
|
||||||
if (strcmp((char*)uncompr, hello)) {
|
if (strcmp((char*)uncompr, hello)) {
|
||||||
fprintf(stderr, "bad inflate with dict\n");
|
fprintf(stderr, "bad inflate with dict\n");
|
||||||
|
exit(1);
|
||||||
} else {
|
} else {
|
||||||
printf("inflate with dictionary: %s\n", uncompr);
|
printf("inflate with dictionary: %s\n", (char *)uncompr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -461,8 +513,9 @@ int main(argc, argv)
|
|||||||
Byte *compr, *uncompr;
|
Byte *compr, *uncompr;
|
||||||
uLong comprLen = 10000*sizeof(int); /* don't overflow on MSDOS */
|
uLong comprLen = 10000*sizeof(int); /* don't overflow on MSDOS */
|
||||||
uLong uncomprLen = comprLen;
|
uLong uncomprLen = comprLen;
|
||||||
|
static const char* myVersion = ZLIB_VERSION;
|
||||||
|
|
||||||
if (zlibVersion()[0] != ZLIB_VERSION[0]) {
|
if (zlibVersion()[0] != myVersion[0]) {
|
||||||
fprintf(stderr, "incompatible zlib version\n");
|
fprintf(stderr, "incompatible zlib version\n");
|
||||||
exit(1);
|
exit(1);
|
||||||
|
|
||||||
@@ -479,11 +532,10 @@ int main(argc, argv)
|
|||||||
printf("out of memory\n");
|
printf("out of memory\n");
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
test_compress(compr, comprLen, uncompr, uncomprLen);
|
test_compress(compr, comprLen, uncompr, uncomprLen);
|
||||||
|
|
||||||
test_gzio((argc > 1 ? argv[1] : "foo.gz"),
|
test_gzio((argc > 1 ? argv[1] : TESTFILE),
|
||||||
(argc > 2 ? argv[2] : "foo.gz"),
|
(argc > 2 ? argv[2] : TESTFILE),
|
||||||
uncompr, (int)uncomprLen);
|
uncompr, (int)uncomprLen);
|
||||||
|
|
||||||
test_deflate(compr, comprLen);
|
test_deflate(compr, comprLen);
|
||||||
@@ -492,8 +544,9 @@ int main(argc, argv)
|
|||||||
test_large_deflate(compr, comprLen, uncompr, uncomprLen);
|
test_large_deflate(compr, comprLen, uncompr, uncomprLen);
|
||||||
test_large_inflate(compr, comprLen, uncompr, uncomprLen);
|
test_large_inflate(compr, comprLen, uncompr, uncomprLen);
|
||||||
|
|
||||||
test_flush(compr, comprLen);
|
test_flush(compr, &comprLen);
|
||||||
test_sync(compr, comprLen, uncompr, uncomprLen);
|
test_sync(compr, comprLen, uncompr, uncomprLen);
|
||||||
|
comprLen = uncomprLen;
|
||||||
|
|
||||||
test_dict_deflate(compr, comprLen);
|
test_dict_deflate(compr, comprLen);
|
||||||
test_dict_inflate(compr, comprLen, uncompr, uncomprLen);
|
test_dict_inflate(compr, comprLen, uncompr, uncomprLen);
|
||||||
|
|||||||
424
gzio.c
424
gzio.c
@@ -1,9 +1,11 @@
|
|||||||
/* gzio.c -- IO on .gz files
|
/* gzio.c -- IO on .gz files
|
||||||
* Copyright (C) 1995-1996 Jean-loup Gailly.
|
* Copyright (C) 1995-1998 Jean-loup Gailly.
|
||||||
* For conditions of distribution and use, see copyright notice in zlib.h
|
* For conditions of distribution and use, see copyright notice in zlib.h
|
||||||
|
*
|
||||||
|
* Compile this file with -DNO_DEFLATE to avoid the compression code.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* $Id: gzio.c,v 1.14 1996/07/24 13:41:01 me Exp $ */
|
/* @(#) $Id$ */
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
@@ -11,7 +13,16 @@
|
|||||||
|
|
||||||
struct internal_state {int dummy;}; /* for buggy compilers */
|
struct internal_state {int dummy;}; /* for buggy compilers */
|
||||||
|
|
||||||
#define Z_BUFSIZE 4096
|
#ifndef Z_BUFSIZE
|
||||||
|
# ifdef MAXSEG_64K
|
||||||
|
# define Z_BUFSIZE 4096 /* minimize memory usage for 16-bit DOS */
|
||||||
|
# else
|
||||||
|
# define Z_BUFSIZE 16384
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
#ifndef Z_PRINTF_BUFSIZE
|
||||||
|
# define Z_PRINTF_BUFSIZE 4096
|
||||||
|
#endif
|
||||||
|
|
||||||
#define ALLOC(size) malloc(size)
|
#define ALLOC(size) malloc(size)
|
||||||
#define TRYFREE(p) {if (p) free(p);}
|
#define TRYFREE(p) {if (p) free(p);}
|
||||||
@@ -38,10 +49,12 @@ typedef struct gz_stream {
|
|||||||
char *path; /* path name for debugging only */
|
char *path; /* path name for debugging only */
|
||||||
int transparent; /* 1 if input file is not a .gz file */
|
int transparent; /* 1 if input file is not a .gz file */
|
||||||
char mode; /* 'w' or 'r' */
|
char mode; /* 'w' or 'r' */
|
||||||
|
long startpos; /* start of compressed data in file (header skipped) */
|
||||||
} gz_stream;
|
} gz_stream;
|
||||||
|
|
||||||
|
|
||||||
local gzFile gz_open OF((const char *path, const char *mode, int fd));
|
local gzFile gz_open OF((const char *path, const char *mode, int fd));
|
||||||
|
local int do_flush OF((gzFile file, int flush));
|
||||||
local int get_byte OF((gz_stream *s));
|
local int get_byte OF((gz_stream *s));
|
||||||
local void check_header OF((gz_stream *s));
|
local void check_header OF((gz_stream *s));
|
||||||
local int destroy OF((gz_stream *s));
|
local int destroy OF((gz_stream *s));
|
||||||
@@ -64,6 +77,7 @@ local gzFile gz_open (path, mode, fd)
|
|||||||
{
|
{
|
||||||
int err;
|
int err;
|
||||||
int level = Z_DEFAULT_COMPRESSION; /* compression level */
|
int level = Z_DEFAULT_COMPRESSION; /* compression level */
|
||||||
|
int strategy = Z_DEFAULT_STRATEGY; /* compression strategy */
|
||||||
char *p = (char*)mode;
|
char *p = (char*)mode;
|
||||||
gz_stream *s;
|
gz_stream *s;
|
||||||
char fmode[80]; /* copy of mode, without the compression level */
|
char fmode[80]; /* copy of mode, without the compression level */
|
||||||
@@ -99,6 +113,10 @@ local gzFile gz_open (path, mode, fd)
|
|||||||
if (*p == 'w' || *p == 'a') s->mode = 'w';
|
if (*p == 'w' || *p == 'a') s->mode = 'w';
|
||||||
if (*p >= '0' && *p <= '9') {
|
if (*p >= '0' && *p <= '9') {
|
||||||
level = *p - '0';
|
level = *p - '0';
|
||||||
|
} else if (*p == 'f') {
|
||||||
|
strategy = Z_FILTERED;
|
||||||
|
} else if (*p == 'h') {
|
||||||
|
strategy = Z_HUFFMAN_ONLY;
|
||||||
} else {
|
} else {
|
||||||
*m++ = *p; /* copy the mode */
|
*m++ = *p; /* copy the mode */
|
||||||
}
|
}
|
||||||
@@ -106,19 +124,28 @@ local gzFile gz_open (path, mode, fd)
|
|||||||
if (s->mode == '\0') return destroy(s), (gzFile)Z_NULL;
|
if (s->mode == '\0') return destroy(s), (gzFile)Z_NULL;
|
||||||
|
|
||||||
if (s->mode == 'w') {
|
if (s->mode == 'w') {
|
||||||
|
#ifdef NO_DEFLATE
|
||||||
|
err = Z_STREAM_ERROR;
|
||||||
|
#else
|
||||||
err = deflateInit2(&(s->stream), level,
|
err = deflateInit2(&(s->stream), level,
|
||||||
Z_DEFLATED, -MAX_WBITS, DEF_MEM_LEVEL, 0);
|
Z_DEFLATED, -MAX_WBITS, DEF_MEM_LEVEL, strategy);
|
||||||
/* windowBits is passed < 0 to suppress zlib header */
|
/* windowBits is passed < 0 to suppress zlib header */
|
||||||
|
|
||||||
s->stream.next_out = s->outbuf = (Byte*)ALLOC(Z_BUFSIZE);
|
s->stream.next_out = s->outbuf = (Byte*)ALLOC(Z_BUFSIZE);
|
||||||
|
#endif
|
||||||
if (err != Z_OK || s->outbuf == Z_NULL) {
|
if (err != Z_OK || s->outbuf == Z_NULL) {
|
||||||
return destroy(s), (gzFile)Z_NULL;
|
return destroy(s), (gzFile)Z_NULL;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
err = inflateInit2(&(s->stream), -MAX_WBITS);
|
|
||||||
s->stream.next_in = s->inbuf = (Byte*)ALLOC(Z_BUFSIZE);
|
s->stream.next_in = s->inbuf = (Byte*)ALLOC(Z_BUFSIZE);
|
||||||
|
|
||||||
|
err = inflateInit2(&(s->stream), -MAX_WBITS);
|
||||||
|
/* windowBits is passed < 0 to tell that there is no zlib header.
|
||||||
|
* Note that in this case inflate *requires* an extra "dummy" byte
|
||||||
|
* after the compressed stream in order to complete decompression and
|
||||||
|
* return Z_STREAM_END. Here the gzip CRC32 ensures that 4 bytes are
|
||||||
|
* present after the compressed stream.
|
||||||
|
*/
|
||||||
if (err != Z_OK || s->inbuf == Z_NULL) {
|
if (err != Z_OK || s->inbuf == Z_NULL) {
|
||||||
return destroy(s), (gzFile)Z_NULL;
|
return destroy(s), (gzFile)Z_NULL;
|
||||||
}
|
}
|
||||||
@@ -126,7 +153,7 @@ local gzFile gz_open (path, mode, fd)
|
|||||||
s->stream.avail_out = Z_BUFSIZE;
|
s->stream.avail_out = Z_BUFSIZE;
|
||||||
|
|
||||||
errno = 0;
|
errno = 0;
|
||||||
s->file = fd < 0 ? FOPEN(path, fmode) : (FILE*)fdopen(fd, fmode);
|
s->file = fd < 0 ? F_OPEN(path, fmode) : (FILE*)fdopen(fd, fmode);
|
||||||
|
|
||||||
if (s->file == NULL) {
|
if (s->file == NULL) {
|
||||||
return destroy(s), (gzFile)Z_NULL;
|
return destroy(s), (gzFile)Z_NULL;
|
||||||
@@ -136,16 +163,24 @@ local gzFile gz_open (path, mode, fd)
|
|||||||
*/
|
*/
|
||||||
fprintf(s->file, "%c%c%c%c%c%c%c%c%c%c", gz_magic[0], gz_magic[1],
|
fprintf(s->file, "%c%c%c%c%c%c%c%c%c%c", gz_magic[0], gz_magic[1],
|
||||||
Z_DEFLATED, 0 /*flags*/, 0,0,0,0 /*time*/, 0 /*xflags*/, OS_CODE);
|
Z_DEFLATED, 0 /*flags*/, 0,0,0,0 /*time*/, 0 /*xflags*/, OS_CODE);
|
||||||
|
s->startpos = 10L;
|
||||||
|
/* We use 10L instead of ftell(s->file) to because ftell causes an
|
||||||
|
* fflush on some systems. This version of the library doesn't use
|
||||||
|
* startpos anyway in write mode, so this initialization is not
|
||||||
|
* necessary.
|
||||||
|
*/
|
||||||
} else {
|
} else {
|
||||||
check_header(s); /* skip the .gz header */
|
check_header(s); /* skip the .gz header */
|
||||||
|
s->startpos = (ftell(s->file) - s->stream.avail_in);
|
||||||
}
|
}
|
||||||
|
|
||||||
return (gzFile)s;
|
return (gzFile)s;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ===========================================================================
|
/* ===========================================================================
|
||||||
Opens a gzip (.gz) file for reading or writing.
|
Opens a gzip (.gz) file for reading or writing.
|
||||||
*/
|
*/
|
||||||
gzFile gzopen (path, mode)
|
gzFile ZEXPORT gzopen (path, mode)
|
||||||
const char *path;
|
const char *path;
|
||||||
const char *mode;
|
const char *mode;
|
||||||
{
|
{
|
||||||
@@ -156,7 +191,7 @@ gzFile gzopen (path, mode)
|
|||||||
Associate a gzFile with the file descriptor fd. fd is not dup'ed here
|
Associate a gzFile with the file descriptor fd. fd is not dup'ed here
|
||||||
to mimic the behavio(u)r of fdopen.
|
to mimic the behavio(u)r of fdopen.
|
||||||
*/
|
*/
|
||||||
gzFile gzdopen (fd, mode)
|
gzFile ZEXPORT gzdopen (fd, mode)
|
||||||
int fd;
|
int fd;
|
||||||
const char *mode;
|
const char *mode;
|
||||||
{
|
{
|
||||||
@@ -168,6 +203,31 @@ gzFile gzdopen (fd, mode)
|
|||||||
return gz_open (name, mode, fd);
|
return gz_open (name, mode, fd);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* ===========================================================================
|
||||||
|
* Update the compression level and strategy
|
||||||
|
*/
|
||||||
|
int ZEXPORT gzsetparams (file, level, strategy)
|
||||||
|
gzFile file;
|
||||||
|
int level;
|
||||||
|
int strategy;
|
||||||
|
{
|
||||||
|
gz_stream *s = (gz_stream*)file;
|
||||||
|
|
||||||
|
if (s == NULL || s->mode != 'w') return Z_STREAM_ERROR;
|
||||||
|
|
||||||
|
/* Make room to allow flushing */
|
||||||
|
if (s->stream.avail_out == 0) {
|
||||||
|
|
||||||
|
s->stream.next_out = s->outbuf;
|
||||||
|
if (fwrite(s->outbuf, 1, Z_BUFSIZE, s->file) != Z_BUFSIZE) {
|
||||||
|
s->z_err = Z_ERRNO;
|
||||||
|
}
|
||||||
|
s->stream.avail_out = Z_BUFSIZE;
|
||||||
|
}
|
||||||
|
|
||||||
|
return deflateParams (&(s->stream), level, strategy);
|
||||||
|
}
|
||||||
|
|
||||||
/* ===========================================================================
|
/* ===========================================================================
|
||||||
Read a byte from a gz_stream; update next_in and avail_in. Return EOF
|
Read a byte from a gz_stream; update next_in and avail_in. Return EOF
|
||||||
for end of file.
|
for end of file.
|
||||||
@@ -212,8 +272,11 @@ local void check_header(s)
|
|||||||
for (len = 0; len < 2; len++) {
|
for (len = 0; len < 2; len++) {
|
||||||
c = get_byte(s);
|
c = get_byte(s);
|
||||||
if (c != gz_magic[len]) {
|
if (c != gz_magic[len]) {
|
||||||
s->transparent = 1;
|
if (len != 0) s->stream.avail_in++, s->stream.next_in--;
|
||||||
if (c != EOF) s->stream.avail_in++, s->stream.next_in--;
|
if (c != EOF) {
|
||||||
|
s->stream.avail_in++, s->stream.next_in--;
|
||||||
|
s->transparent = 1;
|
||||||
|
}
|
||||||
s->z_err = s->stream.avail_in != 0 ? Z_OK : Z_STREAM_END;
|
s->z_err = s->stream.avail_in != 0 ? Z_OK : Z_STREAM_END;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -260,14 +323,21 @@ local int destroy (s)
|
|||||||
TRYFREE(s->msg);
|
TRYFREE(s->msg);
|
||||||
|
|
||||||
if (s->stream.state != NULL) {
|
if (s->stream.state != NULL) {
|
||||||
if (s->mode == 'w') {
|
if (s->mode == 'w') {
|
||||||
err = deflateEnd(&(s->stream));
|
#ifdef NO_DEFLATE
|
||||||
} else if (s->mode == 'r') {
|
err = Z_STREAM_ERROR;
|
||||||
err = inflateEnd(&(s->stream));
|
#else
|
||||||
}
|
err = deflateEnd(&(s->stream));
|
||||||
|
#endif
|
||||||
|
} else if (s->mode == 'r') {
|
||||||
|
err = inflateEnd(&(s->stream));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (s->file != NULL && fclose(s->file)) {
|
if (s->file != NULL && fclose(s->file)) {
|
||||||
err = Z_ERRNO;
|
#ifdef ESPIPE
|
||||||
|
if (errno != ESPIPE) /* fclose is broken for pipes in HP/UX */
|
||||||
|
#endif
|
||||||
|
err = Z_ERRNO;
|
||||||
}
|
}
|
||||||
if (s->z_err < 0) err = s->z_err;
|
if (s->z_err < 0) err = s->z_err;
|
||||||
|
|
||||||
@@ -282,13 +352,13 @@ local int destroy (s)
|
|||||||
Reads the given number of uncompressed bytes from the compressed file.
|
Reads the given number of uncompressed bytes from the compressed file.
|
||||||
gzread returns the number of bytes actually read (0 for end of file).
|
gzread returns the number of bytes actually read (0 for end of file).
|
||||||
*/
|
*/
|
||||||
int gzread (file, buf, len)
|
int ZEXPORT gzread (file, buf, len)
|
||||||
gzFile file;
|
gzFile file;
|
||||||
voidp buf;
|
voidp buf;
|
||||||
unsigned len;
|
unsigned len;
|
||||||
{
|
{
|
||||||
gz_stream *s = (gz_stream*)file;
|
gz_stream *s = (gz_stream*)file;
|
||||||
Bytef *start = buf; /* starting point for crc computation */
|
Bytef *start = (Bytef*)buf; /* starting point for crc computation */
|
||||||
Byte *next_out; /* == stream.next_out but not forced far (for MSDOS) */
|
Byte *next_out; /* == stream.next_out but not forced far (for MSDOS) */
|
||||||
|
|
||||||
if (s == NULL || s->mode != 'r') return Z_STREAM_ERROR;
|
if (s == NULL || s->mode != 'r') return Z_STREAM_ERROR;
|
||||||
@@ -296,7 +366,8 @@ int gzread (file, buf, len)
|
|||||||
if (s->z_err == Z_DATA_ERROR || s->z_err == Z_ERRNO) return -1;
|
if (s->z_err == Z_DATA_ERROR || s->z_err == Z_ERRNO) return -1;
|
||||||
if (s->z_err == Z_STREAM_END) return 0; /* EOF */
|
if (s->z_err == Z_STREAM_END) return 0; /* EOF */
|
||||||
|
|
||||||
s->stream.next_out = next_out = buf;
|
next_out = (Byte*)buf;
|
||||||
|
s->stream.next_out = (Bytef*)buf;
|
||||||
s->stream.avail_out = len;
|
s->stream.avail_out = len;
|
||||||
|
|
||||||
while (s->stream.avail_out != 0) {
|
while (s->stream.avail_out != 0) {
|
||||||
@@ -317,7 +388,11 @@ int gzread (file, buf, len)
|
|||||||
s->stream.avail_out -= fread(next_out, 1, s->stream.avail_out,
|
s->stream.avail_out -= fread(next_out, 1, s->stream.avail_out,
|
||||||
s->file);
|
s->file);
|
||||||
}
|
}
|
||||||
return (int)(len - s->stream.avail_out);
|
len -= s->stream.avail_out;
|
||||||
|
s->stream.total_in += (uLong)len;
|
||||||
|
s->stream.total_out += (uLong)len;
|
||||||
|
if (len == 0) s->z_eof = 1;
|
||||||
|
return (int)len;
|
||||||
}
|
}
|
||||||
if (s->stream.avail_in == 0 && !s->z_eof) {
|
if (s->stream.avail_in == 0 && !s->z_eof) {
|
||||||
|
|
||||||
@@ -339,13 +414,22 @@ int gzread (file, buf, len)
|
|||||||
s->crc = crc32(s->crc, start, (uInt)(s->stream.next_out - start));
|
s->crc = crc32(s->crc, start, (uInt)(s->stream.next_out - start));
|
||||||
start = s->stream.next_out;
|
start = s->stream.next_out;
|
||||||
|
|
||||||
if (getLong(s) != s->crc || getLong(s) != s->stream.total_out) {
|
if (getLong(s) != s->crc) {
|
||||||
s->z_err = Z_DATA_ERROR;
|
s->z_err = Z_DATA_ERROR;
|
||||||
} else {
|
} else {
|
||||||
/* Check for concatenated .gz files: */
|
(void)getLong(s);
|
||||||
|
/* The uncompressed length returned by above getlong() may
|
||||||
|
* be different from s->stream.total_out) in case of
|
||||||
|
* concatenated .gz files. Check for such files:
|
||||||
|
*/
|
||||||
check_header(s);
|
check_header(s);
|
||||||
if (s->z_err == Z_OK) {
|
if (s->z_err == Z_OK) {
|
||||||
|
uLong total_in = s->stream.total_in;
|
||||||
|
uLong total_out = s->stream.total_out;
|
||||||
|
|
||||||
inflateReset(&(s->stream));
|
inflateReset(&(s->stream));
|
||||||
|
s->stream.total_in = total_in;
|
||||||
|
s->stream.total_out = total_out;
|
||||||
s->crc = crc32(0L, Z_NULL, 0);
|
s->crc = crc32(0L, Z_NULL, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -357,11 +441,49 @@ int gzread (file, buf, len)
|
|||||||
return (int)(len - s->stream.avail_out);
|
return (int)(len - s->stream.avail_out);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* ===========================================================================
|
||||||
|
Reads one byte from the compressed file. gzgetc returns this byte
|
||||||
|
or -1 in case of end of file or error.
|
||||||
|
*/
|
||||||
|
int ZEXPORT gzgetc(file)
|
||||||
|
gzFile file;
|
||||||
|
{
|
||||||
|
unsigned char c;
|
||||||
|
|
||||||
|
return gzread(file, &c, 1) == 1 ? c : -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* ===========================================================================
|
||||||
|
Reads bytes from the compressed file until len-1 characters are
|
||||||
|
read, or a newline character is read and transferred to buf, or an
|
||||||
|
end-of-file condition is encountered. The string is then terminated
|
||||||
|
with a null character.
|
||||||
|
gzgets returns buf, or Z_NULL in case of error.
|
||||||
|
|
||||||
|
The current implementation is not optimized at all.
|
||||||
|
*/
|
||||||
|
char * ZEXPORT gzgets(file, buf, len)
|
||||||
|
gzFile file;
|
||||||
|
char *buf;
|
||||||
|
int len;
|
||||||
|
{
|
||||||
|
char *b = buf;
|
||||||
|
if (buf == Z_NULL || len <= 0) return Z_NULL;
|
||||||
|
|
||||||
|
while (--len > 0 && gzread(file, buf, 1) == 1 && *buf++ != '\n') ;
|
||||||
|
*buf = '\0';
|
||||||
|
return b == buf && len > 0 ? Z_NULL : b;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef NO_DEFLATE
|
||||||
/* ===========================================================================
|
/* ===========================================================================
|
||||||
Writes the given number of uncompressed bytes into the compressed file.
|
Writes the given number of uncompressed bytes into the compressed file.
|
||||||
gzwrite returns the number of bytes actually written (0 in case of error).
|
gzwrite returns the number of bytes actually written (0 in case of error).
|
||||||
*/
|
*/
|
||||||
int gzwrite (file, buf, len)
|
int ZEXPORT gzwrite (file, buf, len)
|
||||||
gzFile file;
|
gzFile file;
|
||||||
const voidp buf;
|
const voidp buf;
|
||||||
unsigned len;
|
unsigned len;
|
||||||
@@ -370,7 +492,7 @@ int gzwrite (file, buf, len)
|
|||||||
|
|
||||||
if (s == NULL || s->mode != 'w') return Z_STREAM_ERROR;
|
if (s == NULL || s->mode != 'w') return Z_STREAM_ERROR;
|
||||||
|
|
||||||
s->stream.next_in = buf;
|
s->stream.next_in = (Bytef*)buf;
|
||||||
s->stream.avail_in = len;
|
s->stream.avail_in = len;
|
||||||
|
|
||||||
while (s->stream.avail_in != 0) {
|
while (s->stream.avail_in != 0) {
|
||||||
@@ -387,18 +509,95 @@ int gzwrite (file, buf, len)
|
|||||||
s->z_err = deflate(&(s->stream), Z_NO_FLUSH);
|
s->z_err = deflate(&(s->stream), Z_NO_FLUSH);
|
||||||
if (s->z_err != Z_OK) break;
|
if (s->z_err != Z_OK) break;
|
||||||
}
|
}
|
||||||
s->crc = crc32(s->crc, buf, len);
|
s->crc = crc32(s->crc, (const Bytef *)buf, len);
|
||||||
|
|
||||||
return (int)(len - s->stream.avail_in);
|
return (int)(len - s->stream.avail_in);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* ===========================================================================
|
||||||
|
Converts, formats, and writes the args to the compressed file under
|
||||||
|
control of the format string, as in fprintf. gzprintf returns the number of
|
||||||
|
uncompressed bytes actually written (0 in case of error).
|
||||||
|
*/
|
||||||
|
#ifdef STDC
|
||||||
|
#include <stdarg.h>
|
||||||
|
|
||||||
|
int ZEXPORTVA gzprintf (gzFile file, const char *format, /* args */ ...)
|
||||||
|
{
|
||||||
|
char buf[Z_PRINTF_BUFSIZE];
|
||||||
|
va_list va;
|
||||||
|
int len;
|
||||||
|
|
||||||
|
va_start(va, format);
|
||||||
|
#ifdef HAS_vsnprintf
|
||||||
|
(void)vsnprintf(buf, sizeof(buf), format, va);
|
||||||
|
#else
|
||||||
|
(void)vsprintf(buf, format, va);
|
||||||
|
#endif
|
||||||
|
va_end(va);
|
||||||
|
len = strlen(buf); /* some *sprintf don't return the nb of bytes written */
|
||||||
|
if (len <= 0) return 0;
|
||||||
|
|
||||||
|
return gzwrite(file, buf, (unsigned)len);
|
||||||
|
}
|
||||||
|
#else /* not ANSI C */
|
||||||
|
|
||||||
|
int ZEXPORTVA gzprintf (file, format, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10,
|
||||||
|
a11, a12, a13, a14, a15, a16, a17, a18, a19, a20)
|
||||||
|
gzFile file;
|
||||||
|
const char *format;
|
||||||
|
int a1, a2, a3, a4, a5, a6, a7, a8, a9, a10,
|
||||||
|
a11, a12, a13, a14, a15, a16, a17, a18, a19, a20;
|
||||||
|
{
|
||||||
|
char buf[Z_PRINTF_BUFSIZE];
|
||||||
|
int len;
|
||||||
|
|
||||||
|
#ifdef HAS_snprintf
|
||||||
|
snprintf(buf, sizeof(buf), format, a1, a2, a3, a4, a5, a6, a7, a8,
|
||||||
|
a9, a10, a11, a12, a13, a14, a15, a16, a17, a18, a19, a20);
|
||||||
|
#else
|
||||||
|
sprintf(buf, format, a1, a2, a3, a4, a5, a6, a7, a8,
|
||||||
|
a9, a10, a11, a12, a13, a14, a15, a16, a17, a18, a19, a20);
|
||||||
|
#endif
|
||||||
|
len = strlen(buf); /* old sprintf doesn't return the nb of bytes written */
|
||||||
|
if (len <= 0) return 0;
|
||||||
|
|
||||||
|
return gzwrite(file, buf, len);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* ===========================================================================
|
||||||
|
Writes c, converted to an unsigned char, into the compressed file.
|
||||||
|
gzputc returns the value that was written, or -1 in case of error.
|
||||||
|
*/
|
||||||
|
int ZEXPORT gzputc(file, c)
|
||||||
|
gzFile file;
|
||||||
|
int c;
|
||||||
|
{
|
||||||
|
unsigned char cc = (unsigned char) c; /* required for big endian systems */
|
||||||
|
|
||||||
|
return gzwrite(file, &cc, 1) == 1 ? (int)cc : -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* ===========================================================================
|
||||||
|
Writes the given null-terminated string to the compressed file, excluding
|
||||||
|
the terminating null character.
|
||||||
|
gzputs returns the number of characters written, or -1 in case of error.
|
||||||
|
*/
|
||||||
|
int ZEXPORT gzputs(file, s)
|
||||||
|
gzFile file;
|
||||||
|
const char *s;
|
||||||
|
{
|
||||||
|
return gzwrite(file, (char*)s, (unsigned)strlen(s));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/* ===========================================================================
|
/* ===========================================================================
|
||||||
Flushes all pending output into the compressed file. The parameter
|
Flushes all pending output into the compressed file. The parameter
|
||||||
flush is as in the deflate() function.
|
flush is as in the deflate() function.
|
||||||
gzflush should be called only when strictly necessary because it can
|
|
||||||
degrade compression.
|
|
||||||
*/
|
*/
|
||||||
int gzflush (file, flush)
|
local int do_flush (file, flush)
|
||||||
gzFile file;
|
gzFile file;
|
||||||
int flush;
|
int flush;
|
||||||
{
|
{
|
||||||
@@ -424,6 +623,9 @@ int gzflush (file, flush)
|
|||||||
if (done) break;
|
if (done) break;
|
||||||
s->z_err = deflate(&(s->stream), flush);
|
s->z_err = deflate(&(s->stream), flush);
|
||||||
|
|
||||||
|
/* Ignore the second of two consecutive flushes: */
|
||||||
|
if (len == 0 && s->z_err == Z_BUF_ERROR) s->z_err = Z_OK;
|
||||||
|
|
||||||
/* deflate has finished flushing only when it hasn't used up
|
/* deflate has finished flushing only when it hasn't used up
|
||||||
* all the available space in the output buffer:
|
* all the available space in the output buffer:
|
||||||
*/
|
*/
|
||||||
@@ -431,9 +633,155 @@ int gzflush (file, flush)
|
|||||||
|
|
||||||
if (s->z_err != Z_OK && s->z_err != Z_STREAM_END) break;
|
if (s->z_err != Z_OK && s->z_err != Z_STREAM_END) break;
|
||||||
}
|
}
|
||||||
|
return s->z_err == Z_STREAM_END ? Z_OK : s->z_err;
|
||||||
|
}
|
||||||
|
|
||||||
|
int ZEXPORT gzflush (file, flush)
|
||||||
|
gzFile file;
|
||||||
|
int flush;
|
||||||
|
{
|
||||||
|
gz_stream *s = (gz_stream*)file;
|
||||||
|
int err = do_flush (file, flush);
|
||||||
|
|
||||||
|
if (err) return err;
|
||||||
fflush(s->file);
|
fflush(s->file);
|
||||||
return s->z_err == Z_STREAM_END ? Z_OK : s->z_err;
|
return s->z_err == Z_STREAM_END ? Z_OK : s->z_err;
|
||||||
}
|
}
|
||||||
|
#endif /* NO_DEFLATE */
|
||||||
|
|
||||||
|
/* ===========================================================================
|
||||||
|
Sets the starting position for the next gzread or gzwrite on the given
|
||||||
|
compressed file. The offset represents a number of bytes in the
|
||||||
|
gzseek returns the resulting offset location as measured in bytes from
|
||||||
|
the beginning of the uncompressed stream, or -1 in case of error.
|
||||||
|
SEEK_END is not implemented, returns error.
|
||||||
|
In this version of the library, gzseek can be extremely slow.
|
||||||
|
*/
|
||||||
|
z_off_t ZEXPORT gzseek (file, offset, whence)
|
||||||
|
gzFile file;
|
||||||
|
z_off_t offset;
|
||||||
|
int whence;
|
||||||
|
{
|
||||||
|
gz_stream *s = (gz_stream*)file;
|
||||||
|
|
||||||
|
if (s == NULL || whence == SEEK_END ||
|
||||||
|
s->z_err == Z_ERRNO || s->z_err == Z_DATA_ERROR) {
|
||||||
|
return -1L;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (s->mode == 'w') {
|
||||||
|
#ifdef NO_DEFLATE
|
||||||
|
return -1L;
|
||||||
|
#else
|
||||||
|
if (whence == SEEK_SET) {
|
||||||
|
offset -= s->stream.total_in;
|
||||||
|
}
|
||||||
|
if (offset < 0) return -1L;
|
||||||
|
|
||||||
|
/* At this point, offset is the number of zero bytes to write. */
|
||||||
|
if (s->inbuf == Z_NULL) {
|
||||||
|
s->inbuf = (Byte*)ALLOC(Z_BUFSIZE); /* for seeking */
|
||||||
|
zmemzero(s->inbuf, Z_BUFSIZE);
|
||||||
|
}
|
||||||
|
while (offset > 0) {
|
||||||
|
uInt size = Z_BUFSIZE;
|
||||||
|
if (offset < Z_BUFSIZE) size = (uInt)offset;
|
||||||
|
|
||||||
|
size = gzwrite(file, s->inbuf, size);
|
||||||
|
if (size == 0) return -1L;
|
||||||
|
|
||||||
|
offset -= size;
|
||||||
|
}
|
||||||
|
return (z_off_t)s->stream.total_in;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
/* Rest of function is for reading only */
|
||||||
|
|
||||||
|
/* compute absolute position */
|
||||||
|
if (whence == SEEK_CUR) {
|
||||||
|
offset += s->stream.total_out;
|
||||||
|
}
|
||||||
|
if (offset < 0) return -1L;
|
||||||
|
|
||||||
|
if (s->transparent) {
|
||||||
|
/* map to fseek */
|
||||||
|
s->stream.avail_in = 0;
|
||||||
|
s->stream.next_in = s->inbuf;
|
||||||
|
if (fseek(s->file, offset, SEEK_SET) < 0) return -1L;
|
||||||
|
|
||||||
|
s->stream.total_in = s->stream.total_out = (uLong)offset;
|
||||||
|
return offset;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* For a negative seek, rewind and use positive seek */
|
||||||
|
if ((uLong)offset >= s->stream.total_out) {
|
||||||
|
offset -= s->stream.total_out;
|
||||||
|
} else if (gzrewind(file) < 0) {
|
||||||
|
return -1L;
|
||||||
|
}
|
||||||
|
/* offset is now the number of bytes to skip. */
|
||||||
|
|
||||||
|
if (offset != 0 && s->outbuf == Z_NULL) {
|
||||||
|
s->outbuf = (Byte*)ALLOC(Z_BUFSIZE);
|
||||||
|
}
|
||||||
|
while (offset > 0) {
|
||||||
|
int size = Z_BUFSIZE;
|
||||||
|
if (offset < Z_BUFSIZE) size = (int)offset;
|
||||||
|
|
||||||
|
size = gzread(file, s->outbuf, (uInt)size);
|
||||||
|
if (size <= 0) return -1L;
|
||||||
|
offset -= size;
|
||||||
|
}
|
||||||
|
return (z_off_t)s->stream.total_out;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* ===========================================================================
|
||||||
|
Rewinds input file.
|
||||||
|
*/
|
||||||
|
int ZEXPORT gzrewind (file)
|
||||||
|
gzFile file;
|
||||||
|
{
|
||||||
|
gz_stream *s = (gz_stream*)file;
|
||||||
|
|
||||||
|
if (s == NULL || s->mode != 'r') return -1;
|
||||||
|
|
||||||
|
s->z_err = Z_OK;
|
||||||
|
s->z_eof = 0;
|
||||||
|
s->stream.avail_in = 0;
|
||||||
|
s->stream.next_in = s->inbuf;
|
||||||
|
s->crc = crc32(0L, Z_NULL, 0);
|
||||||
|
|
||||||
|
if (s->startpos == 0) { /* not a compressed file */
|
||||||
|
rewind(s->file);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
(void) inflateReset(&s->stream);
|
||||||
|
return fseek(s->file, s->startpos, SEEK_SET);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* ===========================================================================
|
||||||
|
Returns the starting position for the next gzread or gzwrite on the
|
||||||
|
given compressed file. This position represents a number of bytes in the
|
||||||
|
uncompressed data stream.
|
||||||
|
*/
|
||||||
|
z_off_t ZEXPORT gztell (file)
|
||||||
|
gzFile file;
|
||||||
|
{
|
||||||
|
return gzseek(file, 0L, SEEK_CUR);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* ===========================================================================
|
||||||
|
Returns 1 when EOF has previously been detected reading the given
|
||||||
|
input stream, otherwise zero.
|
||||||
|
*/
|
||||||
|
int ZEXPORT gzeof (file)
|
||||||
|
gzFile file;
|
||||||
|
{
|
||||||
|
gz_stream *s = (gz_stream*)file;
|
||||||
|
|
||||||
|
return (s == NULL || s->mode != 'r') ? 0 : s->z_eof;
|
||||||
|
}
|
||||||
|
|
||||||
/* ===========================================================================
|
/* ===========================================================================
|
||||||
Outputs a long in LSB order to the given file
|
Outputs a long in LSB order to the given file
|
||||||
@@ -450,7 +798,8 @@ local void putLong (file, x)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* ===========================================================================
|
/* ===========================================================================
|
||||||
Reads a long in LSB order from the given gz_stream. Sets
|
Reads a long in LSB order from the given gz_stream. Sets z_err in case
|
||||||
|
of error.
|
||||||
*/
|
*/
|
||||||
local uLong getLong (s)
|
local uLong getLong (s)
|
||||||
gz_stream *s;
|
gz_stream *s;
|
||||||
@@ -470,7 +819,7 @@ local uLong getLong (s)
|
|||||||
Flushes all pending output if necessary, closes the compressed file
|
Flushes all pending output if necessary, closes the compressed file
|
||||||
and deallocates all the (de)compression state.
|
and deallocates all the (de)compression state.
|
||||||
*/
|
*/
|
||||||
int gzclose (file)
|
int ZEXPORT gzclose (file)
|
||||||
gzFile file;
|
gzFile file;
|
||||||
{
|
{
|
||||||
int err;
|
int err;
|
||||||
@@ -479,14 +828,17 @@ int gzclose (file)
|
|||||||
if (s == NULL) return Z_STREAM_ERROR;
|
if (s == NULL) return Z_STREAM_ERROR;
|
||||||
|
|
||||||
if (s->mode == 'w') {
|
if (s->mode == 'w') {
|
||||||
err = gzflush (file, Z_FINISH);
|
#ifdef NO_DEFLATE
|
||||||
if (err != Z_OK) return destroy(file);
|
return Z_STREAM_ERROR;
|
||||||
|
#else
|
||||||
|
err = do_flush (file, Z_FINISH);
|
||||||
|
if (err != Z_OK) return destroy((gz_stream*)file);
|
||||||
|
|
||||||
putLong (s->file, s->crc);
|
putLong (s->file, s->crc);
|
||||||
putLong (s->file, s->stream.total_in);
|
putLong (s->file, s->stream.total_in);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
return destroy(file);
|
return destroy((gz_stream*)file);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ===========================================================================
|
/* ===========================================================================
|
||||||
@@ -496,7 +848,7 @@ int gzclose (file)
|
|||||||
errnum is set to Z_ERRNO and the application may consult errno
|
errnum is set to Z_ERRNO and the application may consult errno
|
||||||
to get the exact error code.
|
to get the exact error code.
|
||||||
*/
|
*/
|
||||||
const char* gzerror (file, errnum)
|
const char* ZEXPORT gzerror (file, errnum)
|
||||||
gzFile file;
|
gzFile file;
|
||||||
int *errnum;
|
int *errnum;
|
||||||
{
|
{
|
||||||
|
|||||||
98
infblock.c
98
infblock.c
@@ -1,5 +1,5 @@
|
|||||||
/* infblock.c -- interpret and process block types to last block
|
/* infblock.c -- interpret and process block types to last block
|
||||||
* Copyright (C) 1995-1996 Mark Adler
|
* Copyright (C) 1995-1998 Mark Adler
|
||||||
* For conditions of distribution and use, see copyright notice in zlib.h
|
* For conditions of distribution and use, see copyright notice in zlib.h
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@@ -11,8 +11,12 @@
|
|||||||
|
|
||||||
struct inflate_codes_state {int dummy;}; /* for buggy compilers */
|
struct inflate_codes_state {int dummy;}; /* for buggy compilers */
|
||||||
|
|
||||||
|
/* simplify the use of the inflate_huft type with some defines */
|
||||||
|
#define exop word.what.Exop
|
||||||
|
#define bits word.what.Bits
|
||||||
|
|
||||||
/* Table for deflate from PKZIP's appnote.txt. */
|
/* Table for deflate from PKZIP's appnote.txt. */
|
||||||
local uInt border[] = { /* Order of the bit length code lengths */
|
local const uInt border[] = { /* Order of the bit length code lengths */
|
||||||
16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15};
|
16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -66,23 +70,19 @@ inflate_blocks_statef *s;
|
|||||||
z_streamp z;
|
z_streamp z;
|
||||||
uLongf *c;
|
uLongf *c;
|
||||||
{
|
{
|
||||||
if (s->checkfn != Z_NULL)
|
if (c != Z_NULL)
|
||||||
*c = s->check;
|
*c = s->check;
|
||||||
if (s->mode == BTREE || s->mode == DTREE)
|
if (s->mode == BTREE || s->mode == DTREE)
|
||||||
ZFREE(z, s->sub.trees.blens);
|
ZFREE(z, s->sub.trees.blens);
|
||||||
if (s->mode == CODES)
|
if (s->mode == CODES)
|
||||||
{
|
|
||||||
inflate_codes_free(s->sub.decode.codes, z);
|
inflate_codes_free(s->sub.decode.codes, z);
|
||||||
inflate_trees_free(s->sub.decode.td, z);
|
|
||||||
inflate_trees_free(s->sub.decode.tl, z);
|
|
||||||
}
|
|
||||||
s->mode = TYPE;
|
s->mode = TYPE;
|
||||||
s->bitk = 0;
|
s->bitk = 0;
|
||||||
s->bitb = 0;
|
s->bitb = 0;
|
||||||
s->read = s->write = s->window;
|
s->read = s->write = s->window;
|
||||||
if (s->checkfn != Z_NULL)
|
if (s->checkfn != Z_NULL)
|
||||||
z->adler = s->check = (*s->checkfn)(0L, Z_NULL, 0);
|
z->adler = s->check = (*s->checkfn)(0L, (const Bytef *)Z_NULL, 0);
|
||||||
Trace((stderr, "inflate: blocks reset\n"));
|
Tracev((stderr, "inflate: blocks reset\n"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -96,23 +96,27 @@ uInt w;
|
|||||||
if ((s = (inflate_blocks_statef *)ZALLOC
|
if ((s = (inflate_blocks_statef *)ZALLOC
|
||||||
(z,1,sizeof(struct inflate_blocks_state))) == Z_NULL)
|
(z,1,sizeof(struct inflate_blocks_state))) == Z_NULL)
|
||||||
return s;
|
return s;
|
||||||
|
if ((s->hufts =
|
||||||
|
(inflate_huft *)ZALLOC(z, sizeof(inflate_huft), MANY)) == Z_NULL)
|
||||||
|
{
|
||||||
|
ZFREE(z, s);
|
||||||
|
return Z_NULL;
|
||||||
|
}
|
||||||
if ((s->window = (Bytef *)ZALLOC(z, 1, w)) == Z_NULL)
|
if ((s->window = (Bytef *)ZALLOC(z, 1, w)) == Z_NULL)
|
||||||
{
|
{
|
||||||
|
ZFREE(z, s->hufts);
|
||||||
ZFREE(z, s);
|
ZFREE(z, s);
|
||||||
return Z_NULL;
|
return Z_NULL;
|
||||||
}
|
}
|
||||||
s->end = s->window + w;
|
s->end = s->window + w;
|
||||||
s->checkfn = c;
|
s->checkfn = c;
|
||||||
s->mode = TYPE;
|
s->mode = TYPE;
|
||||||
Trace((stderr, "inflate: blocks allocated\n"));
|
Tracev((stderr, "inflate: blocks allocated\n"));
|
||||||
inflate_blocks_reset(s, z, &s->check);
|
inflate_blocks_reset(s, z, Z_NULL);
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#ifdef DEBUG
|
|
||||||
extern uInt inflate_hufts;
|
|
||||||
#endif
|
|
||||||
int inflate_blocks(s, z, r)
|
int inflate_blocks(s, z, r)
|
||||||
inflate_blocks_statef *s;
|
inflate_blocks_statef *s;
|
||||||
z_streamp z;
|
z_streamp z;
|
||||||
@@ -139,7 +143,7 @@ int r;
|
|||||||
switch (t >> 1)
|
switch (t >> 1)
|
||||||
{
|
{
|
||||||
case 0: /* stored */
|
case 0: /* stored */
|
||||||
Trace((stderr, "inflate: stored block%s\n",
|
Tracev((stderr, "inflate: stored block%s\n",
|
||||||
s->last ? " (last)" : ""));
|
s->last ? " (last)" : ""));
|
||||||
DUMPBITS(3)
|
DUMPBITS(3)
|
||||||
t = k & 7; /* go to byte boundary */
|
t = k & 7; /* go to byte boundary */
|
||||||
@@ -147,27 +151,25 @@ int r;
|
|||||||
s->mode = LENS; /* get length of stored block */
|
s->mode = LENS; /* get length of stored block */
|
||||||
break;
|
break;
|
||||||
case 1: /* fixed */
|
case 1: /* fixed */
|
||||||
Trace((stderr, "inflate: fixed codes block%s\n",
|
Tracev((stderr, "inflate: fixed codes block%s\n",
|
||||||
s->last ? " (last)" : ""));
|
s->last ? " (last)" : ""));
|
||||||
{
|
{
|
||||||
uInt bl, bd;
|
uInt bl, bd;
|
||||||
inflate_huft *tl, *td;
|
inflate_huft *tl, *td;
|
||||||
|
|
||||||
inflate_trees_fixed(&bl, &bd, &tl, &td);
|
inflate_trees_fixed(&bl, &bd, &tl, &td, z);
|
||||||
s->sub.decode.codes = inflate_codes_new(bl, bd, tl, td, z);
|
s->sub.decode.codes = inflate_codes_new(bl, bd, tl, td, z);
|
||||||
if (s->sub.decode.codes == Z_NULL)
|
if (s->sub.decode.codes == Z_NULL)
|
||||||
{
|
{
|
||||||
r = Z_MEM_ERROR;
|
r = Z_MEM_ERROR;
|
||||||
LEAVE
|
LEAVE
|
||||||
}
|
}
|
||||||
s->sub.decode.tl = Z_NULL; /* don't try to free these */
|
|
||||||
s->sub.decode.td = Z_NULL;
|
|
||||||
}
|
}
|
||||||
DUMPBITS(3)
|
DUMPBITS(3)
|
||||||
s->mode = CODES;
|
s->mode = CODES;
|
||||||
break;
|
break;
|
||||||
case 2: /* dynamic */
|
case 2: /* dynamic */
|
||||||
Trace((stderr, "inflate: dynamic codes block%s\n",
|
Tracev((stderr, "inflate: dynamic codes block%s\n",
|
||||||
s->last ? " (last)" : ""));
|
s->last ? " (last)" : ""));
|
||||||
DUMPBITS(3)
|
DUMPBITS(3)
|
||||||
s->mode = TABLE;
|
s->mode = TABLE;
|
||||||
@@ -224,8 +226,6 @@ int r;
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
t = 258 + (t & 0x1f) + ((t >> 5) & 0x1f);
|
t = 258 + (t & 0x1f) + ((t >> 5) & 0x1f);
|
||||||
if (t < 19)
|
|
||||||
t = 19;
|
|
||||||
if ((s->sub.trees.blens = (uIntf*)ZALLOC(z, t, sizeof(uInt))) == Z_NULL)
|
if ((s->sub.trees.blens = (uIntf*)ZALLOC(z, t, sizeof(uInt))) == Z_NULL)
|
||||||
{
|
{
|
||||||
r = Z_MEM_ERROR;
|
r = Z_MEM_ERROR;
|
||||||
@@ -246,9 +246,10 @@ int r;
|
|||||||
s->sub.trees.blens[border[s->sub.trees.index++]] = 0;
|
s->sub.trees.blens[border[s->sub.trees.index++]] = 0;
|
||||||
s->sub.trees.bb = 7;
|
s->sub.trees.bb = 7;
|
||||||
t = inflate_trees_bits(s->sub.trees.blens, &s->sub.trees.bb,
|
t = inflate_trees_bits(s->sub.trees.blens, &s->sub.trees.bb,
|
||||||
&s->sub.trees.tb, z);
|
&s->sub.trees.tb, s->hufts, z);
|
||||||
if (t != Z_OK)
|
if (t != Z_OK)
|
||||||
{
|
{
|
||||||
|
ZFREE(z, s->sub.trees.blens);
|
||||||
r = t;
|
r = t;
|
||||||
if (r == Z_DATA_ERROR)
|
if (r == Z_DATA_ERROR)
|
||||||
s->mode = BAD;
|
s->mode = BAD;
|
||||||
@@ -267,8 +268,8 @@ int r;
|
|||||||
t = s->sub.trees.bb;
|
t = s->sub.trees.bb;
|
||||||
NEEDBITS(t)
|
NEEDBITS(t)
|
||||||
h = s->sub.trees.tb + ((uInt)b & inflate_mask[t]);
|
h = s->sub.trees.tb + ((uInt)b & inflate_mask[t]);
|
||||||
t = h->word.what.Bits;
|
t = h->bits;
|
||||||
c = h->more.Base;
|
c = h->base;
|
||||||
if (c < 16)
|
if (c < 16)
|
||||||
{
|
{
|
||||||
DUMPBITS(t)
|
DUMPBITS(t)
|
||||||
@@ -287,6 +288,7 @@ int r;
|
|||||||
if (i + j > 258 + (t & 0x1f) + ((t >> 5) & 0x1f) ||
|
if (i + j > 258 + (t & 0x1f) + ((t >> 5) & 0x1f) ||
|
||||||
(c == 16 && i < 1))
|
(c == 16 && i < 1))
|
||||||
{
|
{
|
||||||
|
ZFREE(z, s->sub.trees.blens);
|
||||||
s->mode = BAD;
|
s->mode = BAD;
|
||||||
z->msg = (char*)"invalid bit length repeat";
|
z->msg = (char*)"invalid bit length repeat";
|
||||||
r = Z_DATA_ERROR;
|
r = Z_DATA_ERROR;
|
||||||
@@ -299,7 +301,6 @@ int r;
|
|||||||
s->sub.trees.index = i;
|
s->sub.trees.index = i;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
inflate_trees_free(s->sub.trees.tb, z);
|
|
||||||
s->sub.trees.tb = Z_NULL;
|
s->sub.trees.tb = Z_NULL;
|
||||||
{
|
{
|
||||||
uInt bl, bd;
|
uInt bl, bd;
|
||||||
@@ -309,11 +310,10 @@ int r;
|
|||||||
bl = 9; /* must be <= 9 for lookahead assumptions */
|
bl = 9; /* must be <= 9 for lookahead assumptions */
|
||||||
bd = 6; /* must be <= 9 for lookahead assumptions */
|
bd = 6; /* must be <= 9 for lookahead assumptions */
|
||||||
t = s->sub.trees.table;
|
t = s->sub.trees.table;
|
||||||
#ifdef DEBUG
|
|
||||||
inflate_hufts = 0;
|
|
||||||
#endif
|
|
||||||
t = inflate_trees_dynamic(257 + (t & 0x1f), 1 + ((t >> 5) & 0x1f),
|
t = inflate_trees_dynamic(257 + (t & 0x1f), 1 + ((t >> 5) & 0x1f),
|
||||||
s->sub.trees.blens, &bl, &bd, &tl, &td, z);
|
s->sub.trees.blens, &bl, &bd, &tl, &td,
|
||||||
|
s->hufts, z);
|
||||||
|
ZFREE(z, s->sub.trees.blens);
|
||||||
if (t != Z_OK)
|
if (t != Z_OK)
|
||||||
{
|
{
|
||||||
if (t == (uInt)Z_DATA_ERROR)
|
if (t == (uInt)Z_DATA_ERROR)
|
||||||
@@ -321,19 +321,13 @@ int r;
|
|||||||
r = t;
|
r = t;
|
||||||
LEAVE
|
LEAVE
|
||||||
}
|
}
|
||||||
Tracev((stderr, "inflate: trees ok, %d * %d bytes used\n",
|
Tracev((stderr, "inflate: trees ok\n"));
|
||||||
inflate_hufts, sizeof(inflate_huft)));
|
|
||||||
if ((c = inflate_codes_new(bl, bd, tl, td, z)) == Z_NULL)
|
if ((c = inflate_codes_new(bl, bd, tl, td, z)) == Z_NULL)
|
||||||
{
|
{
|
||||||
inflate_trees_free(td, z);
|
|
||||||
inflate_trees_free(tl, z);
|
|
||||||
r = Z_MEM_ERROR;
|
r = Z_MEM_ERROR;
|
||||||
LEAVE
|
LEAVE
|
||||||
}
|
}
|
||||||
ZFREE(z, s->sub.trees.blens);
|
|
||||||
s->sub.decode.codes = c;
|
s->sub.decode.codes = c;
|
||||||
s->sub.decode.tl = tl;
|
|
||||||
s->sub.decode.td = td;
|
|
||||||
}
|
}
|
||||||
s->mode = CODES;
|
s->mode = CODES;
|
||||||
case CODES:
|
case CODES:
|
||||||
@@ -342,8 +336,6 @@ int r;
|
|||||||
return inflate_flush(s, z, r);
|
return inflate_flush(s, z, r);
|
||||||
r = Z_OK;
|
r = Z_OK;
|
||||||
inflate_codes_free(s->sub.decode.codes, z);
|
inflate_codes_free(s->sub.decode.codes, z);
|
||||||
inflate_trees_free(s->sub.decode.td, z);
|
|
||||||
inflate_trees_free(s->sub.decode.tl, z);
|
|
||||||
LOAD
|
LOAD
|
||||||
Tracev((stderr, "inflate: codes end, %lu total out\n",
|
Tracev((stderr, "inflate: codes end, %lu total out\n",
|
||||||
z->total_out + (q >= s->read ? q - s->read :
|
z->total_out + (q >= s->read ? q - s->read :
|
||||||
@@ -353,13 +345,6 @@ int r;
|
|||||||
s->mode = TYPE;
|
s->mode = TYPE;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (k > 7) /* return unused byte, if any */
|
|
||||||
{
|
|
||||||
Assert(k < 16, "inflate_codes grabbed too many bytes")
|
|
||||||
k -= 8;
|
|
||||||
n++;
|
|
||||||
p--; /* can always return one */
|
|
||||||
}
|
|
||||||
s->mode = DRY;
|
s->mode = DRY;
|
||||||
case DRY:
|
case DRY:
|
||||||
FLUSH
|
FLUSH
|
||||||
@@ -379,15 +364,15 @@ int r;
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int inflate_blocks_free(s, z, c)
|
int inflate_blocks_free(s, z)
|
||||||
inflate_blocks_statef *s;
|
inflate_blocks_statef *s;
|
||||||
z_streamp z;
|
z_streamp z;
|
||||||
uLongf *c;
|
|
||||||
{
|
{
|
||||||
inflate_blocks_reset(s, z, c);
|
inflate_blocks_reset(s, z, Z_NULL);
|
||||||
ZFREE(z, s->window);
|
ZFREE(z, s->window);
|
||||||
|
ZFREE(z, s->hufts);
|
||||||
ZFREE(z, s);
|
ZFREE(z, s);
|
||||||
Trace((stderr, "inflate: blocks freed\n"));
|
Tracev((stderr, "inflate: blocks freed\n"));
|
||||||
return Z_OK;
|
return Z_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -397,6 +382,17 @@ inflate_blocks_statef *s;
|
|||||||
const Bytef *d;
|
const Bytef *d;
|
||||||
uInt n;
|
uInt n;
|
||||||
{
|
{
|
||||||
zmemcpy((charf *)s->window, d, n);
|
zmemcpy(s->window, d, n);
|
||||||
s->read = s->write = s->window + n;
|
s->read = s->write = s->window + n;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* Returns true if inflate is currently at the end of a block generated
|
||||||
|
* by Z_SYNC_FLUSH or Z_FULL_FLUSH.
|
||||||
|
* IN assertion: s != Z_NULL
|
||||||
|
*/
|
||||||
|
int inflate_blocks_sync_point(s)
|
||||||
|
inflate_blocks_statef *s;
|
||||||
|
{
|
||||||
|
return s->mode == LENS;
|
||||||
|
}
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
/* infblock.h -- header to use infblock.c
|
/* infblock.h -- header to use infblock.c
|
||||||
* Copyright (C) 1995-1996 Mark Adler
|
* Copyright (C) 1995-1998 Mark Adler
|
||||||
* For conditions of distribution and use, see copyright notice in zlib.h
|
* For conditions of distribution and use, see copyright notice in zlib.h
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@@ -28,10 +28,12 @@ extern void inflate_blocks_reset OF((
|
|||||||
|
|
||||||
extern int inflate_blocks_free OF((
|
extern int inflate_blocks_free OF((
|
||||||
inflate_blocks_statef *,
|
inflate_blocks_statef *,
|
||||||
z_streamp ,
|
z_streamp));
|
||||||
uLongf *)); /* check value on output */
|
|
||||||
|
|
||||||
extern void inflate_set_dictionary OF((
|
extern void inflate_set_dictionary OF((
|
||||||
inflate_blocks_statef *s,
|
inflate_blocks_statef *s,
|
||||||
const Bytef *d, /* dictionary */
|
const Bytef *d, /* dictionary */
|
||||||
uInt n)); /* dictionary length */
|
uInt n)); /* dictionary length */
|
||||||
|
|
||||||
|
extern int inflate_blocks_sync_point OF((
|
||||||
|
inflate_blocks_statef *s));
|
||||||
|
|||||||
32
infcodes.c
32
infcodes.c
@@ -1,5 +1,5 @@
|
|||||||
/* infcodes.c -- process literals and length/distance pairs
|
/* infcodes.c -- process literals and length/distance pairs
|
||||||
* Copyright (C) 1995-1996 Mark Adler
|
* Copyright (C) 1995-1998 Mark Adler
|
||||||
* For conditions of distribution and use, see copyright notice in zlib.h
|
* For conditions of distribution and use, see copyright notice in zlib.h
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@@ -11,16 +11,10 @@
|
|||||||
#include "inffast.h"
|
#include "inffast.h"
|
||||||
|
|
||||||
/* simplify the use of the inflate_huft type with some defines */
|
/* simplify the use of the inflate_huft type with some defines */
|
||||||
#define base more.Base
|
|
||||||
#define next more.Next
|
|
||||||
#define exop word.what.Exop
|
#define exop word.what.Exop
|
||||||
#define bits word.what.Bits
|
#define bits word.what.Bits
|
||||||
|
|
||||||
/* inflate codes private state */
|
typedef enum { /* waiting for "i:"=input, "o:"=output, "x:"=nothing */
|
||||||
struct inflate_codes_state {
|
|
||||||
|
|
||||||
/* mode */
|
|
||||||
enum { /* waiting for "i:"=input, "o:"=output, "x:"=nothing */
|
|
||||||
START, /* x: set up for LEN */
|
START, /* x: set up for LEN */
|
||||||
LEN, /* i: get length/literal/eob next */
|
LEN, /* i: get length/literal/eob next */
|
||||||
LENEXT, /* i: getting length extra (have base) */
|
LENEXT, /* i: getting length extra (have base) */
|
||||||
@@ -31,7 +25,13 @@ struct inflate_codes_state {
|
|||||||
WASH, /* o: got eob, possibly still output waiting */
|
WASH, /* o: got eob, possibly still output waiting */
|
||||||
END, /* x: got eob and all data flushed */
|
END, /* x: got eob and all data flushed */
|
||||||
BADCODE} /* x: got error */
|
BADCODE} /* x: got error */
|
||||||
mode; /* current inflate_codes mode */
|
inflate_codes_mode;
|
||||||
|
|
||||||
|
/* inflate codes private state */
|
||||||
|
struct inflate_codes_state {
|
||||||
|
|
||||||
|
/* mode */
|
||||||
|
inflate_codes_mode mode; /* current inflate_codes mode */
|
||||||
|
|
||||||
/* mode dependent information */
|
/* mode dependent information */
|
||||||
uInt len;
|
uInt len;
|
||||||
@@ -143,7 +143,7 @@ int r;
|
|||||||
if ((e & 64) == 0) /* next table */
|
if ((e & 64) == 0) /* next table */
|
||||||
{
|
{
|
||||||
c->sub.code.need = e;
|
c->sub.code.need = e;
|
||||||
c->sub.code.tree = t->next;
|
c->sub.code.tree = t + t->base;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (e & 32) /* end of block */
|
if (e & 32) /* end of block */
|
||||||
@@ -181,7 +181,7 @@ int r;
|
|||||||
if ((e & 64) == 0) /* next table */
|
if ((e & 64) == 0) /* next table */
|
||||||
{
|
{
|
||||||
c->sub.code.need = e;
|
c->sub.code.need = e;
|
||||||
c->sub.code.tree = t->next;
|
c->sub.code.tree = t + t->base;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
c->mode = BADCODE; /* invalid code */
|
c->mode = BADCODE; /* invalid code */
|
||||||
@@ -221,6 +221,13 @@ int r;
|
|||||||
c->mode = START;
|
c->mode = START;
|
||||||
break;
|
break;
|
||||||
case WASH: /* o: got eob, possibly more output */
|
case WASH: /* o: got eob, possibly more output */
|
||||||
|
if (k > 7) /* return unused byte, if any */
|
||||||
|
{
|
||||||
|
Assert(k < 16, "inflate_codes grabbed too many bytes")
|
||||||
|
k -= 8;
|
||||||
|
n++;
|
||||||
|
p--; /* can always return one */
|
||||||
|
}
|
||||||
FLUSH
|
FLUSH
|
||||||
if (s->read != s->write)
|
if (s->read != s->write)
|
||||||
LEAVE
|
LEAVE
|
||||||
@@ -235,6 +242,9 @@ int r;
|
|||||||
r = Z_STREAM_ERROR;
|
r = Z_STREAM_ERROR;
|
||||||
LEAVE
|
LEAVE
|
||||||
}
|
}
|
||||||
|
#ifdef NEED_DUMMY_RETURN
|
||||||
|
return Z_STREAM_ERROR; /* Some dumb compilers complain without this */
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
/* infcodes.h -- header to use infcodes.c
|
/* infcodes.h -- header to use infcodes.c
|
||||||
* Copyright (C) 1995-1996 Mark Adler
|
* Copyright (C) 1995-1998 Mark Adler
|
||||||
* For conditions of distribution and use, see copyright notice in zlib.h
|
* For conditions of distribution and use, see copyright notice in zlib.h
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|||||||
14
inffast.c
14
inffast.c
@@ -1,5 +1,5 @@
|
|||||||
/* inffast.c -- process literals and length/distance pairs fast
|
/* inffast.c -- process literals and length/distance pairs fast
|
||||||
* Copyright (C) 1995-1996 Mark Adler
|
* Copyright (C) 1995-1998 Mark Adler
|
||||||
* For conditions of distribution and use, see copyright notice in zlib.h
|
* For conditions of distribution and use, see copyright notice in zlib.h
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@@ -13,14 +13,12 @@
|
|||||||
struct inflate_codes_state {int dummy;}; /* for buggy compilers */
|
struct inflate_codes_state {int dummy;}; /* for buggy compilers */
|
||||||
|
|
||||||
/* simplify the use of the inflate_huft type with some defines */
|
/* simplify the use of the inflate_huft type with some defines */
|
||||||
#define base more.Base
|
|
||||||
#define next more.Next
|
|
||||||
#define exop word.what.Exop
|
#define exop word.what.Exop
|
||||||
#define bits word.what.Bits
|
#define bits word.what.Bits
|
||||||
|
|
||||||
/* macros for bit input with no checking and for returning unused bytes */
|
/* macros for bit input with no checking and for returning unused bytes */
|
||||||
#define GRABBITS(j) {while(k<(j)){b|=((uLong)NEXTBYTE)<<k;k+=8;}}
|
#define GRABBITS(j) {while(k<(j)){b|=((uLong)NEXTBYTE)<<k;k+=8;}}
|
||||||
#define UNGRAB {n+=(c=k>>3);p-=c;k&=7;}
|
#define UNGRAB {c=z->avail_in-n;c=(k>>3)<c?k>>3:c;n+=c;p-=c;k-=c<<3;}
|
||||||
|
|
||||||
/* Called with number of bytes left to write in window at least 258
|
/* Called with number of bytes left to write in window at least 258
|
||||||
(the maximum string length) and number of input bytes available
|
(the maximum string length) and number of input bytes available
|
||||||
@@ -120,7 +118,10 @@ z_streamp z;
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
else if ((e & 64) == 0)
|
else if ((e & 64) == 0)
|
||||||
e = (t = t->next + ((uInt)b & inflate_mask[e]))->exop;
|
{
|
||||||
|
t += t->base;
|
||||||
|
e = (t += ((uInt)b & inflate_mask[e]))->exop;
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
z->msg = (char*)"invalid distance code";
|
z->msg = (char*)"invalid distance code";
|
||||||
@@ -133,7 +134,8 @@ z_streamp z;
|
|||||||
}
|
}
|
||||||
if ((e & 64) == 0)
|
if ((e & 64) == 0)
|
||||||
{
|
{
|
||||||
if ((e = (t = t->next + ((uInt)b & inflate_mask[e]))->exop) == 0)
|
t += t->base;
|
||||||
|
if ((e = (t += ((uInt)b & inflate_mask[e]))->exop) == 0)
|
||||||
{
|
{
|
||||||
DUMPBITS(t->bits)
|
DUMPBITS(t->bits)
|
||||||
Tracevv((stderr, t->base >= 0x20 && t->base < 0x7f ?
|
Tracevv((stderr, t->base >= 0x20 && t->base < 0x7f ?
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
/* inffast.h -- header to use inffast.c
|
/* inffast.h -- header to use inffast.c
|
||||||
* Copyright (C) 1995-1996 Mark Adler
|
* Copyright (C) 1995-1998 Mark Adler
|
||||||
* For conditions of distribution and use, see copyright notice in zlib.h
|
* For conditions of distribution and use, see copyright notice in zlib.h
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|||||||
151
inffixed.h
Normal file
151
inffixed.h
Normal file
@@ -0,0 +1,151 @@
|
|||||||
|
/* inffixed.h -- table for decoding fixed codes
|
||||||
|
* Generated automatically by the maketree.c program
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* WARNING: this file should *not* be used by applications. It is
|
||||||
|
part of the implementation of the compression library and is
|
||||||
|
subject to change. Applications should only use zlib.h.
|
||||||
|
*/
|
||||||
|
|
||||||
|
local uInt fixed_bl = 9;
|
||||||
|
local uInt fixed_bd = 5;
|
||||||
|
local inflate_huft fixed_tl[] = {
|
||||||
|
{{{96,7}},256}, {{{0,8}},80}, {{{0,8}},16}, {{{84,8}},115},
|
||||||
|
{{{82,7}},31}, {{{0,8}},112}, {{{0,8}},48}, {{{0,9}},192},
|
||||||
|
{{{80,7}},10}, {{{0,8}},96}, {{{0,8}},32}, {{{0,9}},160},
|
||||||
|
{{{0,8}},0}, {{{0,8}},128}, {{{0,8}},64}, {{{0,9}},224},
|
||||||
|
{{{80,7}},6}, {{{0,8}},88}, {{{0,8}},24}, {{{0,9}},144},
|
||||||
|
{{{83,7}},59}, {{{0,8}},120}, {{{0,8}},56}, {{{0,9}},208},
|
||||||
|
{{{81,7}},17}, {{{0,8}},104}, {{{0,8}},40}, {{{0,9}},176},
|
||||||
|
{{{0,8}},8}, {{{0,8}},136}, {{{0,8}},72}, {{{0,9}},240},
|
||||||
|
{{{80,7}},4}, {{{0,8}},84}, {{{0,8}},20}, {{{85,8}},227},
|
||||||
|
{{{83,7}},43}, {{{0,8}},116}, {{{0,8}},52}, {{{0,9}},200},
|
||||||
|
{{{81,7}},13}, {{{0,8}},100}, {{{0,8}},36}, {{{0,9}},168},
|
||||||
|
{{{0,8}},4}, {{{0,8}},132}, {{{0,8}},68}, {{{0,9}},232},
|
||||||
|
{{{80,7}},8}, {{{0,8}},92}, {{{0,8}},28}, {{{0,9}},152},
|
||||||
|
{{{84,7}},83}, {{{0,8}},124}, {{{0,8}},60}, {{{0,9}},216},
|
||||||
|
{{{82,7}},23}, {{{0,8}},108}, {{{0,8}},44}, {{{0,9}},184},
|
||||||
|
{{{0,8}},12}, {{{0,8}},140}, {{{0,8}},76}, {{{0,9}},248},
|
||||||
|
{{{80,7}},3}, {{{0,8}},82}, {{{0,8}},18}, {{{85,8}},163},
|
||||||
|
{{{83,7}},35}, {{{0,8}},114}, {{{0,8}},50}, {{{0,9}},196},
|
||||||
|
{{{81,7}},11}, {{{0,8}},98}, {{{0,8}},34}, {{{0,9}},164},
|
||||||
|
{{{0,8}},2}, {{{0,8}},130}, {{{0,8}},66}, {{{0,9}},228},
|
||||||
|
{{{80,7}},7}, {{{0,8}},90}, {{{0,8}},26}, {{{0,9}},148},
|
||||||
|
{{{84,7}},67}, {{{0,8}},122}, {{{0,8}},58}, {{{0,9}},212},
|
||||||
|
{{{82,7}},19}, {{{0,8}},106}, {{{0,8}},42}, {{{0,9}},180},
|
||||||
|
{{{0,8}},10}, {{{0,8}},138}, {{{0,8}},74}, {{{0,9}},244},
|
||||||
|
{{{80,7}},5}, {{{0,8}},86}, {{{0,8}},22}, {{{192,8}},0},
|
||||||
|
{{{83,7}},51}, {{{0,8}},118}, {{{0,8}},54}, {{{0,9}},204},
|
||||||
|
{{{81,7}},15}, {{{0,8}},102}, {{{0,8}},38}, {{{0,9}},172},
|
||||||
|
{{{0,8}},6}, {{{0,8}},134}, {{{0,8}},70}, {{{0,9}},236},
|
||||||
|
{{{80,7}},9}, {{{0,8}},94}, {{{0,8}},30}, {{{0,9}},156},
|
||||||
|
{{{84,7}},99}, {{{0,8}},126}, {{{0,8}},62}, {{{0,9}},220},
|
||||||
|
{{{82,7}},27}, {{{0,8}},110}, {{{0,8}},46}, {{{0,9}},188},
|
||||||
|
{{{0,8}},14}, {{{0,8}},142}, {{{0,8}},78}, {{{0,9}},252},
|
||||||
|
{{{96,7}},256}, {{{0,8}},81}, {{{0,8}},17}, {{{85,8}},131},
|
||||||
|
{{{82,7}},31}, {{{0,8}},113}, {{{0,8}},49}, {{{0,9}},194},
|
||||||
|
{{{80,7}},10}, {{{0,8}},97}, {{{0,8}},33}, {{{0,9}},162},
|
||||||
|
{{{0,8}},1}, {{{0,8}},129}, {{{0,8}},65}, {{{0,9}},226},
|
||||||
|
{{{80,7}},6}, {{{0,8}},89}, {{{0,8}},25}, {{{0,9}},146},
|
||||||
|
{{{83,7}},59}, {{{0,8}},121}, {{{0,8}},57}, {{{0,9}},210},
|
||||||
|
{{{81,7}},17}, {{{0,8}},105}, {{{0,8}},41}, {{{0,9}},178},
|
||||||
|
{{{0,8}},9}, {{{0,8}},137}, {{{0,8}},73}, {{{0,9}},242},
|
||||||
|
{{{80,7}},4}, {{{0,8}},85}, {{{0,8}},21}, {{{80,8}},258},
|
||||||
|
{{{83,7}},43}, {{{0,8}},117}, {{{0,8}},53}, {{{0,9}},202},
|
||||||
|
{{{81,7}},13}, {{{0,8}},101}, {{{0,8}},37}, {{{0,9}},170},
|
||||||
|
{{{0,8}},5}, {{{0,8}},133}, {{{0,8}},69}, {{{0,9}},234},
|
||||||
|
{{{80,7}},8}, {{{0,8}},93}, {{{0,8}},29}, {{{0,9}},154},
|
||||||
|
{{{84,7}},83}, {{{0,8}},125}, {{{0,8}},61}, {{{0,9}},218},
|
||||||
|
{{{82,7}},23}, {{{0,8}},109}, {{{0,8}},45}, {{{0,9}},186},
|
||||||
|
{{{0,8}},13}, {{{0,8}},141}, {{{0,8}},77}, {{{0,9}},250},
|
||||||
|
{{{80,7}},3}, {{{0,8}},83}, {{{0,8}},19}, {{{85,8}},195},
|
||||||
|
{{{83,7}},35}, {{{0,8}},115}, {{{0,8}},51}, {{{0,9}},198},
|
||||||
|
{{{81,7}},11}, {{{0,8}},99}, {{{0,8}},35}, {{{0,9}},166},
|
||||||
|
{{{0,8}},3}, {{{0,8}},131}, {{{0,8}},67}, {{{0,9}},230},
|
||||||
|
{{{80,7}},7}, {{{0,8}},91}, {{{0,8}},27}, {{{0,9}},150},
|
||||||
|
{{{84,7}},67}, {{{0,8}},123}, {{{0,8}},59}, {{{0,9}},214},
|
||||||
|
{{{82,7}},19}, {{{0,8}},107}, {{{0,8}},43}, {{{0,9}},182},
|
||||||
|
{{{0,8}},11}, {{{0,8}},139}, {{{0,8}},75}, {{{0,9}},246},
|
||||||
|
{{{80,7}},5}, {{{0,8}},87}, {{{0,8}},23}, {{{192,8}},0},
|
||||||
|
{{{83,7}},51}, {{{0,8}},119}, {{{0,8}},55}, {{{0,9}},206},
|
||||||
|
{{{81,7}},15}, {{{0,8}},103}, {{{0,8}},39}, {{{0,9}},174},
|
||||||
|
{{{0,8}},7}, {{{0,8}},135}, {{{0,8}},71}, {{{0,9}},238},
|
||||||
|
{{{80,7}},9}, {{{0,8}},95}, {{{0,8}},31}, {{{0,9}},158},
|
||||||
|
{{{84,7}},99}, {{{0,8}},127}, {{{0,8}},63}, {{{0,9}},222},
|
||||||
|
{{{82,7}},27}, {{{0,8}},111}, {{{0,8}},47}, {{{0,9}},190},
|
||||||
|
{{{0,8}},15}, {{{0,8}},143}, {{{0,8}},79}, {{{0,9}},254},
|
||||||
|
{{{96,7}},256}, {{{0,8}},80}, {{{0,8}},16}, {{{84,8}},115},
|
||||||
|
{{{82,7}},31}, {{{0,8}},112}, {{{0,8}},48}, {{{0,9}},193},
|
||||||
|
{{{80,7}},10}, {{{0,8}},96}, {{{0,8}},32}, {{{0,9}},161},
|
||||||
|
{{{0,8}},0}, {{{0,8}},128}, {{{0,8}},64}, {{{0,9}},225},
|
||||||
|
{{{80,7}},6}, {{{0,8}},88}, {{{0,8}},24}, {{{0,9}},145},
|
||||||
|
{{{83,7}},59}, {{{0,8}},120}, {{{0,8}},56}, {{{0,9}},209},
|
||||||
|
{{{81,7}},17}, {{{0,8}},104}, {{{0,8}},40}, {{{0,9}},177},
|
||||||
|
{{{0,8}},8}, {{{0,8}},136}, {{{0,8}},72}, {{{0,9}},241},
|
||||||
|
{{{80,7}},4}, {{{0,8}},84}, {{{0,8}},20}, {{{85,8}},227},
|
||||||
|
{{{83,7}},43}, {{{0,8}},116}, {{{0,8}},52}, {{{0,9}},201},
|
||||||
|
{{{81,7}},13}, {{{0,8}},100}, {{{0,8}},36}, {{{0,9}},169},
|
||||||
|
{{{0,8}},4}, {{{0,8}},132}, {{{0,8}},68}, {{{0,9}},233},
|
||||||
|
{{{80,7}},8}, {{{0,8}},92}, {{{0,8}},28}, {{{0,9}},153},
|
||||||
|
{{{84,7}},83}, {{{0,8}},124}, {{{0,8}},60}, {{{0,9}},217},
|
||||||
|
{{{82,7}},23}, {{{0,8}},108}, {{{0,8}},44}, {{{0,9}},185},
|
||||||
|
{{{0,8}},12}, {{{0,8}},140}, {{{0,8}},76}, {{{0,9}},249},
|
||||||
|
{{{80,7}},3}, {{{0,8}},82}, {{{0,8}},18}, {{{85,8}},163},
|
||||||
|
{{{83,7}},35}, {{{0,8}},114}, {{{0,8}},50}, {{{0,9}},197},
|
||||||
|
{{{81,7}},11}, {{{0,8}},98}, {{{0,8}},34}, {{{0,9}},165},
|
||||||
|
{{{0,8}},2}, {{{0,8}},130}, {{{0,8}},66}, {{{0,9}},229},
|
||||||
|
{{{80,7}},7}, {{{0,8}},90}, {{{0,8}},26}, {{{0,9}},149},
|
||||||
|
{{{84,7}},67}, {{{0,8}},122}, {{{0,8}},58}, {{{0,9}},213},
|
||||||
|
{{{82,7}},19}, {{{0,8}},106}, {{{0,8}},42}, {{{0,9}},181},
|
||||||
|
{{{0,8}},10}, {{{0,8}},138}, {{{0,8}},74}, {{{0,9}},245},
|
||||||
|
{{{80,7}},5}, {{{0,8}},86}, {{{0,8}},22}, {{{192,8}},0},
|
||||||
|
{{{83,7}},51}, {{{0,8}},118}, {{{0,8}},54}, {{{0,9}},205},
|
||||||
|
{{{81,7}},15}, {{{0,8}},102}, {{{0,8}},38}, {{{0,9}},173},
|
||||||
|
{{{0,8}},6}, {{{0,8}},134}, {{{0,8}},70}, {{{0,9}},237},
|
||||||
|
{{{80,7}},9}, {{{0,8}},94}, {{{0,8}},30}, {{{0,9}},157},
|
||||||
|
{{{84,7}},99}, {{{0,8}},126}, {{{0,8}},62}, {{{0,9}},221},
|
||||||
|
{{{82,7}},27}, {{{0,8}},110}, {{{0,8}},46}, {{{0,9}},189},
|
||||||
|
{{{0,8}},14}, {{{0,8}},142}, {{{0,8}},78}, {{{0,9}},253},
|
||||||
|
{{{96,7}},256}, {{{0,8}},81}, {{{0,8}},17}, {{{85,8}},131},
|
||||||
|
{{{82,7}},31}, {{{0,8}},113}, {{{0,8}},49}, {{{0,9}},195},
|
||||||
|
{{{80,7}},10}, {{{0,8}},97}, {{{0,8}},33}, {{{0,9}},163},
|
||||||
|
{{{0,8}},1}, {{{0,8}},129}, {{{0,8}},65}, {{{0,9}},227},
|
||||||
|
{{{80,7}},6}, {{{0,8}},89}, {{{0,8}},25}, {{{0,9}},147},
|
||||||
|
{{{83,7}},59}, {{{0,8}},121}, {{{0,8}},57}, {{{0,9}},211},
|
||||||
|
{{{81,7}},17}, {{{0,8}},105}, {{{0,8}},41}, {{{0,9}},179},
|
||||||
|
{{{0,8}},9}, {{{0,8}},137}, {{{0,8}},73}, {{{0,9}},243},
|
||||||
|
{{{80,7}},4}, {{{0,8}},85}, {{{0,8}},21}, {{{80,8}},258},
|
||||||
|
{{{83,7}},43}, {{{0,8}},117}, {{{0,8}},53}, {{{0,9}},203},
|
||||||
|
{{{81,7}},13}, {{{0,8}},101}, {{{0,8}},37}, {{{0,9}},171},
|
||||||
|
{{{0,8}},5}, {{{0,8}},133}, {{{0,8}},69}, {{{0,9}},235},
|
||||||
|
{{{80,7}},8}, {{{0,8}},93}, {{{0,8}},29}, {{{0,9}},155},
|
||||||
|
{{{84,7}},83}, {{{0,8}},125}, {{{0,8}},61}, {{{0,9}},219},
|
||||||
|
{{{82,7}},23}, {{{0,8}},109}, {{{0,8}},45}, {{{0,9}},187},
|
||||||
|
{{{0,8}},13}, {{{0,8}},141}, {{{0,8}},77}, {{{0,9}},251},
|
||||||
|
{{{80,7}},3}, {{{0,8}},83}, {{{0,8}},19}, {{{85,8}},195},
|
||||||
|
{{{83,7}},35}, {{{0,8}},115}, {{{0,8}},51}, {{{0,9}},199},
|
||||||
|
{{{81,7}},11}, {{{0,8}},99}, {{{0,8}},35}, {{{0,9}},167},
|
||||||
|
{{{0,8}},3}, {{{0,8}},131}, {{{0,8}},67}, {{{0,9}},231},
|
||||||
|
{{{80,7}},7}, {{{0,8}},91}, {{{0,8}},27}, {{{0,9}},151},
|
||||||
|
{{{84,7}},67}, {{{0,8}},123}, {{{0,8}},59}, {{{0,9}},215},
|
||||||
|
{{{82,7}},19}, {{{0,8}},107}, {{{0,8}},43}, {{{0,9}},183},
|
||||||
|
{{{0,8}},11}, {{{0,8}},139}, {{{0,8}},75}, {{{0,9}},247},
|
||||||
|
{{{80,7}},5}, {{{0,8}},87}, {{{0,8}},23}, {{{192,8}},0},
|
||||||
|
{{{83,7}},51}, {{{0,8}},119}, {{{0,8}},55}, {{{0,9}},207},
|
||||||
|
{{{81,7}},15}, {{{0,8}},103}, {{{0,8}},39}, {{{0,9}},175},
|
||||||
|
{{{0,8}},7}, {{{0,8}},135}, {{{0,8}},71}, {{{0,9}},239},
|
||||||
|
{{{80,7}},9}, {{{0,8}},95}, {{{0,8}},31}, {{{0,9}},159},
|
||||||
|
{{{84,7}},99}, {{{0,8}},127}, {{{0,8}},63}, {{{0,9}},223},
|
||||||
|
{{{82,7}},27}, {{{0,8}},111}, {{{0,8}},47}, {{{0,9}},191},
|
||||||
|
{{{0,8}},15}, {{{0,8}},143}, {{{0,8}},79}, {{{0,9}},255}
|
||||||
|
};
|
||||||
|
local inflate_huft fixed_td[] = {
|
||||||
|
{{{80,5}},1}, {{{87,5}},257}, {{{83,5}},17}, {{{91,5}},4097},
|
||||||
|
{{{81,5}},5}, {{{89,5}},1025}, {{{85,5}},65}, {{{93,5}},16385},
|
||||||
|
{{{80,5}},3}, {{{88,5}},513}, {{{84,5}},33}, {{{92,5}},8193},
|
||||||
|
{{{82,5}},9}, {{{90,5}},2049}, {{{86,5}},129}, {{{192,5}},24577},
|
||||||
|
{{{80,5}},2}, {{{87,5}},385}, {{{83,5}},25}, {{{91,5}},6145},
|
||||||
|
{{{81,5}},7}, {{{89,5}},1537}, {{{85,5}},97}, {{{93,5}},24577},
|
||||||
|
{{{80,5}},4}, {{{88,5}},769}, {{{84,5}},49}, {{{92,5}},12289},
|
||||||
|
{{{82,5}},13}, {{{90,5}},3073}, {{{86,5}},193}, {{{192,5}},24577}
|
||||||
|
};
|
||||||
81
inflate.c
81
inflate.c
@@ -1,5 +1,5 @@
|
|||||||
/* inflate.c -- zlib interface to inflate modules
|
/* inflate.c -- zlib interface to inflate modules
|
||||||
* Copyright (C) 1995-1996 Mark Adler
|
* Copyright (C) 1995-1998 Mark Adler
|
||||||
* For conditions of distribution and use, see copyright notice in zlib.h
|
* For conditions of distribution and use, see copyright notice in zlib.h
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@@ -8,11 +8,7 @@
|
|||||||
|
|
||||||
struct inflate_blocks_state {int dummy;}; /* for buggy compilers */
|
struct inflate_blocks_state {int dummy;}; /* for buggy compilers */
|
||||||
|
|
||||||
/* inflate private state */
|
typedef enum {
|
||||||
struct internal_state {
|
|
||||||
|
|
||||||
/* mode */
|
|
||||||
enum {
|
|
||||||
METHOD, /* waiting for method byte */
|
METHOD, /* waiting for method byte */
|
||||||
FLAG, /* waiting for flag byte */
|
FLAG, /* waiting for flag byte */
|
||||||
DICT4, /* four dictionary check bytes to go */
|
DICT4, /* four dictionary check bytes to go */
|
||||||
@@ -27,7 +23,13 @@ struct internal_state {
|
|||||||
CHECK1, /* one check byte to go */
|
CHECK1, /* one check byte to go */
|
||||||
DONE, /* finished check, done */
|
DONE, /* finished check, done */
|
||||||
BAD} /* got an error--stay here */
|
BAD} /* got an error--stay here */
|
||||||
mode; /* current inflate mode */
|
inflate_mode;
|
||||||
|
|
||||||
|
/* inflate private state */
|
||||||
|
struct internal_state {
|
||||||
|
|
||||||
|
/* mode */
|
||||||
|
inflate_mode mode; /* current inflate mode */
|
||||||
|
|
||||||
/* mode dependent information */
|
/* mode dependent information */
|
||||||
union {
|
union {
|
||||||
@@ -48,39 +50,35 @@ struct internal_state {
|
|||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
int inflateReset(z)
|
int ZEXPORT inflateReset(z)
|
||||||
z_streamp z;
|
z_streamp z;
|
||||||
{
|
{
|
||||||
uLong c;
|
|
||||||
|
|
||||||
if (z == Z_NULL || z->state == Z_NULL)
|
if (z == Z_NULL || z->state == Z_NULL)
|
||||||
return Z_STREAM_ERROR;
|
return Z_STREAM_ERROR;
|
||||||
z->total_in = z->total_out = 0;
|
z->total_in = z->total_out = 0;
|
||||||
z->msg = Z_NULL;
|
z->msg = Z_NULL;
|
||||||
z->state->mode = z->state->nowrap ? BLOCKS : METHOD;
|
z->state->mode = z->state->nowrap ? BLOCKS : METHOD;
|
||||||
inflate_blocks_reset(z->state->blocks, z, &c);
|
inflate_blocks_reset(z->state->blocks, z, Z_NULL);
|
||||||
Trace((stderr, "inflate: reset\n"));
|
Tracev((stderr, "inflate: reset\n"));
|
||||||
return Z_OK;
|
return Z_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int inflateEnd(z)
|
int ZEXPORT inflateEnd(z)
|
||||||
z_streamp z;
|
z_streamp z;
|
||||||
{
|
{
|
||||||
uLong c;
|
|
||||||
|
|
||||||
if (z == Z_NULL || z->state == Z_NULL || z->zfree == Z_NULL)
|
if (z == Z_NULL || z->state == Z_NULL || z->zfree == Z_NULL)
|
||||||
return Z_STREAM_ERROR;
|
return Z_STREAM_ERROR;
|
||||||
if (z->state->blocks != Z_NULL)
|
if (z->state->blocks != Z_NULL)
|
||||||
inflate_blocks_free(z->state->blocks, z, &c);
|
inflate_blocks_free(z->state->blocks, z);
|
||||||
ZFREE(z, z->state);
|
ZFREE(z, z->state);
|
||||||
z->state = Z_NULL;
|
z->state = Z_NULL;
|
||||||
Trace((stderr, "inflate: end\n"));
|
Tracev((stderr, "inflate: end\n"));
|
||||||
return Z_OK;
|
return Z_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int inflateInit2_(z, w, version, stream_size)
|
int ZEXPORT inflateInit2_(z, w, version, stream_size)
|
||||||
z_streamp z;
|
z_streamp z;
|
||||||
int w;
|
int w;
|
||||||
const char *version;
|
const char *version;
|
||||||
@@ -129,7 +127,7 @@ int stream_size;
|
|||||||
inflateEnd(z);
|
inflateEnd(z);
|
||||||
return Z_MEM_ERROR;
|
return Z_MEM_ERROR;
|
||||||
}
|
}
|
||||||
Trace((stderr, "inflate: allocated\n"));
|
Tracev((stderr, "inflate: allocated\n"));
|
||||||
|
|
||||||
/* reset state */
|
/* reset state */
|
||||||
inflateReset(z);
|
inflateReset(z);
|
||||||
@@ -137,7 +135,7 @@ int stream_size;
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int inflateInit_(z, version, stream_size)
|
int ZEXPORT inflateInit_(z, version, stream_size)
|
||||||
z_streamp z;
|
z_streamp z;
|
||||||
const char *version;
|
const char *version;
|
||||||
int stream_size;
|
int stream_size;
|
||||||
@@ -146,18 +144,19 @@ int stream_size;
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#define NEEDBYTE {if(z->avail_in==0)return r;r=Z_OK;}
|
#define NEEDBYTE {if(z->avail_in==0)return r;r=f;}
|
||||||
#define NEXTBYTE (z->avail_in--,z->total_in++,*z->next_in++)
|
#define NEXTBYTE (z->avail_in--,z->total_in++,*z->next_in++)
|
||||||
|
|
||||||
int inflate(z, f)
|
int ZEXPORT inflate(z, f)
|
||||||
z_streamp z;
|
z_streamp z;
|
||||||
int f;
|
int f;
|
||||||
{
|
{
|
||||||
int r;
|
int r;
|
||||||
uInt b;
|
uInt b;
|
||||||
|
|
||||||
if (z == Z_NULL || z->state == Z_NULL || z->next_in == Z_NULL || f < 0)
|
if (z == Z_NULL || z->state == Z_NULL || z->next_in == Z_NULL)
|
||||||
return Z_STREAM_ERROR;
|
return Z_STREAM_ERROR;
|
||||||
|
f = f == Z_FINISH ? Z_BUF_ERROR : Z_OK;
|
||||||
r = Z_BUF_ERROR;
|
r = Z_BUF_ERROR;
|
||||||
while (1) switch (z->state->mode)
|
while (1) switch (z->state->mode)
|
||||||
{
|
{
|
||||||
@@ -188,11 +187,11 @@ int f;
|
|||||||
z->state->sub.marker = 5; /* can't try inflateSync */
|
z->state->sub.marker = 5; /* can't try inflateSync */
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
Trace((stderr, "inflate: zlib header ok\n"));
|
Tracev((stderr, "inflate: zlib header ok\n"));
|
||||||
if (!(b & PRESET_DICT))
|
if (!(b & PRESET_DICT))
|
||||||
{
|
{
|
||||||
z->state->mode = BLOCKS;
|
z->state->mode = BLOCKS;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
z->state->mode = DICT4;
|
z->state->mode = DICT4;
|
||||||
case DICT4:
|
case DICT4:
|
||||||
@@ -226,9 +225,11 @@ int f;
|
|||||||
z->state->sub.marker = 0; /* can try inflateSync */
|
z->state->sub.marker = 0; /* can try inflateSync */
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
if (r == Z_OK)
|
||||||
|
r = f;
|
||||||
if (r != Z_STREAM_END)
|
if (r != Z_STREAM_END)
|
||||||
return r;
|
return r;
|
||||||
r = Z_OK;
|
r = f;
|
||||||
inflate_blocks_reset(z->state->blocks, z, &z->state->sub.check.was);
|
inflate_blocks_reset(z->state->blocks, z, &z->state->sub.check.was);
|
||||||
if (z->state->nowrap)
|
if (z->state->nowrap)
|
||||||
{
|
{
|
||||||
@@ -259,7 +260,7 @@ int f;
|
|||||||
z->state->sub.marker = 5; /* can't try inflateSync */
|
z->state->sub.marker = 5; /* can't try inflateSync */
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
Trace((stderr, "inflate: zlib check ok\n"));
|
Tracev((stderr, "inflate: zlib check ok\n"));
|
||||||
z->state->mode = DONE;
|
z->state->mode = DONE;
|
||||||
case DONE:
|
case DONE:
|
||||||
return Z_STREAM_END;
|
return Z_STREAM_END;
|
||||||
@@ -268,10 +269,13 @@ int f;
|
|||||||
default:
|
default:
|
||||||
return Z_STREAM_ERROR;
|
return Z_STREAM_ERROR;
|
||||||
}
|
}
|
||||||
|
#ifdef NEED_DUMMY_RETURN
|
||||||
|
return Z_STREAM_ERROR; /* Some dumb compilers complain without this */
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int inflateSetDictionary(z, dictionary, dictLength)
|
int ZEXPORT inflateSetDictionary(z, dictionary, dictLength)
|
||||||
z_streamp z;
|
z_streamp z;
|
||||||
const Bytef *dictionary;
|
const Bytef *dictionary;
|
||||||
uInt dictLength;
|
uInt dictLength;
|
||||||
@@ -295,7 +299,7 @@ uInt dictLength;
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int inflateSync(z)
|
int ZEXPORT inflateSync(z)
|
||||||
z_streamp z;
|
z_streamp z;
|
||||||
{
|
{
|
||||||
uInt n; /* number of bytes to look at */
|
uInt n; /* number of bytes to look at */
|
||||||
@@ -319,7 +323,8 @@ z_streamp z;
|
|||||||
/* search */
|
/* search */
|
||||||
while (n && m < 4)
|
while (n && m < 4)
|
||||||
{
|
{
|
||||||
if (*p == (Byte)(m < 2 ? 0 : 0xff))
|
static const Byte mark[4] = {0, 0, 0xff, 0xff};
|
||||||
|
if (*p == mark[m])
|
||||||
m++;
|
m++;
|
||||||
else if (*p)
|
else if (*p)
|
||||||
m = 0;
|
m = 0;
|
||||||
@@ -343,3 +348,19 @@ z_streamp z;
|
|||||||
z->state->mode = BLOCKS;
|
z->state->mode = BLOCKS;
|
||||||
return Z_OK;
|
return Z_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* Returns true if inflate is currently at the end of a block generated
|
||||||
|
* by Z_SYNC_FLUSH or Z_FULL_FLUSH. This function is used by one PPP
|
||||||
|
* implementation to provide an additional safety check. PPP uses Z_SYNC_FLUSH
|
||||||
|
* but removes the length bytes of the resulting empty stored block. When
|
||||||
|
* decompressing, PPP checks that at the end of input packet, inflate is
|
||||||
|
* waiting for these length bytes.
|
||||||
|
*/
|
||||||
|
int ZEXPORT inflateSyncPoint(z)
|
||||||
|
z_streamp z;
|
||||||
|
{
|
||||||
|
if (z == Z_NULL || z->state == Z_NULL || z->state->blocks == Z_NULL)
|
||||||
|
return Z_STREAM_ERROR;
|
||||||
|
return inflate_blocks_sync_point(z->state->blocks);
|
||||||
|
}
|
||||||
|
|||||||
221
inftrees.c
221
inftrees.c
@@ -1,12 +1,17 @@
|
|||||||
/* inftrees.c -- generate Huffman trees for efficient decoding
|
/* inftrees.c -- generate Huffman trees for efficient decoding
|
||||||
* Copyright (C) 1995-1996 Mark Adler
|
* Copyright (C) 1995-1998 Mark Adler
|
||||||
* For conditions of distribution and use, see copyright notice in zlib.h
|
* For conditions of distribution and use, see copyright notice in zlib.h
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "zutil.h"
|
#include "zutil.h"
|
||||||
#include "inftrees.h"
|
#include "inftrees.h"
|
||||||
|
|
||||||
char inflate_copyright[] = " inflate 1.0.4 Copyright 1995-1996 Mark Adler ";
|
#if !defined(BUILDFIXED) && !defined(STDC)
|
||||||
|
# define BUILDFIXED /* non ANSI compilers may not accept inffixed.h */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
const char inflate_copyright[] =
|
||||||
|
" inflate 1.1.3 Copyright 1995-1998 Mark Adler ";
|
||||||
/*
|
/*
|
||||||
If you use the zlib library in a product, an acknowledgment is welcome
|
If you use the zlib library in a product, an acknowledgment is welcome
|
||||||
in the documentation of your product. If for some reason you cannot
|
in the documentation of your product. If for some reason you cannot
|
||||||
@@ -16,8 +21,6 @@ char inflate_copyright[] = " inflate 1.0.4 Copyright 1995-1996 Mark Adler ";
|
|||||||
struct internal_state {int dummy;}; /* for buggy compilers */
|
struct internal_state {int dummy;}; /* for buggy compilers */
|
||||||
|
|
||||||
/* simplify the use of the inflate_huft type with some defines */
|
/* simplify the use of the inflate_huft type with some defines */
|
||||||
#define base more.Base
|
|
||||||
#define next more.Next
|
|
||||||
#define exop word.what.Exop
|
#define exop word.what.Exop
|
||||||
#define bits word.what.Bits
|
#define bits word.what.Bits
|
||||||
|
|
||||||
@@ -26,30 +29,27 @@ local int huft_build OF((
|
|||||||
uIntf *, /* code lengths in bits */
|
uIntf *, /* code lengths in bits */
|
||||||
uInt, /* number of codes */
|
uInt, /* number of codes */
|
||||||
uInt, /* number of "simple" codes */
|
uInt, /* number of "simple" codes */
|
||||||
uIntf *, /* list of base values for non-simple codes */
|
const uIntf *, /* list of base values for non-simple codes */
|
||||||
uIntf *, /* list of extra bits for non-simple codes */
|
const uIntf *, /* list of extra bits for non-simple codes */
|
||||||
inflate_huft * FAR*,/* result: starting table */
|
inflate_huft * FAR*,/* result: starting table */
|
||||||
uIntf *, /* maximum lookup bits (returns actual) */
|
uIntf *, /* maximum lookup bits (returns actual) */
|
||||||
z_streamp )); /* for zalloc function */
|
inflate_huft *, /* space for trees */
|
||||||
|
uInt *, /* hufts used in space */
|
||||||
local voidpf falloc OF((
|
uIntf * )); /* space for values */
|
||||||
voidpf, /* opaque pointer (not used) */
|
|
||||||
uInt, /* number of items */
|
|
||||||
uInt)); /* size of item */
|
|
||||||
|
|
||||||
/* Tables for deflate from PKZIP's appnote.txt. */
|
/* Tables for deflate from PKZIP's appnote.txt. */
|
||||||
local uInt cplens[31] = { /* Copy lengths for literal codes 257..285 */
|
local const uInt cplens[31] = { /* Copy lengths for literal codes 257..285 */
|
||||||
3, 4, 5, 6, 7, 8, 9, 10, 11, 13, 15, 17, 19, 23, 27, 31,
|
3, 4, 5, 6, 7, 8, 9, 10, 11, 13, 15, 17, 19, 23, 27, 31,
|
||||||
35, 43, 51, 59, 67, 83, 99, 115, 131, 163, 195, 227, 258, 0, 0};
|
35, 43, 51, 59, 67, 83, 99, 115, 131, 163, 195, 227, 258, 0, 0};
|
||||||
/* actually lengths - 2; also see note #13 above about 258 */
|
/* see note #13 above about 258 */
|
||||||
local uInt cplext[31] = { /* Extra bits for literal codes 257..285 */
|
local const uInt cplext[31] = { /* Extra bits for literal codes 257..285 */
|
||||||
0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 2, 2, 2, 2,
|
0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 2, 2, 2, 2,
|
||||||
3, 3, 3, 3, 4, 4, 4, 4, 5, 5, 5, 5, 0, 192, 192}; /* 192==invalid */
|
3, 3, 3, 3, 4, 4, 4, 4, 5, 5, 5, 5, 0, 112, 112}; /* 112==invalid */
|
||||||
local uInt cpdist[30] = { /* Copy offsets for distance codes 0..29 */
|
local const uInt cpdist[30] = { /* Copy offsets for distance codes 0..29 */
|
||||||
1, 2, 3, 4, 5, 7, 9, 13, 17, 25, 33, 49, 65, 97, 129, 193,
|
1, 2, 3, 4, 5, 7, 9, 13, 17, 25, 33, 49, 65, 97, 129, 193,
|
||||||
257, 385, 513, 769, 1025, 1537, 2049, 3073, 4097, 6145,
|
257, 385, 513, 769, 1025, 1537, 2049, 3073, 4097, 6145,
|
||||||
8193, 12289, 16385, 24577};
|
8193, 12289, 16385, 24577};
|
||||||
local uInt cpdext[30] = { /* Extra bits for distance codes */
|
local const uInt cpdext[30] = { /* Extra bits for distance codes */
|
||||||
0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6,
|
0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6,
|
||||||
7, 7, 8, 8, 9, 9, 10, 10, 11, 11,
|
7, 7, 8, 8, 9, 9, 10, 10, 11, 11,
|
||||||
12, 12, 13, 13};
|
12, 12, 13, 13};
|
||||||
@@ -89,26 +89,23 @@ local uInt cpdext[30] = { /* Extra bits for distance codes */
|
|||||||
|
|
||||||
/* If BMAX needs to be larger than 16, then h and x[] should be uLong. */
|
/* If BMAX needs to be larger than 16, then h and x[] should be uLong. */
|
||||||
#define BMAX 15 /* maximum bit length of any code */
|
#define BMAX 15 /* maximum bit length of any code */
|
||||||
#define N_MAX 288 /* maximum number of codes in any set */
|
|
||||||
|
|
||||||
#ifdef DEBUG
|
local int huft_build(b, n, s, d, e, t, m, hp, hn, v)
|
||||||
uInt inflate_hufts;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
local int huft_build(b, n, s, d, e, t, m, zs)
|
|
||||||
uIntf *b; /* code lengths in bits (all assumed <= BMAX) */
|
uIntf *b; /* code lengths in bits (all assumed <= BMAX) */
|
||||||
uInt n; /* number of codes (assumed <= N_MAX) */
|
uInt n; /* number of codes (assumed <= 288) */
|
||||||
uInt s; /* number of simple-valued codes (0..s-1) */
|
uInt s; /* number of simple-valued codes (0..s-1) */
|
||||||
uIntf *d; /* list of base values for non-simple codes */
|
const uIntf *d; /* list of base values for non-simple codes */
|
||||||
uIntf *e; /* list of extra bits for non-simple codes */
|
const uIntf *e; /* list of extra bits for non-simple codes */
|
||||||
inflate_huft * FAR *t; /* result: starting table */
|
inflate_huft * FAR *t; /* result: starting table */
|
||||||
uIntf *m; /* maximum lookup bits, returns actual */
|
uIntf *m; /* maximum lookup bits, returns actual */
|
||||||
z_streamp zs; /* for zalloc function */
|
inflate_huft *hp; /* space for trees */
|
||||||
|
uInt *hn; /* hufts used in space */
|
||||||
|
uIntf *v; /* working area: values in order of bit length */
|
||||||
/* Given a list of code lengths and a maximum table size, make a set of
|
/* Given a list of code lengths and a maximum table size, make a set of
|
||||||
tables to decode that set of codes. Return Z_OK on success, Z_BUF_ERROR
|
tables to decode that set of codes. Return Z_OK on success, Z_BUF_ERROR
|
||||||
if the given code set is incomplete (the tables are still built in this
|
if the given code set is incomplete (the tables are still built in this
|
||||||
case), Z_DATA_ERROR if the input is invalid (all zero length codes or an
|
case), Z_DATA_ERROR if the input is invalid (an over-subscribed set of
|
||||||
over-subscribed set of lengths), or Z_MEM_ERROR if not enough memory. */
|
lengths), or Z_MEM_ERROR if not enough memory. */
|
||||||
{
|
{
|
||||||
|
|
||||||
uInt a; /* counter for codes of length k */
|
uInt a; /* counter for codes of length k */
|
||||||
@@ -120,11 +117,11 @@ z_streamp zs; /* for zalloc function */
|
|||||||
register uInt j; /* counter */
|
register uInt j; /* counter */
|
||||||
register int k; /* number of bits in current code */
|
register int k; /* number of bits in current code */
|
||||||
int l; /* bits per table (returned in m) */
|
int l; /* bits per table (returned in m) */
|
||||||
|
uInt mask; /* (1 << w) - 1, to avoid cc -O bug on HP */
|
||||||
register uIntf *p; /* pointer into c[], b[], or v[] */
|
register uIntf *p; /* pointer into c[], b[], or v[] */
|
||||||
inflate_huft *q; /* points to current table */
|
inflate_huft *q; /* points to current table */
|
||||||
struct inflate_huft_s r; /* table entry for structure assignment */
|
struct inflate_huft_s r; /* table entry for structure assignment */
|
||||||
inflate_huft *u[BMAX]; /* table stack */
|
inflate_huft *u[BMAX]; /* table stack */
|
||||||
uInt v[N_MAX]; /* values in order of bit length */
|
|
||||||
register int w; /* bits before this table == (l * h) */
|
register int w; /* bits before this table == (l * h) */
|
||||||
uInt x[BMAX+1]; /* bit offsets, then code stack */
|
uInt x[BMAX+1]; /* bit offsets, then code stack */
|
||||||
uIntf *xp; /* pointer into x */
|
uIntf *xp; /* pointer into x */
|
||||||
@@ -190,6 +187,7 @@ z_streamp zs; /* for zalloc function */
|
|||||||
if ((j = *p++) != 0)
|
if ((j = *p++) != 0)
|
||||||
v[x[j]++] = i;
|
v[x[j]++] = i;
|
||||||
} while (++i < n);
|
} while (++i < n);
|
||||||
|
n = x[g]; /* set n to length of v */
|
||||||
|
|
||||||
|
|
||||||
/* Generate the Huffman codes and for each, make the table entries */
|
/* Generate the Huffman codes and for each, make the table entries */
|
||||||
@@ -231,20 +229,11 @@ z_streamp zs; /* for zalloc function */
|
|||||||
}
|
}
|
||||||
z = 1 << j; /* table entries for j-bit table */
|
z = 1 << j; /* table entries for j-bit table */
|
||||||
|
|
||||||
/* allocate and link in new table */
|
/* allocate new table */
|
||||||
if ((q = (inflate_huft *)ZALLOC
|
if (*hn + z > MANY) /* (note: doesn't matter for fixed) */
|
||||||
(zs,z + 1,sizeof(inflate_huft))) == Z_NULL)
|
|
||||||
{
|
|
||||||
if (h)
|
|
||||||
inflate_trees_free(u[0], zs);
|
|
||||||
return Z_MEM_ERROR; /* not enough memory */
|
return Z_MEM_ERROR; /* not enough memory */
|
||||||
}
|
u[h] = q = hp + *hn;
|
||||||
#ifdef DEBUG
|
*hn += z;
|
||||||
inflate_hufts += z + 1;
|
|
||||||
#endif
|
|
||||||
*t = q + 1; /* link to list for huft_free() */
|
|
||||||
*(t = &(q->next)) = Z_NULL;
|
|
||||||
u[h] = ++q; /* table starts after link */
|
|
||||||
|
|
||||||
/* connect to last table, if there is one */
|
/* connect to last table, if there is one */
|
||||||
if (h)
|
if (h)
|
||||||
@@ -252,10 +241,12 @@ z_streamp zs; /* for zalloc function */
|
|||||||
x[h] = i; /* save pattern for backing up */
|
x[h] = i; /* save pattern for backing up */
|
||||||
r.bits = (Byte)l; /* bits to dump before this table */
|
r.bits = (Byte)l; /* bits to dump before this table */
|
||||||
r.exop = (Byte)j; /* bits in this table */
|
r.exop = (Byte)j; /* bits in this table */
|
||||||
r.next = q; /* pointer to this table */
|
j = i >> (w - l);
|
||||||
j = i >> (w - l); /* (get around Turbo C bug) */
|
r.base = (uInt)(q - u[h-1] - j); /* offset to this table */
|
||||||
u[h-1][j] = r; /* connect to last table */
|
u[h-1][j] = r; /* connect to last table */
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
*t = q; /* first table is returned result */
|
||||||
}
|
}
|
||||||
|
|
||||||
/* set up table entry in r */
|
/* set up table entry in r */
|
||||||
@@ -284,10 +275,12 @@ z_streamp zs; /* for zalloc function */
|
|||||||
i ^= j;
|
i ^= j;
|
||||||
|
|
||||||
/* backup over finished tables */
|
/* backup over finished tables */
|
||||||
while ((i & ((1 << w) - 1)) != x[h])
|
mask = (1 << w) - 1; /* needed on HP, cc -O bug */
|
||||||
|
while ((i & mask) != x[h])
|
||||||
{
|
{
|
||||||
h--; /* don't need to update q */
|
h--; /* don't need to update q */
|
||||||
w -= l;
|
w -= l;
|
||||||
|
mask = (1 << w) - 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -298,28 +291,34 @@ z_streamp zs; /* for zalloc function */
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int inflate_trees_bits(c, bb, tb, z)
|
int inflate_trees_bits(c, bb, tb, hp, z)
|
||||||
uIntf *c; /* 19 code lengths */
|
uIntf *c; /* 19 code lengths */
|
||||||
uIntf *bb; /* bits tree desired/actual depth */
|
uIntf *bb; /* bits tree desired/actual depth */
|
||||||
inflate_huft * FAR *tb; /* bits tree result */
|
inflate_huft * FAR *tb; /* bits tree result */
|
||||||
z_streamp z; /* for zfree function */
|
inflate_huft *hp; /* space for trees */
|
||||||
|
z_streamp z; /* for messages */
|
||||||
{
|
{
|
||||||
int r;
|
int r;
|
||||||
|
uInt hn = 0; /* hufts used in space */
|
||||||
|
uIntf *v; /* work area for huft_build */
|
||||||
|
|
||||||
r = huft_build(c, 19, 19, (uIntf*)Z_NULL, (uIntf*)Z_NULL, tb, bb, z);
|
if ((v = (uIntf*)ZALLOC(z, 19, sizeof(uInt))) == Z_NULL)
|
||||||
|
return Z_MEM_ERROR;
|
||||||
|
r = huft_build(c, 19, 19, (uIntf*)Z_NULL, (uIntf*)Z_NULL,
|
||||||
|
tb, bb, hp, &hn, v);
|
||||||
if (r == Z_DATA_ERROR)
|
if (r == Z_DATA_ERROR)
|
||||||
z->msg = (char*)"oversubscribed dynamic bit lengths tree";
|
z->msg = (char*)"oversubscribed dynamic bit lengths tree";
|
||||||
else if (r == Z_BUF_ERROR)
|
else if (r == Z_BUF_ERROR || *bb == 0)
|
||||||
{
|
{
|
||||||
inflate_trees_free(*tb, z);
|
|
||||||
z->msg = (char*)"incomplete dynamic bit lengths tree";
|
z->msg = (char*)"incomplete dynamic bit lengths tree";
|
||||||
r = Z_DATA_ERROR;
|
r = Z_DATA_ERROR;
|
||||||
}
|
}
|
||||||
|
ZFREE(z, v);
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int inflate_trees_dynamic(nl, nd, c, bl, bd, tl, td, z)
|
int inflate_trees_dynamic(nl, nd, c, bl, bd, tl, td, hp, z)
|
||||||
uInt nl; /* number of literal/length codes */
|
uInt nl; /* number of literal/length codes */
|
||||||
uInt nd; /* number of distance codes */
|
uInt nd; /* number of distance codes */
|
||||||
uIntf *c; /* that many (total) code lengths */
|
uIntf *c; /* that many (total) code lengths */
|
||||||
@@ -327,88 +326,100 @@ uIntf *bl; /* literal desired/actual bit depth */
|
|||||||
uIntf *bd; /* distance desired/actual bit depth */
|
uIntf *bd; /* distance desired/actual bit depth */
|
||||||
inflate_huft * FAR *tl; /* literal/length tree result */
|
inflate_huft * FAR *tl; /* literal/length tree result */
|
||||||
inflate_huft * FAR *td; /* distance tree result */
|
inflate_huft * FAR *td; /* distance tree result */
|
||||||
z_streamp z; /* for zfree function */
|
inflate_huft *hp; /* space for trees */
|
||||||
|
z_streamp z; /* for messages */
|
||||||
{
|
{
|
||||||
int r;
|
int r;
|
||||||
|
uInt hn = 0; /* hufts used in space */
|
||||||
|
uIntf *v; /* work area for huft_build */
|
||||||
|
|
||||||
|
/* allocate work area */
|
||||||
|
if ((v = (uIntf*)ZALLOC(z, 288, sizeof(uInt))) == Z_NULL)
|
||||||
|
return Z_MEM_ERROR;
|
||||||
|
|
||||||
/* build literal/length tree */
|
/* build literal/length tree */
|
||||||
if ((r = huft_build(c, nl, 257, cplens, cplext, tl, bl, z)) != Z_OK)
|
r = huft_build(c, nl, 257, cplens, cplext, tl, bl, hp, &hn, v);
|
||||||
|
if (r != Z_OK || *bl == 0)
|
||||||
{
|
{
|
||||||
if (r == Z_DATA_ERROR)
|
if (r == Z_DATA_ERROR)
|
||||||
z->msg = (char*)"oversubscribed literal/length tree";
|
z->msg = (char*)"oversubscribed literal/length tree";
|
||||||
else if (r == Z_BUF_ERROR)
|
else if (r != Z_MEM_ERROR)
|
||||||
{
|
{
|
||||||
inflate_trees_free(*tl, z);
|
|
||||||
z->msg = (char*)"incomplete literal/length tree";
|
z->msg = (char*)"incomplete literal/length tree";
|
||||||
r = Z_DATA_ERROR;
|
r = Z_DATA_ERROR;
|
||||||
}
|
}
|
||||||
|
ZFREE(z, v);
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* build distance tree */
|
/* build distance tree */
|
||||||
if ((r = huft_build(c + nl, nd, 0, cpdist, cpdext, td, bd, z)) != Z_OK)
|
r = huft_build(c + nl, nd, 0, cpdist, cpdext, td, bd, hp, &hn, v);
|
||||||
|
if (r != Z_OK || (*bd == 0 && nl > 257))
|
||||||
{
|
{
|
||||||
if (r == Z_DATA_ERROR)
|
if (r == Z_DATA_ERROR)
|
||||||
z->msg = (char*)"oversubscribed literal/length tree";
|
z->msg = (char*)"oversubscribed distance tree";
|
||||||
else if (r == Z_BUF_ERROR) {
|
else if (r == Z_BUF_ERROR) {
|
||||||
#ifdef PKZIP_BUG_WORKAROUND
|
#ifdef PKZIP_BUG_WORKAROUND
|
||||||
r = Z_OK;
|
r = Z_OK;
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
inflate_trees_free(*td, z);
|
z->msg = (char*)"incomplete distance tree";
|
||||||
z->msg = (char*)"incomplete literal/length tree";
|
|
||||||
r = Z_DATA_ERROR;
|
r = Z_DATA_ERROR;
|
||||||
}
|
}
|
||||||
inflate_trees_free(*tl, z);
|
else if (r != Z_MEM_ERROR)
|
||||||
|
{
|
||||||
|
z->msg = (char*)"empty distance tree with lengths";
|
||||||
|
r = Z_DATA_ERROR;
|
||||||
|
}
|
||||||
|
ZFREE(z, v);
|
||||||
return r;
|
return r;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
/* done */
|
/* done */
|
||||||
|
ZFREE(z, v);
|
||||||
return Z_OK;
|
return Z_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* build fixed tables only once--keep them here */
|
/* build fixed tables only once--keep them here */
|
||||||
|
#ifdef BUILDFIXED
|
||||||
local int fixed_built = 0;
|
local int fixed_built = 0;
|
||||||
#define FIXEDH 530 /* number of hufts used by fixed tables */
|
#define FIXEDH 544 /* number of hufts used by fixed tables */
|
||||||
local inflate_huft fixed_mem[FIXEDH];
|
local inflate_huft fixed_mem[FIXEDH];
|
||||||
local uInt fixed_bl;
|
local uInt fixed_bl;
|
||||||
local uInt fixed_bd;
|
local uInt fixed_bd;
|
||||||
local inflate_huft *fixed_tl;
|
local inflate_huft *fixed_tl;
|
||||||
local inflate_huft *fixed_td;
|
local inflate_huft *fixed_td;
|
||||||
|
#else
|
||||||
|
#include "inffixed.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
local voidpf falloc(q, n, s)
|
int inflate_trees_fixed(bl, bd, tl, td, z)
|
||||||
voidpf q; /* opaque pointer */
|
|
||||||
uInt n; /* number of items */
|
|
||||||
uInt s; /* size of item */
|
|
||||||
{
|
|
||||||
Assert(s == sizeof(inflate_huft) && n <= *(intf *)q,
|
|
||||||
"inflate_trees falloc overflow");
|
|
||||||
*(intf *)q -= n+s-s; /* s-s to avoid warning */
|
|
||||||
return (voidpf)(fixed_mem + *(intf *)q);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
int inflate_trees_fixed(bl, bd, tl, td)
|
|
||||||
uIntf *bl; /* literal desired/actual bit depth */
|
uIntf *bl; /* literal desired/actual bit depth */
|
||||||
uIntf *bd; /* distance desired/actual bit depth */
|
uIntf *bd; /* distance desired/actual bit depth */
|
||||||
inflate_huft * FAR *tl; /* literal/length tree result */
|
inflate_huft * FAR *tl; /* literal/length tree result */
|
||||||
inflate_huft * FAR *td; /* distance tree result */
|
inflate_huft * FAR *td; /* distance tree result */
|
||||||
|
z_streamp z; /* for memory allocation */
|
||||||
{
|
{
|
||||||
/* build fixed tables if not already (multiple overlapped executions ok) */
|
#ifdef BUILDFIXED
|
||||||
|
/* build fixed tables if not already */
|
||||||
if (!fixed_built)
|
if (!fixed_built)
|
||||||
{
|
{
|
||||||
int k; /* temporary variable */
|
int k; /* temporary variable */
|
||||||
unsigned c[288]; /* length list for huft_build */
|
uInt f = 0; /* number of hufts used in fixed_mem */
|
||||||
z_stream z; /* for falloc function */
|
uIntf *c; /* length list for huft_build */
|
||||||
int f = FIXEDH; /* number of hufts left in fixed_mem */
|
uIntf *v; /* work area for huft_build */
|
||||||
|
|
||||||
/* set up fake z_stream for memory routines */
|
/* allocate memory */
|
||||||
z.zalloc = falloc;
|
if ((c = (uIntf*)ZALLOC(z, 288, sizeof(uInt))) == Z_NULL)
|
||||||
z.zfree = Z_NULL;
|
return Z_MEM_ERROR;
|
||||||
z.opaque = (voidpf)&f;
|
if ((v = (uIntf*)ZALLOC(z, 288, sizeof(uInt))) == Z_NULL)
|
||||||
|
{
|
||||||
|
ZFREE(z, c);
|
||||||
|
return Z_MEM_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
/* literal table */
|
/* literal table */
|
||||||
for (k = 0; k < 144; k++)
|
for (k = 0; k < 144; k++)
|
||||||
@@ -419,52 +430,26 @@ inflate_huft * FAR *td; /* distance tree result */
|
|||||||
c[k] = 7;
|
c[k] = 7;
|
||||||
for (; k < 288; k++)
|
for (; k < 288; k++)
|
||||||
c[k] = 8;
|
c[k] = 8;
|
||||||
fixed_bl = 7;
|
fixed_bl = 9;
|
||||||
huft_build(c, 288, 257, cplens, cplext, &fixed_tl, &fixed_bl, &z);
|
huft_build(c, 288, 257, cplens, cplext, &fixed_tl, &fixed_bl,
|
||||||
|
fixed_mem, &f, v);
|
||||||
|
|
||||||
/* distance table */
|
/* distance table */
|
||||||
for (k = 0; k < 30; k++)
|
for (k = 0; k < 30; k++)
|
||||||
c[k] = 5;
|
c[k] = 5;
|
||||||
fixed_bd = 5;
|
fixed_bd = 5;
|
||||||
huft_build(c, 30, 0, cpdist, cpdext, &fixed_td, &fixed_bd, &z);
|
huft_build(c, 30, 0, cpdist, cpdext, &fixed_td, &fixed_bd,
|
||||||
|
fixed_mem, &f, v);
|
||||||
|
|
||||||
/* done */
|
/* done */
|
||||||
Assert(f == 0, "invalid build of fixed tables");
|
ZFREE(z, v);
|
||||||
|
ZFREE(z, c);
|
||||||
fixed_built = 1;
|
fixed_built = 1;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
*bl = fixed_bl;
|
*bl = fixed_bl;
|
||||||
*bd = fixed_bd;
|
*bd = fixed_bd;
|
||||||
*tl = fixed_tl;
|
*tl = fixed_tl;
|
||||||
*td = fixed_td;
|
*td = fixed_td;
|
||||||
return Z_OK;
|
return Z_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int inflate_trees_free(t, z)
|
|
||||||
inflate_huft *t; /* table to free */
|
|
||||||
z_streamp z; /* for zfree function */
|
|
||||||
/* 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. */
|
|
||||||
{
|
|
||||||
register inflate_huft *p, *q, *r;
|
|
||||||
|
|
||||||
/* Reverse linked list */
|
|
||||||
p = Z_NULL;
|
|
||||||
q = t;
|
|
||||||
while (q != Z_NULL)
|
|
||||||
{
|
|
||||||
r = (q - 1)->next;
|
|
||||||
(q - 1)->next = p;
|
|
||||||
p = q;
|
|
||||||
q = r;
|
|
||||||
}
|
|
||||||
/* Go through linked list, freeing from the malloced (t[-1]) address. */
|
|
||||||
while (p != Z_NULL)
|
|
||||||
{
|
|
||||||
q = (--p)->next;
|
|
||||||
ZFREE(z,p);
|
|
||||||
p = q;
|
|
||||||
}
|
|
||||||
return Z_OK;
|
|
||||||
}
|
|
||||||
|
|||||||
35
inftrees.h
35
inftrees.h
@@ -1,5 +1,5 @@
|
|||||||
/* inftrees.h -- header to use inftrees.c
|
/* inftrees.h -- header to use inftrees.c
|
||||||
* Copyright (C) 1995-1996 Mark Adler
|
* Copyright (C) 1995-1998 Mark Adler
|
||||||
* For conditions of distribution and use, see copyright notice in zlib.h
|
* For conditions of distribution and use, see copyright notice in zlib.h
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@@ -19,23 +19,25 @@ struct inflate_huft_s {
|
|||||||
Byte Exop; /* number of extra bits or operation */
|
Byte Exop; /* number of extra bits or operation */
|
||||||
Byte Bits; /* number of bits in this code or subcode */
|
Byte Bits; /* number of bits in this code or subcode */
|
||||||
} what;
|
} what;
|
||||||
Bytef *pad; /* pad structure to a power of 2 (4 bytes for */
|
uInt pad; /* pad structure to a power of 2 (4 bytes for */
|
||||||
} word; /* 16-bit, 8 bytes for 32-bit machines) */
|
} word; /* 16-bit, 8 bytes for 32-bit int's) */
|
||||||
union {
|
uInt base; /* literal, length base, distance base,
|
||||||
uInt Base; /* literal, length base, or distance base */
|
or table offset */
|
||||||
inflate_huft *Next; /* pointer to next level of table */
|
|
||||||
} more;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#ifdef DEBUG
|
/* Maximum size of dynamic tree. The maximum found in a long but non-
|
||||||
extern uInt inflate_hufts;
|
exhaustive search was 1004 huft structures (850 for length/literals
|
||||||
#endif
|
and 154 for distances, the latter actually the result of an
|
||||||
|
exhaustive search). The actual maximum is not known, but the
|
||||||
|
value below is more than safe. */
|
||||||
|
#define MANY 1440
|
||||||
|
|
||||||
extern int inflate_trees_bits OF((
|
extern int inflate_trees_bits OF((
|
||||||
uIntf *, /* 19 code lengths */
|
uIntf *, /* 19 code lengths */
|
||||||
uIntf *, /* bits tree desired/actual depth */
|
uIntf *, /* bits tree desired/actual depth */
|
||||||
inflate_huft * FAR *, /* bits tree result */
|
inflate_huft * FAR *, /* bits tree result */
|
||||||
z_streamp )); /* for zalloc, zfree functions */
|
inflate_huft *, /* space for trees */
|
||||||
|
z_streamp)); /* for messages */
|
||||||
|
|
||||||
extern int inflate_trees_dynamic OF((
|
extern int inflate_trees_dynamic OF((
|
||||||
uInt, /* number of literal/length codes */
|
uInt, /* number of literal/length codes */
|
||||||
@@ -45,15 +47,12 @@ extern int inflate_trees_dynamic OF((
|
|||||||
uIntf *, /* distance desired/actual bit depth */
|
uIntf *, /* distance desired/actual bit depth */
|
||||||
inflate_huft * FAR *, /* literal/length tree result */
|
inflate_huft * FAR *, /* literal/length tree result */
|
||||||
inflate_huft * FAR *, /* distance tree result */
|
inflate_huft * FAR *, /* distance tree result */
|
||||||
z_streamp )); /* for zalloc, zfree functions */
|
inflate_huft *, /* space for trees */
|
||||||
|
z_streamp)); /* for messages */
|
||||||
|
|
||||||
extern int inflate_trees_fixed OF((
|
extern int inflate_trees_fixed OF((
|
||||||
uIntf *, /* literal desired/actual bit depth */
|
uIntf *, /* literal desired/actual bit depth */
|
||||||
uIntf *, /* distance desired/actual bit depth */
|
uIntf *, /* distance desired/actual bit depth */
|
||||||
inflate_huft * FAR *, /* literal/length tree result */
|
inflate_huft * FAR *, /* literal/length tree result */
|
||||||
inflate_huft * FAR *)); /* distance tree result */
|
inflate_huft * FAR *, /* distance tree result */
|
||||||
|
z_streamp)); /* for memory allocation */
|
||||||
extern int inflate_trees_free OF((
|
|
||||||
inflate_huft *, /* tables to free */
|
|
||||||
z_streamp )); /* for zfree function */
|
|
||||||
|
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
/* inflate_util.c -- data and routines common to blocks and codes
|
/* inflate_util.c -- data and routines common to blocks and codes
|
||||||
* Copyright (C) 1995-1996 Mark Adler
|
* Copyright (C) 1995-1998 Mark Adler
|
||||||
* For conditions of distribution and use, see copyright notice in zlib.h
|
* For conditions of distribution and use, see copyright notice in zlib.h
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
/* infutil.h -- types and macros common to blocks and codes
|
/* infutil.h -- types and macros common to blocks and codes
|
||||||
* Copyright (C) 1995-1996 Mark Adler
|
* Copyright (C) 1995-1998 Mark Adler
|
||||||
* For conditions of distribution and use, see copyright notice in zlib.h
|
* For conditions of distribution and use, see copyright notice in zlib.h
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@@ -41,8 +41,6 @@ struct inflate_blocks_state {
|
|||||||
inflate_huft *tb; /* bit length decoding tree */
|
inflate_huft *tb; /* bit length decoding tree */
|
||||||
} trees; /* if DTREE, decoding info for trees */
|
} trees; /* if DTREE, decoding info for trees */
|
||||||
struct {
|
struct {
|
||||||
inflate_huft *tl;
|
|
||||||
inflate_huft *td; /* trees to free */
|
|
||||||
inflate_codes_statef
|
inflate_codes_statef
|
||||||
*codes;
|
*codes;
|
||||||
} decode; /* if CODES, current state */
|
} decode; /* if CODES, current state */
|
||||||
@@ -52,6 +50,7 @@ struct inflate_blocks_state {
|
|||||||
/* mode independent information */
|
/* mode independent information */
|
||||||
uInt bitk; /* bits in bit buffer */
|
uInt bitk; /* bits in bit buffer */
|
||||||
uLong bitb; /* bit buffer */
|
uLong bitb; /* bit buffer */
|
||||||
|
inflate_huft *hufts; /* single malloc for tree space */
|
||||||
Bytef *window; /* sliding window */
|
Bytef *window; /* sliding window */
|
||||||
Bytef *end; /* one byte after sliding window */
|
Bytef *end; /* one byte after sliding window */
|
||||||
Bytef *read; /* window read pointer */
|
Bytef *read; /* window read pointer */
|
||||||
|
|||||||
85
maketree.c
Normal file
85
maketree.c
Normal file
@@ -0,0 +1,85 @@
|
|||||||
|
/* maketree.c -- make inffixed.h table for decoding fixed codes
|
||||||
|
* Copyright (C) 1998 Mark Adler
|
||||||
|
* For conditions of distribution and use, see copyright notice in zlib.h
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* WARNING: this file should *not* be used by applications. It is
|
||||||
|
part of the implementation of the compression library and is
|
||||||
|
subject to change. Applications should only use zlib.h.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* This program is included in the distribution for completeness.
|
||||||
|
You do not need to compile or run this program since inffixed.h
|
||||||
|
is already included in the distribution. To use this program
|
||||||
|
you need to compile zlib with BUILDFIXED defined and then compile
|
||||||
|
and link this program with the zlib library. Then the output of
|
||||||
|
this program can be piped to inffixed.h. */
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include "zutil.h"
|
||||||
|
#include "inftrees.h"
|
||||||
|
|
||||||
|
/* simplify the use of the inflate_huft type with some defines */
|
||||||
|
#define exop word.what.Exop
|
||||||
|
#define bits word.what.Bits
|
||||||
|
|
||||||
|
/* generate initialization table for an inflate_huft structure array */
|
||||||
|
void maketree(uInt b, inflate_huft *t)
|
||||||
|
{
|
||||||
|
int i, e;
|
||||||
|
|
||||||
|
i = 0;
|
||||||
|
while (1)
|
||||||
|
{
|
||||||
|
e = t[i].exop;
|
||||||
|
if (e && (e & (16+64)) == 0) /* table pointer */
|
||||||
|
{
|
||||||
|
fprintf(stderr, "maketree: cannot initialize sub-tables!\n");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
if (i % 4 == 0)
|
||||||
|
printf("\n ");
|
||||||
|
printf(" {{{%u,%u}},%u}", t[i].exop, t[i].bits, t[i].base);
|
||||||
|
if (++i == (1<<b))
|
||||||
|
break;
|
||||||
|
putchar(',');
|
||||||
|
}
|
||||||
|
puts("");
|
||||||
|
}
|
||||||
|
|
||||||
|
/* create the fixed tables in C initialization syntax */
|
||||||
|
void main(void)
|
||||||
|
{
|
||||||
|
int r;
|
||||||
|
uInt bl, bd;
|
||||||
|
inflate_huft *tl, *td;
|
||||||
|
z_stream z;
|
||||||
|
|
||||||
|
z.zalloc = zcalloc;
|
||||||
|
z.opaque = (voidpf)0;
|
||||||
|
z.zfree = zcfree;
|
||||||
|
r = inflate_trees_fixed(&bl, &bd, &tl, &td, &z);
|
||||||
|
if (r)
|
||||||
|
{
|
||||||
|
fprintf(stderr, "inflate_trees_fixed error %d\n", r);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
puts("/* inffixed.h -- table for decoding fixed codes");
|
||||||
|
puts(" * Generated automatically by the maketree.c program");
|
||||||
|
puts(" */");
|
||||||
|
puts("");
|
||||||
|
puts("/* WARNING: this file should *not* be used by applications. It is");
|
||||||
|
puts(" part of the implementation of the compression library and is");
|
||||||
|
puts(" subject to change. Applications should only use zlib.h.");
|
||||||
|
puts(" */");
|
||||||
|
puts("");
|
||||||
|
printf("local uInt fixed_bl = %d;\n", bl);
|
||||||
|
printf("local uInt fixed_bd = %d;\n", bd);
|
||||||
|
printf("local inflate_huft fixed_tl[] = {");
|
||||||
|
maketree(bl, tl);
|
||||||
|
puts(" };");
|
||||||
|
printf("local inflate_huft fixed_td[] = {");
|
||||||
|
maketree(bd, td);
|
||||||
|
puts(" };");
|
||||||
|
}
|
||||||
128
minigzip.c
128
minigzip.c
@@ -1,5 +1,5 @@
|
|||||||
/* minigzip.c -- simulate gzip using the zlib compression library
|
/* minigzip.c -- simulate gzip using the zlib compression library
|
||||||
* Copyright (C) 1995-1996 Jean-loup Gailly.
|
* Copyright (C) 1995-1998 Jean-loup Gailly.
|
||||||
* For conditions of distribution and use, see copyright notice in zlib.h
|
* For conditions of distribution and use, see copyright notice in zlib.h
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@@ -13,7 +13,7 @@
|
|||||||
* or in pipe mode.
|
* or in pipe mode.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* $Id: minigzip.c,v 1.10 1996/07/24 13:41:04 me Exp $ */
|
/* @(#) $Id$ */
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include "zlib.h"
|
#include "zlib.h"
|
||||||
@@ -25,6 +25,11 @@
|
|||||||
extern void exit OF((int));
|
extern void exit OF((int));
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef USE_MMAP
|
||||||
|
# include <sys/types.h>
|
||||||
|
# include <sys/mman.h>
|
||||||
|
# include <sys/stat.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
#if defined(MSDOS) || defined(OS2) || defined(WIN32)
|
#if defined(MSDOS) || defined(OS2) || defined(WIN32)
|
||||||
# include <fcntl.h>
|
# include <fcntl.h>
|
||||||
@@ -43,31 +48,40 @@
|
|||||||
# define GZ_SUFFIX "-gz"
|
# define GZ_SUFFIX "-gz"
|
||||||
# define fileno(file) file->__file
|
# define fileno(file) file->__file
|
||||||
#endif
|
#endif
|
||||||
|
#if defined(__MWERKS__) && __dest_os != __be_os && __dest_os != __win32_os
|
||||||
|
# include <unix.h> /* for fileno */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef WIN32 /* unlink already in stdio.h for WIN32 */
|
||||||
|
extern int unlink OF((const char *));
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifndef GZ_SUFFIX
|
#ifndef GZ_SUFFIX
|
||||||
# define GZ_SUFFIX ".gz"
|
# define GZ_SUFFIX ".gz"
|
||||||
#endif
|
#endif
|
||||||
#define SUFFIX_LEN sizeof(GZ_SUFFIX)
|
#define SUFFIX_LEN (sizeof(GZ_SUFFIX)-1)
|
||||||
|
|
||||||
extern int unlink OF((const char *));
|
#define BUFLEN 16384
|
||||||
|
|
||||||
#define BUFLEN 4096
|
|
||||||
#define MAX_NAME_LEN 1024
|
#define MAX_NAME_LEN 1024
|
||||||
|
|
||||||
#define local static
|
#ifdef MAXSEG_64K
|
||||||
/* For MSDOS and other systems with limitation on stack size. For Unix,
|
# define local static
|
||||||
#define local
|
/* Needed for systems with limitation on stack size. */
|
||||||
works also.
|
#else
|
||||||
*/
|
# define local
|
||||||
|
#endif
|
||||||
|
|
||||||
char *prog;
|
char *prog;
|
||||||
|
|
||||||
void error OF((const char *msg));
|
void error OF((const char *msg));
|
||||||
void gz_compress OF((FILE *in, gzFile out));
|
void gz_compress OF((FILE *in, gzFile out));
|
||||||
void gz_uncompress OF((gzFile in, FILE *out));
|
#ifdef USE_MMAP
|
||||||
void file_compress OF((char *file));
|
int gz_compress_mmap OF((FILE *in, gzFile out));
|
||||||
void file_uncompress OF((char *file));
|
#endif
|
||||||
int main OF((int argc, char *argv[]));
|
void gz_uncompress OF((gzFile in, FILE *out));
|
||||||
|
void file_compress OF((char *file, char *mode));
|
||||||
|
void file_uncompress OF((char *file));
|
||||||
|
int main OF((int argc, char *argv[]));
|
||||||
|
|
||||||
/* ===========================================================================
|
/* ===========================================================================
|
||||||
* Display error message and exit
|
* Display error message and exit
|
||||||
@@ -82,6 +96,7 @@ void error(msg)
|
|||||||
/* ===========================================================================
|
/* ===========================================================================
|
||||||
* Compress input to output then close both files.
|
* Compress input to output then close both files.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
void gz_compress(in, out)
|
void gz_compress(in, out)
|
||||||
FILE *in;
|
FILE *in;
|
||||||
gzFile out;
|
gzFile out;
|
||||||
@@ -90,6 +105,12 @@ void gz_compress(in, out)
|
|||||||
int len;
|
int len;
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
|
#ifdef USE_MMAP
|
||||||
|
/* Try first compressing with mmap. If mmap fails (minigzip used in a
|
||||||
|
* pipe), use the normal fread loop.
|
||||||
|
*/
|
||||||
|
if (gz_compress_mmap(in, out) == Z_OK) return;
|
||||||
|
#endif
|
||||||
for (;;) {
|
for (;;) {
|
||||||
len = fread(buf, 1, sizeof(buf), in);
|
len = fread(buf, 1, sizeof(buf), in);
|
||||||
if (ferror(in)) {
|
if (ferror(in)) {
|
||||||
@@ -104,6 +125,43 @@ void gz_compress(in, out)
|
|||||||
if (gzclose(out) != Z_OK) error("failed gzclose");
|
if (gzclose(out) != Z_OK) error("failed gzclose");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef USE_MMAP /* MMAP version, Miguel Albrecht <malbrech@eso.org> */
|
||||||
|
|
||||||
|
/* Try compressing the input file at once using mmap. Return Z_OK if
|
||||||
|
* if success, Z_ERRNO otherwise.
|
||||||
|
*/
|
||||||
|
int gz_compress_mmap(in, out)
|
||||||
|
FILE *in;
|
||||||
|
gzFile out;
|
||||||
|
{
|
||||||
|
int len;
|
||||||
|
int err;
|
||||||
|
int ifd = fileno(in);
|
||||||
|
caddr_t buf; /* mmap'ed buffer for the entire input file */
|
||||||
|
off_t buf_len; /* length of the input file */
|
||||||
|
struct stat sb;
|
||||||
|
|
||||||
|
/* Determine the size of the file, needed for mmap: */
|
||||||
|
if (fstat(ifd, &sb) < 0) return Z_ERRNO;
|
||||||
|
buf_len = sb.st_size;
|
||||||
|
if (buf_len <= 0) return Z_ERRNO;
|
||||||
|
|
||||||
|
/* Now do the actual mmap: */
|
||||||
|
buf = mmap((caddr_t) 0, buf_len, PROT_READ, MAP_SHARED, ifd, (off_t)0);
|
||||||
|
if (buf == (caddr_t)(-1)) return Z_ERRNO;
|
||||||
|
|
||||||
|
/* Compress the whole file at once: */
|
||||||
|
len = gzwrite(out, (char *)buf, (unsigned)buf_len);
|
||||||
|
|
||||||
|
if (len != (int)buf_len) error(gzerror(out, &err));
|
||||||
|
|
||||||
|
munmap(buf, buf_len);
|
||||||
|
fclose(in);
|
||||||
|
if (gzclose(out) != Z_OK) error("failed gzclose");
|
||||||
|
return Z_OK;
|
||||||
|
}
|
||||||
|
#endif /* USE_MMAP */
|
||||||
|
|
||||||
/* ===========================================================================
|
/* ===========================================================================
|
||||||
* Uncompress input to output then close both files.
|
* Uncompress input to output then close both files.
|
||||||
*/
|
*/
|
||||||
@@ -134,8 +192,9 @@ void gz_uncompress(in, out)
|
|||||||
* Compress the given file: create a corresponding .gz file and remove the
|
* Compress the given file: create a corresponding .gz file and remove the
|
||||||
* original.
|
* original.
|
||||||
*/
|
*/
|
||||||
void file_compress(file)
|
void file_compress(file, mode)
|
||||||
char *file;
|
char *file;
|
||||||
|
char *mode;
|
||||||
{
|
{
|
||||||
local char outfile[MAX_NAME_LEN];
|
local char outfile[MAX_NAME_LEN];
|
||||||
FILE *in;
|
FILE *in;
|
||||||
@@ -149,7 +208,7 @@ void file_compress(file)
|
|||||||
perror(file);
|
perror(file);
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
out = gzopen(outfile, "wb"); /* use "wb9" for maximal compression */
|
out = gzopen(outfile, mode);
|
||||||
if (out == NULL) {
|
if (out == NULL) {
|
||||||
fprintf(stderr, "%s: can't gzopen %s\n", prog, outfile);
|
fprintf(stderr, "%s: can't gzopen %s\n", prog, outfile);
|
||||||
exit(1);
|
exit(1);
|
||||||
@@ -201,7 +260,11 @@ void file_uncompress(file)
|
|||||||
|
|
||||||
|
|
||||||
/* ===========================================================================
|
/* ===========================================================================
|
||||||
* Usage: minigzip [-d] [files...]
|
* Usage: minigzip [-d] [-f] [-h] [-1 to -9] [files...]
|
||||||
|
* -d : decompress
|
||||||
|
* -f : compress with Z_FILTERED
|
||||||
|
* -h : compress with Z_HUFFMAN_ONLY
|
||||||
|
* -1 to -9 : compression level
|
||||||
*/
|
*/
|
||||||
|
|
||||||
int main(argc, argv)
|
int main(argc, argv)
|
||||||
@@ -210,15 +273,26 @@ int main(argc, argv)
|
|||||||
{
|
{
|
||||||
int uncompr = 0;
|
int uncompr = 0;
|
||||||
gzFile file;
|
gzFile file;
|
||||||
|
char outmode[20];
|
||||||
|
|
||||||
|
strcpy(outmode, "wb6 ");
|
||||||
|
|
||||||
prog = argv[0];
|
prog = argv[0];
|
||||||
argc--, argv++;
|
argc--, argv++;
|
||||||
|
|
||||||
if (argc > 0) {
|
while (argc > 0) {
|
||||||
uncompr = (strcmp(*argv, "-d") == 0);
|
if (strcmp(*argv, "-d") == 0)
|
||||||
if (uncompr) {
|
uncompr = 1;
|
||||||
argc--, argv++;
|
else if (strcmp(*argv, "-f") == 0)
|
||||||
}
|
outmode[3] = 'f';
|
||||||
|
else if (strcmp(*argv, "-h") == 0)
|
||||||
|
outmode[3] = 'h';
|
||||||
|
else if ((*argv)[0] == '-' && (*argv)[1] >= '1' && (*argv)[1] <= '9' &&
|
||||||
|
(*argv)[2] == 0)
|
||||||
|
outmode[2] = (*argv)[1];
|
||||||
|
else
|
||||||
|
break;
|
||||||
|
argc--, argv++;
|
||||||
}
|
}
|
||||||
if (argc == 0) {
|
if (argc == 0) {
|
||||||
SET_BINARY_MODE(stdin);
|
SET_BINARY_MODE(stdin);
|
||||||
@@ -228,7 +302,7 @@ int main(argc, argv)
|
|||||||
if (file == NULL) error("can't gzdopen stdin");
|
if (file == NULL) error("can't gzdopen stdin");
|
||||||
gz_uncompress(file, stdout);
|
gz_uncompress(file, stdout);
|
||||||
} else {
|
} else {
|
||||||
file = gzdopen(fileno(stdout), "wb"); /* "wb9" for max compr. */
|
file = gzdopen(fileno(stdout), outmode);
|
||||||
if (file == NULL) error("can't gzdopen stdout");
|
if (file == NULL) error("can't gzdopen stdout");
|
||||||
gz_compress(stdin, file);
|
gz_compress(stdin, file);
|
||||||
}
|
}
|
||||||
@@ -237,7 +311,7 @@ int main(argc, argv)
|
|||||||
if (uncompr) {
|
if (uncompr) {
|
||||||
file_uncompress(*argv);
|
file_uncompress(*argv);
|
||||||
} else {
|
} else {
|
||||||
file_compress(*argv);
|
file_compress(*argv, outmode);
|
||||||
}
|
}
|
||||||
} while (argv++, --argc);
|
} while (argv++, --argc);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -33,13 +33,13 @@ OBJP2 = zutil$(O)+inflate$(O)+infblock$(O)+inftrees$(O)+infcodes$(O)+\
|
|||||||
|
|
||||||
all: test
|
all: test
|
||||||
|
|
||||||
adler32.obj: adler32.c zutil.h zlib.h zconf.h
|
adler32.obj: adler32.c zlib.h zconf.h
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
compress.obj: compress.c zlib.h zconf.h
|
compress.obj: compress.c zlib.h zconf.h
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
crc32.obj: crc32.c zutil.h zlib.h zconf.h
|
crc32.obj: crc32.c zlib.h zconf.h
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
deflate.obj: deflate.c deflate.h zutil.h zlib.h zconf.h
|
deflate.obj: deflate.c deflate.h zutil.h zlib.h zconf.h
|
||||||
125
msdos/Makefile.bor
Normal file
125
msdos/Makefile.bor
Normal file
@@ -0,0 +1,125 @@
|
|||||||
|
# Makefile for zlib
|
||||||
|
# Borland C++ ************ UNTESTED ***********
|
||||||
|
|
||||||
|
# To use, do "make -fmakefile.bor"
|
||||||
|
# To compile in small model, set below: MODEL=s
|
||||||
|
|
||||||
|
# WARNING: the small model is supported but only for small values of
|
||||||
|
# MAX_WBITS and MAX_MEM_LEVEL. For example:
|
||||||
|
# -DMAX_WBITS=11 -DDEF_WBITS=11 -DMAX_MEM_LEVEL=3
|
||||||
|
# If you wish to reduce the memory requirements (default 256K for big
|
||||||
|
# objects plus a few K), you can add to the LOC macro below:
|
||||||
|
# -DMAX_MEM_LEVEL=7 -DMAX_WBITS=14
|
||||||
|
# See zconf.h for details about the memory requirements.
|
||||||
|
|
||||||
|
# ------------- Turbo C++, Borland C++ -------------
|
||||||
|
|
||||||
|
# Optional nonstandard preprocessor flags (e.g. -DMAX_MEM_LEVEL=7)
|
||||||
|
# should be added to the environment via "set LOCAL_ZLIB=-DFOO" or added
|
||||||
|
# to the declaration of LOC here:
|
||||||
|
LOC = $(LOCAL_ZLIB)
|
||||||
|
|
||||||
|
# Type for CPU required: 0: 8086, 1: 80186, 2: 80286, 3: 80386, etc.
|
||||||
|
CPU_TYP = 0
|
||||||
|
|
||||||
|
# Memory model: one of s, m, c, l (small, medium, compact, large)
|
||||||
|
MODEL=l
|
||||||
|
|
||||||
|
CC=bcc
|
||||||
|
# replace bcc with tcc for Turbo C++ 1.0, with bcc32 for the 32 bit version
|
||||||
|
LD=$(CC)
|
||||||
|
AR=tlib
|
||||||
|
|
||||||
|
# compiler flags
|
||||||
|
CFLAGS=-O2 -Z -m$(MODEL) $(LOC)
|
||||||
|
# replace "-O2" by "-O -G -a -d" for Turbo C++ 1.0
|
||||||
|
|
||||||
|
LDFLAGS=-m$(MODEL)
|
||||||
|
|
||||||
|
O=.obj
|
||||||
|
|
||||||
|
# variables
|
||||||
|
OBJ1 = adler32$(O) compress$(O) crc32$(O) gzio$(O) uncompr$(O) deflate$(O) \
|
||||||
|
trees$(O)
|
||||||
|
OBJP1 = adler32$(O)+compress$(O)+crc32$(O)+gzio$(O)+uncompr$(O)+deflate$(O)+\
|
||||||
|
trees$(O)
|
||||||
|
OBJ2 = zutil$(O) inflate$(O) infblock$(O) inftrees$(O) infcodes$(O) \
|
||||||
|
infutil$(O) inffast$(O)
|
||||||
|
OBJP2 = zutil$(O)+inflate$(O)+infblock$(O)+inftrees$(O)+infcodes$(O)+\
|
||||||
|
infutil$(O)+inffast$(O)
|
||||||
|
|
||||||
|
ZLIB_H = zlib.h zconf.h
|
||||||
|
ZUTIL_H = zutil.h $(ZLIB_H)
|
||||||
|
|
||||||
|
ZLIB_LIB = zlib_$(MODEL).lib
|
||||||
|
|
||||||
|
all: test
|
||||||
|
|
||||||
|
# individual dependencies and action rules:
|
||||||
|
adler32.obj: adler32.c $(ZLIB_H)
|
||||||
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
compress.obj: compress.c $(ZLIB_H)
|
||||||
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
crc32.obj: crc32.c $(ZLIB_H)
|
||||||
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
deflate.obj: deflate.c deflate.h $(ZUTIL_H)
|
||||||
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
gzio.obj: gzio.c $(ZUTIL_H)
|
||||||
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
infblock.obj: infblock.c $(ZUTIL_H) infblock.h inftrees.h infcodes.h infutil.h
|
||||||
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
infcodes.obj: infcodes.c $(ZUTIL_H) inftrees.h infutil.h infcodes.h inffast.h
|
||||||
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
inflate.obj: inflate.c $(ZUTIL_H) infblock.h
|
||||||
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
inftrees.obj: inftrees.c $(ZUTIL_H) inftrees.h
|
||||||
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
infutil.obj: infutil.c $(ZUTIL_H) inftrees.h infutil.h
|
||||||
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
inffast.obj: inffast.c $(ZUTIL_H) inftrees.h infutil.h inffast.h
|
||||||
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
trees.obj: trees.c deflate.h $(ZUTIL_H)
|
||||||
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
uncompr.obj: uncompr.c $(ZLIB_H)
|
||||||
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
zutil.obj: zutil.c $(ZUTIL_H)
|
||||||
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
example.obj: example.c $(ZLIB_H)
|
||||||
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
minigzip.obj: minigzip.c $(ZLIB_H)
|
||||||
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
# we must cut the command line to fit in the MS/DOS 128 byte limit:
|
||||||
|
$(ZLIB_LIB): $(OBJ1) $(OBJ2)
|
||||||
|
del $(ZLIB_LIB)
|
||||||
|
$(AR) $(ZLIB_LIB) +$(OBJP1)
|
||||||
|
$(AR) $(ZLIB_LIB) +$(OBJP2)
|
||||||
|
|
||||||
|
example.exe: example.obj $(ZLIB_LIB)
|
||||||
|
$(LD) $(LDFLAGS) example.obj $(ZLIB_LIB)
|
||||||
|
|
||||||
|
minigzip.exe: minigzip.obj $(ZLIB_LIB)
|
||||||
|
$(LD) $(LDFLAGS) minigzip.obj $(ZLIB_LIB)
|
||||||
|
|
||||||
|
test: example.exe minigzip.exe
|
||||||
|
example
|
||||||
|
echo hello world | minigzip | minigzip -d
|
||||||
|
|
||||||
|
#clean:
|
||||||
|
# del *.obj
|
||||||
|
# del *.exe
|
||||||
@@ -1,5 +1,5 @@
|
|||||||
# Makefile for zlib. Modified for djgpp v2.0 by F. J. Donahoe, 3/15/96.
|
# Makefile for zlib. Modified for djgpp v2.0 by F. J. Donahoe, 3/15/96.
|
||||||
# Copyright (C) 1995-1996 Jean-loup Gailly.
|
# Copyright (C) 1995-1998 Jean-loup Gailly.
|
||||||
# For conditions of distribution and use, see copyright notice in zlib.h
|
# For conditions of distribution and use, see copyright notice in zlib.h
|
||||||
|
|
||||||
# To compile, or to compile and test, type:
|
# To compile, or to compile and test, type:
|
||||||
@@ -22,7 +22,8 @@
|
|||||||
# - - - - -
|
# - - - - -
|
||||||
# Alternately, these variables may be defined below, overriding the values
|
# Alternately, these variables may be defined below, overriding the values
|
||||||
# in djgpp.env, as
|
# in djgpp.env, as
|
||||||
INCLUDE_PATH=c:\usr\include
|
# INCLUDE_PATH=c:\usr\include
|
||||||
|
# LIBRARY_PATH=c:\usr\lib
|
||||||
|
|
||||||
CC=gcc
|
CC=gcc
|
||||||
|
|
||||||
@@ -32,12 +33,12 @@ CC=gcc
|
|||||||
CFLAGS=-MMD -O3 $(BUTT) -Wall -Wwrite-strings -Wpointer-arith -Wconversion \
|
CFLAGS=-MMD -O3 $(BUTT) -Wall -Wwrite-strings -Wpointer-arith -Wconversion \
|
||||||
-Wstrict-prototypes -Wmissing-prototypes
|
-Wstrict-prototypes -Wmissing-prototypes
|
||||||
|
|
||||||
# If cp.exe is not found, replace with copy /Y .
|
# If cp.exe is available, replace "copy /Y" with "cp -fp" .
|
||||||
CP=cp -f
|
CP=copy /Y
|
||||||
# If install.exe is not found, replace with $(CP).
|
# If gnu install.exe is available, replace $(CP) with ginstall.
|
||||||
INSTALL=install
|
INSTALL=$(CP)
|
||||||
# The default value of RM is "rm -f." If "rm.exe" is not found, uncomment:
|
# The default value of RM is "rm -f." If "rm.exe" is found, comment out:
|
||||||
# RM=del
|
RM=del
|
||||||
LDLIBS=-L. -lz
|
LDLIBS=-L. -lz
|
||||||
LD=$(CC) -s -o
|
LD=$(CC) -s -o
|
||||||
LDSHARED=$(CC)
|
LDSHARED=$(CC)
|
||||||
@@ -77,15 +78,21 @@ libz.a: $(OBJS)
|
|||||||
install: $(INCL) $(LIBS)
|
install: $(INCL) $(LIBS)
|
||||||
-@if not exist $(INCLUDE_PATH)\nul mkdir $(INCLUDE_PATH)
|
-@if not exist $(INCLUDE_PATH)\nul mkdir $(INCLUDE_PATH)
|
||||||
-@if not exist $(LIBRARY_PATH)\nul mkdir $(LIBRARY_PATH)
|
-@if not exist $(LIBRARY_PATH)\nul mkdir $(LIBRARY_PATH)
|
||||||
for %%f in ($(INCL)) do $(INSTALL) %%f $(INCLUDE_PATH)
|
$(INSTALL) zlib.h $(INCLUDE_PATH)
|
||||||
for %%p in ($(LIBS)) do $(INSTALL) %%p $(LIBRARY_PATH)
|
$(INSTALL) zconf.h $(INCLUDE_PATH)
|
||||||
|
$(INSTALL) libz.a $(LIBRARY_PATH)
|
||||||
|
|
||||||
uninstall:
|
uninstall:
|
||||||
for %%f in ($(INCL)) do $(RM) $(INCLUDE_PATH)\%%f
|
$(RM) $(INCLUDE_PATH)\zlib.h
|
||||||
for %%p in ($(LIBS)) do $(RM) $(LIBRARY_PATH)\%%p
|
$(RM) $(INCLUDE_PATH)\zconf.h
|
||||||
|
$(RM) $(LIBRARY_PATH)\libz.a
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
for %%p in (*.d *.o *.exe libz.a libz.so* foo.gz) do $(RM) %%p
|
$(RM) *.d
|
||||||
|
$(RM) *.o
|
||||||
|
$(RM) *.exe
|
||||||
|
$(RM) libz.a
|
||||||
|
$(RM) foo.gz
|
||||||
|
|
||||||
DEPS := $(wildcard *.d)
|
DEPS := $(wildcard *.d)
|
||||||
ifneq ($(DEPS),)
|
ifneq ($(DEPS),)
|
||||||
69
msdos/Makefile.emx
Normal file
69
msdos/Makefile.emx
Normal file
@@ -0,0 +1,69 @@
|
|||||||
|
# Makefile for zlib. Modified for emx 0.9c by Chr. Spieler, 6/17/98.
|
||||||
|
# Copyright (C) 1995-1998 Jean-loup Gailly.
|
||||||
|
# For conditions of distribution and use, see copyright notice in zlib.h
|
||||||
|
|
||||||
|
# To compile, or to compile and test, type:
|
||||||
|
#
|
||||||
|
# make -fmakefile.emx; make test -fmakefile.emx
|
||||||
|
#
|
||||||
|
|
||||||
|
CC=gcc
|
||||||
|
|
||||||
|
#CFLAGS=-MMD -O
|
||||||
|
#CFLAGS=-O -DMAX_WBITS=14 -DMAX_MEM_LEVEL=7
|
||||||
|
#CFLAGS=-MMD -g -DDEBUG
|
||||||
|
CFLAGS=-MMD -O3 $(BUTT) -Wall -Wwrite-strings -Wpointer-arith -Wconversion \
|
||||||
|
-Wstrict-prototypes -Wmissing-prototypes
|
||||||
|
|
||||||
|
# If cp.exe is available, replace "copy /Y" with "cp -fp" .
|
||||||
|
CP=copy /Y
|
||||||
|
# If gnu install.exe is available, replace $(CP) with ginstall.
|
||||||
|
INSTALL=$(CP)
|
||||||
|
# The default value of RM is "rm -f." If "rm.exe" is found, comment out:
|
||||||
|
RM=del
|
||||||
|
LDLIBS=-L. -lzlib
|
||||||
|
LD=$(CC) -s -o
|
||||||
|
LDSHARED=$(CC)
|
||||||
|
|
||||||
|
INCL=zlib.h zconf.h
|
||||||
|
LIBS=zlib.a
|
||||||
|
|
||||||
|
AR=ar rcs
|
||||||
|
|
||||||
|
prefix=/usr/local
|
||||||
|
exec_prefix = $(prefix)
|
||||||
|
|
||||||
|
OBJS = adler32.o compress.o crc32.o gzio.o uncompr.o deflate.o trees.o \
|
||||||
|
zutil.o inflate.o infblock.o inftrees.o infcodes.o infutil.o inffast.o
|
||||||
|
|
||||||
|
TEST_OBJS = example.o minigzip.o
|
||||||
|
|
||||||
|
all: example.exe minigzip.exe
|
||||||
|
|
||||||
|
test: all
|
||||||
|
./example
|
||||||
|
echo hello world | .\minigzip | .\minigzip -d
|
||||||
|
|
||||||
|
%.o : %.c
|
||||||
|
$(CC) $(CFLAGS) -c $< -o $@
|
||||||
|
|
||||||
|
zlib.a: $(OBJS)
|
||||||
|
$(AR) $@ $(OBJS)
|
||||||
|
|
||||||
|
%.exe : %.o $(LIBS)
|
||||||
|
$(LD) $@ $< $(LDLIBS)
|
||||||
|
|
||||||
|
|
||||||
|
.PHONY : clean
|
||||||
|
|
||||||
|
clean:
|
||||||
|
$(RM) *.d
|
||||||
|
$(RM) *.o
|
||||||
|
$(RM) *.exe
|
||||||
|
$(RM) zlib.a
|
||||||
|
$(RM) foo.gz
|
||||||
|
|
||||||
|
DEPS := $(wildcard *.d)
|
||||||
|
ifneq ($(DEPS),)
|
||||||
|
include $(DEPS)
|
||||||
|
endif
|
||||||
121
msdos/Makefile.msc
Normal file
121
msdos/Makefile.msc
Normal file
@@ -0,0 +1,121 @@
|
|||||||
|
# Makefile for zlib
|
||||||
|
# Microsoft C 5.1 or later
|
||||||
|
|
||||||
|
# To use, do "make makefile.msc"
|
||||||
|
# To compile in small model, set below: MODEL=S
|
||||||
|
|
||||||
|
# If you wish to reduce the memory requirements (default 256K for big
|
||||||
|
# objects plus a few K), you can add to the LOC macro below:
|
||||||
|
# -DMAX_MEM_LEVEL=7 -DMAX_WBITS=14
|
||||||
|
# See zconf.h for details about the memory requirements.
|
||||||
|
|
||||||
|
# ------------- Microsoft C 5.1 and later -------------
|
||||||
|
|
||||||
|
# Optional nonstandard preprocessor flags (e.g. -DMAX_MEM_LEVEL=7)
|
||||||
|
# should be added to the environment via "set LOCAL_ZLIB=-DFOO" or added
|
||||||
|
# to the declaration of LOC here:
|
||||||
|
LOC = $(LOCAL_ZLIB)
|
||||||
|
|
||||||
|
# Type for CPU required: 0: 8086, 1: 80186, 2: 80286, 3: 80386, etc.
|
||||||
|
CPU_TYP = 0
|
||||||
|
|
||||||
|
# Memory model: one of S, M, C, L (small, medium, compact, large)
|
||||||
|
MODEL=L
|
||||||
|
|
||||||
|
CC=cl
|
||||||
|
CFLAGS=-nologo -A$(MODEL) -G$(CPU_TYP) -W3 -Oait -Gs $(LOC)
|
||||||
|
#-Ox generates bad code with MSC 5.1
|
||||||
|
LIB_CFLAGS=-Zl $(CFLAGS)
|
||||||
|
|
||||||
|
LD=link
|
||||||
|
LDFLAGS=/noi/e/st:0x1500/noe/farcall/packcode
|
||||||
|
# "/farcall/packcode" are only useful for `large code' memory models
|
||||||
|
# but should be a "no-op" for small code models.
|
||||||
|
|
||||||
|
O=.obj
|
||||||
|
|
||||||
|
# variables
|
||||||
|
OBJ1 = adler32$(O) compress$(O) crc32$(O) gzio$(O) uncompr$(O) deflate$(O) \
|
||||||
|
trees$(O)
|
||||||
|
OBJP1 = adler32$(O)+compress$(O)+crc32$(O)+gzio$(O)+uncompr$(O)+deflate$(O)+\
|
||||||
|
trees$(O)
|
||||||
|
OBJ2 = zutil$(O) inflate$(O) infblock$(O) inftrees$(O) infcodes$(O) \
|
||||||
|
infutil$(O) inffast$(O)
|
||||||
|
OBJP2 = zutil$(O)+inflate$(O)+infblock$(O)+inftrees$(O)+infcodes$(O)+\
|
||||||
|
infutil$(O)+inffast$(O)
|
||||||
|
|
||||||
|
ZLIB_H = zlib.h zconf.h
|
||||||
|
ZUTIL_H = zutil.h $(ZLIB_H)
|
||||||
|
|
||||||
|
ZLIB_LIB = zlib_$(MODEL).lib
|
||||||
|
|
||||||
|
all: $(ZLIB_LIB) example.exe minigzip.exe
|
||||||
|
|
||||||
|
# individual dependencies and action rules:
|
||||||
|
adler32.obj: adler32.c $(ZLIB_H)
|
||||||
|
$(CC) -c $(LIB_CFLAGS) $*.c
|
||||||
|
|
||||||
|
compress.obj: compress.c $(ZLIB_H)
|
||||||
|
$(CC) -c $(LIB_CFLAGS) $*.c
|
||||||
|
|
||||||
|
crc32.obj: crc32.c $(ZLIB_H)
|
||||||
|
$(CC) -c $(LIB_CFLAGS) $*.c
|
||||||
|
|
||||||
|
deflate.obj: deflate.c deflate.h $(ZUTIL_H)
|
||||||
|
$(CC) -c $(LIB_CFLAGS) $*.c
|
||||||
|
|
||||||
|
gzio.obj: gzio.c $(ZUTIL_H)
|
||||||
|
$(CC) -c $(LIB_CFLAGS) $*.c
|
||||||
|
|
||||||
|
infblock.obj: infblock.c $(ZUTIL_H) infblock.h inftrees.h infcodes.h infutil.h
|
||||||
|
$(CC) -c $(LIB_CFLAGS) $*.c
|
||||||
|
|
||||||
|
infcodes.obj: infcodes.c $(ZUTIL_H) inftrees.h infutil.h infcodes.h inffast.h
|
||||||
|
$(CC) -c $(LIB_CFLAGS) $*.c
|
||||||
|
|
||||||
|
inflate.obj: inflate.c $(ZUTIL_H) infblock.h
|
||||||
|
$(CC) -c $(LIB_CFLAGS) $*.c
|
||||||
|
|
||||||
|
inftrees.obj: inftrees.c $(ZUTIL_H) inftrees.h
|
||||||
|
$(CC) -c $(LIB_CFLAGS) $*.c
|
||||||
|
|
||||||
|
infutil.obj: infutil.c $(ZUTIL_H) inftrees.h infutil.h
|
||||||
|
$(CC) -c $(LIB_CFLAGS) $*.c
|
||||||
|
|
||||||
|
inffast.obj: inffast.c $(ZUTIL_H) inftrees.h infutil.h inffast.h
|
||||||
|
$(CC) -c $(LIB_CFLAGS) $*.c
|
||||||
|
|
||||||
|
trees.obj: trees.c deflate.h $(ZUTIL_H)
|
||||||
|
$(CC) -c $(LIB_CFLAGS) $*.c
|
||||||
|
|
||||||
|
uncompr.obj: uncompr.c $(ZLIB_H)
|
||||||
|
$(CC) -c $(LIB_CFLAGS) $*.c
|
||||||
|
|
||||||
|
zutil.obj: zutil.c $(ZUTIL_H)
|
||||||
|
$(CC) -c $(LIB_CFLAGS) $*.c
|
||||||
|
|
||||||
|
example.obj: example.c $(ZLIB_H)
|
||||||
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
minigzip.obj: minigzip.c $(ZLIB_H)
|
||||||
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
# we must cut the command line to fit in the MS/DOS 128 byte limit:
|
||||||
|
$(ZLIB_LIB): $(OBJ1) $(OBJ2)
|
||||||
|
if exist $(ZLIB_LIB) del $(ZLIB_LIB)
|
||||||
|
lib $(ZLIB_LIB) $(OBJ1);
|
||||||
|
lib $(ZLIB_LIB) $(OBJ2);
|
||||||
|
|
||||||
|
example.exe: example.obj $(ZLIB_LIB)
|
||||||
|
$(LD) $(LDFLAGS) example.obj,,,$(ZLIB_LIB);
|
||||||
|
|
||||||
|
minigzip.exe: minigzip.obj $(ZLIB_LIB)
|
||||||
|
$(LD) $(LDFLAGS) minigzip.obj,,,$(ZLIB_LIB);
|
||||||
|
|
||||||
|
test: example.exe minigzip.exe
|
||||||
|
example
|
||||||
|
echo hello world | minigzip | minigzip -d
|
||||||
|
|
||||||
|
#clean:
|
||||||
|
# del *.obj
|
||||||
|
# del *.exe
|
||||||
@@ -8,18 +8,18 @@
|
|||||||
# MAX_WBITS and MAX_MEM_LEVEL. For example:
|
# MAX_WBITS and MAX_MEM_LEVEL. For example:
|
||||||
# -DMAX_WBITS=11 -DMAX_MEM_LEVEL=3
|
# -DMAX_WBITS=11 -DMAX_MEM_LEVEL=3
|
||||||
# If you wish to reduce the memory requirements (default 256K for big
|
# If you wish to reduce the memory requirements (default 256K for big
|
||||||
# objects plus a few K), you can add to CFLAGS below:
|
# objects plus a few K), you can add to CFLAGS below:
|
||||||
# -DMAX_MEM_LEVEL=7 -DMAX_WBITS=14
|
# -DMAX_MEM_LEVEL=7 -DMAX_WBITS=14
|
||||||
# See zconf.h for details about the memory requirements.
|
# See zconf.h for details about the memory requirements.
|
||||||
|
|
||||||
# ------------- Turbo C 2.0 -------------
|
# ------------- Turbo C 2.0 -------------
|
||||||
MODEL=-ml
|
MODEL=l
|
||||||
# CFLAGS=-O2 -G -Z $(MODEL) -DMAX_WBITS=11 -DMAX_MEM_LEVEL=3
|
# CFLAGS=-O2 -G -Z -m$(MODEL) -DMAX_WBITS=11 -DMAX_MEM_LEVEL=3
|
||||||
CFLAGS=-O2 -G -Z $(MODEL)
|
CFLAGS=-O2 -G -Z -m$(MODEL)
|
||||||
CC=tcc -I\tc\include
|
CC=tcc -I\tc\include
|
||||||
LD=tcc -L\tc\lib
|
LD=tcc -L\tc\lib
|
||||||
LIB=tlib
|
AR=tlib
|
||||||
LDFLAGS=$(MODEL) -f-
|
LDFLAGS=-m$(MODEL) -f-
|
||||||
O=.obj
|
O=.obj
|
||||||
|
|
||||||
# variables
|
# variables
|
||||||
@@ -32,69 +32,72 @@ OBJ2 = zutil$(O) inflate$(O) infblock$(O) inftrees$(O) infcodes$(O) \
|
|||||||
OBJP2 = zutil$(O)+inflate$(O)+infblock$(O)+inftrees$(O)+infcodes$(O)+\
|
OBJP2 = zutil$(O)+inflate$(O)+infblock$(O)+inftrees$(O)+infcodes$(O)+\
|
||||||
infutil$(O)+inffast$(O)
|
infutil$(O)+inffast$(O)
|
||||||
|
|
||||||
|
ZLIB_H = zlib.h zconf.h
|
||||||
|
ZUTIL_H = zutil.h $(ZLIB_H)
|
||||||
|
|
||||||
|
ZLIB_LIB = zlib_$(MODEL).lib
|
||||||
|
|
||||||
all: test
|
all: test
|
||||||
|
|
||||||
adler32.obj: adler32.c zutil.h zlib.h zconf.h
|
adler32.obj: adler32.c $(ZLIB_H)
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
compress.obj: compress.c zlib.h zconf.h
|
compress.obj: compress.c $(ZLIB_H)
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
crc32.obj: crc32.c zutil.h zlib.h zconf.h
|
crc32.obj: crc32.c $(ZLIB_H)
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
deflate.obj: deflate.c deflate.h zutil.h zlib.h zconf.h
|
deflate.obj: deflate.c deflate.h $(ZUTIL_H)
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
gzio.obj: gzio.c zutil.h zlib.h zconf.h
|
gzio.obj: gzio.c $(ZUTIL_H)
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
infblock.obj: infblock.c zutil.h zlib.h zconf.h infblock.h inftrees.h\
|
infblock.obj: infblock.c $(ZUTIL_H) infblock.h inftrees.h infcodes.h infutil.h
|
||||||
infcodes.h infutil.h
|
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
infcodes.obj: infcodes.c zutil.h zlib.h zconf.h inftrees.h infutil.h\
|
infcodes.obj: infcodes.c $(ZUTIL_H) inftrees.h infutil.h infcodes.h inffast.h
|
||||||
infcodes.h inffast.h
|
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
inflate.obj: inflate.c zutil.h zlib.h zconf.h infblock.h
|
inflate.obj: inflate.c $(ZUTIL_H) infblock.h
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
inftrees.obj: inftrees.c zutil.h zlib.h zconf.h inftrees.h
|
inftrees.obj: inftrees.c $(ZUTIL_H) inftrees.h
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
infutil.obj: infutil.c zutil.h zlib.h zconf.h inftrees.h infutil.h
|
infutil.obj: infutil.c $(ZUTIL_H) inftrees.h infutil.h
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
inffast.obj: inffast.c zutil.h zlib.h zconf.h inftrees.h infutil.h inffast.h
|
inffast.obj: inffast.c $(ZUTIL_H) inftrees.h infutil.h inffast.h
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
trees.obj: trees.c deflate.h zutil.h zlib.h zconf.h
|
trees.obj: trees.c deflate.h $(ZUTIL_H)
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
uncompr.obj: uncompr.c zlib.h zconf.h
|
uncompr.obj: uncompr.c $(ZLIB_H)
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
zutil.obj: zutil.c zutil.h zlib.h zconf.h
|
zutil.obj: zutil.c $(ZUTIL_H)
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
example.obj: example.c zlib.h zconf.h
|
example.obj: example.c $(ZLIB_H)
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
minigzip.obj: minigzip.c zlib.h zconf.h
|
minigzip.obj: minigzip.c $(ZLIB_H)
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
# we must cut the command line to fit in the MS/DOS 128 byte limit:
|
# we must cut the command line to fit in the MS/DOS 128 byte limit:
|
||||||
zlib.lib: $(OBJ1) $(OBJ2)
|
$(ZLIB_LIB): $(OBJ1) $(OBJ2)
|
||||||
del zlib.lib
|
del $(ZLIB_LIB)
|
||||||
$(LIB) zlib +$(OBJP1)
|
$(AR) $(ZLIB_LIB) +$(OBJP1)
|
||||||
$(LIB) zlib +$(OBJP2)
|
$(AR) $(ZLIB_LIB) +$(OBJP2)
|
||||||
|
|
||||||
example.exe: example.obj zlib.lib
|
example.exe: example.obj $(ZLIB_LIB)
|
||||||
$(LD) $(LDFLAGS) -eexample.exe example.obj zlib.lib
|
$(LD) $(LDFLAGS) -eexample.exe example.obj $(ZLIB_LIB)
|
||||||
|
|
||||||
minigzip.exe: minigzip.obj zlib.lib
|
minigzip.exe: minigzip.obj $(ZLIB_LIB)
|
||||||
$(LD) $(LDFLAGS) -eminigzip.exe minigzip.obj zlib.lib
|
$(LD) $(LDFLAGS) -eminigzip.exe minigzip.obj $(ZLIB_LIB)
|
||||||
|
|
||||||
test: example.exe minigzip.exe
|
test: example.exe minigzip.exe
|
||||||
example
|
example
|
||||||
@@ -1,21 +1,19 @@
|
|||||||
# Makefile for zlib
|
# Makefile for zlib
|
||||||
# Microsoft C 5.1 or later
|
# Microsoft 32-bit Visual C++ 4.0 or later (may work on earlier versions)
|
||||||
|
|
||||||
# To use, do "make makefile.msc"
|
# To use, do "nmake /f makefile.w32"
|
||||||
# To compile in small model, set below: MODEL=-AS
|
|
||||||
|
|
||||||
# If you wish to reduce the memory requirements (default 256K for big
|
# If you wish to reduce the memory requirements (default 256K for big
|
||||||
# objects plus a few K), you can add to CFLAGS below:
|
# objects plus a few K), you can add to CFLAGS below:
|
||||||
# -DMAX_MEM_LEVEL=7 -DMAX_WBITS=14
|
# -DMAX_MEM_LEVEL=7 -DMAX_WBITS=14
|
||||||
# See zconf.h for details about the memory requirements.
|
# See zconf.h for details about the memory requirements.
|
||||||
|
|
||||||
# ------------- Microsoft C 5.1 and later -------------
|
# ------------- Microsoft Visual C++ 4.0 and later -------------
|
||||||
MODEL=-AL
|
MODEL=
|
||||||
CFLAGS=-Oait -Gs -nologo -W3 $(MODEL)
|
CFLAGS=-Ox -GA3s -nologo -W3
|
||||||
#-Ox generates bad code with MSC 5.1
|
|
||||||
CC=cl
|
CC=cl
|
||||||
LD=link
|
LD=link
|
||||||
LDFLAGS=/e/st:0x1000/noe
|
LDFLAGS=
|
||||||
O=.obj
|
O=.obj
|
||||||
|
|
||||||
# variables
|
# variables
|
||||||
@@ -30,72 +28,70 @@ OBJP2 = zutil$(O)+inflate$(O)+infblock$(O)+inftrees$(O)+infcodes$(O)+\
|
|||||||
|
|
||||||
all: zlib.lib example.exe minigzip.exe
|
all: zlib.lib example.exe minigzip.exe
|
||||||
|
|
||||||
adler32.obj: adler32.c zutil.h zlib.h zconf.h
|
adler32.obj: adler32.c zlib.h zconf.h
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
compress.obj: compress.c zlib.h zconf.h
|
compress.obj: compress.c zlib.h zconf.h
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
crc32.obj: crc32.c zutil.h zlib.h zconf.h
|
crc32.obj: crc32.c zlib.h zconf.h
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
deflate.obj: deflate.c deflate.h zutil.h zlib.h zconf.h
|
deflate.obj: deflate.c deflate.h zutil.h zlib.h zconf.h
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
gzio.obj: gzio.c zutil.h zlib.h zconf.h
|
gzio.obj: gzio.c zutil.h zlib.h zconf.h
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
infblock.obj: infblock.c zutil.h zlib.h zconf.h infblock.h inftrees.h\
|
infblock.obj: infblock.c zutil.h zlib.h zconf.h infblock.h inftrees.h\
|
||||||
infcodes.h infutil.h
|
infcodes.h infutil.h
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
infcodes.obj: infcodes.c zutil.h zlib.h zconf.h inftrees.h infutil.h\
|
infcodes.obj: infcodes.c zutil.h zlib.h zconf.h inftrees.h infutil.h\
|
||||||
infcodes.h inffast.h
|
infcodes.h inffast.h
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
inflate.obj: inflate.c zutil.h zlib.h zconf.h infblock.h
|
inflate.obj: inflate.c zutil.h zlib.h zconf.h infblock.h
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
inftrees.obj: inftrees.c zutil.h zlib.h zconf.h inftrees.h
|
inftrees.obj: inftrees.c zutil.h zlib.h zconf.h inftrees.h
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
infutil.obj: infutil.c zutil.h zlib.h zconf.h inftrees.h infutil.h
|
infutil.obj: infutil.c zutil.h zlib.h zconf.h inftrees.h infutil.h
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
inffast.obj: inffast.c zutil.h zlib.h zconf.h inftrees.h infutil.h inffast.h
|
inffast.obj: inffast.c zutil.h zlib.h zconf.h inftrees.h infutil.h inffast.h
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
trees.obj: trees.c deflate.h zutil.h zlib.h zconf.h
|
trees.obj: trees.c deflate.h zutil.h zlib.h zconf.h
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
uncompr.obj: uncompr.c zlib.h zconf.h
|
uncompr.obj: uncompr.c zlib.h zconf.h
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
zutil.obj: zutil.c zutil.h zlib.h zconf.h
|
zutil.obj: zutil.c zutil.h zlib.h zconf.h
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
example.obj: example.c zlib.h zconf.h
|
example.obj: example.c zlib.h zconf.h
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
minigzip.obj: minigzip.c zlib.h zconf.h
|
minigzip.obj: minigzip.c zlib.h zconf.h
|
||||||
$(CC) -c $(CFLAGS) $*.c
|
$(CC) -c $(CFLAGS) $*.c
|
||||||
|
|
||||||
# we must cut the command line to fit in the MS/DOS 128 byte limit:
|
|
||||||
zlib.lib: $(OBJ1) $(OBJ2)
|
zlib.lib: $(OBJ1) $(OBJ2)
|
||||||
if exist zlib.lib del zlib.lib
|
if exist zlib.lib del zlib.lib
|
||||||
lib zlib $(OBJ1);
|
lib /OUT:zlib.lib $(OBJ1) $(OBJ2)
|
||||||
lib zlib $(OBJ2);
|
|
||||||
|
|
||||||
example.exe: example.obj zlib.lib
|
example.exe: example.obj zlib.lib
|
||||||
$(LD) $(LDFLAGS) example.obj,,,zlib.lib;
|
$(LD) $(LDFLAGS) example.obj zlib.lib /OUT:example.exe /SUBSYSTEM:CONSOLE
|
||||||
|
|
||||||
minigzip.exe: minigzip.obj zlib.lib
|
minigzip.exe: minigzip.obj zlib.lib
|
||||||
$(LD) $(LDFLAGS) minigzip.obj,,,zlib.lib;
|
$(LD) $(LDFLAGS) minigzip.obj zlib.lib /OUT:minigzip.exe /SUBSYSTEM:CONSOLE
|
||||||
|
|
||||||
test: example.exe minigzip.exe
|
test: example.exe minigzip.exe
|
||||||
example
|
example
|
||||||
echo hello world | minigzip | minigzip -d
|
echo hello world | minigzip | minigzip -d
|
||||||
|
|
||||||
#clean:
|
#clean:
|
||||||
# del *.obj
|
# del *.obj
|
||||||
# del *.exe
|
# del *.exe
|
||||||
@@ -30,13 +30,13 @@ OBJP3=infutil$(O)+inffast$(O)
|
|||||||
|
|
||||||
all: test
|
all: test
|
||||||
|
|
||||||
adler32.obj: adler32.c zutil.h zlib.h zconf.h
|
adler32.obj: adler32.c zlib.h zconf.h
|
||||||
$(CC) $(CFLAGS) $*.c
|
$(CC) $(CFLAGS) $*.c
|
||||||
|
|
||||||
compress.obj: compress.c zlib.h zconf.h
|
compress.obj: compress.c zlib.h zconf.h
|
||||||
$(CC) $(CFLAGS) $*.c
|
$(CC) $(CFLAGS) $*.c
|
||||||
|
|
||||||
crc32.obj: crc32.c zutil.h zlib.h zconf.h
|
crc32.obj: crc32.c zlib.h zconf.h
|
||||||
$(CC) $(CFLAGS) $*.c
|
$(CC) $(CFLAGS) $*.c
|
||||||
|
|
||||||
deflate.obj: deflate.c deflate.h zutil.h zlib.h zconf.h
|
deflate.obj: deflate.c deflate.h zutil.h zlib.h zconf.h
|
||||||
60
msdos/zlib.def
Normal file
60
msdos/zlib.def
Normal file
@@ -0,0 +1,60 @@
|
|||||||
|
LIBRARY "zlib"
|
||||||
|
|
||||||
|
DESCRIPTION '"""zlib data compression library"""'
|
||||||
|
|
||||||
|
EXETYPE NT
|
||||||
|
|
||||||
|
SUBSYSTEM WINDOWS
|
||||||
|
|
||||||
|
STUB 'WINSTUB.EXE'
|
||||||
|
|
||||||
|
VERSION 1.13
|
||||||
|
|
||||||
|
CODE EXECUTE READ
|
||||||
|
|
||||||
|
DATA READ WRITE
|
||||||
|
|
||||||
|
HEAPSIZE 1048576,4096
|
||||||
|
|
||||||
|
EXPORTS
|
||||||
|
adler32 @1
|
||||||
|
compress @2
|
||||||
|
crc32 @3
|
||||||
|
deflate @4
|
||||||
|
deflateCopy @5
|
||||||
|
deflateEnd @6
|
||||||
|
deflateInit2_ @7
|
||||||
|
deflateInit_ @8
|
||||||
|
deflateParams @9
|
||||||
|
deflateReset @10
|
||||||
|
deflateSetDictionary @11
|
||||||
|
gzclose @12
|
||||||
|
gzdopen @13
|
||||||
|
gzerror @14
|
||||||
|
gzflush @15
|
||||||
|
gzopen @16
|
||||||
|
gzread @17
|
||||||
|
gzwrite @18
|
||||||
|
inflate @19
|
||||||
|
inflateEnd @20
|
||||||
|
inflateInit2_ @21
|
||||||
|
inflateInit_ @22
|
||||||
|
inflateReset @23
|
||||||
|
inflateSetDictionary @24
|
||||||
|
inflateSync @25
|
||||||
|
uncompress @26
|
||||||
|
zlibVersion @27
|
||||||
|
gzprintf @28
|
||||||
|
gzputc @29
|
||||||
|
gzgetc @30
|
||||||
|
gzseek @31
|
||||||
|
gzrewind @32
|
||||||
|
gztell @33
|
||||||
|
gzeof @34
|
||||||
|
gzsetparams @35
|
||||||
|
zError @36
|
||||||
|
inflateSyncPoint @37
|
||||||
|
get_crc_table @38
|
||||||
|
compress2 @39
|
||||||
|
gzputs @40
|
||||||
|
gzgets @41
|
||||||
@@ -2,8 +2,8 @@
|
|||||||
|
|
||||||
#define IDR_VERSION1 1
|
#define IDR_VERSION1 1
|
||||||
IDR_VERSION1 VERSIONINFO MOVEABLE IMPURE LOADONCALL DISCARDABLE
|
IDR_VERSION1 VERSIONINFO MOVEABLE IMPURE LOADONCALL DISCARDABLE
|
||||||
FILEVERSION 1,0,4,0
|
FILEVERSION 1,1,3,0
|
||||||
PRODUCTVERSION 1,0,4,0
|
PRODUCTVERSION 1,1,3,0
|
||||||
FILEFLAGSMASK VS_FFI_FILEFLAGSMASK
|
FILEFLAGSMASK VS_FFI_FILEFLAGSMASK
|
||||||
FILEFLAGS 0
|
FILEFLAGS 0
|
||||||
FILEOS VOS_DOS_WINDOWS32
|
FILEOS VOS_DOS_WINDOWS32
|
||||||
@@ -17,12 +17,12 @@ BEGIN
|
|||||||
|
|
||||||
BEGIN
|
BEGIN
|
||||||
VALUE "FileDescription", "zlib data compression library\0"
|
VALUE "FileDescription", "zlib data compression library\0"
|
||||||
VALUE "FileVersion", "1.0.4\0"
|
VALUE "FileVersion", "1.1.3\0"
|
||||||
VALUE "InternalName", "zlib\0"
|
VALUE "InternalName", "zlib\0"
|
||||||
VALUE "OriginalFilename", "zlib.lib\0"
|
VALUE "OriginalFilename", "zlib.dll\0"
|
||||||
VALUE "ProductName", "ZLib.DLL\0"
|
VALUE "ProductName", "ZLib.DLL\0"
|
||||||
VALUE "Comments", "DLL support by Alessandro Iacopetti\0"
|
VALUE "Comments","DLL support by Alessandro Iacopetti & Gilles Vollant\0"
|
||||||
VALUE "LegalCopyright", "(C) 1995-1996 Jean-loup Gailly & Mark Adler\0"
|
VALUE "LegalCopyright", "(C) 1995-1998 Jean-loup Gailly & Mark Adler\0"
|
||||||
END
|
END
|
||||||
END
|
END
|
||||||
BLOCK "VarFileInfo"
|
BLOCK "VarFileInfo"
|
||||||
138
nt/Makefile.emx
Normal file
138
nt/Makefile.emx
Normal file
@@ -0,0 +1,138 @@
|
|||||||
|
# Makefile for zlib. Modified for emx/rsxnt by Chr. Spieler, 6/16/98.
|
||||||
|
# Copyright (C) 1995-1998 Jean-loup Gailly.
|
||||||
|
# For conditions of distribution and use, see copyright notice in zlib.h
|
||||||
|
|
||||||
|
# To compile, or to compile and test, type:
|
||||||
|
#
|
||||||
|
# make -fmakefile.emx; make test -fmakefile.emx
|
||||||
|
#
|
||||||
|
|
||||||
|
CC=gcc -Zwin32
|
||||||
|
|
||||||
|
#CFLAGS=-MMD -O
|
||||||
|
#CFLAGS=-O -DMAX_WBITS=14 -DMAX_MEM_LEVEL=7
|
||||||
|
#CFLAGS=-MMD -g -DDEBUG
|
||||||
|
CFLAGS=-MMD -O3 $(BUTT) -Wall -Wwrite-strings -Wpointer-arith -Wconversion \
|
||||||
|
-Wstrict-prototypes -Wmissing-prototypes
|
||||||
|
|
||||||
|
# If cp.exe is available, replace "copy /Y" with "cp -fp" .
|
||||||
|
CP=copy /Y
|
||||||
|
# If gnu install.exe is available, replace $(CP) with ginstall.
|
||||||
|
INSTALL=$(CP)
|
||||||
|
# The default value of RM is "rm -f." If "rm.exe" is found, comment out:
|
||||||
|
RM=del
|
||||||
|
LDLIBS=-L. -lzlib
|
||||||
|
LD=$(CC) -s -o
|
||||||
|
LDSHARED=$(CC)
|
||||||
|
|
||||||
|
INCL=zlib.h zconf.h
|
||||||
|
LIBS=zlib.a
|
||||||
|
|
||||||
|
AR=ar rcs
|
||||||
|
|
||||||
|
prefix=/usr/local
|
||||||
|
exec_prefix = $(prefix)
|
||||||
|
|
||||||
|
OBJS = adler32.o compress.o crc32.o gzio.o uncompr.o deflate.o trees.o \
|
||||||
|
zutil.o inflate.o infblock.o inftrees.o infcodes.o infutil.o inffast.o
|
||||||
|
|
||||||
|
TEST_OBJS = example.o minigzip.o
|
||||||
|
|
||||||
|
all: example.exe minigzip.exe
|
||||||
|
|
||||||
|
test: all
|
||||||
|
./example
|
||||||
|
echo hello world | .\minigzip | .\minigzip -d
|
||||||
|
|
||||||
|
%.o : %.c
|
||||||
|
$(CC) $(CFLAGS) -c $< -o $@
|
||||||
|
|
||||||
|
zlib.a: $(OBJS)
|
||||||
|
$(AR) $@ $(OBJS)
|
||||||
|
|
||||||
|
%.exe : %.o $(LIBS)
|
||||||
|
$(LD) $@ $< $(LDLIBS)
|
||||||
|
|
||||||
|
|
||||||
|
.PHONY : clean
|
||||||
|
|
||||||
|
clean:
|
||||||
|
$(RM) *.d
|
||||||
|
$(RM) *.o
|
||||||
|
$(RM) *.exe
|
||||||
|
$(RM) zlib.a
|
||||||
|
$(RM) foo.gz
|
||||||
|
|
||||||
|
DEPS := $(wildcard *.d)
|
||||||
|
ifneq ($(DEPS),)
|
||||||
|
include $(DEPS)
|
||||||
|
endif
|
||||||
|
# Makefile for zlib. Modified for emx 0.9c by Chr. Spieler, 6/17/98.
|
||||||
|
# Copyright (C) 1995-1998 Jean-loup Gailly.
|
||||||
|
# For conditions of distribution and use, see copyright notice in zlib.h
|
||||||
|
|
||||||
|
# To compile, or to compile and test, type:
|
||||||
|
#
|
||||||
|
# make -fmakefile.emx; make test -fmakefile.emx
|
||||||
|
#
|
||||||
|
|
||||||
|
CC=gcc
|
||||||
|
|
||||||
|
#CFLAGS=-MMD -O
|
||||||
|
#CFLAGS=-O -DMAX_WBITS=14 -DMAX_MEM_LEVEL=7
|
||||||
|
#CFLAGS=-MMD -g -DDEBUG
|
||||||
|
CFLAGS=-MMD -O3 $(BUTT) -Wall -Wwrite-strings -Wpointer-arith -Wconversion \
|
||||||
|
-Wstrict-prototypes -Wmissing-prototypes
|
||||||
|
|
||||||
|
# If cp.exe is available, replace "copy /Y" with "cp -fp" .
|
||||||
|
CP=copy /Y
|
||||||
|
# If gnu install.exe is available, replace $(CP) with ginstall.
|
||||||
|
INSTALL=$(CP)
|
||||||
|
# The default value of RM is "rm -f." If "rm.exe" is found, comment out:
|
||||||
|
RM=del
|
||||||
|
LDLIBS=-L. -lzlib
|
||||||
|
LD=$(CC) -s -o
|
||||||
|
LDSHARED=$(CC)
|
||||||
|
|
||||||
|
INCL=zlib.h zconf.h
|
||||||
|
LIBS=zlib.a
|
||||||
|
|
||||||
|
AR=ar rcs
|
||||||
|
|
||||||
|
prefix=/usr/local
|
||||||
|
exec_prefix = $(prefix)
|
||||||
|
|
||||||
|
OBJS = adler32.o compress.o crc32.o gzio.o uncompr.o deflate.o trees.o \
|
||||||
|
zutil.o inflate.o infblock.o inftrees.o infcodes.o infutil.o inffast.o
|
||||||
|
|
||||||
|
TEST_OBJS = example.o minigzip.o
|
||||||
|
|
||||||
|
all: example.exe minigzip.exe
|
||||||
|
|
||||||
|
test: all
|
||||||
|
./example
|
||||||
|
echo hello world | .\minigzip | .\minigzip -d
|
||||||
|
|
||||||
|
%.o : %.c
|
||||||
|
$(CC) $(CFLAGS) -c $< -o $@
|
||||||
|
|
||||||
|
zlib.a: $(OBJS)
|
||||||
|
$(AR) $@ $(OBJS)
|
||||||
|
|
||||||
|
%.exe : %.o $(LIBS)
|
||||||
|
$(LD) $@ $< $(LDLIBS)
|
||||||
|
|
||||||
|
|
||||||
|
.PHONY : clean
|
||||||
|
|
||||||
|
clean:
|
||||||
|
$(RM) *.d
|
||||||
|
$(RM) *.o
|
||||||
|
$(RM) *.exe
|
||||||
|
$(RM) zlib.a
|
||||||
|
$(RM) foo.gz
|
||||||
|
|
||||||
|
DEPS := $(wildcard *.d)
|
||||||
|
ifneq ($(DEPS),)
|
||||||
|
include $(DEPS)
|
||||||
|
endif
|
||||||
87
nt/Makefile.gcc
Normal file
87
nt/Makefile.gcc
Normal file
@@ -0,0 +1,87 @@
|
|||||||
|
# Makefile for zlib. Modified for mingw32 by C. Spieler, 6/16/98.
|
||||||
|
# (This Makefile is directly derived from Makefile.dj2)
|
||||||
|
# Copyright (C) 1995-1998 Jean-loup Gailly.
|
||||||
|
# For conditions of distribution and use, see copyright notice in zlib.h
|
||||||
|
|
||||||
|
# To compile, or to compile and test, type:
|
||||||
|
#
|
||||||
|
# make -fmakefile.gcc; make test -fmakefile.gcc
|
||||||
|
#
|
||||||
|
# To install libz.a, zconf.h and zlib.h in the mingw32 directories, type:
|
||||||
|
#
|
||||||
|
# make install -fmakefile.gcc
|
||||||
|
#
|
||||||
|
|
||||||
|
CC=gcc
|
||||||
|
|
||||||
|
#CFLAGS=-MMD -O
|
||||||
|
#CFLAGS=-O -DMAX_WBITS=14 -DMAX_MEM_LEVEL=7
|
||||||
|
#CFLAGS=-MMD -g -DDEBUG
|
||||||
|
CFLAGS=-MMD -O3 $(BUTT) -Wall -Wwrite-strings -Wpointer-arith -Wconversion \
|
||||||
|
-Wstrict-prototypes -Wmissing-prototypes
|
||||||
|
|
||||||
|
# If cp.exe is available, replace "copy /Y" with "cp -fp" .
|
||||||
|
CP=copy /Y
|
||||||
|
# If gnu install.exe is available, replace $(CP) with ginstall.
|
||||||
|
INSTALL=$(CP)
|
||||||
|
# The default value of RM is "rm -f." If "rm.exe" is found, comment out:
|
||||||
|
RM=del
|
||||||
|
LDLIBS=-L. -lz
|
||||||
|
LD=$(CC) -s -o
|
||||||
|
LDSHARED=$(CC)
|
||||||
|
|
||||||
|
INCL=zlib.h zconf.h
|
||||||
|
LIBS=libz.a
|
||||||
|
|
||||||
|
AR=ar rcs
|
||||||
|
|
||||||
|
prefix=/usr/local
|
||||||
|
exec_prefix = $(prefix)
|
||||||
|
|
||||||
|
OBJS = adler32.o compress.o crc32.o gzio.o uncompr.o deflate.o trees.o \
|
||||||
|
zutil.o inflate.o infblock.o inftrees.o infcodes.o infutil.o inffast.o
|
||||||
|
|
||||||
|
TEST_OBJS = example.o minigzip.o
|
||||||
|
|
||||||
|
all: example.exe minigzip.exe
|
||||||
|
|
||||||
|
test: all
|
||||||
|
./example
|
||||||
|
echo hello world | .\minigzip | .\minigzip -d
|
||||||
|
|
||||||
|
%.o : %.c
|
||||||
|
$(CC) $(CFLAGS) -c $< -o $@
|
||||||
|
|
||||||
|
libz.a: $(OBJS)
|
||||||
|
$(AR) $@ $(OBJS)
|
||||||
|
|
||||||
|
%.exe : %.o $(LIBS)
|
||||||
|
$(LD) $@ $< $(LDLIBS)
|
||||||
|
|
||||||
|
# INCLUDE_PATH and LIBRARY_PATH were set for [make] in djgpp.env .
|
||||||
|
|
||||||
|
.PHONY : uninstall clean
|
||||||
|
|
||||||
|
install: $(INCL) $(LIBS)
|
||||||
|
-@if not exist $(INCLUDE_PATH)\nul mkdir $(INCLUDE_PATH)
|
||||||
|
-@if not exist $(LIBRARY_PATH)\nul mkdir $(LIBRARY_PATH)
|
||||||
|
$(INSTALL) zlib.h $(INCLUDE_PATH)
|
||||||
|
$(INSTALL) zconf.h $(INCLUDE_PATH)
|
||||||
|
$(INSTALL) libz.a $(LIBRARY_PATH)
|
||||||
|
|
||||||
|
uninstall:
|
||||||
|
$(RM) $(INCLUDE_PATH)\zlib.h
|
||||||
|
$(RM) $(INCLUDE_PATH)\zconf.h
|
||||||
|
$(RM) $(LIBRARY_PATH)\libz.a
|
||||||
|
|
||||||
|
clean:
|
||||||
|
$(RM) *.d
|
||||||
|
$(RM) *.o
|
||||||
|
$(RM) *.exe
|
||||||
|
$(RM) libz.a
|
||||||
|
$(RM) foo.gz
|
||||||
|
|
||||||
|
DEPS := $(wildcard *.d)
|
||||||
|
ifneq ($(DEPS),)
|
||||||
|
include $(DEPS)
|
||||||
|
endif
|
||||||
88
nt/Makefile.nt
Normal file
88
nt/Makefile.nt
Normal file
@@ -0,0 +1,88 @@
|
|||||||
|
# Makefile for zlib
|
||||||
|
|
||||||
|
!include <ntwin32.mak>
|
||||||
|
|
||||||
|
CC=cl
|
||||||
|
LD=link
|
||||||
|
CFLAGS=-O -nologo
|
||||||
|
LDFLAGS=
|
||||||
|
O=.obj
|
||||||
|
|
||||||
|
# variables
|
||||||
|
OBJ1 = adler32$(O) compress$(O) crc32$(O) gzio$(O) uncompr$(O) deflate$(O) \
|
||||||
|
trees$(O)
|
||||||
|
OBJ2 = zutil$(O) inflate$(O) infblock$(O) inftrees$(O) infcodes$(O) \
|
||||||
|
infutil$(O) inffast$(O)
|
||||||
|
|
||||||
|
all: zlib.dll example.exe minigzip.exe
|
||||||
|
|
||||||
|
adler32.obj: adler32.c zutil.h zlib.h zconf.h
|
||||||
|
$(CC) -c $(cvarsdll) $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
compress.obj: compress.c zlib.h zconf.h
|
||||||
|
$(CC) -c $(cvarsdll) $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
crc32.obj: crc32.c zutil.h zlib.h zconf.h
|
||||||
|
$(CC) -c $(cvarsdll) $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
deflate.obj: deflate.c deflate.h zutil.h zlib.h zconf.h
|
||||||
|
$(CC) -c $(cvarsdll) $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
gzio.obj: gzio.c zutil.h zlib.h zconf.h
|
||||||
|
$(CC) -c $(cvarsdll) $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
infblock.obj: infblock.c zutil.h zlib.h zconf.h infblock.h inftrees.h\
|
||||||
|
infcodes.h infutil.h
|
||||||
|
$(CC) -c $(cvarsdll) $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
infcodes.obj: infcodes.c zutil.h zlib.h zconf.h inftrees.h infutil.h\
|
||||||
|
infcodes.h inffast.h
|
||||||
|
$(CC) -c $(cvarsdll) $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
inflate.obj: inflate.c zutil.h zlib.h zconf.h infblock.h
|
||||||
|
$(CC) -c $(cvarsdll) $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
inftrees.obj: inftrees.c zutil.h zlib.h zconf.h inftrees.h
|
||||||
|
$(CC) -c $(cvarsdll) $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
infutil.obj: infutil.c zutil.h zlib.h zconf.h inftrees.h infutil.h
|
||||||
|
$(CC) -c $(cvarsdll) $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
inffast.obj: inffast.c zutil.h zlib.h zconf.h inftrees.h infutil.h inffast.h
|
||||||
|
$(CC) -c $(cvarsdll) $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
trees.obj: trees.c deflate.h zutil.h zlib.h zconf.h
|
||||||
|
$(CC) -c $(cvarsdll) $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
uncompr.obj: uncompr.c zlib.h zconf.h
|
||||||
|
$(CC) -c $(cvarsdll) $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
zutil.obj: zutil.c zutil.h zlib.h zconf.h
|
||||||
|
$(CC) -c $(cvarsdll) $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
example.obj: example.c zlib.h zconf.h
|
||||||
|
$(CC) -c $(cvarsdll) $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
minigzip.obj: minigzip.c zlib.h zconf.h
|
||||||
|
$(CC) -c $(cvarsdll) $(CFLAGS) $*.c
|
||||||
|
|
||||||
|
zlib.dll: $(OBJ1) $(OBJ2) zlib.dnt
|
||||||
|
link $(dlllflags) -out:$@ -def:zlib.dnt $(OBJ1) $(OBJ2) $(guilibsdll)
|
||||||
|
|
||||||
|
zlib.lib: zlib.dll
|
||||||
|
|
||||||
|
example.exe: example.obj zlib.lib
|
||||||
|
$(LD) $(LDFLAGS) example.obj zlib.lib
|
||||||
|
|
||||||
|
minigzip.exe: minigzip.obj zlib.lib
|
||||||
|
$(LD) $(LDFLAGS) minigzip.obj zlib.lib
|
||||||
|
|
||||||
|
test: example.exe minigzip.exe
|
||||||
|
example
|
||||||
|
echo hello world | minigzip | minigzip -d
|
||||||
|
|
||||||
|
clean:
|
||||||
|
del *.obj
|
||||||
|
del *.exe
|
||||||
|
del *.dll
|
||||||
|
del *.lib
|
||||||
47
nt/zlib.dnt
Normal file
47
nt/zlib.dnt
Normal file
@@ -0,0 +1,47 @@
|
|||||||
|
LIBRARY zlib.dll
|
||||||
|
EXETYPE WINDOWS
|
||||||
|
CODE PRELOAD MOVEABLE DISCARDABLE
|
||||||
|
DATA PRELOAD MOVEABLE MULTIPLE
|
||||||
|
|
||||||
|
EXPORTS
|
||||||
|
adler32 @1
|
||||||
|
compress @2
|
||||||
|
crc32 @3
|
||||||
|
deflate @4
|
||||||
|
deflateCopy @5
|
||||||
|
deflateEnd @6
|
||||||
|
deflateInit2_ @7
|
||||||
|
deflateInit_ @8
|
||||||
|
deflateParams @9
|
||||||
|
deflateReset @10
|
||||||
|
deflateSetDictionary @11
|
||||||
|
gzclose @12
|
||||||
|
gzdopen @13
|
||||||
|
gzerror @14
|
||||||
|
gzflush @15
|
||||||
|
gzopen @16
|
||||||
|
gzread @17
|
||||||
|
gzwrite @18
|
||||||
|
inflate @19
|
||||||
|
inflateEnd @20
|
||||||
|
inflateInit2_ @21
|
||||||
|
inflateInit_ @22
|
||||||
|
inflateReset @23
|
||||||
|
inflateSetDictionary @24
|
||||||
|
inflateSync @25
|
||||||
|
uncompress @26
|
||||||
|
zlibVersion @27
|
||||||
|
gzprintf @28
|
||||||
|
gzputc @29
|
||||||
|
gzgetc @30
|
||||||
|
gzseek @31
|
||||||
|
gzrewind @32
|
||||||
|
gztell @33
|
||||||
|
gzeof @34
|
||||||
|
gzsetparams @35
|
||||||
|
zError @36
|
||||||
|
inflateSyncPoint @37
|
||||||
|
get_crc_table @38
|
||||||
|
compress2 @39
|
||||||
|
gzputs @40
|
||||||
|
gzgets @41
|
||||||
136
os2/Makefile.os2
Normal file
136
os2/Makefile.os2
Normal file
@@ -0,0 +1,136 @@
|
|||||||
|
# Makefile for zlib under OS/2 using GCC (PGCC)
|
||||||
|
# For conditions of distribution and use, see copyright notice in zlib.h
|
||||||
|
|
||||||
|
# To compile and test, type:
|
||||||
|
# cp Makefile.os2 ..
|
||||||
|
# cd ..
|
||||||
|
# make -f Makefile.os2 test
|
||||||
|
|
||||||
|
# This makefile will build a static library z.lib, a shared library
|
||||||
|
# z.dll and a import library zdll.lib. You can use either z.lib or
|
||||||
|
# zdll.lib by specifying either -lz or -lzdll on gcc's command line
|
||||||
|
|
||||||
|
CC=gcc -Zomf -s
|
||||||
|
|
||||||
|
CFLAGS=-O6 -Wall
|
||||||
|
#CFLAGS=-O -DMAX_WBITS=14 -DMAX_MEM_LEVEL=7
|
||||||
|
#CFLAGS=-g -DDEBUG
|
||||||
|
#CFLAGS=-O3 -Wall -Wwrite-strings -Wpointer-arith -Wconversion \
|
||||||
|
# -Wstrict-prototypes -Wmissing-prototypes
|
||||||
|
|
||||||
|
#################### BUG WARNING: #####################
|
||||||
|
## infcodes.c hits a bug in pgcc-1.0, so you have to use either
|
||||||
|
## -O# where # <= 4 or one of (-fno-ommit-frame-pointer or -fno-force-mem)
|
||||||
|
## This bug is reportedly fixed in pgcc >1.0, but this was not tested
|
||||||
|
CFLAGS+=-fno-force-mem
|
||||||
|
|
||||||
|
LDFLAGS=-s -L. -lzdll -Zcrtdll
|
||||||
|
LDSHARED=$(CC) -s -Zomf -Zdll -Zcrtdll
|
||||||
|
|
||||||
|
VER=1.1.0
|
||||||
|
ZLIB=z.lib
|
||||||
|
SHAREDLIB=z.dll
|
||||||
|
SHAREDLIBIMP=zdll.lib
|
||||||
|
LIBS=$(ZLIB) $(SHAREDLIB) $(SHAREDLIBIMP)
|
||||||
|
|
||||||
|
AR=emxomfar cr
|
||||||
|
IMPLIB=emximp
|
||||||
|
RANLIB=echo
|
||||||
|
TAR=tar
|
||||||
|
SHELL=bash
|
||||||
|
|
||||||
|
prefix=/usr/local
|
||||||
|
exec_prefix = $(prefix)
|
||||||
|
|
||||||
|
OBJS = adler32.o compress.o crc32.o gzio.o uncompr.o deflate.o trees.o \
|
||||||
|
zutil.o inflate.o infblock.o inftrees.o infcodes.o infutil.o inffast.o
|
||||||
|
|
||||||
|
TEST_OBJS = example.o minigzip.o
|
||||||
|
|
||||||
|
DISTFILES = README INDEX ChangeLog configure Make*[a-z0-9] *.[ch] descrip.mms \
|
||||||
|
algorithm.txt zlib.3 msdos/Make*[a-z0-9] msdos/zlib.def msdos/zlib.rc \
|
||||||
|
nt/Makefile.nt nt/zlib.dnt contrib/README.contrib contrib/*.txt \
|
||||||
|
contrib/asm386/*.asm contrib/asm386/*.c \
|
||||||
|
contrib/asm386/*.bat contrib/asm386/zlibvc.d?? contrib/iostream/*.cpp \
|
||||||
|
contrib/iostream/*.h contrib/iostream2/*.h contrib/iostream2/*.cpp \
|
||||||
|
contrib/untgz/Makefile contrib/untgz/*.c contrib/untgz/*.w32
|
||||||
|
|
||||||
|
all: example.exe minigzip.exe
|
||||||
|
|
||||||
|
test: all
|
||||||
|
@LD_LIBRARY_PATH=.:$(LD_LIBRARY_PATH) ; export LD_LIBRARY_PATH; \
|
||||||
|
echo hello world | ./minigzip | ./minigzip -d || \
|
||||||
|
echo ' *** minigzip test FAILED ***' ; \
|
||||||
|
if ./example; then \
|
||||||
|
echo ' *** zlib test OK ***'; \
|
||||||
|
else \
|
||||||
|
echo ' *** zlib test FAILED ***'; \
|
||||||
|
fi
|
||||||
|
|
||||||
|
$(ZLIB): $(OBJS)
|
||||||
|
$(AR) $@ $(OBJS)
|
||||||
|
-@ ($(RANLIB) $@ || true) >/dev/null 2>&1
|
||||||
|
|
||||||
|
$(SHAREDLIB): $(OBJS) os2/z.def
|
||||||
|
$(LDSHARED) -o $@ $^
|
||||||
|
|
||||||
|
$(SHAREDLIBIMP): os2/z.def
|
||||||
|
$(IMPLIB) -o $@ $^
|
||||||
|
|
||||||
|
example.exe: example.o $(LIBS)
|
||||||
|
$(CC) $(CFLAGS) -o $@ example.o $(LDFLAGS)
|
||||||
|
|
||||||
|
minigzip.exe: minigzip.o $(LIBS)
|
||||||
|
$(CC) $(CFLAGS) -o $@ minigzip.o $(LDFLAGS)
|
||||||
|
|
||||||
|
clean:
|
||||||
|
rm -f *.o *~ example minigzip libz.a libz.so* foo.gz
|
||||||
|
|
||||||
|
distclean: clean
|
||||||
|
|
||||||
|
zip:
|
||||||
|
mv Makefile Makefile~; cp -p Makefile.in Makefile
|
||||||
|
rm -f test.c ztest*.c
|
||||||
|
v=`sed -n -e 's/\.//g' -e '/VERSION "/s/.*"\(.*\)".*/\1/p' < zlib.h`;\
|
||||||
|
zip -ul9 zlib$$v $(DISTFILES)
|
||||||
|
mv Makefile~ Makefile
|
||||||
|
|
||||||
|
dist:
|
||||||
|
mv Makefile Makefile~; cp -p Makefile.in Makefile
|
||||||
|
rm -f test.c ztest*.c
|
||||||
|
d=zlib-`sed -n '/VERSION "/s/.*"\(.*\)".*/\1/p' < zlib.h`;\
|
||||||
|
rm -f $$d.tar.gz; \
|
||||||
|
if test ! -d ../$$d; then rm -f ../$$d; ln -s `pwd` ../$$d; fi; \
|
||||||
|
files=""; \
|
||||||
|
for f in $(DISTFILES); do files="$$files $$d/$$f"; done; \
|
||||||
|
cd ..; \
|
||||||
|
GZIP=-9 $(TAR) chofz $$d/$$d.tar.gz $$files; \
|
||||||
|
if test ! -d $$d; then rm -f $$d; fi
|
||||||
|
mv Makefile~ Makefile
|
||||||
|
|
||||||
|
tags:
|
||||||
|
etags *.[ch]
|
||||||
|
|
||||||
|
depend:
|
||||||
|
makedepend -- $(CFLAGS) -- *.[ch]
|
||||||
|
|
||||||
|
# DO NOT DELETE THIS LINE -- make depend depends on it.
|
||||||
|
|
||||||
|
adler32.o: zlib.h zconf.h
|
||||||
|
compress.o: zlib.h zconf.h
|
||||||
|
crc32.o: zlib.h zconf.h
|
||||||
|
deflate.o: deflate.h zutil.h zlib.h zconf.h
|
||||||
|
example.o: zlib.h zconf.h
|
||||||
|
gzio.o: zutil.h zlib.h zconf.h
|
||||||
|
infblock.o: infblock.h inftrees.h infcodes.h infutil.h zutil.h zlib.h zconf.h
|
||||||
|
infcodes.o: zutil.h zlib.h zconf.h
|
||||||
|
infcodes.o: inftrees.h infblock.h infcodes.h infutil.h inffast.h
|
||||||
|
inffast.o: zutil.h zlib.h zconf.h inftrees.h
|
||||||
|
inffast.o: infblock.h infcodes.h infutil.h inffast.h
|
||||||
|
inflate.o: zutil.h zlib.h zconf.h infblock.h
|
||||||
|
inftrees.o: zutil.h zlib.h zconf.h inftrees.h
|
||||||
|
infutil.o: zutil.h zlib.h zconf.h infblock.h inftrees.h infcodes.h infutil.h
|
||||||
|
minigzip.o: zlib.h zconf.h
|
||||||
|
trees.o: deflate.h zutil.h zlib.h zconf.h trees.h
|
||||||
|
uncompr.o: zlib.h zconf.h
|
||||||
|
zutil.o: zutil.h zlib.h zconf.h
|
||||||
51
os2/zlib.def
Normal file
51
os2/zlib.def
Normal file
@@ -0,0 +1,51 @@
|
|||||||
|
;
|
||||||
|
; Slightly modified version of ../nt/zlib.dnt :-)
|
||||||
|
;
|
||||||
|
|
||||||
|
LIBRARY Z
|
||||||
|
DESCRIPTION "Zlib compression library for OS/2"
|
||||||
|
CODE PRELOAD MOVEABLE DISCARDABLE
|
||||||
|
DATA PRELOAD MOVEABLE MULTIPLE
|
||||||
|
|
||||||
|
EXPORTS
|
||||||
|
adler32
|
||||||
|
compress
|
||||||
|
crc32
|
||||||
|
deflate
|
||||||
|
deflateCopy
|
||||||
|
deflateEnd
|
||||||
|
deflateInit2_
|
||||||
|
deflateInit_
|
||||||
|
deflateParams
|
||||||
|
deflateReset
|
||||||
|
deflateSetDictionary
|
||||||
|
gzclose
|
||||||
|
gzdopen
|
||||||
|
gzerror
|
||||||
|
gzflush
|
||||||
|
gzopen
|
||||||
|
gzread
|
||||||
|
gzwrite
|
||||||
|
inflate
|
||||||
|
inflateEnd
|
||||||
|
inflateInit2_
|
||||||
|
inflateInit_
|
||||||
|
inflateReset
|
||||||
|
inflateSetDictionary
|
||||||
|
inflateSync
|
||||||
|
uncompress
|
||||||
|
zlibVersion
|
||||||
|
gzprintf
|
||||||
|
gzputc
|
||||||
|
gzgetc
|
||||||
|
gzseek
|
||||||
|
gzrewind
|
||||||
|
gztell
|
||||||
|
gzeof
|
||||||
|
gzsetparams
|
||||||
|
zError
|
||||||
|
inflateSyncPoint
|
||||||
|
get_crc_table
|
||||||
|
compress2
|
||||||
|
gzputs
|
||||||
|
gzgets
|
||||||
205
trees.c
205
trees.c
@@ -1,5 +1,5 @@
|
|||||||
/* trees.c -- output deflated data using Huffman coding
|
/* trees.c -- output deflated data using Huffman coding
|
||||||
* Copyright (C) 1995-1996 Jean-loup Gailly
|
* Copyright (C) 1995-1998 Jean-loup Gailly
|
||||||
* For conditions of distribution and use, see copyright notice in zlib.h
|
* For conditions of distribution and use, see copyright notice in zlib.h
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@@ -29,7 +29,9 @@
|
|||||||
* Addison-Wesley, 1983. ISBN 0-201-06672-6.
|
* Addison-Wesley, 1983. ISBN 0-201-06672-6.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* $Id: trees.c,v 1.11 1996/07/24 13:41:06 me Exp $ */
|
/* @(#) $Id$ */
|
||||||
|
|
||||||
|
/* #define GEN_TREES_H */
|
||||||
|
|
||||||
#include "deflate.h"
|
#include "deflate.h"
|
||||||
|
|
||||||
@@ -56,16 +58,16 @@
|
|||||||
#define REPZ_11_138 18
|
#define REPZ_11_138 18
|
||||||
/* repeat a zero length 11-138 times (7 bits of repeat count) */
|
/* repeat a zero length 11-138 times (7 bits of repeat count) */
|
||||||
|
|
||||||
local int extra_lbits[LENGTH_CODES] /* extra bits for each length code */
|
local const int extra_lbits[LENGTH_CODES] /* extra bits for each length code */
|
||||||
= {0,0,0,0,0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4,5,5,5,5,0};
|
= {0,0,0,0,0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4,5,5,5,5,0};
|
||||||
|
|
||||||
local int extra_dbits[D_CODES] /* extra bits for each distance code */
|
local const int extra_dbits[D_CODES] /* extra bits for each distance code */
|
||||||
= {0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13};
|
= {0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13};
|
||||||
|
|
||||||
local int extra_blbits[BL_CODES]/* extra bits for each bit length code */
|
local const int extra_blbits[BL_CODES]/* extra bits for each bit length code */
|
||||||
= {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,3,7};
|
= {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,3,7};
|
||||||
|
|
||||||
local uch bl_order[BL_CODES]
|
local const uch bl_order[BL_CODES]
|
||||||
= {16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15};
|
= {16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15};
|
||||||
/* The lengths of the bit length codes are sent in order of decreasing
|
/* The lengths of the bit length codes are sent in order of decreasing
|
||||||
* probability, to avoid transmitting the lengths for unused bit length codes.
|
* probability, to avoid transmitting the lengths for unused bit length codes.
|
||||||
@@ -80,6 +82,11 @@ local uch bl_order[BL_CODES]
|
|||||||
* Local data. These are initialized only once.
|
* Local data. These are initialized only once.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#define DIST_CODE_LEN 512 /* see definition of array dist_code below */
|
||||||
|
|
||||||
|
#if defined(GEN_TREES_H) || !defined(STDC)
|
||||||
|
/* non ANSI compilers may not accept trees.h */
|
||||||
|
|
||||||
local ct_data static_ltree[L_CODES+2];
|
local ct_data static_ltree[L_CODES+2];
|
||||||
/* The static literal tree. Since the bit lengths are imposed, there is no
|
/* The static literal tree. Since the bit lengths are imposed, there is no
|
||||||
* need for the L_CODES extra codes used during heap construction. However
|
* need for the L_CODES extra codes used during heap construction. However
|
||||||
@@ -92,13 +99,13 @@ local ct_data static_dtree[D_CODES];
|
|||||||
* 5 bits.)
|
* 5 bits.)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
local uch dist_code[512];
|
uch _dist_code[DIST_CODE_LEN];
|
||||||
/* distance codes. The first 256 values correspond to the distances
|
/* Distance codes. The first 256 values correspond to the distances
|
||||||
* 3 .. 258, the last 256 values correspond to the top 8 bits of
|
* 3 .. 258, the last 256 values correspond to the top 8 bits of
|
||||||
* the 15 bit distances.
|
* the 15 bit distances.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
local uch length_code[MAX_MATCH-MIN_MATCH+1];
|
uch _length_code[MAX_MATCH-MIN_MATCH+1];
|
||||||
/* length code for each normalized match length (0 == MIN_MATCH) */
|
/* length code for each normalized match length (0 == MIN_MATCH) */
|
||||||
|
|
||||||
local int base_length[LENGTH_CODES];
|
local int base_length[LENGTH_CODES];
|
||||||
@@ -107,9 +114,13 @@ local int base_length[LENGTH_CODES];
|
|||||||
local int base_dist[D_CODES];
|
local int base_dist[D_CODES];
|
||||||
/* First normalized distance for each code (0 = distance of 1) */
|
/* First normalized distance for each code (0 = distance of 1) */
|
||||||
|
|
||||||
|
#else
|
||||||
|
# include "trees.h"
|
||||||
|
#endif /* GEN_TREES_H */
|
||||||
|
|
||||||
struct static_tree_desc_s {
|
struct static_tree_desc_s {
|
||||||
ct_data *static_tree; /* static tree or NULL */
|
const ct_data *static_tree; /* static tree or NULL */
|
||||||
intf *extra_bits; /* extra bits for each code or NULL */
|
const intf *extra_bits; /* extra bits for each code or NULL */
|
||||||
int extra_base; /* base index for extra_bits */
|
int extra_base; /* base index for extra_bits */
|
||||||
int elems; /* max number of elements in the tree */
|
int elems; /* max number of elements in the tree */
|
||||||
int max_length; /* max bit length for the codes */
|
int max_length; /* max bit length for the codes */
|
||||||
@@ -122,7 +133,7 @@ local static_tree_desc static_d_desc =
|
|||||||
{static_dtree, extra_dbits, 0, D_CODES, MAX_BITS};
|
{static_dtree, extra_dbits, 0, D_CODES, MAX_BITS};
|
||||||
|
|
||||||
local static_tree_desc static_bl_desc =
|
local static_tree_desc static_bl_desc =
|
||||||
{(ct_data *)0, extra_blbits, 0, BL_CODES, MAX_BL_BITS};
|
{(const ct_data *)0, extra_blbits, 0, BL_CODES, MAX_BL_BITS};
|
||||||
|
|
||||||
/* ===========================================================================
|
/* ===========================================================================
|
||||||
* Local (static) routines in this file.
|
* Local (static) routines in this file.
|
||||||
@@ -148,23 +159,20 @@ local void bi_flush OF((deflate_state *s));
|
|||||||
local void copy_block OF((deflate_state *s, charf *buf, unsigned len,
|
local void copy_block OF((deflate_state *s, charf *buf, unsigned len,
|
||||||
int header));
|
int header));
|
||||||
|
|
||||||
|
#ifdef GEN_TREES_H
|
||||||
|
local void gen_trees_header OF((void));
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifndef DEBUG
|
#ifndef DEBUG
|
||||||
# define send_code(s, c, tree) send_bits(s, tree[c].Code, tree[c].Len)
|
# define send_code(s, c, tree) send_bits(s, tree[c].Code, tree[c].Len)
|
||||||
/* Send a code of the given tree. c and tree must not have side effects */
|
/* Send a code of the given tree. c and tree must not have side effects */
|
||||||
|
|
||||||
#else /* DEBUG */
|
#else /* DEBUG */
|
||||||
# define send_code(s, c, tree) \
|
# define send_code(s, c, tree) \
|
||||||
{ if (verbose>2) fprintf(stderr,"\ncd %3d ",(c)); \
|
{ if (z_verbose>2) fprintf(stderr,"\ncd %3d ",(c)); \
|
||||||
send_bits(s, tree[c].Code, tree[c].Len); }
|
send_bits(s, tree[c].Code, tree[c].Len); }
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define d_code(dist) \
|
|
||||||
((dist) < 256 ? dist_code[dist] : dist_code[256+((dist)>>7)])
|
|
||||||
/* Mapping from a distance to a distance code. dist is the distance - 1 and
|
|
||||||
* must not have side effects. dist_code[256] and dist_code[257] are never
|
|
||||||
* used.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* ===========================================================================
|
/* ===========================================================================
|
||||||
* Output a short LSB first on the stream.
|
* Output a short LSB first on the stream.
|
||||||
* IN assertion: there is enough room in pendingBuf.
|
* IN assertion: there is enough room in pendingBuf.
|
||||||
@@ -226,12 +234,11 @@ local void send_bits(s, value, length)
|
|||||||
/* the arguments must not have side effects */
|
/* the arguments must not have side effects */
|
||||||
|
|
||||||
/* ===========================================================================
|
/* ===========================================================================
|
||||||
* Initialize the various 'constant' tables. In a multi-threaded environment,
|
* Initialize the various 'constant' tables.
|
||||||
* this function may be called by two threads concurrently, but this is
|
|
||||||
* harmless since both invocations do exactly the same thing.
|
|
||||||
*/
|
*/
|
||||||
local void tr_static_init()
|
local void tr_static_init()
|
||||||
{
|
{
|
||||||
|
#if defined(GEN_TREES_H) || !defined(STDC)
|
||||||
static int static_init_done = 0;
|
static int static_init_done = 0;
|
||||||
int n; /* iterates over tree elements */
|
int n; /* iterates over tree elements */
|
||||||
int bits; /* bit counter */
|
int bits; /* bit counter */
|
||||||
@@ -243,12 +250,19 @@ local void tr_static_init()
|
|||||||
|
|
||||||
if (static_init_done) return;
|
if (static_init_done) return;
|
||||||
|
|
||||||
|
/* For some embedded targets, global variables are not initialized: */
|
||||||
|
static_l_desc.static_tree = static_ltree;
|
||||||
|
static_l_desc.extra_bits = extra_lbits;
|
||||||
|
static_d_desc.static_tree = static_dtree;
|
||||||
|
static_d_desc.extra_bits = extra_dbits;
|
||||||
|
static_bl_desc.extra_bits = extra_blbits;
|
||||||
|
|
||||||
/* Initialize the mapping length (0..255) -> length code (0..28) */
|
/* Initialize the mapping length (0..255) -> length code (0..28) */
|
||||||
length = 0;
|
length = 0;
|
||||||
for (code = 0; code < LENGTH_CODES-1; code++) {
|
for (code = 0; code < LENGTH_CODES-1; code++) {
|
||||||
base_length[code] = length;
|
base_length[code] = length;
|
||||||
for (n = 0; n < (1<<extra_lbits[code]); n++) {
|
for (n = 0; n < (1<<extra_lbits[code]); n++) {
|
||||||
length_code[length++] = (uch)code;
|
_length_code[length++] = (uch)code;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Assert (length == 256, "tr_static_init: length != 256");
|
Assert (length == 256, "tr_static_init: length != 256");
|
||||||
@@ -256,14 +270,14 @@ local void tr_static_init()
|
|||||||
* in two different ways: code 284 + 5 bits or code 285, so we
|
* in two different ways: code 284 + 5 bits or code 285, so we
|
||||||
* overwrite length_code[255] to use the best encoding:
|
* overwrite length_code[255] to use the best encoding:
|
||||||
*/
|
*/
|
||||||
length_code[length-1] = (uch)code;
|
_length_code[length-1] = (uch)code;
|
||||||
|
|
||||||
/* Initialize the mapping dist (0..32K) -> dist code (0..29) */
|
/* Initialize the mapping dist (0..32K) -> dist code (0..29) */
|
||||||
dist = 0;
|
dist = 0;
|
||||||
for (code = 0 ; code < 16; code++) {
|
for (code = 0 ; code < 16; code++) {
|
||||||
base_dist[code] = dist;
|
base_dist[code] = dist;
|
||||||
for (n = 0; n < (1<<extra_dbits[code]); n++) {
|
for (n = 0; n < (1<<extra_dbits[code]); n++) {
|
||||||
dist_code[dist++] = (uch)code;
|
_dist_code[dist++] = (uch)code;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Assert (dist == 256, "tr_static_init: dist != 256");
|
Assert (dist == 256, "tr_static_init: dist != 256");
|
||||||
@@ -271,7 +285,7 @@ local void tr_static_init()
|
|||||||
for ( ; code < D_CODES; code++) {
|
for ( ; code < D_CODES; code++) {
|
||||||
base_dist[code] = dist << 7;
|
base_dist[code] = dist << 7;
|
||||||
for (n = 0; n < (1<<(extra_dbits[code]-7)); n++) {
|
for (n = 0; n < (1<<(extra_dbits[code]-7)); n++) {
|
||||||
dist_code[256 + dist++] = (uch)code;
|
_dist_code[256 + dist++] = (uch)code;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Assert (dist == 256, "tr_static_init: 256+dist != 512");
|
Assert (dist == 256, "tr_static_init: 256+dist != 512");
|
||||||
@@ -295,8 +309,74 @@ local void tr_static_init()
|
|||||||
static_dtree[n].Code = bi_reverse((unsigned)n, 5);
|
static_dtree[n].Code = bi_reverse((unsigned)n, 5);
|
||||||
}
|
}
|
||||||
static_init_done = 1;
|
static_init_done = 1;
|
||||||
|
|
||||||
|
# ifdef GEN_TREES_H
|
||||||
|
gen_trees_header();
|
||||||
|
# endif
|
||||||
|
#endif /* defined(GEN_TREES_H) || !defined(STDC) */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* ===========================================================================
|
||||||
|
* Genererate the file trees.h describing the static trees.
|
||||||
|
*/
|
||||||
|
#ifdef GEN_TREES_H
|
||||||
|
# ifndef DEBUG
|
||||||
|
# include <stdio.h>
|
||||||
|
# endif
|
||||||
|
|
||||||
|
# define SEPARATOR(i, last, width) \
|
||||||
|
((i) == (last)? "\n};\n\n" : \
|
||||||
|
((i) % (width) == (width)-1 ? ",\n" : ", "))
|
||||||
|
|
||||||
|
void gen_trees_header()
|
||||||
|
{
|
||||||
|
FILE *header = fopen("trees.h", "w");
|
||||||
|
int i;
|
||||||
|
|
||||||
|
Assert (header != NULL, "Can't open trees.h");
|
||||||
|
fprintf(header,
|
||||||
|
"/* header created automatically with -DGEN_TREES_H */\n\n");
|
||||||
|
|
||||||
|
fprintf(header, "local const ct_data static_ltree[L_CODES+2] = {\n");
|
||||||
|
for (i = 0; i < L_CODES+2; i++) {
|
||||||
|
fprintf(header, "{{%3u},{%3u}}%s", static_ltree[i].Code,
|
||||||
|
static_ltree[i].Len, SEPARATOR(i, L_CODES+1, 5));
|
||||||
|
}
|
||||||
|
|
||||||
|
fprintf(header, "local const ct_data static_dtree[D_CODES] = {\n");
|
||||||
|
for (i = 0; i < D_CODES; i++) {
|
||||||
|
fprintf(header, "{{%2u},{%2u}}%s", static_dtree[i].Code,
|
||||||
|
static_dtree[i].Len, SEPARATOR(i, D_CODES-1, 5));
|
||||||
|
}
|
||||||
|
|
||||||
|
fprintf(header, "const uch _dist_code[DIST_CODE_LEN] = {\n");
|
||||||
|
for (i = 0; i < DIST_CODE_LEN; i++) {
|
||||||
|
fprintf(header, "%2u%s", _dist_code[i],
|
||||||
|
SEPARATOR(i, DIST_CODE_LEN-1, 20));
|
||||||
|
}
|
||||||
|
|
||||||
|
fprintf(header, "const uch _length_code[MAX_MATCH-MIN_MATCH+1]= {\n");
|
||||||
|
for (i = 0; i < MAX_MATCH-MIN_MATCH+1; i++) {
|
||||||
|
fprintf(header, "%2u%s", _length_code[i],
|
||||||
|
SEPARATOR(i, MAX_MATCH-MIN_MATCH, 20));
|
||||||
|
}
|
||||||
|
|
||||||
|
fprintf(header, "local const int base_length[LENGTH_CODES] = {\n");
|
||||||
|
for (i = 0; i < LENGTH_CODES; i++) {
|
||||||
|
fprintf(header, "%1u%s", base_length[i],
|
||||||
|
SEPARATOR(i, LENGTH_CODES-1, 20));
|
||||||
|
}
|
||||||
|
|
||||||
|
fprintf(header, "local const int base_dist[D_CODES] = {\n");
|
||||||
|
for (i = 0; i < D_CODES; i++) {
|
||||||
|
fprintf(header, "%5u%s", base_dist[i],
|
||||||
|
SEPARATOR(i, D_CODES-1, 10));
|
||||||
|
}
|
||||||
|
|
||||||
|
fclose(header);
|
||||||
|
}
|
||||||
|
#endif /* GEN_TREES_H */
|
||||||
|
|
||||||
/* ===========================================================================
|
/* ===========================================================================
|
||||||
* Initialize the tree data structures for a new zlib stream.
|
* Initialize the tree data structures for a new zlib stream.
|
||||||
*/
|
*/
|
||||||
@@ -305,8 +385,6 @@ void _tr_init(s)
|
|||||||
{
|
{
|
||||||
tr_static_init();
|
tr_static_init();
|
||||||
|
|
||||||
s->compressed_len = 0L;
|
|
||||||
|
|
||||||
s->l_desc.dyn_tree = s->dyn_ltree;
|
s->l_desc.dyn_tree = s->dyn_ltree;
|
||||||
s->l_desc.stat_desc = &static_l_desc;
|
s->l_desc.stat_desc = &static_l_desc;
|
||||||
|
|
||||||
@@ -320,6 +398,7 @@ void _tr_init(s)
|
|||||||
s->bi_valid = 0;
|
s->bi_valid = 0;
|
||||||
s->last_eob_len = 8; /* enough lookahead for inflate */
|
s->last_eob_len = 8; /* enough lookahead for inflate */
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
|
s->compressed_len = 0L;
|
||||||
s->bits_sent = 0L;
|
s->bits_sent = 0L;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@@ -413,12 +492,12 @@ local void gen_bitlen(s, desc)
|
|||||||
deflate_state *s;
|
deflate_state *s;
|
||||||
tree_desc *desc; /* the tree descriptor */
|
tree_desc *desc; /* the tree descriptor */
|
||||||
{
|
{
|
||||||
ct_data *tree = desc->dyn_tree;
|
ct_data *tree = desc->dyn_tree;
|
||||||
int max_code = desc->max_code;
|
int max_code = desc->max_code;
|
||||||
ct_data *stree = desc->stat_desc->static_tree;
|
const ct_data *stree = desc->stat_desc->static_tree;
|
||||||
intf *extra = desc->stat_desc->extra_bits;
|
const intf *extra = desc->stat_desc->extra_bits;
|
||||||
int base = desc->stat_desc->extra_base;
|
int base = desc->stat_desc->extra_base;
|
||||||
int max_length = desc->stat_desc->max_length;
|
int max_length = desc->stat_desc->max_length;
|
||||||
int h; /* heap index */
|
int h; /* heap index */
|
||||||
int n, m; /* iterate over the tree elements */
|
int n, m; /* iterate over the tree elements */
|
||||||
int bits; /* bit length */
|
int bits; /* bit length */
|
||||||
@@ -542,9 +621,9 @@ local void build_tree(s, desc)
|
|||||||
deflate_state *s;
|
deflate_state *s;
|
||||||
tree_desc *desc; /* the tree descriptor */
|
tree_desc *desc; /* the tree descriptor */
|
||||||
{
|
{
|
||||||
ct_data *tree = desc->dyn_tree;
|
ct_data *tree = desc->dyn_tree;
|
||||||
ct_data *stree = desc->stat_desc->static_tree;
|
const ct_data *stree = desc->stat_desc->static_tree;
|
||||||
int elems = desc->stat_desc->elems;
|
int elems = desc->stat_desc->elems;
|
||||||
int n, m; /* iterate over heap elements */
|
int n, m; /* iterate over heap elements */
|
||||||
int max_code = -1; /* largest code with non zero frequency */
|
int max_code = -1; /* largest code with non zero frequency */
|
||||||
int node; /* new node being created */
|
int node; /* new node being created */
|
||||||
@@ -792,9 +871,10 @@ void _tr_stored_block(s, buf, stored_len, eof)
|
|||||||
int eof; /* true if this is the last block for a file */
|
int eof; /* true if this is the last block for a file */
|
||||||
{
|
{
|
||||||
send_bits(s, (STORED_BLOCK<<1)+eof, 3); /* send block type */
|
send_bits(s, (STORED_BLOCK<<1)+eof, 3); /* send block type */
|
||||||
|
#ifdef DEBUG
|
||||||
s->compressed_len = (s->compressed_len + 3 + 7) & (ulg)~7L;
|
s->compressed_len = (s->compressed_len + 3 + 7) & (ulg)~7L;
|
||||||
s->compressed_len += (stored_len + 4) << 3;
|
s->compressed_len += (stored_len + 4) << 3;
|
||||||
|
#endif
|
||||||
copy_block(s, buf, (unsigned)stored_len, 1); /* with header */
|
copy_block(s, buf, (unsigned)stored_len, 1); /* with header */
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -814,7 +894,9 @@ void _tr_align(s)
|
|||||||
{
|
{
|
||||||
send_bits(s, STATIC_TREES<<1, 3);
|
send_bits(s, STATIC_TREES<<1, 3);
|
||||||
send_code(s, END_BLOCK, static_ltree);
|
send_code(s, END_BLOCK, static_ltree);
|
||||||
|
#ifdef DEBUG
|
||||||
s->compressed_len += 10L; /* 3 for block type, 7 for EOB */
|
s->compressed_len += 10L; /* 3 for block type, 7 for EOB */
|
||||||
|
#endif
|
||||||
bi_flush(s);
|
bi_flush(s);
|
||||||
/* Of the 10 bits for the empty block, we have already sent
|
/* Of the 10 bits for the empty block, we have already sent
|
||||||
* (10 - bi_valid) bits. The lookahead for the last real code (before
|
* (10 - bi_valid) bits. The lookahead for the last real code (before
|
||||||
@@ -824,7 +906,9 @@ void _tr_align(s)
|
|||||||
if (1 + s->last_eob_len + 10 - s->bi_valid < 9) {
|
if (1 + s->last_eob_len + 10 - s->bi_valid < 9) {
|
||||||
send_bits(s, STATIC_TREES<<1, 3);
|
send_bits(s, STATIC_TREES<<1, 3);
|
||||||
send_code(s, END_BLOCK, static_ltree);
|
send_code(s, END_BLOCK, static_ltree);
|
||||||
|
#ifdef DEBUG
|
||||||
s->compressed_len += 10L;
|
s->compressed_len += 10L;
|
||||||
|
#endif
|
||||||
bi_flush(s);
|
bi_flush(s);
|
||||||
}
|
}
|
||||||
s->last_eob_len = 7;
|
s->last_eob_len = 7;
|
||||||
@@ -832,10 +916,9 @@ void _tr_align(s)
|
|||||||
|
|
||||||
/* ===========================================================================
|
/* ===========================================================================
|
||||||
* Determine the best encoding for the current block: dynamic trees, static
|
* Determine the best encoding for the current block: dynamic trees, static
|
||||||
* trees or store, and output the encoded block to the zip file. This function
|
* trees or store, and output the encoded block to the zip file.
|
||||||
* returns the total compressed length for the file so far.
|
|
||||||
*/
|
*/
|
||||||
ulg _tr_flush_block(s, buf, stored_len, eof)
|
void _tr_flush_block(s, buf, stored_len, eof)
|
||||||
deflate_state *s;
|
deflate_state *s;
|
||||||
charf *buf; /* input block, or NULL if too old */
|
charf *buf; /* input block, or NULL if too old */
|
||||||
ulg stored_len; /* length of input block */
|
ulg stored_len; /* length of input block */
|
||||||
@@ -882,25 +965,6 @@ ulg _tr_flush_block(s, buf, stored_len, eof)
|
|||||||
opt_lenb = static_lenb = stored_len + 5; /* force a stored block */
|
opt_lenb = static_lenb = stored_len + 5; /* force a stored block */
|
||||||
}
|
}
|
||||||
|
|
||||||
/* If compression failed and this is the first and last block,
|
|
||||||
* and if the .zip file can be seeked (to rewrite the local header),
|
|
||||||
* the whole file is transformed into a stored file:
|
|
||||||
*/
|
|
||||||
#ifdef STORED_FILE_OK
|
|
||||||
# ifdef FORCE_STORED_FILE
|
|
||||||
if (eof && s->compressed_len == 0L) { /* force stored file */
|
|
||||||
# else
|
|
||||||
if (stored_len <= opt_lenb && eof && s->compressed_len==0L && seekable()) {
|
|
||||||
# endif
|
|
||||||
/* Since LIT_BUFSIZE <= 2*WSIZE, the input data must be there: */
|
|
||||||
if (buf == (charf*)0) error ("block vanished");
|
|
||||||
|
|
||||||
copy_block(buf, (unsigned)stored_len, 0); /* without header */
|
|
||||||
s->compressed_len = stored_len << 3;
|
|
||||||
s->method = STORED;
|
|
||||||
} else
|
|
||||||
#endif /* STORED_FILE_OK */
|
|
||||||
|
|
||||||
#ifdef FORCE_STORED
|
#ifdef FORCE_STORED
|
||||||
if (buf != (char*)0) { /* force stored block */
|
if (buf != (char*)0) { /* force stored block */
|
||||||
#else
|
#else
|
||||||
@@ -922,25 +986,32 @@ ulg _tr_flush_block(s, buf, stored_len, eof)
|
|||||||
#endif
|
#endif
|
||||||
send_bits(s, (STATIC_TREES<<1)+eof, 3);
|
send_bits(s, (STATIC_TREES<<1)+eof, 3);
|
||||||
compress_block(s, (ct_data *)static_ltree, (ct_data *)static_dtree);
|
compress_block(s, (ct_data *)static_ltree, (ct_data *)static_dtree);
|
||||||
|
#ifdef DEBUG
|
||||||
s->compressed_len += 3 + s->static_len;
|
s->compressed_len += 3 + s->static_len;
|
||||||
|
#endif
|
||||||
} else {
|
} else {
|
||||||
send_bits(s, (DYN_TREES<<1)+eof, 3);
|
send_bits(s, (DYN_TREES<<1)+eof, 3);
|
||||||
send_all_trees(s, s->l_desc.max_code+1, s->d_desc.max_code+1,
|
send_all_trees(s, s->l_desc.max_code+1, s->d_desc.max_code+1,
|
||||||
max_blindex+1);
|
max_blindex+1);
|
||||||
compress_block(s, (ct_data *)s->dyn_ltree, (ct_data *)s->dyn_dtree);
|
compress_block(s, (ct_data *)s->dyn_ltree, (ct_data *)s->dyn_dtree);
|
||||||
|
#ifdef DEBUG
|
||||||
s->compressed_len += 3 + s->opt_len;
|
s->compressed_len += 3 + s->opt_len;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
Assert (s->compressed_len == s->bits_sent, "bad compressed size");
|
Assert (s->compressed_len == s->bits_sent, "bad compressed size");
|
||||||
|
/* The above check is made mod 2^32, for files larger than 512 MB
|
||||||
|
* and uLong implemented on 32 bits.
|
||||||
|
*/
|
||||||
init_block(s);
|
init_block(s);
|
||||||
|
|
||||||
if (eof) {
|
if (eof) {
|
||||||
bi_windup(s);
|
bi_windup(s);
|
||||||
|
#ifdef DEBUG
|
||||||
s->compressed_len += 7; /* align on byte boundary */
|
s->compressed_len += 7; /* align on byte boundary */
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
Tracev((stderr,"\ncomprlen %lu(%lu) ", s->compressed_len>>3,
|
Tracev((stderr,"\ncomprlen %lu(%lu) ", s->compressed_len>>3,
|
||||||
s->compressed_len-7*eof));
|
s->compressed_len-7*eof));
|
||||||
|
|
||||||
return s->compressed_len >> 3;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ===========================================================================
|
/* ===========================================================================
|
||||||
@@ -965,12 +1036,13 @@ int _tr_tally (s, dist, lc)
|
|||||||
(ush)lc <= (ush)(MAX_MATCH-MIN_MATCH) &&
|
(ush)lc <= (ush)(MAX_MATCH-MIN_MATCH) &&
|
||||||
(ush)d_code(dist) < (ush)D_CODES, "_tr_tally: bad match");
|
(ush)d_code(dist) < (ush)D_CODES, "_tr_tally: bad match");
|
||||||
|
|
||||||
s->dyn_ltree[length_code[lc]+LITERALS+1].Freq++;
|
s->dyn_ltree[_length_code[lc]+LITERALS+1].Freq++;
|
||||||
s->dyn_dtree[d_code(dist)].Freq++;
|
s->dyn_dtree[d_code(dist)].Freq++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef TRUNCATE_BLOCK
|
||||||
/* Try to guess if it is profitable to stop the current block here */
|
/* Try to guess if it is profitable to stop the current block here */
|
||||||
if (s->level > 2 && (s->last_lit & 0xfff) == 0) {
|
if ((s->last_lit & 0x1fff) == 0 && s->level > 2) {
|
||||||
/* Compute an upper bound for the compressed length */
|
/* Compute an upper bound for the compressed length */
|
||||||
ulg out_length = (ulg)s->last_lit*8L;
|
ulg out_length = (ulg)s->last_lit*8L;
|
||||||
ulg in_length = (ulg)((long)s->strstart - s->block_start);
|
ulg in_length = (ulg)((long)s->strstart - s->block_start);
|
||||||
@@ -985,6 +1057,7 @@ int _tr_tally (s, dist, lc)
|
|||||||
100L - out_length*100L/in_length));
|
100L - out_length*100L/in_length));
|
||||||
if (s->matches < s->last_lit/2 && out_length < in_length/2) return 1;
|
if (s->matches < s->last_lit/2 && out_length < in_length/2) return 1;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
return (s->last_lit == s->lit_bufsize-1);
|
return (s->last_lit == s->lit_bufsize-1);
|
||||||
/* We avoid equality with lit_bufsize because of wraparound at 64K
|
/* We avoid equality with lit_bufsize because of wraparound at 64K
|
||||||
* on 16 bit machines and because stored blocks are restricted to
|
* on 16 bit machines and because stored blocks are restricted to
|
||||||
@@ -1014,7 +1087,7 @@ local void compress_block(s, ltree, dtree)
|
|||||||
Tracecv(isgraph(lc), (stderr," '%c' ", lc));
|
Tracecv(isgraph(lc), (stderr," '%c' ", lc));
|
||||||
} else {
|
} else {
|
||||||
/* Here, lc is the match length - MIN_MATCH */
|
/* Here, lc is the match length - MIN_MATCH */
|
||||||
code = length_code[lc];
|
code = _length_code[lc];
|
||||||
send_code(s, code+LITERALS+1, ltree); /* send the length code */
|
send_code(s, code+LITERALS+1, ltree); /* send the length code */
|
||||||
extra = extra_lbits[code];
|
extra = extra_lbits[code];
|
||||||
if (extra != 0) {
|
if (extra != 0) {
|
||||||
|
|||||||
128
trees.h
Normal file
128
trees.h
Normal file
@@ -0,0 +1,128 @@
|
|||||||
|
/* header created automatically with -DGEN_TREES_H */
|
||||||
|
|
||||||
|
local const ct_data static_ltree[L_CODES+2] = {
|
||||||
|
{{ 12},{ 8}}, {{140},{ 8}}, {{ 76},{ 8}}, {{204},{ 8}}, {{ 44},{ 8}},
|
||||||
|
{{172},{ 8}}, {{108},{ 8}}, {{236},{ 8}}, {{ 28},{ 8}}, {{156},{ 8}},
|
||||||
|
{{ 92},{ 8}}, {{220},{ 8}}, {{ 60},{ 8}}, {{188},{ 8}}, {{124},{ 8}},
|
||||||
|
{{252},{ 8}}, {{ 2},{ 8}}, {{130},{ 8}}, {{ 66},{ 8}}, {{194},{ 8}},
|
||||||
|
{{ 34},{ 8}}, {{162},{ 8}}, {{ 98},{ 8}}, {{226},{ 8}}, {{ 18},{ 8}},
|
||||||
|
{{146},{ 8}}, {{ 82},{ 8}}, {{210},{ 8}}, {{ 50},{ 8}}, {{178},{ 8}},
|
||||||
|
{{114},{ 8}}, {{242},{ 8}}, {{ 10},{ 8}}, {{138},{ 8}}, {{ 74},{ 8}},
|
||||||
|
{{202},{ 8}}, {{ 42},{ 8}}, {{170},{ 8}}, {{106},{ 8}}, {{234},{ 8}},
|
||||||
|
{{ 26},{ 8}}, {{154},{ 8}}, {{ 90},{ 8}}, {{218},{ 8}}, {{ 58},{ 8}},
|
||||||
|
{{186},{ 8}}, {{122},{ 8}}, {{250},{ 8}}, {{ 6},{ 8}}, {{134},{ 8}},
|
||||||
|
{{ 70},{ 8}}, {{198},{ 8}}, {{ 38},{ 8}}, {{166},{ 8}}, {{102},{ 8}},
|
||||||
|
{{230},{ 8}}, {{ 22},{ 8}}, {{150},{ 8}}, {{ 86},{ 8}}, {{214},{ 8}},
|
||||||
|
{{ 54},{ 8}}, {{182},{ 8}}, {{118},{ 8}}, {{246},{ 8}}, {{ 14},{ 8}},
|
||||||
|
{{142},{ 8}}, {{ 78},{ 8}}, {{206},{ 8}}, {{ 46},{ 8}}, {{174},{ 8}},
|
||||||
|
{{110},{ 8}}, {{238},{ 8}}, {{ 30},{ 8}}, {{158},{ 8}}, {{ 94},{ 8}},
|
||||||
|
{{222},{ 8}}, {{ 62},{ 8}}, {{190},{ 8}}, {{126},{ 8}}, {{254},{ 8}},
|
||||||
|
{{ 1},{ 8}}, {{129},{ 8}}, {{ 65},{ 8}}, {{193},{ 8}}, {{ 33},{ 8}},
|
||||||
|
{{161},{ 8}}, {{ 97},{ 8}}, {{225},{ 8}}, {{ 17},{ 8}}, {{145},{ 8}},
|
||||||
|
{{ 81},{ 8}}, {{209},{ 8}}, {{ 49},{ 8}}, {{177},{ 8}}, {{113},{ 8}},
|
||||||
|
{{241},{ 8}}, {{ 9},{ 8}}, {{137},{ 8}}, {{ 73},{ 8}}, {{201},{ 8}},
|
||||||
|
{{ 41},{ 8}}, {{169},{ 8}}, {{105},{ 8}}, {{233},{ 8}}, {{ 25},{ 8}},
|
||||||
|
{{153},{ 8}}, {{ 89},{ 8}}, {{217},{ 8}}, {{ 57},{ 8}}, {{185},{ 8}},
|
||||||
|
{{121},{ 8}}, {{249},{ 8}}, {{ 5},{ 8}}, {{133},{ 8}}, {{ 69},{ 8}},
|
||||||
|
{{197},{ 8}}, {{ 37},{ 8}}, {{165},{ 8}}, {{101},{ 8}}, {{229},{ 8}},
|
||||||
|
{{ 21},{ 8}}, {{149},{ 8}}, {{ 85},{ 8}}, {{213},{ 8}}, {{ 53},{ 8}},
|
||||||
|
{{181},{ 8}}, {{117},{ 8}}, {{245},{ 8}}, {{ 13},{ 8}}, {{141},{ 8}},
|
||||||
|
{{ 77},{ 8}}, {{205},{ 8}}, {{ 45},{ 8}}, {{173},{ 8}}, {{109},{ 8}},
|
||||||
|
{{237},{ 8}}, {{ 29},{ 8}}, {{157},{ 8}}, {{ 93},{ 8}}, {{221},{ 8}},
|
||||||
|
{{ 61},{ 8}}, {{189},{ 8}}, {{125},{ 8}}, {{253},{ 8}}, {{ 19},{ 9}},
|
||||||
|
{{275},{ 9}}, {{147},{ 9}}, {{403},{ 9}}, {{ 83},{ 9}}, {{339},{ 9}},
|
||||||
|
{{211},{ 9}}, {{467},{ 9}}, {{ 51},{ 9}}, {{307},{ 9}}, {{179},{ 9}},
|
||||||
|
{{435},{ 9}}, {{115},{ 9}}, {{371},{ 9}}, {{243},{ 9}}, {{499},{ 9}},
|
||||||
|
{{ 11},{ 9}}, {{267},{ 9}}, {{139},{ 9}}, {{395},{ 9}}, {{ 75},{ 9}},
|
||||||
|
{{331},{ 9}}, {{203},{ 9}}, {{459},{ 9}}, {{ 43},{ 9}}, {{299},{ 9}},
|
||||||
|
{{171},{ 9}}, {{427},{ 9}}, {{107},{ 9}}, {{363},{ 9}}, {{235},{ 9}},
|
||||||
|
{{491},{ 9}}, {{ 27},{ 9}}, {{283},{ 9}}, {{155},{ 9}}, {{411},{ 9}},
|
||||||
|
{{ 91},{ 9}}, {{347},{ 9}}, {{219},{ 9}}, {{475},{ 9}}, {{ 59},{ 9}},
|
||||||
|
{{315},{ 9}}, {{187},{ 9}}, {{443},{ 9}}, {{123},{ 9}}, {{379},{ 9}},
|
||||||
|
{{251},{ 9}}, {{507},{ 9}}, {{ 7},{ 9}}, {{263},{ 9}}, {{135},{ 9}},
|
||||||
|
{{391},{ 9}}, {{ 71},{ 9}}, {{327},{ 9}}, {{199},{ 9}}, {{455},{ 9}},
|
||||||
|
{{ 39},{ 9}}, {{295},{ 9}}, {{167},{ 9}}, {{423},{ 9}}, {{103},{ 9}},
|
||||||
|
{{359},{ 9}}, {{231},{ 9}}, {{487},{ 9}}, {{ 23},{ 9}}, {{279},{ 9}},
|
||||||
|
{{151},{ 9}}, {{407},{ 9}}, {{ 87},{ 9}}, {{343},{ 9}}, {{215},{ 9}},
|
||||||
|
{{471},{ 9}}, {{ 55},{ 9}}, {{311},{ 9}}, {{183},{ 9}}, {{439},{ 9}},
|
||||||
|
{{119},{ 9}}, {{375},{ 9}}, {{247},{ 9}}, {{503},{ 9}}, {{ 15},{ 9}},
|
||||||
|
{{271},{ 9}}, {{143},{ 9}}, {{399},{ 9}}, {{ 79},{ 9}}, {{335},{ 9}},
|
||||||
|
{{207},{ 9}}, {{463},{ 9}}, {{ 47},{ 9}}, {{303},{ 9}}, {{175},{ 9}},
|
||||||
|
{{431},{ 9}}, {{111},{ 9}}, {{367},{ 9}}, {{239},{ 9}}, {{495},{ 9}},
|
||||||
|
{{ 31},{ 9}}, {{287},{ 9}}, {{159},{ 9}}, {{415},{ 9}}, {{ 95},{ 9}},
|
||||||
|
{{351},{ 9}}, {{223},{ 9}}, {{479},{ 9}}, {{ 63},{ 9}}, {{319},{ 9}},
|
||||||
|
{{191},{ 9}}, {{447},{ 9}}, {{127},{ 9}}, {{383},{ 9}}, {{255},{ 9}},
|
||||||
|
{{511},{ 9}}, {{ 0},{ 7}}, {{ 64},{ 7}}, {{ 32},{ 7}}, {{ 96},{ 7}},
|
||||||
|
{{ 16},{ 7}}, {{ 80},{ 7}}, {{ 48},{ 7}}, {{112},{ 7}}, {{ 8},{ 7}},
|
||||||
|
{{ 72},{ 7}}, {{ 40},{ 7}}, {{104},{ 7}}, {{ 24},{ 7}}, {{ 88},{ 7}},
|
||||||
|
{{ 56},{ 7}}, {{120},{ 7}}, {{ 4},{ 7}}, {{ 68},{ 7}}, {{ 36},{ 7}},
|
||||||
|
{{100},{ 7}}, {{ 20},{ 7}}, {{ 84},{ 7}}, {{ 52},{ 7}}, {{116},{ 7}},
|
||||||
|
{{ 3},{ 8}}, {{131},{ 8}}, {{ 67},{ 8}}, {{195},{ 8}}, {{ 35},{ 8}},
|
||||||
|
{{163},{ 8}}, {{ 99},{ 8}}, {{227},{ 8}}
|
||||||
|
};
|
||||||
|
|
||||||
|
local const ct_data static_dtree[D_CODES] = {
|
||||||
|
{{ 0},{ 5}}, {{16},{ 5}}, {{ 8},{ 5}}, {{24},{ 5}}, {{ 4},{ 5}},
|
||||||
|
{{20},{ 5}}, {{12},{ 5}}, {{28},{ 5}}, {{ 2},{ 5}}, {{18},{ 5}},
|
||||||
|
{{10},{ 5}}, {{26},{ 5}}, {{ 6},{ 5}}, {{22},{ 5}}, {{14},{ 5}},
|
||||||
|
{{30},{ 5}}, {{ 1},{ 5}}, {{17},{ 5}}, {{ 9},{ 5}}, {{25},{ 5}},
|
||||||
|
{{ 5},{ 5}}, {{21},{ 5}}, {{13},{ 5}}, {{29},{ 5}}, {{ 3},{ 5}},
|
||||||
|
{{19},{ 5}}, {{11},{ 5}}, {{27},{ 5}}, {{ 7},{ 5}}, {{23},{ 5}}
|
||||||
|
};
|
||||||
|
|
||||||
|
const uch _dist_code[DIST_CODE_LEN] = {
|
||||||
|
0, 1, 2, 3, 4, 4, 5, 5, 6, 6, 6, 6, 7, 7, 7, 7, 8, 8, 8, 8,
|
||||||
|
8, 8, 8, 8, 9, 9, 9, 9, 9, 9, 9, 9, 10, 10, 10, 10, 10, 10, 10, 10,
|
||||||
|
10, 10, 10, 10, 10, 10, 10, 10, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11,
|
||||||
|
11, 11, 11, 11, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12,
|
||||||
|
12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 13, 13, 13, 13,
|
||||||
|
13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13,
|
||||||
|
13, 13, 13, 13, 13, 13, 13, 13, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14,
|
||||||
|
14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14,
|
||||||
|
14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14,
|
||||||
|
14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 15, 15, 15, 15, 15, 15, 15, 15,
|
||||||
|
15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15,
|
||||||
|
15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15,
|
||||||
|
15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 0, 0, 16, 17,
|
||||||
|
18, 18, 19, 19, 20, 20, 20, 20, 21, 21, 21, 21, 22, 22, 22, 22, 22, 22, 22, 22,
|
||||||
|
23, 23, 23, 23, 23, 23, 23, 23, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24,
|
||||||
|
24, 24, 24, 24, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25,
|
||||||
|
26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26,
|
||||||
|
26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 27, 27, 27, 27, 27, 27, 27, 27,
|
||||||
|
27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27,
|
||||||
|
27, 27, 27, 27, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
|
||||||
|
28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
|
||||||
|
28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
|
||||||
|
28, 28, 28, 28, 28, 28, 28, 28, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29,
|
||||||
|
29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29,
|
||||||
|
29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29,
|
||||||
|
29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29
|
||||||
|
};
|
||||||
|
|
||||||
|
const uch _length_code[MAX_MATCH-MIN_MATCH+1]= {
|
||||||
|
0, 1, 2, 3, 4, 5, 6, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 12, 12,
|
||||||
|
13, 13, 13, 13, 14, 14, 14, 14, 15, 15, 15, 15, 16, 16, 16, 16, 16, 16, 16, 16,
|
||||||
|
17, 17, 17, 17, 17, 17, 17, 17, 18, 18, 18, 18, 18, 18, 18, 18, 19, 19, 19, 19,
|
||||||
|
19, 19, 19, 19, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20,
|
||||||
|
21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 22, 22, 22, 22,
|
||||||
|
22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 23, 23, 23, 23, 23, 23, 23, 23,
|
||||||
|
23, 23, 23, 23, 23, 23, 23, 23, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24,
|
||||||
|
24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24,
|
||||||
|
25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25,
|
||||||
|
25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 26, 26, 26, 26, 26, 26, 26, 26,
|
||||||
|
26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26,
|
||||||
|
26, 26, 26, 26, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27,
|
||||||
|
27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 28
|
||||||
|
};
|
||||||
|
|
||||||
|
local const int base_length[LENGTH_CODES] = {
|
||||||
|
0, 1, 2, 3, 4, 5, 6, 7, 8, 10, 12, 14, 16, 20, 24, 28, 32, 40, 48, 56,
|
||||||
|
64, 80, 96, 112, 128, 160, 192, 224, 0
|
||||||
|
};
|
||||||
|
|
||||||
|
local const int base_dist[D_CODES] = {
|
||||||
|
0, 1, 2, 3, 4, 6, 8, 12, 16, 24,
|
||||||
|
32, 48, 64, 96, 128, 192, 256, 384, 512, 768,
|
||||||
|
1024, 1536, 2048, 3072, 4096, 6144, 8192, 12288, 16384, 24576
|
||||||
|
};
|
||||||
|
|
||||||
@@ -1,9 +1,9 @@
|
|||||||
/* uncompr.c -- decompress a memory buffer
|
/* uncompr.c -- decompress a memory buffer
|
||||||
* Copyright (C) 1995-1996 Jean-loup Gailly.
|
* Copyright (C) 1995-1998 Jean-loup Gailly.
|
||||||
* For conditions of distribution and use, see copyright notice in zlib.h
|
* For conditions of distribution and use, see copyright notice in zlib.h
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* $Id: uncompr.c,v 1.8 1996/01/30 21:59:26 me Exp $ */
|
/* @(#) $Id$ */
|
||||||
|
|
||||||
#include "zlib.h"
|
#include "zlib.h"
|
||||||
|
|
||||||
@@ -22,7 +22,7 @@
|
|||||||
enough memory, Z_BUF_ERROR if there was not enough room in the output
|
enough memory, Z_BUF_ERROR if there was not enough room in the output
|
||||||
buffer, or Z_DATA_ERROR if the input data was corrupted.
|
buffer, or Z_DATA_ERROR if the input data was corrupted.
|
||||||
*/
|
*/
|
||||||
int uncompress (dest, destLen, source, sourceLen)
|
int ZEXPORT uncompress (dest, destLen, source, sourceLen)
|
||||||
Bytef *dest;
|
Bytef *dest;
|
||||||
uLongf *destLen;
|
uLongf *destLen;
|
||||||
const Bytef *source;
|
const Bytef *source;
|
||||||
@@ -49,7 +49,7 @@ int uncompress (dest, destLen, source, sourceLen)
|
|||||||
err = inflate(&stream, Z_FINISH);
|
err = inflate(&stream, Z_FINISH);
|
||||||
if (err != Z_STREAM_END) {
|
if (err != Z_STREAM_END) {
|
||||||
inflateEnd(&stream);
|
inflateEnd(&stream);
|
||||||
return err;
|
return err == Z_OK ? Z_BUF_ERROR : err;
|
||||||
}
|
}
|
||||||
*destLen = stream.total_out;
|
*destLen = stream.total_out;
|
||||||
|
|
||||||
|
|||||||
127
zconf.h
127
zconf.h
@@ -1,9 +1,9 @@
|
|||||||
/* zconf.h -- configuration of the zlib compression library
|
/* zconf.h -- configuration of the zlib compression library
|
||||||
* Copyright (C) 1995-1996 Jean-loup Gailly.
|
* Copyright (C) 1995-1998 Jean-loup Gailly.
|
||||||
* For conditions of distribution and use, see copyright notice in zlib.h
|
* For conditions of distribution and use, see copyright notice in zlib.h
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* $Id: zconf.h,v 1.20 1996/07/02 15:09:28 me Exp $ */
|
/* @(#) $Id$ */
|
||||||
|
|
||||||
#ifndef _ZCONF_H
|
#ifndef _ZCONF_H
|
||||||
#define _ZCONF_H
|
#define _ZCONF_H
|
||||||
@@ -27,8 +27,10 @@
|
|||||||
# define inflateInit2_ z_inflateInit2_
|
# define inflateInit2_ z_inflateInit2_
|
||||||
# define inflateSetDictionary z_inflateSetDictionary
|
# define inflateSetDictionary z_inflateSetDictionary
|
||||||
# define inflateSync z_inflateSync
|
# define inflateSync z_inflateSync
|
||||||
|
# define inflateSyncPoint z_inflateSyncPoint
|
||||||
# define inflateReset z_inflateReset
|
# define inflateReset z_inflateReset
|
||||||
# define compress z_compress
|
# define compress z_compress
|
||||||
|
# define compress2 z_compress2
|
||||||
# define uncompress z_uncompress
|
# define uncompress z_uncompress
|
||||||
# define adler32 z_adler32
|
# define adler32 z_adler32
|
||||||
# define crc32 z_crc32
|
# define crc32 z_crc32
|
||||||
@@ -72,8 +74,10 @@
|
|||||||
#if (defined(MSDOS) || defined(_WINDOWS) || defined(WIN32)) && !defined(STDC)
|
#if (defined(MSDOS) || defined(_WINDOWS) || defined(WIN32)) && !defined(STDC)
|
||||||
# define STDC
|
# define STDC
|
||||||
#endif
|
#endif
|
||||||
#if (defined(__STDC__) || defined(__cplusplus)) && !defined(STDC)
|
#if defined(__STDC__) || defined(__cplusplus) || defined(__OS2__)
|
||||||
# define STDC
|
# ifndef STDC
|
||||||
|
# define STDC
|
||||||
|
# endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef STDC
|
#ifndef STDC
|
||||||
@@ -87,6 +91,12 @@
|
|||||||
# define NO_DUMMY_DECL
|
# define NO_DUMMY_DECL
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* Old Borland C incorrectly complains about missing returns: */
|
||||||
|
#if defined(__BORLANDC__) && (__BORLANDC__ < 0x500)
|
||||||
|
# define NEED_DUMMY_RETURN
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/* Maximum value for memLevel in deflateInit2 */
|
/* Maximum value for memLevel in deflateInit2 */
|
||||||
#ifndef MAX_MEM_LEVEL
|
#ifndef MAX_MEM_LEVEL
|
||||||
# ifdef MAXSEG_64K
|
# ifdef MAXSEG_64K
|
||||||
@@ -96,13 +106,17 @@
|
|||||||
# endif
|
# endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Maximum value for windowBits in deflateInit2 and inflateInit2 */
|
/* Maximum value for windowBits in deflateInit2 and inflateInit2.
|
||||||
|
* WARNING: reducing MAX_WBITS makes minigzip unable to extract .gz files
|
||||||
|
* created by gzip. (Files created by minigzip can still be extracted by
|
||||||
|
* gzip.)
|
||||||
|
*/
|
||||||
#ifndef MAX_WBITS
|
#ifndef MAX_WBITS
|
||||||
# define MAX_WBITS 15 /* 32K LZ77 window */
|
# define MAX_WBITS 15 /* 32K LZ77 window */
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* The memory requirements for deflate are (in bytes):
|
/* The memory requirements for deflate are (in bytes):
|
||||||
1 << (windowBits+2) + 1 << (memLevel+9)
|
(1 << (windowBits+2)) + (1 << (memLevel+9))
|
||||||
that is: 128K for windowBits=15 + 128K for memLevel = 8 (default values)
|
that is: 128K for windowBits=15 + 128K for memLevel = 8 (default values)
|
||||||
plus a few kilobytes for small objects. For example, if you want to reduce
|
plus a few kilobytes for small objects. For example, if you want to reduce
|
||||||
the default memory requirements from 256K to 128K, compile with
|
the default memory requirements from 256K to 128K, compile with
|
||||||
@@ -134,7 +148,7 @@
|
|||||||
/* MSC small or medium model */
|
/* MSC small or medium model */
|
||||||
# define SMALL_MEDIUM
|
# define SMALL_MEDIUM
|
||||||
# ifdef _MSC_VER
|
# ifdef _MSC_VER
|
||||||
# define FAR __far
|
# define FAR _far
|
||||||
# else
|
# else
|
||||||
# define FAR far
|
# define FAR far
|
||||||
# endif
|
# endif
|
||||||
@@ -142,19 +156,68 @@
|
|||||||
#if defined(__BORLANDC__) && (defined(__SMALL__) || defined(__MEDIUM__))
|
#if defined(__BORLANDC__) && (defined(__SMALL__) || defined(__MEDIUM__))
|
||||||
# ifndef __32BIT__
|
# ifndef __32BIT__
|
||||||
# define SMALL_MEDIUM
|
# define SMALL_MEDIUM
|
||||||
# define FAR __far
|
# define FAR _far
|
||||||
# endif
|
# endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* Compile with -DZLIB_DLL for Windows DLL support */
|
||||||
|
#if defined(ZLIB_DLL)
|
||||||
|
# if defined(_WINDOWS) || defined(WINDOWS)
|
||||||
|
# ifdef FAR
|
||||||
|
# undef FAR
|
||||||
|
# endif
|
||||||
|
# include <windows.h>
|
||||||
|
# define ZEXPORT WINAPI
|
||||||
|
# ifdef WIN32
|
||||||
|
# define ZEXPORTVA WINAPIV
|
||||||
|
# else
|
||||||
|
# define ZEXPORTVA FAR _cdecl _export
|
||||||
|
# endif
|
||||||
|
# endif
|
||||||
|
# if defined (__BORLANDC__)
|
||||||
|
# if (__BORLANDC__ >= 0x0500) && defined (WIN32)
|
||||||
|
# include <windows.h>
|
||||||
|
# define ZEXPORT __declspec(dllexport) WINAPI
|
||||||
|
# define ZEXPORTRVA __declspec(dllexport) WINAPIV
|
||||||
|
# else
|
||||||
|
# if defined (_Windows) && defined (__DLL__)
|
||||||
|
# define ZEXPORT _export
|
||||||
|
# define ZEXPORTVA _export
|
||||||
|
# endif
|
||||||
|
# endif
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined (__BEOS__)
|
||||||
|
# if defined (ZLIB_DLL)
|
||||||
|
# define ZEXTERN extern __declspec(dllexport)
|
||||||
|
# else
|
||||||
|
# define ZEXTERN extern __declspec(dllimport)
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef ZEXPORT
|
||||||
|
# define ZEXPORT
|
||||||
|
#endif
|
||||||
|
#ifndef ZEXPORTVA
|
||||||
|
# define ZEXPORTVA
|
||||||
|
#endif
|
||||||
|
#ifndef ZEXTERN
|
||||||
|
# define ZEXTERN extern
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifndef FAR
|
#ifndef FAR
|
||||||
# define FAR
|
# define FAR
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if !defined(MACOS) && !defined(TARGET_OS_MAC)
|
||||||
typedef unsigned char Byte; /* 8 bits */
|
typedef unsigned char Byte; /* 8 bits */
|
||||||
|
#endif
|
||||||
typedef unsigned int uInt; /* 16 bits or more */
|
typedef unsigned int uInt; /* 16 bits or more */
|
||||||
typedef unsigned long uLong; /* 32 bits or more */
|
typedef unsigned long uLong; /* 32 bits or more */
|
||||||
|
|
||||||
#if defined(__BORLANDC__) && defined(SMALL_MEDIUM)
|
#ifdef SMALL_MEDIUM
|
||||||
/* Borland C/C++ ignores FAR inside typedef */
|
/* Borland C/C++ and some old MSC versions ignore FAR inside typedef */
|
||||||
# define Bytef Byte FAR
|
# define Bytef Byte FAR
|
||||||
#else
|
#else
|
||||||
typedef Byte FAR Bytef;
|
typedef Byte FAR Bytef;
|
||||||
@@ -172,13 +235,45 @@ typedef uLong FAR uLongf;
|
|||||||
typedef Byte *voidp;
|
typedef Byte *voidp;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_UNISTD_H
|
||||||
|
# include <sys/types.h> /* for off_t */
|
||||||
|
# include <unistd.h> /* for SEEK_* and off_t */
|
||||||
|
# define z_off_t off_t
|
||||||
|
#endif
|
||||||
|
#ifndef SEEK_SET
|
||||||
|
# define SEEK_SET 0 /* Seek from beginning of file. */
|
||||||
|
# define SEEK_CUR 1 /* Seek from current position. */
|
||||||
|
# define SEEK_END 2 /* Set file pointer to EOF plus "offset" */
|
||||||
|
#endif
|
||||||
|
#ifndef z_off_t
|
||||||
|
# define z_off_t long
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Compile with -DZLIB_DLL for Windows DLL support */
|
/* MVS linker does not support external names larger than 8 bytes */
|
||||||
#if (defined(_WINDOWS) || defined(WINDOWS)) && defined(ZLIB_DLL)
|
#if defined(__MVS__)
|
||||||
# include <windows.h>
|
# pragma map(deflateInit_,"DEIN")
|
||||||
# define EXPORT WINAPI
|
# pragma map(deflateInit2_,"DEIN2")
|
||||||
#else
|
# pragma map(deflateEnd,"DEEND")
|
||||||
# define EXPORT
|
# pragma map(inflateInit_,"ININ")
|
||||||
|
# pragma map(inflateInit2_,"ININ2")
|
||||||
|
# pragma map(inflateEnd,"INEND")
|
||||||
|
# pragma map(inflateSync,"INSY")
|
||||||
|
# pragma map(inflateSetDictionary,"INSEDI")
|
||||||
|
# pragma map(inflate_blocks,"INBL")
|
||||||
|
# pragma map(inflate_blocks_new,"INBLNE")
|
||||||
|
# pragma map(inflate_blocks_free,"INBLFR")
|
||||||
|
# pragma map(inflate_blocks_reset,"INBLRE")
|
||||||
|
# pragma map(inflate_codes_free,"INCOFR")
|
||||||
|
# pragma map(inflate_codes,"INCO")
|
||||||
|
# pragma map(inflate_fast,"INFA")
|
||||||
|
# pragma map(inflate_flush,"INFLU")
|
||||||
|
# pragma map(inflate_mask,"INMA")
|
||||||
|
# pragma map(inflate_set_dictionary,"INSEDI2")
|
||||||
|
# pragma map(inflate_copyright,"INCOPY")
|
||||||
|
# pragma map(inflate_trees_bits,"INTRBI")
|
||||||
|
# pragma map(inflate_trees_dynamic,"INTRDY")
|
||||||
|
# pragma map(inflate_trees_fixed,"INTRFI")
|
||||||
|
# pragma map(inflate_trees_free,"INTRFR")
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif /* _ZCONF_H */
|
#endif /* _ZCONF_H */
|
||||||
|
|||||||
107
zlib.3
Normal file
107
zlib.3
Normal file
@@ -0,0 +1,107 @@
|
|||||||
|
.TH ZLIB 3 "9 July 1998"
|
||||||
|
.SH NAME
|
||||||
|
zlib \- compression/decompression library
|
||||||
|
.SH SYNOPSIS
|
||||||
|
[see
|
||||||
|
.I zlib.h
|
||||||
|
for full description]
|
||||||
|
.SH DESCRIPTION
|
||||||
|
The
|
||||||
|
.I zlib
|
||||||
|
library is a general purpose data compression library.
|
||||||
|
The code is thread safe.
|
||||||
|
It provides in-memory compression and decompression functions,
|
||||||
|
including integrity checks of the uncompressed data.
|
||||||
|
This version of the library supports only one compression method (deflation)
|
||||||
|
but other algorithms will be added later and will have the same stream interface.
|
||||||
|
.LP
|
||||||
|
Compression can be done in a single step if the buffers are large enough
|
||||||
|
(for example if an input file is mmap'ed),
|
||||||
|
or can be done by repeated calls of the compression function.
|
||||||
|
In the latter case,
|
||||||
|
the application must provide more input and/or consume the output
|
||||||
|
(providing more output space) before each call.
|
||||||
|
.LP
|
||||||
|
The library also supports reading and writing files in
|
||||||
|
.I gzip
|
||||||
|
(.gz) format
|
||||||
|
with an interface similar to that of stdio.
|
||||||
|
.LP
|
||||||
|
The library does not install any signal handler. The decoder checks
|
||||||
|
the consistency of the compressed data, so the library should never
|
||||||
|
crash even in case of corrupted input.
|
||||||
|
.LP
|
||||||
|
All functions of the compression library are documented in the file
|
||||||
|
.IR zlib.h.
|
||||||
|
The distribution source includes examples of use of the library
|
||||||
|
the files
|
||||||
|
.I example.c
|
||||||
|
and
|
||||||
|
.IR minigzip.c .
|
||||||
|
.LP
|
||||||
|
A Java implementation of
|
||||||
|
.IR zlib
|
||||||
|
is available in the Java Development Kit 1.1
|
||||||
|
.IP
|
||||||
|
http://www.javasoft.com/products/JDK/1.1/docs/api/Package-java.util.zip.html
|
||||||
|
.LP
|
||||||
|
A Perl interface to
|
||||||
|
.IR zlib ,
|
||||||
|
written by Paul Marquess (pmarquess@bfsec.bt.co.uk)
|
||||||
|
is available at CPAN (Comprehensive Perl Archive Network) sites,
|
||||||
|
such as:
|
||||||
|
.IP
|
||||||
|
ftp://ftp.cis.ufl.edu/pub/perl/CPAN/modules/by-module/Compress/Compress-Zlib*
|
||||||
|
.LP
|
||||||
|
A Python interface to
|
||||||
|
.IR zlib
|
||||||
|
written by A.M. Kuchling <amk@magnet.com>
|
||||||
|
is available from the Python Software Association sites, such as:
|
||||||
|
.IP
|
||||||
|
ftp://ftp.python.org/pub/python/contrib/Encoding/zlib*.tar.gz
|
||||||
|
.SH "SEE ALSO"
|
||||||
|
Questions about zlib should be sent to:
|
||||||
|
.IP
|
||||||
|
zlib@quest.jpl.nasa.gov
|
||||||
|
or, if this fails, to the author addresses given below.
|
||||||
|
The zlib home page is:
|
||||||
|
.IP
|
||||||
|
http://www.cdrom.com/pub/infozip/zlib/
|
||||||
|
.LP
|
||||||
|
The data format used by the zlib library is described by RFC
|
||||||
|
(Request for Comments) 1950 to 1952 in the files:
|
||||||
|
.IP
|
||||||
|
ftp://ds.internic.net/rfc/rfc1950.txt (zlib format)
|
||||||
|
.br
|
||||||
|
rfc1951.txt (deflate format)
|
||||||
|
.br
|
||||||
|
rfc1952.txt (gzip format)
|
||||||
|
.LP
|
||||||
|
These documents are also available in other formats from:
|
||||||
|
.IP
|
||||||
|
ftp://ftp.uu.net/graphics/png/documents/zlib/zdoc-index.html
|
||||||
|
.SH AUTHORS
|
||||||
|
Version 1.1.3
|
||||||
|
Copyright (C) 1995-1998 Jean-loup Gailly (jloup@gzip.org)
|
||||||
|
and Mark Adler (madler@alumni.caltech.edu).
|
||||||
|
.LP
|
||||||
|
This software is provided "as-is,"
|
||||||
|
without any express or implied warranty.
|
||||||
|
In no event will the authors be held liable for any damages
|
||||||
|
arising from the use of this software.
|
||||||
|
See the distribution directory with respect to requirements
|
||||||
|
governing redistribution.
|
||||||
|
The deflate format used by
|
||||||
|
.I zlib
|
||||||
|
was defined by Phil Katz.
|
||||||
|
The deflate and
|
||||||
|
.I zlib
|
||||||
|
specifications were written by L. Peter Deutsch.
|
||||||
|
Thanks to all the people who reported problems and suggested various
|
||||||
|
improvements in
|
||||||
|
.IR zlib ;
|
||||||
|
who are too numerous to cite here.
|
||||||
|
.LP
|
||||||
|
UNIX manual page by R. P. C. Rodgers,
|
||||||
|
U.S. National Library of Medicine (rodgers@nlm.nih.gov).
|
||||||
|
.\" end of man page
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user