README 6.9 KB
Newer Older
M
Mark Adler 已提交
1
zlib 1.1.3 is a general purpose data compression library.  All the code
M
Mark Adler 已提交
2
is thread safe.  The data format used by the zlib library
M
Mark Adler 已提交
3 4 5 6
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
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
M
Mark Adler 已提交
7

M
Mark Adler 已提交
8 9 10 11 12 13
All functions of the compression library are documented in the file zlib.h
(volunteer to write man pages welcome, contact jloup@gzip.org). A usage
example of the library is given in the file example.c which also tests that
the library is working correctly. Another example is given in the file
minigzip.c. The compression library itself is composed of all source files
except example.c and minigzip.c.
M
Mark Adler 已提交
14

M
Mark Adler 已提交
15 16
To compile all files and run the test program, follow the instructions
given at the top of Makefile. In short "make test; make install"
M
Mark Adler 已提交
17 18 19
should work for most machines. For Unix: "configure; make test; make install"
For MSDOS, use one of the special makefiles such as Makefile.msc.
For VMS, use Make_vms.com or descrip.mms.
M
Mark Adler 已提交
20

M
Mark Adler 已提交
21 22
Questions about zlib should be sent to <zlib@quest.jpl.nasa.gov>, or to
Gilles Vollant <info@winimage.com> for the Windows DLL version.
M
Mark Adler 已提交
23
The zlib home page is http://www.cdrom.com/pub/infozip/zlib/
M
Mark Adler 已提交
24
The official zlib ftp site is ftp://ftp.cdrom.com/pub/infozip/zlib/
M
Mark Adler 已提交
25 26 27 28
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.

M
Mark Adler 已提交
29 30
Mark Nelson <markn@tiny.com> wrote an article about zlib for the Jan. 1997
issue of  Dr. Dobb's Journal; a copy of the article is available in
M
Mark Adler 已提交
31 32
http://web2.airmail.net/markn/articles/zlibtool/zlibtool.htm

M
Mark Adler 已提交
33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51
The changes made in version 1.1.3 are documented in the file ChangeLog.
The main changes since 1.1.2 are:

- 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.
M
Mark Adler 已提交
52 53 54 55 56 57

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.
M
Mark Adler 已提交
58 59 60 61 62

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:
ftp://ftp.cis.ufl.edu/pub/perl/CPAN/modules/by-module/Compress/Compress-Zlib*

M
Mark Adler 已提交
63
A Python interface to zlib written by A.M. Kuchling <amk@magnet.com>
M
Mark Adler 已提交
64 65
is available in Python 1.5 and later versions, see
http://www.python.org/doc/lib/module-zlib.html
M
Mark Adler 已提交
66

M
Mark Adler 已提交
67 68 69 70 71 72 73
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.
M
Mark Adler 已提交
74 75


M
Mark Adler 已提交
76
Notes for some targets:
M
Mark Adler 已提交
77

M
Mark Adler 已提交
78 79 80 81 82
- To build a Windows DLL version, include in a DLL project zlib.def, zlib.rc
  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
M
Mark Adler 已提交
83

M
Mark Adler 已提交
84 85
  From Visual Basic, you can call the DLL functions which do not take
  a structure as argument: compress, uncompress and all gz* functions.
M
Mark Adler 已提交
86 87
  See contrib/visual-basic.txt for more information, or get
  http://www.tcfb.com/dowseware/cmp-z-it.zip
M
Mark Adler 已提交
88 89

- For 64-bit Irix, deflate.c must be compiled without any optimization.
M
Mark Adler 已提交
90
  With -O, one libpng test fails. The test works in 32 bit mode (with
M
Mark Adler 已提交
91
  the -n32 compiler flag). The compiler bug has been reported to SGI.
M
Mark Adler 已提交
92 93 94 95

- 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.

M
Mark Adler 已提交
96 97 98
- on Digital Unix 4.0D (formely OSF/1) on AlphaServer, the cc option -std1
  is necessary to get gzprintf working correctly. This is done by configure.

M
Mark Adler 已提交
99 100
- zlib doesn't work on HP-UX 9.05 with some versions of /bin/cc. It works
  with other compilers. Use "make test" to check your compiler.
M
Mark Adler 已提交
101

M
Mark Adler 已提交
102
- gzdopen is not supported on RISCOS, BEOS and by some Mac compilers.
M
Mark Adler 已提交
103

M
Mark Adler 已提交
104 105 106
- 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

M
Mark Adler 已提交
107 108 109
- For PalmOs, see http://www.cs.uit.no/~perm/PASTA/pilot/software.html
  Per Harald Myrvang <perm@stud.cs.uit.no>

M
Mark Adler 已提交
110 111

Acknowledgments:
M
Mark Adler 已提交
112

M
Mark Adler 已提交
113
  The deflate format used by zlib was defined by Phil Katz. The deflate
M
Mark Adler 已提交
114
  and zlib specifications were written by L. Peter Deutsch. Thanks to all the
M
Mark Adler 已提交
115 116
  people who reported problems and suggested various improvements in zlib;
  they are too numerous to cite here.
M
Mark Adler 已提交
117 118 119

Copyright notice:

M
Mark Adler 已提交
120
 (C) 1995-1998 Jean-loup Gailly and Mark Adler
M
Mark Adler 已提交
121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138

  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.

  Jean-loup Gailly        Mark Adler
M
Mark Adler 已提交
139
  jloup@gzip.org          madler@alumni.caltech.edu
M
Mark Adler 已提交
140 141 142 143 144 145 146 147 148

If you use the zlib library in a product, we would appreciate *not*
receiving lengthy legal documents to sign. The sources are provided
for free but without warranty of any kind.  The library has been
entirely written by Jean-loup Gailly and Mark Adler; it does not
include third-party code.

If you redistribute modified sources, we would appreciate that you include
in the file ChangeLog history information documenting your changes.