mirror of
git://git.gnupg.org/gnupg.git
synced 2024-12-22 10:19:57 +01:00
See ChangeLog: Thu Jan 21 06:22:10 CET 1999 Werner Koch
This commit is contained in:
parent
7debff3867
commit
9ef0f26270
@ -1,3 +1,7 @@
|
|||||||
|
Wed Jan 20 21:40:21 CET 1999 Werner Koch <wk@isil.d.shuttle.de>
|
||||||
|
|
||||||
|
* configure.in: --enable-m-guard is now default
|
||||||
|
|
||||||
Wed Jan 13 12:49:36 CET 1999 Werner Koch <wk@isil.d.shuttle.de>
|
Wed Jan 13 12:49:36 CET 1999 Werner Koch <wk@isil.d.shuttle.de>
|
||||||
|
|
||||||
* INSTALL: Applied new information how to build rpms by Fabio Coatti
|
* INSTALL: Applied new information how to build rpms by Fabio Coatti
|
||||||
|
6
NEWS
6
NEWS
@ -1,9 +1,11 @@
|
|||||||
|
Noteworthy changes in version 0.9.2
|
||||||
|
-----------------------------------
|
||||||
|
|
||||||
* add some additional time warp checks.
|
* add some additional time warp checks.
|
||||||
|
|
||||||
* Option --keyserver and command --send-keys to utilize HKP servers
|
* Option --keyserver and command --send-keys to utilize HKP servers.
|
||||||
|
|
||||||
* Upgraded to zlib 1.1.3
|
* Upgraded to zlib 1.1.3 and fixed an inflate bug
|
||||||
|
|
||||||
* More cleanup on the cleartext signatures.
|
* More cleanup on the cleartext signatures.
|
||||||
|
|
||||||
|
10
TODO
10
TODO
@ -19,16 +19,6 @@ Important
|
|||||||
|
|
||||||
* print a warning when a revoked/expired secret key is used.
|
* print a warning when a revoked/expired secret key is used.
|
||||||
|
|
||||||
> 0.9.1: I get some occasional segfaults during 'make check' unless I use
|
|
||||||
> --with-included-zlib. It's strange, I have zlib-1.1.2 on one machine, and
|
|
||||||
> zlib-1.1.3 on another, and both of them fail on occasion (maybe half of the
|
|
||||||
[ I hope this is fixed ]
|
|
||||||
|
|
||||||
> gpg: /home/jam/.gnupg/pubring.gpg: can't open gdbm file: Can't be writer
|
|
||||||
> gpg: keyblock resource `/home/jam/.gnupg/pubring.gpg': file open error
|
|
||||||
> gpg: OOPS in close enum_keyblocks - ignored
|
|
||||||
|
|
||||||
|
|
||||||
Needed
|
Needed
|
||||||
------
|
------
|
||||||
* remove more "Fixmes"
|
* remove more "Fixmes"
|
||||||
|
@ -22,6 +22,7 @@
|
|||||||
#include <string.h> /* for memcmp() */
|
#include <string.h> /* for memcmp() */
|
||||||
|
|
||||||
#include "types.h" /* for byte and u32 typedefs */
|
#include "types.h" /* for byte and u32 typedefs */
|
||||||
|
#include "util.h"
|
||||||
#include "errors.h"
|
#include "errors.h"
|
||||||
|
|
||||||
|
|
||||||
|
@ -49,8 +49,8 @@ if test "$use_m_debug" = yes; then
|
|||||||
else
|
else
|
||||||
AC_MSG_CHECKING([whether memory guard is requested])
|
AC_MSG_CHECKING([whether memory guard is requested])
|
||||||
AC_ARG_ENABLE(m-guard,
|
AC_ARG_ENABLE(m-guard,
|
||||||
[ --disable-m-guard disable memory guard facility],
|
[ --enable-m-guard enable memory guard facility],
|
||||||
use_m_guard=$enableval, use_m_guard=yes)
|
use_m_guard=$enableval, use_m_guard=no)
|
||||||
AC_MSG_RESULT($use_m_guard)
|
AC_MSG_RESULT($use_m_guard)
|
||||||
fi
|
fi
|
||||||
if test "$use_m_guard" = yes ; then
|
if test "$use_m_guard" = yes ; then
|
||||||
|
8
debian/changelog
vendored
8
debian/changelog
vendored
@ -1,3 +1,11 @@
|
|||||||
|
gnupg (0.9.2-1) unstable; urgency=low
|
||||||
|
|
||||||
|
* New version.
|
||||||
|
* debian/rules (build): Removed CFLAGS as the default is now sufficient.
|
||||||
|
* debian/rules (clean): remove special handling cleanup in intl.
|
||||||
|
|
||||||
|
-- Werner Koch <wk@isil.d.suttle.de> Wed, 20 Jan 1999 21:23:11 +0100
|
||||||
|
|
||||||
gnupg (0.9.1-1) unstable; urgency=low
|
gnupg (0.9.1-1) unstable; urgency=low
|
||||||
|
|
||||||
* New upstream version.
|
* New upstream version.
|
||||||
|
4
debian/copyright
vendored
4
debian/copyright
vendored
@ -4,13 +4,13 @@ have some bugs and some features may not work at all.
|
|||||||
|
|
||||||
This package was put together by me, James Troup
|
This package was put together by me, James Troup
|
||||||
<james@nocrew.org>, from the sources, which I obtained from
|
<james@nocrew.org>, from the sources, which I obtained from
|
||||||
ftp://ftp.guug.de/pub/gcrypt/gnupg-0.9.1.tar.gz. The changes were
|
ftp://ftp.gnupg.org/pub/gcrypt/gnupg-0.9.2.tar.gz. The changes were
|
||||||
minimal, namely:
|
minimal, namely:
|
||||||
|
|
||||||
- adding support for the Debian package maintenance scheme, by adding
|
- adding support for the Debian package maintenance scheme, by adding
|
||||||
various debian/* files.
|
various debian/* files.
|
||||||
|
|
||||||
Program Copyright (C) 1997, 1998 Werner Koch (dd9jn).
|
Program Copyright (C) 1998, 1999 Free Software Foundation, Inc.
|
||||||
Modifications for Debian Copyright (C) 1998 James Troup.
|
Modifications for Debian Copyright (C) 1998 James Troup.
|
||||||
|
|
||||||
GNUPG is free software; you can redistribute it and/or modify
|
GNUPG is free software; you can redistribute it and/or modify
|
||||||
|
8
debian/rules
vendored
8
debian/rules
vendored
@ -1,5 +1,5 @@
|
|||||||
#!/usr/bin/make -f
|
#!/usr/bin/make -f
|
||||||
# debian/rules file - for GNUPG (0.9.1)
|
# debian/rules file - for GNUPG (0.9.2)
|
||||||
# Based on sample debian/rules file - for GNU Hello (1.3).
|
# Based on sample debian/rules file - for GNU Hello (1.3).
|
||||||
# Copyright 1994,1995 by Ian Jackson.
|
# Copyright 1994,1995 by Ian Jackson.
|
||||||
# Copyright 1998 James Troup
|
# Copyright 1998 James Troup
|
||||||
@ -12,7 +12,7 @@
|
|||||||
build:
|
build:
|
||||||
$(checkdir)
|
$(checkdir)
|
||||||
./configure --prefix=/usr --with-included-gettext
|
./configure --prefix=/usr --with-included-gettext
|
||||||
$(MAKE) CFLAGS="-O2 -g -Wall"
|
$(MAKE)
|
||||||
touch build
|
touch build
|
||||||
|
|
||||||
test: build
|
test: build
|
||||||
@ -25,8 +25,6 @@ clean:
|
|||||||
-rm -f build
|
-rm -f build
|
||||||
-$(MAKE) -i distclean || $(MAKE) -f Makefile.in distclean
|
-$(MAKE) -i distclean || $(MAKE) -f Makefile.in distclean
|
||||||
-rm -rf debian/tmp debian/*~ debian/files* debian/substvars
|
-rm -rf debian/tmp debian/*~ debian/files* debian/substvars
|
||||||
# Cruft not removed by `make clean'
|
|
||||||
-rm -f intl/libintl.h
|
|
||||||
|
|
||||||
binary-indep:
|
binary-indep:
|
||||||
|
|
||||||
@ -63,7 +61,7 @@ endef
|
|||||||
|
|
||||||
# Below here is fairly generic really
|
# Below here is fairly generic really
|
||||||
|
|
||||||
binary: binary-indep binary-arch
|
binary: binary-indep binary-arch
|
||||||
|
|
||||||
checkroot:
|
checkroot:
|
||||||
$(checkdir)
|
$(checkdir)
|
||||||
|
@ -575,7 +575,7 @@ radix64_read( armor_filter_context_t *afx, IOBUF a, size_t *retn,
|
|||||||
byte *buf, size_t size )
|
byte *buf, size_t size )
|
||||||
{
|
{
|
||||||
byte val;
|
byte val;
|
||||||
int c, c2;
|
int c=0, c2; /*init c because gcc is not clever enough for the continue*/
|
||||||
int checkcrc=0;
|
int checkcrc=0;
|
||||||
int rc = 0;
|
int rc = 0;
|
||||||
size_t n = 0;
|
size_t n = 0;
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/* g10.c - The GnuPG utility (main for gpg)
|
/* g10.c - The GnuPG utility (main for gpg)
|
||||||
* Copyright (C) 1998 Free Software Foundation, Inc.
|
* Copyright (C) 1998, 1999 Free Software Foundation, Inc.
|
||||||
*
|
*
|
||||||
* This file is part of GnuPG.
|
* This file is part of GnuPG.
|
||||||
*
|
*
|
||||||
|
@ -126,6 +126,7 @@ hkp_export( STRLIST users )
|
|||||||
iobuf_write( hd.fp_write, iobuf_get_temp_buffer(temp),
|
iobuf_write( hd.fp_write, iobuf_get_temp_buffer(temp),
|
||||||
iobuf_get_temp_length(temp) );
|
iobuf_get_temp_length(temp) );
|
||||||
iobuf_put( hd.fp_write, '\n' );
|
iobuf_put( hd.fp_write, '\n' );
|
||||||
|
iobuf_flush_temp( temp );
|
||||||
iobuf_close(temp);
|
iobuf_close(temp);
|
||||||
|
|
||||||
rc = http_wait_response( &hd, &status );
|
rc = http_wait_response( &hd, &status );
|
||||||
|
@ -279,7 +279,7 @@ proc_plaintext( CTX c, PACKET *pkt )
|
|||||||
md_enable( c->mfx.md, DIGEST_ALGO_SHA1 );
|
md_enable( c->mfx.md, DIGEST_ALGO_SHA1 );
|
||||||
md_enable( c->mfx.md, DIGEST_ALGO_MD5 );
|
md_enable( c->mfx.md, DIGEST_ALGO_MD5 );
|
||||||
}
|
}
|
||||||
md_start_debug( c->mfx.md, "verify" );
|
/*md_start_debug( c->mfx.md, "verify" );*/
|
||||||
rc = handle_plaintext( pt, &c->mfx, c->sigs_only, clearsig );
|
rc = handle_plaintext( pt, &c->mfx, c->sigs_only, clearsig );
|
||||||
if( rc == G10ERR_CREATE_FILE && !c->sigs_only) {
|
if( rc == G10ERR_CREATE_FILE && !c->sigs_only) {
|
||||||
/* can't write output but we hash it anyway to
|
/* can't write output but we hash it anyway to
|
||||||
|
@ -646,7 +646,7 @@ clearsign_file( const char *fname, STRLIST locusr, const char *outfile )
|
|||||||
PKT_secret_key *sk = sk_rover->sk;
|
PKT_secret_key *sk = sk_rover->sk;
|
||||||
md_enable(textmd, hash_for(sk->pubkey_algo));
|
md_enable(textmd, hash_for(sk->pubkey_algo));
|
||||||
}
|
}
|
||||||
md_start_debug( textmd, "sign" );
|
/*md_start_debug( textmd, "sign" );*/
|
||||||
tfx.clearsign = 1;
|
tfx.clearsign = 1;
|
||||||
tfx.not_dash_escaped = opt.not_dash_escaped;
|
tfx.not_dash_escaped = opt.not_dash_escaped;
|
||||||
tfx.escape_from = opt.escape_from;
|
tfx.escape_from = opt.escape_from;
|
||||||
|
@ -56,7 +56,7 @@ static int
|
|||||||
is_insecure( PKT_secret_key *sk )
|
is_insecure( PKT_secret_key *sk )
|
||||||
{
|
{
|
||||||
|
|
||||||
BUG();
|
return 0; /* FIXME!! */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -8,6 +8,7 @@ types.h
|
|||||||
util.h
|
util.h
|
||||||
i18n.h
|
i18n.h
|
||||||
host2net.h
|
host2net.h
|
||||||
|
http.h
|
||||||
|
|
||||||
g10lib.h
|
g10lib.h
|
||||||
|
|
||||||
|
23
mpi/mips3/README
Normal file
23
mpi/mips3/README
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
This directory contains mpn functions optimized for MIPS3. Example of
|
||||||
|
processors that implement MIPS3 are R4000, R4400, R4600, R4700, and R8000.
|
||||||
|
|
||||||
|
RELEVANT OPTIMIZATION ISSUES
|
||||||
|
|
||||||
|
1. On the R4000 and R4400, branches, both the plain and the "likely" ones,
|
||||||
|
take 3 cycles to execute. (The fastest possible loop will take 4 cycles,
|
||||||
|
because of the delay insn.)
|
||||||
|
|
||||||
|
On the R4600, branches takes a single cycle
|
||||||
|
|
||||||
|
On the R8000, branches often take no noticable cycles, as they are
|
||||||
|
executed in a separate function unit..
|
||||||
|
|
||||||
|
2. The R4000 and R4400 have a load latency of 4 cycles.
|
||||||
|
|
||||||
|
3. On the R4000 and R4400, multiplies take a data-dependent number of
|
||||||
|
cycles, contrary to the SGI documentation. There seem to be 3 or 4
|
||||||
|
possible latencies.
|
||||||
|
|
||||||
|
STATUS
|
||||||
|
|
||||||
|
Good...
|
@ -1,3 +1,7 @@
|
|||||||
|
Wed Jan 20 21:40:21 CET 1999 Werner Koch <wk@isil.d.shuttle.de>
|
||||||
|
|
||||||
|
* es_ES.po: Import of new version.
|
||||||
|
|
||||||
Wed Jan 13 12:49:36 CET 1999 Werner Koch <wk@isil.d.shuttle.de>
|
Wed Jan 13 12:49:36 CET 1999 Werner Koch <wk@isil.d.shuttle.de>
|
||||||
|
|
||||||
* de.po de.glo: New version imported.
|
* de.po de.glo: New version imported.
|
||||||
|
34
po/de.glo
34
po/de.glo
@ -9,21 +9,21 @@ algorithm Verfahren
|
|||||||
anonymous ungenannter
|
anonymous ungenannter
|
||||||
armor ASCII-Hülle
|
armor ASCII-Hülle
|
||||||
available vorhanden [besser?: verfügbar]
|
available vorhanden [besser?: verfügbar]
|
||||||
bad [signature] falsch[e] Unterschrift
|
bad [signature] falsch[e] Unterschrift
|
||||||
bug "Bug (Programmfehler)"
|
bug "Bug (Programmfehler)"
|
||||||
cache Lager [ ob das ernst gemeint ist? :-) ]
|
cache Lager [ ob das ernst gemeint ist? :-) ]
|
||||||
certificate Zertifikat
|
certificate Zertifikat
|
||||||
character set Zeichensatz
|
character set Zeichensatz
|
||||||
checksum Prüfsumme
|
checksum Prüfsumme
|
||||||
cipher algorithm Verschlüsselungsverfahren
|
cipher algorithm Verschlüsselungsverfahren
|
||||||
clearsig header Klartextsignatur-Einleitung
|
clearsig header Klartextsignatur-Einleitung
|
||||||
command Befehl
|
command Befehl
|
||||||
compress algorithm Komprimierverfahren *
|
compress algorithm Komprimierverfahren *
|
||||||
core dump core-dump-Datei
|
core dump core-dump-Datei
|
||||||
corrupted beschädigter
|
corrupted beschädigter
|
||||||
dash escaped mit Bindestrich \"escapte\"
|
dash escaped mit Bindestrich \"escapte\"
|
||||||
decryption Enschlüsselung
|
decryption Enschlüsselung
|
||||||
DEK ???
|
DEK ???
|
||||||
delete entfernen
|
delete entfernen
|
||||||
depreciated nicht viel wert
|
depreciated nicht viel wert
|
||||||
digest algorithm Hashmethode
|
digest algorithm Hashmethode
|
||||||
@ -31,7 +31,7 @@ disabled abgeschaltet
|
|||||||
encrypted verschlüsselte
|
encrypted verschlüsselte
|
||||||
expire date Verfallsdatum
|
expire date Verfallsdatum
|
||||||
failed fehlgeschlagen
|
failed fehlgeschlagen
|
||||||
fingerprint Fingerabdruck
|
fingerprint Fingerabdruck
|
||||||
for-your-eyes-only Vertraulichkeit (\"for-your-eyes-only\")
|
for-your-eyes-only Vertraulichkeit (\"for-your-eyes-only\")
|
||||||
generated erzeugter
|
generated erzeugter
|
||||||
good certificate Korrektes Zertifikat
|
good certificate Korrektes Zertifikat
|
||||||
@ -44,7 +44,7 @@ main key Hauptschl
|
|||||||
maintenance utility Wartungs-Hilfsprogramm
|
maintenance utility Wartungs-Hilfsprogramm
|
||||||
malformed ungünstig aufgebaute
|
malformed ungünstig aufgebaute
|
||||||
message Botschaft
|
message Botschaft
|
||||||
mode Modus, Methode *
|
mode Modus, Methode *
|
||||||
move schieben
|
move schieben
|
||||||
note Hinweis
|
note Hinweis
|
||||||
okay in Ordnung
|
okay in Ordnung
|
||||||
@ -61,8 +61,8 @@ primary keys Hauptschl
|
|||||||
protection algorithm Schutzverfahren
|
protection algorithm Schutzverfahren
|
||||||
pubkey algorithm Public-Key Verfahren (*)
|
pubkey algorithm Public-Key Verfahren (*)
|
||||||
public key öffentlicher Schüssel
|
public key öffentlicher Schüssel
|
||||||
public key algorithm Public-Key Verfahren
|
public key algorithm Public-Key Verfahren
|
||||||
radix64 radix64
|
radix64 radix64
|
||||||
retry ????
|
retry ????
|
||||||
revo... Widerruf
|
revo... Widerruf
|
||||||
secondary key Zweitschlüssel
|
secondary key Zweitschlüssel
|
||||||
@ -70,16 +70,16 @@ secret key geheimer Schl
|
|||||||
self-signature Eigenbeglaubigung
|
self-signature Eigenbeglaubigung
|
||||||
sender Absender
|
sender Absender
|
||||||
sign user id User-ID beglaubigen *
|
sign user id User-ID beglaubigen *
|
||||||
signature (files) Unterschrift *
|
signature (files) Unterschrift *
|
||||||
signature (keys) Beglaubigung *
|
signature (keys) Beglaubigung *
|
||||||
simple S2K mode ????
|
simple S2K mode ????
|
||||||
skipped übergangen, übersprungen, ignoriert
|
skipped übergangen, übersprungen, ignoriert
|
||||||
stdin - stdin
|
stdin - stdin
|
||||||
terminal charset Terminalzeichensatz
|
terminal charset Terminalzeichensatz
|
||||||
throw verwerfe
|
throw verwerfe
|
||||||
Timestamp conflict Zeitangaben differieren
|
Timestamp conflict Zeitangaben differieren
|
||||||
Trust-DB 'Trust'-Datenbank
|
Trust-DB 'Trust'-Datenbank
|
||||||
trusted - vertrauenswürdig
|
trusted - vertrauenswürdig
|
||||||
trustvalues - trustvalues
|
trustvalues - trustvalues
|
||||||
trying Versuch
|
trying Versuch
|
||||||
type [message] [Botschaft] eintippen
|
type [message] [Botschaft] eintippen
|
||||||
@ -90,8 +90,10 @@ user ID User-ID
|
|||||||
user IDs User-IDs
|
user IDs User-IDs
|
||||||
username Username
|
username Username
|
||||||
untrusted - nichtvertruenswürdigen
|
untrusted - nichtvertruenswürdigen
|
||||||
warning Warnung
|
warning Warnung
|
||||||
weak key unsicherer Schlüssel
|
weak key unsicherer Schlüssel
|
||||||
|
|
||||||
(*) Uneinheitlich verwendet
|
(*) Uneinheitlich verwendet
|
||||||
- Gefällt mir nicht so toll
|
- Gefällt mir nicht so toll
|
||||||
|
|
||||||
|
|
||||||
|
1254
po/es_ES.po
1254
po/es_ES.po
File diff suppressed because it is too large
Load Diff
518
po/pt_BR.po
518
po/pt_BR.po
File diff suppressed because it is too large
Load Diff
2
scripts/config.sub
vendored
2
scripts/config.sub
vendored
@ -968,7 +968,7 @@ case $os in
|
|||||||
-xenix)
|
-xenix)
|
||||||
os=-xenix
|
os=-xenix
|
||||||
;;
|
;;
|
||||||
-MiNT | -mint)
|
-mint)
|
||||||
os=-mint
|
os=-mint
|
||||||
;;
|
;;
|
||||||
-none)
|
-none)
|
||||||
|
@ -1,3 +1,7 @@
|
|||||||
|
Wed Jan 20 21:40:21 CET 1999 Werner Koch <wk@isil.d.shuttle.de>
|
||||||
|
|
||||||
|
* http.c (http_wait_response): Moved the shutdown behind the dup
|
||||||
|
|
||||||
Wed Jan 20 18:59:49 CET 1999 Werner Koch <wk@isil.d.shuttle.de>
|
Wed Jan 20 18:59:49 CET 1999 Werner Koch <wk@isil.d.shuttle.de>
|
||||||
|
|
||||||
* http.c (send_request): Removed double LF
|
* http.c (send_request): Removed double LF
|
||||||
|
@ -118,14 +118,14 @@ http_wait_response( HTTP_HD hd, unsigned int *ret_status )
|
|||||||
|
|
||||||
http_start_data( hd ); /* make sure that we are in the data */
|
http_start_data( hd ); /* make sure that we are in the data */
|
||||||
iobuf_flush( hd->fp_write );
|
iobuf_flush( hd->fp_write );
|
||||||
shutdown( hd->socket, 1 );
|
|
||||||
hd->in_data = 0;
|
|
||||||
|
|
||||||
hd->socket = dup( hd->socket );
|
hd->socket = dup( hd->socket );
|
||||||
if( hd->socket == -1 )
|
if( hd->socket == -1 )
|
||||||
return G10ERR_GENERAL;
|
return G10ERR_GENERAL;
|
||||||
iobuf_close( hd->fp_write );
|
iobuf_close( hd->fp_write );
|
||||||
hd->fp_write = NULL;
|
hd->fp_write = NULL;
|
||||||
|
shutdown( hd->socket, 1 );
|
||||||
|
hd->in_data = 0;
|
||||||
|
|
||||||
hd->fp_read = iobuf_fdopen( hd->socket , "r" );
|
hd->fp_read = iobuf_fdopen( hd->socket , "r" );
|
||||||
if( !hd->fp_read )
|
if( !hd->fp_read )
|
||||||
@ -674,6 +674,7 @@ write_server( int socket, const char *data, size_t length )
|
|||||||
select(0, NULL, NULL, NULL, &tv);
|
select(0, NULL, NULL, NULL, &tv);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
log_info("write failed: %s\n", strerror(errno));
|
||||||
return G10ERR_NETWORK;
|
return G10ERR_NETWORK;
|
||||||
}
|
}
|
||||||
nleft -=nwritten;
|
nleft -=nwritten;
|
||||||
|
@ -1,3 +1,7 @@
|
|||||||
|
Wed Jan 20 21:40:21 CET 1999 Werner Koch <wk@isil.d.shuttle.de>
|
||||||
|
|
||||||
|
* Makefile.am: Corrected the list of sources
|
||||||
|
|
||||||
Wed Jan 13 14:10:15 CET 1999 Werner Koch <wk@isil.d.shuttle.de>
|
Wed Jan 13 14:10:15 CET 1999 Werner Koch <wk@isil.d.shuttle.de>
|
||||||
|
|
||||||
|
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
|
|
||||||
CFLAGS = -O -Wall
|
CFLAGS = -O -Wall
|
||||||
|
|
||||||
EXTRA_DIST = README algorithm.doc ChangeLog example.c
|
EXTRA_DIST = README algorithm.doc ChangeLog
|
||||||
|
|
||||||
# I found no other easy way to use this only if zlib is neede
|
# I found no other easy way to use this only if zlib is neede
|
||||||
# doing this with SUBDIR = @xxx@ in the top Makefile.am does not
|
# doing this with SUBDIR = @xxx@ in the top Makefile.am does not
|
||||||
@ -15,15 +15,16 @@ noinst_LIBRARIES = libzlib.a
|
|||||||
endif
|
endif
|
||||||
|
|
||||||
|
|
||||||
libzlib_a_SOURCES = adler32.c compress.c crc32.c gzio.c \
|
libzlib_a_SOURCES = adler32.c compress.c crc32.c \
|
||||||
uncompr.c deflate.c trees.c zutil.c \
|
uncompr.c deflate.c trees.c zutil.c \
|
||||||
inflate.c infblock.c inftrees.c \
|
inflate.c infblock.c inftrees.c \
|
||||||
infcodes.c infutil.c inffast.c \
|
infcodes.c infutil.c inffast.c \
|
||||||
zlib.h zconf.h deflate.h infblock.h \
|
deflate.h infblock.h infcodes.h inffast.h \
|
||||||
infcodes.h inffast.h inftrees.h infutil.h zutil.h
|
inffixed.h inftrees.h infutil.h trees.h \
|
||||||
|
zconf.h zlib.h zutil.h
|
||||||
|
|
||||||
|
|
||||||
CLEANFILES = example foo.gz
|
CLEANFILES = foo.gz
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,29 +0,0 @@
|
|||||||
# Process this file with automake to produce Makefile.in
|
|
||||||
# Copyright (C) 1995-1996 Jean-loup Gailly.
|
|
||||||
# For conditions of distribution and use, see copyright notice in zlib.h
|
|
||||||
# This is used if a systems lacks support of zlib
|
|
||||||
|
|
||||||
CFLAGS = -O -Wall
|
|
||||||
|
|
||||||
EXTRA_DIST = README algorithm.doc ChangeLog gzio.c example.c
|
|
||||||
|
|
||||||
# I found no other easy way to use this only if zlib is neede
|
|
||||||
# doing this with SUBDIR = @xxx@ in the top Makefile.am does not
|
|
||||||
# work because automake doesn't scan this Makefile.am here.
|
|
||||||
if ENABLE_LOCAL_ZLIB
|
|
||||||
noinst_LIBRARIES = libzlib.a
|
|
||||||
endif
|
|
||||||
|
|
||||||
|
|
||||||
libzlib_a_SOURCES = adler32.c compress.c crc32.c \
|
|
||||||
uncompr.c deflate.c trees.c zutil.c \
|
|
||||||
inflate.c infblock.c inftrees.c \
|
|
||||||
infcodes.c infutil.c inffast.c \
|
|
||||||
zlib.h zconf.h deflate.h infblock.h \
|
|
||||||
infcodes.h inffast.h inftrees.h infutil.h zutil.h
|
|
||||||
|
|
||||||
|
|
||||||
CLEANFILES = example foo.gz
|
|
||||||
|
|
||||||
|
|
||||||
|
|
875
zlib/gzio.c
875
zlib/gzio.c
@ -1,875 +0,0 @@
|
|||||||
/* gzio.c -- IO on .gz files
|
|
||||||
* Copyright (C) 1995-1998 Jean-loup Gailly.
|
|
||||||
* For conditions of distribution and use, see copyright notice in zlib.h
|
|
||||||
*
|
|
||||||
* Compile this file with -DNO_DEFLATE to avoid the compression code.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* @(#) $Id$ */
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
|
|
||||||
#include "zutil.h"
|
|
||||||
|
|
||||||
struct internal_state {int dummy;}; /* for buggy compilers */
|
|
||||||
|
|
||||||
#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 TRYFREE(p) {if (p) free(p);}
|
|
||||||
|
|
||||||
static int gz_magic[2] = {0x1f, 0x8b}; /* gzip magic header */
|
|
||||||
|
|
||||||
/* gzip flag byte */
|
|
||||||
#define ASCII_FLAG 0x01 /* bit 0 set: file probably ascii text */
|
|
||||||
#define HEAD_CRC 0x02 /* bit 1 set: header CRC present */
|
|
||||||
#define EXTRA_FIELD 0x04 /* bit 2 set: extra field present */
|
|
||||||
#define ORIG_NAME 0x08 /* bit 3 set: original file name present */
|
|
||||||
#define COMMENT 0x10 /* bit 4 set: file comment present */
|
|
||||||
#define RESERVED 0xE0 /* bits 5..7: reserved */
|
|
||||||
|
|
||||||
typedef struct gz_stream {
|
|
||||||
z_stream stream;
|
|
||||||
int z_err; /* error code for last stream operation */
|
|
||||||
int z_eof; /* set if end of input file */
|
|
||||||
FILE *file; /* .gz file */
|
|
||||||
Byte *inbuf; /* input buffer */
|
|
||||||
Byte *outbuf; /* output buffer */
|
|
||||||
uLong crc; /* crc32 of uncompressed data */
|
|
||||||
char *msg; /* error message */
|
|
||||||
char *path; /* path name for debugging only */
|
|
||||||
int transparent; /* 1 if input file is not a .gz file */
|
|
||||||
char mode; /* 'w' or 'r' */
|
|
||||||
long startpos; /* start of compressed data in file (header skipped) */
|
|
||||||
} gz_stream;
|
|
||||||
|
|
||||||
|
|
||||||
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 void check_header OF((gz_stream *s));
|
|
||||||
local int destroy OF((gz_stream *s));
|
|
||||||
local void putLong OF((FILE *file, uLong x));
|
|
||||||
local uLong getLong OF((gz_stream *s));
|
|
||||||
|
|
||||||
/* ===========================================================================
|
|
||||||
Opens a gzip (.gz) file for reading or writing. The mode parameter
|
|
||||||
is as in fopen ("rb" or "wb"). The file is given either by file descriptor
|
|
||||||
or path name (if fd == -1).
|
|
||||||
gz_open return NULL if the file could not be opened or if there was
|
|
||||||
insufficient memory to allocate the (de)compression state; errno
|
|
||||||
can be checked to distinguish the two cases (if errno is zero, the
|
|
||||||
zlib error is Z_MEM_ERROR).
|
|
||||||
*/
|
|
||||||
local gzFile gz_open (path, mode, fd)
|
|
||||||
const char *path;
|
|
||||||
const char *mode;
|
|
||||||
int fd;
|
|
||||||
{
|
|
||||||
int err;
|
|
||||||
int level = Z_DEFAULT_COMPRESSION; /* compression level */
|
|
||||||
int strategy = Z_DEFAULT_STRATEGY; /* compression strategy */
|
|
||||||
char *p = (char*)mode;
|
|
||||||
gz_stream *s;
|
|
||||||
char fmode[80]; /* copy of mode, without the compression level */
|
|
||||||
char *m = fmode;
|
|
||||||
|
|
||||||
if (!path || !mode) return Z_NULL;
|
|
||||||
|
|
||||||
s = (gz_stream *)ALLOC(sizeof(gz_stream));
|
|
||||||
if (!s) return Z_NULL;
|
|
||||||
|
|
||||||
s->stream.zalloc = (alloc_func)0;
|
|
||||||
s->stream.zfree = (free_func)0;
|
|
||||||
s->stream.opaque = (voidpf)0;
|
|
||||||
s->stream.next_in = s->inbuf = Z_NULL;
|
|
||||||
s->stream.next_out = s->outbuf = Z_NULL;
|
|
||||||
s->stream.avail_in = s->stream.avail_out = 0;
|
|
||||||
s->file = NULL;
|
|
||||||
s->z_err = Z_OK;
|
|
||||||
s->z_eof = 0;
|
|
||||||
s->crc = crc32(0L, Z_NULL, 0);
|
|
||||||
s->msg = NULL;
|
|
||||||
s->transparent = 0;
|
|
||||||
|
|
||||||
s->path = (char*)ALLOC(strlen(path)+1);
|
|
||||||
if (s->path == NULL) {
|
|
||||||
return destroy(s), (gzFile)Z_NULL;
|
|
||||||
}
|
|
||||||
strcpy(s->path, path); /* do this early for debugging */
|
|
||||||
|
|
||||||
s->mode = '\0';
|
|
||||||
do {
|
|
||||||
if (*p == 'r') s->mode = 'r';
|
|
||||||
if (*p == 'w' || *p == 'a') s->mode = 'w';
|
|
||||||
if (*p >= '0' && *p <= '9') {
|
|
||||||
level = *p - '0';
|
|
||||||
} else if (*p == 'f') {
|
|
||||||
strategy = Z_FILTERED;
|
|
||||||
} else if (*p == 'h') {
|
|
||||||
strategy = Z_HUFFMAN_ONLY;
|
|
||||||
} else {
|
|
||||||
*m++ = *p; /* copy the mode */
|
|
||||||
}
|
|
||||||
} while (*p++ && m != fmode + sizeof(fmode));
|
|
||||||
if (s->mode == '\0') return destroy(s), (gzFile)Z_NULL;
|
|
||||||
|
|
||||||
if (s->mode == 'w') {
|
|
||||||
#ifdef NO_DEFLATE
|
|
||||||
err = Z_STREAM_ERROR;
|
|
||||||
#else
|
|
||||||
err = deflateInit2(&(s->stream), level,
|
|
||||||
Z_DEFLATED, -MAX_WBITS, DEF_MEM_LEVEL, strategy);
|
|
||||||
/* windowBits is passed < 0 to suppress zlib header */
|
|
||||||
|
|
||||||
s->stream.next_out = s->outbuf = (Byte*)ALLOC(Z_BUFSIZE);
|
|
||||||
#endif
|
|
||||||
if (err != Z_OK || s->outbuf == Z_NULL) {
|
|
||||||
return destroy(s), (gzFile)Z_NULL;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
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) {
|
|
||||||
return destroy(s), (gzFile)Z_NULL;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
s->stream.avail_out = Z_BUFSIZE;
|
|
||||||
|
|
||||||
errno = 0;
|
|
||||||
s->file = fd < 0 ? F_OPEN(path, fmode) : (FILE*)fdopen(fd, fmode);
|
|
||||||
|
|
||||||
if (s->file == NULL) {
|
|
||||||
return destroy(s), (gzFile)Z_NULL;
|
|
||||||
}
|
|
||||||
if (s->mode == 'w') {
|
|
||||||
/* Write a very simple .gz header:
|
|
||||||
*/
|
|
||||||
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);
|
|
||||||
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 {
|
|
||||||
check_header(s); /* skip the .gz header */
|
|
||||||
s->startpos = (ftell(s->file) - s->stream.avail_in);
|
|
||||||
}
|
|
||||||
|
|
||||||
return (gzFile)s;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ===========================================================================
|
|
||||||
Opens a gzip (.gz) file for reading or writing.
|
|
||||||
*/
|
|
||||||
gzFile ZEXPORT gzopen (path, mode)
|
|
||||||
const char *path;
|
|
||||||
const char *mode;
|
|
||||||
{
|
|
||||||
return gz_open (path, mode, -1);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ===========================================================================
|
|
||||||
Associate a gzFile with the file descriptor fd. fd is not dup'ed here
|
|
||||||
to mimic the behavio(u)r of fdopen.
|
|
||||||
*/
|
|
||||||
gzFile ZEXPORT gzdopen (fd, mode)
|
|
||||||
int fd;
|
|
||||||
const char *mode;
|
|
||||||
{
|
|
||||||
char name[20];
|
|
||||||
|
|
||||||
if (fd < 0) return (gzFile)Z_NULL;
|
|
||||||
sprintf(name, "<fd:%d>", fd); /* for debugging */
|
|
||||||
|
|
||||||
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
|
|
||||||
for end of file.
|
|
||||||
IN assertion: the stream s has been sucessfully opened for reading.
|
|
||||||
*/
|
|
||||||
local int get_byte(s)
|
|
||||||
gz_stream *s;
|
|
||||||
{
|
|
||||||
if (s->z_eof) return EOF;
|
|
||||||
if (s->stream.avail_in == 0) {
|
|
||||||
errno = 0;
|
|
||||||
s->stream.avail_in = fread(s->inbuf, 1, Z_BUFSIZE, s->file);
|
|
||||||
if (s->stream.avail_in == 0) {
|
|
||||||
s->z_eof = 1;
|
|
||||||
if (ferror(s->file)) s->z_err = Z_ERRNO;
|
|
||||||
return EOF;
|
|
||||||
}
|
|
||||||
s->stream.next_in = s->inbuf;
|
|
||||||
}
|
|
||||||
s->stream.avail_in--;
|
|
||||||
return *(s->stream.next_in)++;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ===========================================================================
|
|
||||||
Check the gzip header of a gz_stream opened for reading. Set the stream
|
|
||||||
mode to transparent if the gzip magic header is not present; set s->err
|
|
||||||
to Z_DATA_ERROR if the magic header is present but the rest of the header
|
|
||||||
is incorrect.
|
|
||||||
IN assertion: the stream s has already been created sucessfully;
|
|
||||||
s->stream.avail_in is zero for the first time, but may be non-zero
|
|
||||||
for concatenated .gz files.
|
|
||||||
*/
|
|
||||||
local void check_header(s)
|
|
||||||
gz_stream *s;
|
|
||||||
{
|
|
||||||
int method; /* method byte */
|
|
||||||
int flags; /* flags byte */
|
|
||||||
uInt len;
|
|
||||||
int c;
|
|
||||||
|
|
||||||
/* Check the gzip magic header */
|
|
||||||
for (len = 0; len < 2; len++) {
|
|
||||||
c = get_byte(s);
|
|
||||||
if (c != gz_magic[len]) {
|
|
||||||
if (len != 0) 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;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
method = get_byte(s);
|
|
||||||
flags = get_byte(s);
|
|
||||||
if (method != Z_DEFLATED || (flags & RESERVED) != 0) {
|
|
||||||
s->z_err = Z_DATA_ERROR;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Discard time, xflags and OS code: */
|
|
||||||
for (len = 0; len < 6; len++) (void)get_byte(s);
|
|
||||||
|
|
||||||
if ((flags & EXTRA_FIELD) != 0) { /* skip the extra field */
|
|
||||||
len = (uInt)get_byte(s);
|
|
||||||
len += ((uInt)get_byte(s))<<8;
|
|
||||||
/* len is garbage if EOF but the loop below will quit anyway */
|
|
||||||
while (len-- != 0 && get_byte(s) != EOF) ;
|
|
||||||
}
|
|
||||||
if ((flags & ORIG_NAME) != 0) { /* skip the original file name */
|
|
||||||
while ((c = get_byte(s)) != 0 && c != EOF) ;
|
|
||||||
}
|
|
||||||
if ((flags & COMMENT) != 0) { /* skip the .gz file comment */
|
|
||||||
while ((c = get_byte(s)) != 0 && c != EOF) ;
|
|
||||||
}
|
|
||||||
if ((flags & HEAD_CRC) != 0) { /* skip the header crc */
|
|
||||||
for (len = 0; len < 2; len++) (void)get_byte(s);
|
|
||||||
}
|
|
||||||
s->z_err = s->z_eof ? Z_DATA_ERROR : Z_OK;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ===========================================================================
|
|
||||||
* Cleanup then free the given gz_stream. Return a zlib error code.
|
|
||||||
Try freeing in the reverse order of allocations.
|
|
||||||
*/
|
|
||||||
local int destroy (s)
|
|
||||||
gz_stream *s;
|
|
||||||
{
|
|
||||||
int err = Z_OK;
|
|
||||||
|
|
||||||
if (!s) return Z_STREAM_ERROR;
|
|
||||||
|
|
||||||
TRYFREE(s->msg);
|
|
||||||
|
|
||||||
if (s->stream.state != NULL) {
|
|
||||||
if (s->mode == 'w') {
|
|
||||||
#ifdef NO_DEFLATE
|
|
||||||
err = Z_STREAM_ERROR;
|
|
||||||
#else
|
|
||||||
err = deflateEnd(&(s->stream));
|
|
||||||
#endif
|
|
||||||
} else if (s->mode == 'r') {
|
|
||||||
err = inflateEnd(&(s->stream));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (s->file != NULL && fclose(s->file)) {
|
|
||||||
#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;
|
|
||||||
|
|
||||||
TRYFREE(s->inbuf);
|
|
||||||
TRYFREE(s->outbuf);
|
|
||||||
TRYFREE(s->path);
|
|
||||||
TRYFREE(s);
|
|
||||||
return err;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ===========================================================================
|
|
||||||
Reads the given number of uncompressed bytes from the compressed file.
|
|
||||||
gzread returns the number of bytes actually read (0 for end of file).
|
|
||||||
*/
|
|
||||||
int ZEXPORT gzread (file, buf, len)
|
|
||||||
gzFile file;
|
|
||||||
voidp buf;
|
|
||||||
unsigned len;
|
|
||||||
{
|
|
||||||
gz_stream *s = (gz_stream*)file;
|
|
||||||
Bytef *start = (Bytef*)buf; /* starting point for crc computation */
|
|
||||||
Byte *next_out; /* == stream.next_out but not forced far (for MSDOS) */
|
|
||||||
|
|
||||||
if (s == NULL || s->mode != 'r') return Z_STREAM_ERROR;
|
|
||||||
|
|
||||||
if (s->z_err == Z_DATA_ERROR || s->z_err == Z_ERRNO) return -1;
|
|
||||||
if (s->z_err == Z_STREAM_END) return 0; /* EOF */
|
|
||||||
|
|
||||||
next_out = (Byte*)buf;
|
|
||||||
s->stream.next_out = (Bytef*)buf;
|
|
||||||
s->stream.avail_out = len;
|
|
||||||
|
|
||||||
while (s->stream.avail_out != 0) {
|
|
||||||
|
|
||||||
if (s->transparent) {
|
|
||||||
/* Copy first the lookahead bytes: */
|
|
||||||
uInt n = s->stream.avail_in;
|
|
||||||
if (n > s->stream.avail_out) n = s->stream.avail_out;
|
|
||||||
if (n > 0) {
|
|
||||||
zmemcpy(s->stream.next_out, s->stream.next_in, n);
|
|
||||||
next_out += n;
|
|
||||||
s->stream.next_out = next_out;
|
|
||||||
s->stream.next_in += n;
|
|
||||||
s->stream.avail_out -= n;
|
|
||||||
s->stream.avail_in -= n;
|
|
||||||
}
|
|
||||||
if (s->stream.avail_out > 0) {
|
|
||||||
s->stream.avail_out -= fread(next_out, 1, s->stream.avail_out,
|
|
||||||
s->file);
|
|
||||||
}
|
|
||||||
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) {
|
|
||||||
|
|
||||||
errno = 0;
|
|
||||||
s->stream.avail_in = fread(s->inbuf, 1, Z_BUFSIZE, s->file);
|
|
||||||
if (s->stream.avail_in == 0) {
|
|
||||||
s->z_eof = 1;
|
|
||||||
if (ferror(s->file)) {
|
|
||||||
s->z_err = Z_ERRNO;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
s->stream.next_in = s->inbuf;
|
|
||||||
}
|
|
||||||
s->z_err = inflate(&(s->stream), Z_NO_FLUSH);
|
|
||||||
|
|
||||||
if (s->z_err == Z_STREAM_END) {
|
|
||||||
/* Check CRC and original size */
|
|
||||||
s->crc = crc32(s->crc, start, (uInt)(s->stream.next_out - start));
|
|
||||||
start = s->stream.next_out;
|
|
||||||
|
|
||||||
if (getLong(s) != s->crc) {
|
|
||||||
s->z_err = Z_DATA_ERROR;
|
|
||||||
} else {
|
|
||||||
(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);
|
|
||||||
if (s->z_err == Z_OK) {
|
|
||||||
uLong total_in = s->stream.total_in;
|
|
||||||
uLong total_out = s->stream.total_out;
|
|
||||||
|
|
||||||
inflateReset(&(s->stream));
|
|
||||||
s->stream.total_in = total_in;
|
|
||||||
s->stream.total_out = total_out;
|
|
||||||
s->crc = crc32(0L, Z_NULL, 0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (s->z_err != Z_OK || s->z_eof) break;
|
|
||||||
}
|
|
||||||
s->crc = crc32(s->crc, start, (uInt)(s->stream.next_out - start));
|
|
||||||
|
|
||||||
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.
|
|
||||||
gzwrite returns the number of bytes actually written (0 in case of error).
|
|
||||||
*/
|
|
||||||
int ZEXPORT gzwrite (file, buf, len)
|
|
||||||
gzFile file;
|
|
||||||
const voidp buf;
|
|
||||||
unsigned len;
|
|
||||||
{
|
|
||||||
gz_stream *s = (gz_stream*)file;
|
|
||||||
|
|
||||||
if (s == NULL || s->mode != 'w') return Z_STREAM_ERROR;
|
|
||||||
|
|
||||||
s->stream.next_in = (Bytef*)buf;
|
|
||||||
s->stream.avail_in = len;
|
|
||||||
|
|
||||||
while (s->stream.avail_in != 0) {
|
|
||||||
|
|
||||||
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;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
s->stream.avail_out = Z_BUFSIZE;
|
|
||||||
}
|
|
||||||
s->z_err = deflate(&(s->stream), Z_NO_FLUSH);
|
|
||||||
if (s->z_err != Z_OK) break;
|
|
||||||
}
|
|
||||||
s->crc = crc32(s->crc, (const Bytef *)buf, len);
|
|
||||||
|
|
||||||
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
|
|
||||||
flush is as in the deflate() function.
|
|
||||||
*/
|
|
||||||
local int do_flush (file, flush)
|
|
||||||
gzFile file;
|
|
||||||
int flush;
|
|
||||||
{
|
|
||||||
uInt len;
|
|
||||||
int done = 0;
|
|
||||||
gz_stream *s = (gz_stream*)file;
|
|
||||||
|
|
||||||
if (s == NULL || s->mode != 'w') return Z_STREAM_ERROR;
|
|
||||||
|
|
||||||
s->stream.avail_in = 0; /* should be zero already anyway */
|
|
||||||
|
|
||||||
for (;;) {
|
|
||||||
len = Z_BUFSIZE - s->stream.avail_out;
|
|
||||||
|
|
||||||
if (len != 0) {
|
|
||||||
if ((uInt)fwrite(s->outbuf, 1, len, s->file) != len) {
|
|
||||||
s->z_err = Z_ERRNO;
|
|
||||||
return Z_ERRNO;
|
|
||||||
}
|
|
||||||
s->stream.next_out = s->outbuf;
|
|
||||||
s->stream.avail_out = Z_BUFSIZE;
|
|
||||||
}
|
|
||||||
if (done) break;
|
|
||||||
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
|
|
||||||
* all the available space in the output buffer:
|
|
||||||
*/
|
|
||||||
done = (s->stream.avail_out != 0 || s->z_err == Z_STREAM_END);
|
|
||||||
|
|
||||||
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);
|
|
||||||
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
|
|
||||||
*/
|
|
||||||
local void putLong (file, x)
|
|
||||||
FILE *file;
|
|
||||||
uLong x;
|
|
||||||
{
|
|
||||||
int n;
|
|
||||||
for (n = 0; n < 4; n++) {
|
|
||||||
fputc((int)(x & 0xff), file);
|
|
||||||
x >>= 8;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ===========================================================================
|
|
||||||
Reads a long in LSB order from the given gz_stream. Sets z_err in case
|
|
||||||
of error.
|
|
||||||
*/
|
|
||||||
local uLong getLong (s)
|
|
||||||
gz_stream *s;
|
|
||||||
{
|
|
||||||
uLong x = (uLong)get_byte(s);
|
|
||||||
int c;
|
|
||||||
|
|
||||||
x += ((uLong)get_byte(s))<<8;
|
|
||||||
x += ((uLong)get_byte(s))<<16;
|
|
||||||
c = get_byte(s);
|
|
||||||
if (c == EOF) s->z_err = Z_DATA_ERROR;
|
|
||||||
x += ((uLong)c)<<24;
|
|
||||||
return x;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ===========================================================================
|
|
||||||
Flushes all pending output if necessary, closes the compressed file
|
|
||||||
and deallocates all the (de)compression state.
|
|
||||||
*/
|
|
||||||
int ZEXPORT gzclose (file)
|
|
||||||
gzFile file;
|
|
||||||
{
|
|
||||||
int err;
|
|
||||||
gz_stream *s = (gz_stream*)file;
|
|
||||||
|
|
||||||
if (s == NULL) return Z_STREAM_ERROR;
|
|
||||||
|
|
||||||
if (s->mode == 'w') {
|
|
||||||
#ifdef NO_DEFLATE
|
|
||||||
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->stream.total_in);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
return destroy((gz_stream*)file);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ===========================================================================
|
|
||||||
Returns the error message for the last error which occured on the
|
|
||||||
given compressed file. errnum is set to zlib error number. If an
|
|
||||||
error occured 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* ZEXPORT gzerror (file, errnum)
|
|
||||||
gzFile file;
|
|
||||||
int *errnum;
|
|
||||||
{
|
|
||||||
char *m;
|
|
||||||
gz_stream *s = (gz_stream*)file;
|
|
||||||
|
|
||||||
if (s == NULL) {
|
|
||||||
*errnum = Z_STREAM_ERROR;
|
|
||||||
return (const char*)ERR_MSG(Z_STREAM_ERROR);
|
|
||||||
}
|
|
||||||
*errnum = s->z_err;
|
|
||||||
if (*errnum == Z_OK) return (const char*)"";
|
|
||||||
|
|
||||||
m = (char*)(*errnum == Z_ERRNO ? zstrerror(errno) : s->stream.msg);
|
|
||||||
|
|
||||||
if (m == NULL || *m == '\0') m = (char*)ERR_MSG(s->z_err);
|
|
||||||
|
|
||||||
TRYFREE(s->msg);
|
|
||||||
s->msg = (char*)ALLOC(strlen(s->path) + strlen(m) + 3);
|
|
||||||
strcpy(s->msg, s->path);
|
|
||||||
strcat(s->msg, ": ");
|
|
||||||
strcat(s->msg, m);
|
|
||||||
return (const char*)s->msg;
|
|
||||||
}
|
|
151
zlib/inffixed.h
Normal file
151
zlib/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}
|
||||||
|
};
|
128
zlib/trees.h
Normal file
128
zlib/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
|
||||||
|
};
|
||||||
|
|
186
zlib/zconf.h~
186
zlib/zconf.h~
@ -1,186 +0,0 @@
|
|||||||
#warning local zconf
|
|
||||||
|
|
||||||
/* zconf.h -- configuration of the zlib compression library
|
|
||||||
* Copyright (C) 1995-1996 Jean-loup Gailly.
|
|
||||||
* For conditions of distribution and use, see copyright notice in zlib.h
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* $Id$ */
|
|
||||||
|
|
||||||
#ifndef _ZCONF_H
|
|
||||||
#define _ZCONF_H
|
|
||||||
|
|
||||||
/*
|
|
||||||
* If you *really* need a unique prefix for all types and library functions,
|
|
||||||
* compile with -DZ_PREFIX. The "standard" zlib should be compiled without it.
|
|
||||||
*/
|
|
||||||
#ifdef Z_PREFIX
|
|
||||||
# define deflateInit_ z_deflateInit_
|
|
||||||
# define deflate z_deflate
|
|
||||||
# define deflateEnd z_deflateEnd
|
|
||||||
# define inflateInit_ z_inflateInit_
|
|
||||||
# define inflate z_inflate
|
|
||||||
# define inflateEnd z_inflateEnd
|
|
||||||
# define deflateInit2_ z_deflateInit2_
|
|
||||||
# define deflateSetDictionary z_deflateSetDictionary
|
|
||||||
# define deflateCopy z_deflateCopy
|
|
||||||
# define deflateReset z_deflateReset
|
|
||||||
# define deflateParams z_deflateParams
|
|
||||||
# define inflateInit2_ z_inflateInit2_
|
|
||||||
# define inflateSetDictionary z_inflateSetDictionary
|
|
||||||
# define inflateSync z_inflateSync
|
|
||||||
# define inflateReset z_inflateReset
|
|
||||||
# define compress z_compress
|
|
||||||
# define uncompress z_uncompress
|
|
||||||
# define adler32 z_adler32
|
|
||||||
# define crc32 z_crc32
|
|
||||||
# define get_crc_table z_get_crc_table
|
|
||||||
|
|
||||||
# define Byte z_Byte
|
|
||||||
# define uInt z_uInt
|
|
||||||
# define uLong z_uLong
|
|
||||||
# define Bytef z_Bytef
|
|
||||||
# define charf z_charf
|
|
||||||
# define intf z_intf
|
|
||||||
# define uIntf z_uIntf
|
|
||||||
# define uLongf z_uLongf
|
|
||||||
# define voidpf z_voidpf
|
|
||||||
# define voidp z_voidp
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if (defined(_WIN32) || defined(__WIN32__)) && !defined(WIN32)
|
|
||||||
# define WIN32
|
|
||||||
#endif
|
|
||||||
#if defined(__GNUC__) || defined(WIN32) || defined(__386__) || defined(i386)
|
|
||||||
# ifndef __32BIT__
|
|
||||||
# define __32BIT__
|
|
||||||
# endif
|
|
||||||
#endif
|
|
||||||
#if defined(__MSDOS__) && !defined(MSDOS)
|
|
||||||
# define MSDOS
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Compile with -DMAXSEG_64K if the alloc function cannot allocate more
|
|
||||||
* than 64k bytes at a time (needed on systems with 16-bit int).
|
|
||||||
*/
|
|
||||||
#if defined(MSDOS) && !defined(__32BIT__)
|
|
||||||
# define MAXSEG_64K
|
|
||||||
#endif
|
|
||||||
#ifdef MSDOS
|
|
||||||
# define UNALIGNED_OK
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if (defined(MSDOS) || defined(_WINDOWS) || defined(WIN32)) && !defined(STDC)
|
|
||||||
# define STDC
|
|
||||||
#endif
|
|
||||||
#if (defined(__STDC__) || defined(__cplusplus)) && !defined(STDC)
|
|
||||||
# define STDC
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef STDC
|
|
||||||
# ifndef const /* cannot use !defined(STDC) && !defined(const) on Mac */
|
|
||||||
# define const
|
|
||||||
# endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Some Mac compilers merge all .h files incorrectly: */
|
|
||||||
#if defined(__MWERKS__) || defined(applec) ||defined(THINK_C) ||defined(__SC__)
|
|
||||||
# define NO_DUMMY_DECL
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Maximum value for memLevel in deflateInit2 */
|
|
||||||
#ifndef MAX_MEM_LEVEL
|
|
||||||
# ifdef MAXSEG_64K
|
|
||||||
# define MAX_MEM_LEVEL 8
|
|
||||||
# else
|
|
||||||
# define MAX_MEM_LEVEL 9
|
|
||||||
# endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Maximum value for windowBits in deflateInit2 and inflateInit2 */
|
|
||||||
#ifndef MAX_WBITS
|
|
||||||
# define MAX_WBITS 15 /* 32K LZ77 window */
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* The memory requirements for deflate are (in bytes):
|
|
||||||
1 << (windowBits+2) + 1 << (memLevel+9)
|
|
||||||
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
|
|
||||||
the default memory requirements from 256K to 128K, compile with
|
|
||||||
make CFLAGS="-O -DMAX_WBITS=14 -DMAX_MEM_LEVEL=7"
|
|
||||||
Of course this will generally degrade compression (there's no free lunch).
|
|
||||||
|
|
||||||
The memory requirements for inflate are (in bytes) 1 << windowBits
|
|
||||||
that is, 32K for windowBits=15 (default value) plus a few kilobytes
|
|
||||||
for small objects.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* Type declarations */
|
|
||||||
|
|
||||||
#ifndef OF /* function prototypes */
|
|
||||||
# ifdef STDC
|
|
||||||
# define OF(args) args
|
|
||||||
# else
|
|
||||||
# define OF(args) ()
|
|
||||||
# endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* The following definitions for FAR are needed only for MSDOS mixed
|
|
||||||
* model programming (small or medium model with some far allocations).
|
|
||||||
* This was tested only with MSC; for other MSDOS compilers you may have
|
|
||||||
* to define NO_MEMCPY in zutil.h. If you don't need the mixed model,
|
|
||||||
* just define FAR to be empty.
|
|
||||||
*/
|
|
||||||
#if (defined(M_I86SM) || defined(M_I86MM)) && !defined(__32BIT__)
|
|
||||||
/* MSC small or medium model */
|
|
||||||
# define SMALL_MEDIUM
|
|
||||||
# ifdef _MSC_VER
|
|
||||||
# define FAR __far
|
|
||||||
# else
|
|
||||||
# define FAR far
|
|
||||||
# endif
|
|
||||||
#endif
|
|
||||||
#if defined(__BORLANDC__) && (defined(__SMALL__) || defined(__MEDIUM__))
|
|
||||||
# ifndef __32BIT__
|
|
||||||
# define SMALL_MEDIUM
|
|
||||||
# define FAR __far
|
|
||||||
# endif
|
|
||||||
#endif
|
|
||||||
#ifndef FAR
|
|
||||||
# define FAR
|
|
||||||
#endif
|
|
||||||
|
|
||||||
typedef unsigned char Byte; /* 8 bits */
|
|
||||||
typedef unsigned int uInt; /* 16 bits or more */
|
|
||||||
typedef unsigned long uLong; /* 32 bits or more */
|
|
||||||
|
|
||||||
#if defined(__BORLANDC__) && defined(SMALL_MEDIUM)
|
|
||||||
/* Borland C/C++ ignores FAR inside typedef */
|
|
||||||
# define Bytef Byte FAR
|
|
||||||
#else
|
|
||||||
typedef Byte FAR Bytef;
|
|
||||||
#endif
|
|
||||||
typedef char FAR charf;
|
|
||||||
typedef int FAR intf;
|
|
||||||
typedef uInt FAR uIntf;
|
|
||||||
typedef uLong FAR uLongf;
|
|
||||||
|
|
||||||
#ifdef STDC
|
|
||||||
typedef void FAR *voidpf;
|
|
||||||
typedef void *voidp;
|
|
||||||
#else
|
|
||||||
typedef Byte FAR *voidpf;
|
|
||||||
typedef Byte *voidp;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
/* Compile with -DZLIB_DLL for Windows DLL support */
|
|
||||||
#if (defined(_WINDOWS) || defined(WINDOWS)) && defined(ZLIB_DLL)
|
|
||||||
# include <windows.h>
|
|
||||||
# define EXPORT WINAPI
|
|
||||||
#else
|
|
||||||
# define EXPORT
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* _ZCONF_H */
|
|
782
zlib/zlib.h~
782
zlib/zlib.h~
@ -1,782 +0,0 @@
|
|||||||
|
|
||||||
#warning static zlib
|
|
||||||
/* zlib.h -- interface of the 'zlib' general purpose compression library
|
|
||||||
version 1.0.4, Jul 24th, 1996.
|
|
||||||
|
|
||||||
Copyright (C) 1995-1996 Jean-loup Gailly and Mark Adler
|
|
||||||
|
|
||||||
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
|
|
||||||
gzip@prep.ai.mit.edu madler@alumni.caltech.edu
|
|
||||||
|
|
||||||
|
|
||||||
The data format used by the zlib library 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).
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef _ZLIB_H
|
|
||||||
#define _ZLIB_H
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "zconf.h"
|
|
||||||
|
|
||||||
#define ZLIB_VERSION "1.0.4"
|
|
||||||
|
|
||||||
/*
|
|
||||||
The 'zlib' compression library 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 may be added later and will have the same
|
|
||||||
stream interface.
|
|
||||||
|
|
||||||
For compression the application must provide the output buffer and
|
|
||||||
may optionally provide the input buffer for optimization. For decompression,
|
|
||||||
the application must provide the input buffer and may optionally provide
|
|
||||||
the output buffer for optimization.
|
|
||||||
|
|
||||||
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.
|
|
||||||
|
|
||||||
The library does not install any signal handler. It is recommended to
|
|
||||||
add at least a handler for SIGSEGV when decompressing; the library checks
|
|
||||||
the consistency of the input data whenever possible but may go nuts
|
|
||||||
for some forms of corrupted input.
|
|
||||||
*/
|
|
||||||
|
|
||||||
typedef voidpf (*alloc_func) OF((voidpf opaque, uInt items, uInt size));
|
|
||||||
typedef void (*free_func) OF((voidpf opaque, voidpf address));
|
|
||||||
|
|
||||||
struct internal_state;
|
|
||||||
|
|
||||||
typedef struct z_stream_s {
|
|
||||||
Bytef *next_in; /* next input byte */
|
|
||||||
uInt avail_in; /* number of bytes available at next_in */
|
|
||||||
uLong total_in; /* total nb of input bytes read so far */
|
|
||||||
|
|
||||||
Bytef *next_out; /* next output byte should be put there */
|
|
||||||
uInt avail_out; /* remaining free space at next_out */
|
|
||||||
uLong total_out; /* total nb of bytes output so far */
|
|
||||||
|
|
||||||
char *msg; /* last error message, NULL if no error */
|
|
||||||
struct internal_state FAR *state; /* not visible by applications */
|
|
||||||
|
|
||||||
alloc_func zalloc; /* used to allocate the internal state */
|
|
||||||
free_func zfree; /* used to free the internal state */
|
|
||||||
voidpf opaque; /* private data object passed to zalloc and zfree */
|
|
||||||
|
|
||||||
int data_type; /* best guess about the data type: ascii or binary */
|
|
||||||
uLong adler; /* adler32 value of the uncompressed data */
|
|
||||||
uLong reserved; /* reserved for future use */
|
|
||||||
} z_stream;
|
|
||||||
|
|
||||||
typedef z_stream FAR *z_streamp;
|
|
||||||
|
|
||||||
/*
|
|
||||||
The application must update next_in and avail_in when avail_in has
|
|
||||||
dropped to zero. It must update next_out and avail_out when avail_out
|
|
||||||
has dropped to zero. The application must initialize zalloc, zfree and
|
|
||||||
opaque before calling the init function. All other fields are set by the
|
|
||||||
compression library and must not be updated by the application.
|
|
||||||
|
|
||||||
The opaque value provided by the application will be passed as the first
|
|
||||||
parameter for calls of zalloc and zfree. This can be useful for custom
|
|
||||||
memory management. The compression library attaches no meaning to the
|
|
||||||
opaque value.
|
|
||||||
|
|
||||||
zalloc must return Z_NULL if there is not enough memory for the object.
|
|
||||||
On 16-bit systems, the functions zalloc and zfree must be able to allocate
|
|
||||||
exactly 65536 bytes, but will not be required to allocate more than this
|
|
||||||
if the symbol MAXSEG_64K is defined (see zconf.h). WARNING: On MSDOS,
|
|
||||||
pointers returned by zalloc for objects of exactly 65536 bytes *must*
|
|
||||||
have their offset normalized to zero. The default allocation function
|
|
||||||
provided by this library ensures this (see zutil.c). To reduce memory
|
|
||||||
requirements and avoid any allocation of 64K objects, at the expense of
|
|
||||||
compression ratio, compile the library with -DMAX_WBITS=14 (see zconf.h).
|
|
||||||
|
|
||||||
The fields total_in and total_out can be used for statistics or
|
|
||||||
progress reports. After compression, total_in holds the total size of
|
|
||||||
the uncompressed data and may be saved for use in the decompressor
|
|
||||||
(particularly if the decompressor wants to decompress everything in
|
|
||||||
a single step).
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* constants */
|
|
||||||
|
|
||||||
#define Z_NO_FLUSH 0
|
|
||||||
#define Z_PARTIAL_FLUSH 1
|
|
||||||
#define Z_SYNC_FLUSH 2
|
|
||||||
#define Z_FULL_FLUSH 3
|
|
||||||
#define Z_FINISH 4
|
|
||||||
/* Allowed flush values; see deflate() below for details */
|
|
||||||
|
|
||||||
#define Z_OK 0
|
|
||||||
#define Z_STREAM_END 1
|
|
||||||
#define Z_NEED_DICT 2
|
|
||||||
#define Z_ERRNO (-1)
|
|
||||||
#define Z_STREAM_ERROR (-2)
|
|
||||||
#define Z_DATA_ERROR (-3)
|
|
||||||
#define Z_MEM_ERROR (-4)
|
|
||||||
#define Z_BUF_ERROR (-5)
|
|
||||||
#define Z_VERSION_ERROR (-6)
|
|
||||||
/* Return codes for the compression/decompression functions. Negative
|
|
||||||
* values are errors, positive values are used for special but normal events.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#define Z_NO_COMPRESSION 0
|
|
||||||
#define Z_BEST_SPEED 1
|
|
||||||
#define Z_BEST_COMPRESSION 9
|
|
||||||
#define Z_DEFAULT_COMPRESSION (-1)
|
|
||||||
/* compression levels */
|
|
||||||
|
|
||||||
#define Z_FILTERED 1
|
|
||||||
#define Z_HUFFMAN_ONLY 2
|
|
||||||
#define Z_DEFAULT_STRATEGY 0
|
|
||||||
/* compression strategy; see deflateInit2() below for details */
|
|
||||||
|
|
||||||
#define Z_BINARY 0
|
|
||||||
#define Z_ASCII 1
|
|
||||||
#define Z_UNKNOWN 2
|
|
||||||
/* Possible values of the data_type field */
|
|
||||||
|
|
||||||
#define Z_DEFLATED 8
|
|
||||||
/* The deflate compression method (the only one supported in this version) */
|
|
||||||
|
|
||||||
#define Z_NULL 0 /* for initializing zalloc, zfree, opaque */
|
|
||||||
|
|
||||||
#define zlib_version zlibVersion()
|
|
||||||
/* for compatibility with versions < 1.0.2 */
|
|
||||||
|
|
||||||
/* basic functions */
|
|
||||||
|
|
||||||
extern const char * EXPORT zlibVersion OF((void));
|
|
||||||
/* The application can compare zlibVersion and ZLIB_VERSION for consistency.
|
|
||||||
If the first character differs, the library code actually used is
|
|
||||||
not compatible with the zlib.h header file used by the application.
|
|
||||||
This check is automatically made by deflateInit and inflateInit.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
extern int EXPORT deflateInit OF((z_streamp strm, int level));
|
|
||||||
|
|
||||||
Initializes the internal stream state for compression. The fields
|
|
||||||
zalloc, zfree and opaque must be initialized before by the caller.
|
|
||||||
If zalloc and zfree are set to Z_NULL, deflateInit updates them to
|
|
||||||
use default allocation functions.
|
|
||||||
|
|
||||||
The compression level must be Z_DEFAULT_COMPRESSION, or between 0 and 9:
|
|
||||||
1 gives best speed, 9 gives best compression, 0 gives no compression at
|
|
||||||
all (the input data is simply copied a block at a time).
|
|
||||||
Z_DEFAULT_COMPRESSION requests a default compromise between speed and
|
|
||||||
compression (currently equivalent to level 6).
|
|
||||||
|
|
||||||
deflateInit returns Z_OK if success, Z_MEM_ERROR if there was not
|
|
||||||
enough memory, Z_STREAM_ERROR if level is not a valid compression level,
|
|
||||||
Z_VERSION_ERROR if the zlib library version (zlib_version) is incompatible
|
|
||||||
with the version assumed by the caller (ZLIB_VERSION).
|
|
||||||
msg is set to null if there is no error message. deflateInit does not
|
|
||||||
perform any compression: this will be done by deflate().
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
extern int EXPORT deflate OF((z_streamp strm, int flush));
|
|
||||||
/*
|
|
||||||
Performs one or both of the following actions:
|
|
||||||
|
|
||||||
- Compress more input starting at next_in and update next_in and avail_in
|
|
||||||
accordingly. If not all input can be processed (because there is not
|
|
||||||
enough room in the output buffer), next_in and avail_in are updated and
|
|
||||||
processing will resume at this point for the next call of deflate().
|
|
||||||
|
|
||||||
- Provide more output starting at next_out and update next_out and avail_out
|
|
||||||
accordingly. This action is forced if the parameter flush is non zero.
|
|
||||||
Forcing flush frequently degrades the compression ratio, so this parameter
|
|
||||||
should be set only when necessary (in interactive applications).
|
|
||||||
Some output may be provided even if flush is not set.
|
|
||||||
|
|
||||||
Before the call of deflate(), the application should ensure that at least
|
|
||||||
one of the actions is possible, by providing more input and/or consuming
|
|
||||||
more output, and updating avail_in or avail_out accordingly; avail_out
|
|
||||||
should never be zero before the call. The application can consume the
|
|
||||||
compressed output when it wants, for example when the output buffer is full
|
|
||||||
(avail_out == 0), or after each call of deflate(). If deflate returns Z_OK
|
|
||||||
and with zero avail_out, it must be called again after making room in the
|
|
||||||
output buffer because there might be more output pending.
|
|
||||||
|
|
||||||
If the parameter flush is set to Z_PARTIAL_FLUSH, the current compression
|
|
||||||
block is terminated and flushed to the output buffer so that the
|
|
||||||
decompressor can get all input data available so far. For method 9, a future
|
|
||||||
variant on method 8, the current block will be flushed but not terminated.
|
|
||||||
Z_SYNC_FLUSH has the same effect as partial flush except that the compressed
|
|
||||||
output is byte aligned (the compressor can clear its internal bit buffer)
|
|
||||||
and the current block is always terminated; this can be useful if the
|
|
||||||
compressor has to be restarted from scratch after an interruption (in which
|
|
||||||
case the internal state of the compressor may be lost).
|
|
||||||
If flush is set to Z_FULL_FLUSH, the compression block is terminated, a
|
|
||||||
special marker is output and the compression dictionary is discarded; this
|
|
||||||
is useful to allow the decompressor to synchronize if one compressed block
|
|
||||||
has been damaged (see inflateSync below). Flushing degrades compression and
|
|
||||||
so should be used only when necessary. Using Z_FULL_FLUSH too often can
|
|
||||||
seriously degrade the compression. If deflate returns with avail_out == 0,
|
|
||||||
this function must be called again with the same value of the flush
|
|
||||||
parameter and more output space (updated avail_out), until the flush is
|
|
||||||
complete (deflate returns with non-zero avail_out).
|
|
||||||
|
|
||||||
If the parameter flush is set to Z_FINISH, pending input is processed,
|
|
||||||
pending output is flushed and deflate returns with Z_STREAM_END if there
|
|
||||||
was enough output space; if deflate returns with Z_OK, this function must be
|
|
||||||
called again with Z_FINISH and more output space (updated avail_out) but no
|
|
||||||
more input data, until it returns with Z_STREAM_END or an error. After
|
|
||||||
deflate has returned Z_STREAM_END, the only possible operations on the
|
|
||||||
stream are deflateReset or deflateEnd.
|
|
||||||
|
|
||||||
Z_FINISH can be used immediately after deflateInit if all the compression
|
|
||||||
is to be done in a single step. In this case, avail_out must be at least
|
|
||||||
0.1% larger than avail_in plus 12 bytes. If deflate does not return
|
|
||||||
Z_STREAM_END, then it must be called again as described above.
|
|
||||||
|
|
||||||
deflate() may update data_type if it can make a good guess about
|
|
||||||
the input data type (Z_ASCII or Z_BINARY). In doubt, the data is considered
|
|
||||||
binary. This field is only for information purposes and does not affect
|
|
||||||
the compression algorithm in any manner.
|
|
||||||
|
|
||||||
deflate() returns Z_OK if some progress has been made (more input
|
|
||||||
processed or more output produced), Z_STREAM_END if all input has been
|
|
||||||
consumed and all output has been produced (only when flush is set to
|
|
||||||
Z_FINISH), Z_STREAM_ERROR if the stream state was inconsistent (for example
|
|
||||||
if next_in or next_out was NULL), Z_BUF_ERROR if no progress is possible.
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
extern int EXPORT deflateEnd OF((z_streamp strm));
|
|
||||||
/*
|
|
||||||
All dynamically allocated data structures for this stream are freed.
|
|
||||||
This function discards any unprocessed input and does not flush any
|
|
||||||
pending output.
|
|
||||||
|
|
||||||
deflateEnd returns Z_OK if success, Z_STREAM_ERROR if the
|
|
||||||
stream state was inconsistent, Z_DATA_ERROR if the stream was freed
|
|
||||||
prematurely (some input or output was discarded). In the error case,
|
|
||||||
msg may be set but then points to a static string (which must not be
|
|
||||||
deallocated).
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
extern int EXPORT inflateInit OF((z_streamp strm));
|
|
||||||
|
|
||||||
Initializes the internal stream state for decompression. The fields
|
|
||||||
zalloc, zfree and opaque must be initialized before by the caller. If
|
|
||||||
zalloc and zfree are set to Z_NULL, inflateInit updates them to use default
|
|
||||||
allocation functions.
|
|
||||||
|
|
||||||
inflateInit returns Z_OK if success, Z_MEM_ERROR if there was not
|
|
||||||
enough memory, Z_VERSION_ERROR if the zlib library version is incompatible
|
|
||||||
with the version assumed by the caller. msg is set to null if there is no
|
|
||||||
error message. inflateInit does not perform any decompression: this will be
|
|
||||||
done by inflate().
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
extern int EXPORT inflate OF((z_streamp strm, int flush));
|
|
||||||
/*
|
|
||||||
Performs one or both of the following actions:
|
|
||||||
|
|
||||||
- Decompress more input starting at next_in and update next_in and avail_in
|
|
||||||
accordingly. If not all input can be processed (because there is not
|
|
||||||
enough room in the output buffer), next_in is updated and processing
|
|
||||||
will resume at this point for the next call of inflate().
|
|
||||||
|
|
||||||
- Provide more output starting at next_out and update next_out and avail_out
|
|
||||||
accordingly. inflate() provides as much output as possible, until there
|
|
||||||
is no more input data or no more space in the output buffer (see below
|
|
||||||
about the flush parameter).
|
|
||||||
|
|
||||||
Before the call of inflate(), the application should ensure that at least
|
|
||||||
one of the actions is possible, by providing more input and/or consuming
|
|
||||||
more output, and updating the next_* and avail_* values accordingly.
|
|
||||||
The application can consume the uncompressed output when it wants, for
|
|
||||||
example when the output buffer is full (avail_out == 0), or after each
|
|
||||||
call of inflate(). If inflate returns Z_OK and with zero avail_out, it
|
|
||||||
must be called again after making room in the output buffer because there
|
|
||||||
might be more output pending.
|
|
||||||
|
|
||||||
If the parameter flush is set to Z_PARTIAL_FLUSH, inflate flushes as much
|
|
||||||
output as possible to the output buffer. The flushing behavior of inflate is
|
|
||||||
not specified for values of the flush parameter other than Z_PARTIAL_FLUSH
|
|
||||||
and Z_FINISH, but the current implementation actually flushes as much output
|
|
||||||
as possible anyway.
|
|
||||||
|
|
||||||
inflate() should normally be called until it returns Z_STREAM_END or an
|
|
||||||
error. However if all decompression is to be performed in a single step
|
|
||||||
(a single call of inflate), the parameter flush should be set to
|
|
||||||
Z_FINISH. In this case all pending input is processed and all pending
|
|
||||||
output is flushed; avail_out must be large enough to hold all the
|
|
||||||
uncompressed data. (The size of the uncompressed data may have been saved
|
|
||||||
by the compressor for this purpose.) The next operation on this stream must
|
|
||||||
be inflateEnd to deallocate the decompression state. The use of Z_FINISH
|
|
||||||
is never required, but can be used to inform inflate that a faster routine
|
|
||||||
may be used for the single inflate() call.
|
|
||||||
|
|
||||||
inflate() returns Z_OK if some progress has been made (more input
|
|
||||||
processed or more output produced), Z_STREAM_END if the end of the
|
|
||||||
compressed data has been reached and all uncompressed output has been
|
|
||||||
produced, Z_NEED_DICT if a preset dictionary is needed at this point (see
|
|
||||||
inflateSetDictionary below), Z_DATA_ERROR if the input data was corrupted,
|
|
||||||
Z_STREAM_ERROR if the stream structure was inconsistent (for example if
|
|
||||||
next_in or next_out was NULL), Z_MEM_ERROR if there was not enough memory,
|
|
||||||
Z_BUF_ERROR if no progress is possible or if there was not enough room in
|
|
||||||
the output buffer when Z_FINISH is used. In the Z_DATA_ERROR case, the
|
|
||||||
application may then call inflateSync to look for a good compression block.
|
|
||||||
In the Z_NEED_DICT case, strm->adler is set to the Adler32 value of the
|
|
||||||
dictionary chosen by the compressor.
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
extern int EXPORT inflateEnd OF((z_streamp strm));
|
|
||||||
/*
|
|
||||||
All dynamically allocated data structures for this stream are freed.
|
|
||||||
This function discards any unprocessed input and does not flush any
|
|
||||||
pending output.
|
|
||||||
|
|
||||||
inflateEnd returns Z_OK if success, Z_STREAM_ERROR if the stream state
|
|
||||||
was inconsistent. In the error case, msg may be set but then points to a
|
|
||||||
static string (which must not be deallocated).
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* Advanced functions */
|
|
||||||
|
|
||||||
/*
|
|
||||||
The following functions are needed only in some special applications.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
extern int EXPORT deflateInit2 OF((z_streamp strm,
|
|
||||||
int level,
|
|
||||||
int method,
|
|
||||||
int windowBits,
|
|
||||||
int memLevel,
|
|
||||||
int strategy));
|
|
||||||
|
|
||||||
This is another version of deflateInit with more compression options. The
|
|
||||||
fields next_in, zalloc, zfree and opaque must be initialized before by
|
|
||||||
the caller.
|
|
||||||
|
|
||||||
The method parameter is the compression method. It must be Z_DEFLATED in
|
|
||||||
this version of the library. (Method 9 will allow a 64K history buffer and
|
|
||||||
partial block flushes.)
|
|
||||||
|
|
||||||
The windowBits parameter is the base two logarithm of the window size
|
|
||||||
(the size of the history buffer). It should be in the range 8..15 for this
|
|
||||||
version of the library (the value 16 will be allowed for method 9). Larger
|
|
||||||
values of this parameter result in better compression at the expense of
|
|
||||||
memory usage. The default value is 15 if deflateInit is used instead.
|
|
||||||
|
|
||||||
The memLevel parameter specifies how much memory should be allocated
|
|
||||||
for the internal compression state. memLevel=1 uses minimum memory but
|
|
||||||
is slow and reduces compression ratio; memLevel=9 uses maximum memory
|
|
||||||
for optimal speed. The default value is 8. See zconf.h for total memory
|
|
||||||
usage as a function of windowBits and memLevel.
|
|
||||||
|
|
||||||
The strategy parameter is used to tune the compression algorithm. Use the
|
|
||||||
value Z_DEFAULT_STRATEGY for normal data, Z_FILTERED for data produced by a
|
|
||||||
filter (or predictor), or Z_HUFFMAN_ONLY to force Huffman encoding only (no
|
|
||||||
string match). Filtered data consists mostly of small values with a
|
|
||||||
somewhat random distribution. In this case, the compression algorithm is
|
|
||||||
tuned to compress them better. The effect of Z_FILTERED is to force more
|
|
||||||
Huffman coding and less string matching; it is somewhat intermediate
|
|
||||||
between Z_DEFAULT and Z_HUFFMAN_ONLY. The strategy parameter only affects
|
|
||||||
the compression ratio but not the correctness of the compressed output even
|
|
||||||
if it is not set appropriately.
|
|
||||||
|
|
||||||
If next_in is not null, the library will use this buffer to hold also
|
|
||||||
some history information; the buffer must either hold the entire input
|
|
||||||
data, or have at least 1<<(windowBits+1) bytes and be writable. If next_in
|
|
||||||
is null, the library will allocate its own history buffer (and leave next_in
|
|
||||||
null). next_out need not be provided here but must be provided by the
|
|
||||||
application for the next call of deflate().
|
|
||||||
|
|
||||||
If the history buffer is provided by the application, next_in must
|
|
||||||
must never be changed by the application since the compressor maintains
|
|
||||||
information inside this buffer from call to call; the application
|
|
||||||
must provide more input only by increasing avail_in. next_in is always
|
|
||||||
reset by the library in this case.
|
|
||||||
|
|
||||||
deflateInit2 returns Z_OK if success, Z_MEM_ERROR if there was
|
|
||||||
not enough memory, Z_STREAM_ERROR if a parameter is invalid (such as
|
|
||||||
an invalid method). msg is set to null if there is no error message.
|
|
||||||
deflateInit2 does not perform any compression: this will be done by
|
|
||||||
deflate().
|
|
||||||
*/
|
|
||||||
|
|
||||||
extern int EXPORT deflateSetDictionary OF((z_streamp strm,
|
|
||||||
const Bytef *dictionary,
|
|
||||||
uInt dictLength));
|
|
||||||
/*
|
|
||||||
Initializes the compression dictionary (history buffer) from the given
|
|
||||||
byte sequence without producing any compressed output. This function must
|
|
||||||
be called immediately after deflateInit or deflateInit2, before any call
|
|
||||||
of deflate. The compressor and decompressor must use exactly the same
|
|
||||||
dictionary (see inflateSetDictionary).
|
|
||||||
The dictionary should consist of strings (byte sequences) that are likely
|
|
||||||
to be encountered later in the data to be compressed, with the most commonly
|
|
||||||
used strings preferably put towards the end of the dictionary. Using a
|
|
||||||
dictionary is most useful when the data to be compressed is short and
|
|
||||||
can be predicted with good accuracy; the data can then be compressed better
|
|
||||||
than with the default empty dictionary. In this version of the library,
|
|
||||||
only the last 32K bytes of the dictionary are used.
|
|
||||||
Upon return of this function, strm->adler is set to the Adler32 value
|
|
||||||
of the dictionary; the decompressor may later use this value to determine
|
|
||||||
which dictionary has been used by the compressor. (The Adler32 value
|
|
||||||
applies to the whole dictionary even if only a subset of the dictionary is
|
|
||||||
actually used by the compressor.)
|
|
||||||
|
|
||||||
deflateSetDictionary returns Z_OK if success, or Z_STREAM_ERROR if a
|
|
||||||
parameter is invalid (such as NULL dictionary) or the stream state
|
|
||||||
is inconsistent (for example if deflate has already been called for this
|
|
||||||
stream). deflateSetDictionary does not perform any compression: this will
|
|
||||||
be done by deflate().
|
|
||||||
*/
|
|
||||||
|
|
||||||
extern int EXPORT deflateCopy OF((z_streamp dest,
|
|
||||||
z_streamp source));
|
|
||||||
/*
|
|
||||||
Sets the destination stream as a complete copy of the source stream. If
|
|
||||||
the source stream is using an application-supplied history buffer, a new
|
|
||||||
buffer is allocated for the destination stream. The compressed output
|
|
||||||
buffer is always application-supplied. It's the responsibility of the
|
|
||||||
application to provide the correct values of next_out and avail_out for the
|
|
||||||
next call of deflate.
|
|
||||||
|
|
||||||
This function can be useful when several compression strategies will be
|
|
||||||
tried, for example when there are several ways of pre-processing the input
|
|
||||||
data with a filter. The streams that will be discarded should then be freed
|
|
||||||
by calling deflateEnd. Note that deflateCopy duplicates the internal
|
|
||||||
compression state which can be quite large, so this strategy is slow and
|
|
||||||
can consume lots of memory.
|
|
||||||
|
|
||||||
deflateCopy returns Z_OK if success, Z_MEM_ERROR if there was not
|
|
||||||
enough memory, Z_STREAM_ERROR if the source stream state was inconsistent
|
|
||||||
(such as zalloc being NULL). msg is left unchanged in both source and
|
|
||||||
destination.
|
|
||||||
*/
|
|
||||||
|
|
||||||
extern int EXPORT deflateReset OF((z_streamp strm));
|
|
||||||
/*
|
|
||||||
This function is equivalent to deflateEnd followed by deflateInit,
|
|
||||||
but does not free and reallocate all the internal compression state.
|
|
||||||
The stream will keep the same compression level and any other attributes
|
|
||||||
that may have been set by deflateInit2.
|
|
||||||
|
|
||||||
deflateReset returns Z_OK if success, or Z_STREAM_ERROR if the source
|
|
||||||
stream state was inconsistent (such as zalloc or state being NULL).
|
|
||||||
*/
|
|
||||||
|
|
||||||
extern int EXPORT deflateParams OF((z_streamp strm, int level, int strategy));
|
|
||||||
/*
|
|
||||||
Dynamically update the compression level and compression strategy.
|
|
||||||
This can be used to switch between compression and straight copy of
|
|
||||||
the input data, or to switch to a different kind of input data requiring
|
|
||||||
a different strategy. If the compression level is changed, the input
|
|
||||||
available so far is compressed with the old level (and may be flushed);
|
|
||||||
the new level will take effect only at the next call of deflate().
|
|
||||||
|
|
||||||
Before the call of deflateParams, the stream state must be set as for
|
|
||||||
a call of deflate(), since the currently available input may have to
|
|
||||||
be compressed and flushed. In particular, strm->avail_out must be non-zero.
|
|
||||||
|
|
||||||
deflateParams returns Z_OK if success, Z_STREAM_ERROR if the source
|
|
||||||
stream state was inconsistent or if a parameter was invalid, Z_BUF_ERROR
|
|
||||||
if strm->avail_out was zero.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
extern int EXPORT inflateInit2 OF((z_streamp strm,
|
|
||||||
int windowBits));
|
|
||||||
|
|
||||||
This is another version of inflateInit with more compression options. The
|
|
||||||
fields next_out, zalloc, zfree and opaque must be initialized before by
|
|
||||||
the caller.
|
|
||||||
|
|
||||||
The windowBits parameter is the base two logarithm of the maximum window
|
|
||||||
size (the size of the history buffer). It should be in the range 8..15 for
|
|
||||||
this version of the library (the value 16 will be allowed soon). The
|
|
||||||
default value is 15 if inflateInit is used instead. If a compressed stream
|
|
||||||
with a larger window size is given as input, inflate() will return with
|
|
||||||
the error code Z_DATA_ERROR instead of trying to allocate a larger window.
|
|
||||||
|
|
||||||
If next_out is not null, the library will use this buffer for the history
|
|
||||||
buffer; the buffer must either be large enough to hold the entire output
|
|
||||||
data, or have at least 1<<windowBits bytes. If next_out is null, the
|
|
||||||
library will allocate its own buffer (and leave next_out null). next_in
|
|
||||||
need not be provided here but must be provided by the application for the
|
|
||||||
next call of inflate().
|
|
||||||
|
|
||||||
If the history buffer is provided by the application, next_out must
|
|
||||||
never be changed by the application since the decompressor maintains
|
|
||||||
history information inside this buffer from call to call; the application
|
|
||||||
can only reset next_out to the beginning of the history buffer when
|
|
||||||
avail_out is zero and all output has been consumed.
|
|
||||||
|
|
||||||
inflateInit2 returns Z_OK if success, Z_MEM_ERROR if there was
|
|
||||||
not enough memory, Z_STREAM_ERROR if a parameter is invalid (such as
|
|
||||||
windowBits < 8). msg is set to null if there is no error message.
|
|
||||||
inflateInit2 does not perform any decompression: this will be done by
|
|
||||||
inflate().
|
|
||||||
*/
|
|
||||||
|
|
||||||
extern int EXPORT inflateSetDictionary OF((z_streamp strm,
|
|
||||||
const Bytef *dictionary,
|
|
||||||
uInt dictLength));
|
|
||||||
/*
|
|
||||||
Initializes the decompression dictionary (history buffer) from the given
|
|
||||||
uncompressed byte sequence. This function must be called immediately after
|
|
||||||
a call of inflate if this call returned Z_NEED_DICT. The dictionary chosen
|
|
||||||
by the compressor can be determined from the Adler32 value returned by this
|
|
||||||
call of inflate. The compressor and decompressor must use exactly the same
|
|
||||||
dictionary (see deflateSetDictionary).
|
|
||||||
|
|
||||||
inflateSetDictionary returns Z_OK if success, Z_STREAM_ERROR if a
|
|
||||||
parameter is invalid (such as NULL dictionary) or the stream state is
|
|
||||||
inconsistent, Z_DATA_ERROR if the given dictionary doesn't match the
|
|
||||||
expected one (incorrect Adler32 value). inflateSetDictionary does not
|
|
||||||
perform any decompression: this will be done by subsequent calls of
|
|
||||||
inflate().
|
|
||||||
*/
|
|
||||||
|
|
||||||
extern int EXPORT inflateSync OF((z_streamp strm));
|
|
||||||
/*
|
|
||||||
Skips invalid compressed data until the special marker (see deflate()
|
|
||||||
above) can be found, or until all available input is skipped. No output
|
|
||||||
is provided.
|
|
||||||
|
|
||||||
inflateSync returns Z_OK if the special marker has been found, Z_BUF_ERROR
|
|
||||||
if no more input was provided, Z_DATA_ERROR if no marker has been found,
|
|
||||||
or Z_STREAM_ERROR if the stream structure was inconsistent. In the success
|
|
||||||
case, the application may save the current current value of total_in which
|
|
||||||
indicates where valid compressed data was found. In the error case, the
|
|
||||||
application may repeatedly call inflateSync, providing more input each time,
|
|
||||||
until success or end of the input data.
|
|
||||||
*/
|
|
||||||
|
|
||||||
extern int EXPORT inflateReset OF((z_streamp strm));
|
|
||||||
/*
|
|
||||||
This function is equivalent to inflateEnd followed by inflateInit,
|
|
||||||
but does not free and reallocate all the internal decompression state.
|
|
||||||
The stream will keep attributes that may have been set by inflateInit2.
|
|
||||||
|
|
||||||
inflateReset returns Z_OK if success, or Z_STREAM_ERROR if the source
|
|
||||||
stream state was inconsistent (such as zalloc or state being NULL).
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
/* utility functions */
|
|
||||||
|
|
||||||
/*
|
|
||||||
The following utility functions are implemented on top of the
|
|
||||||
basic stream-oriented functions. To simplify the interface, some
|
|
||||||
default options are assumed (compression level, window size,
|
|
||||||
standard memory allocation functions). The source code of these
|
|
||||||
utility functions can easily be modified if you need special options.
|
|
||||||
*/
|
|
||||||
|
|
||||||
extern int EXPORT compress OF((Bytef *dest, uLongf *destLen,
|
|
||||||
const Bytef *source, uLong sourceLen));
|
|
||||||
/*
|
|
||||||
Compresses the source buffer into the destination buffer. sourceLen is
|
|
||||||
the byte length of the source buffer. Upon entry, destLen is the total
|
|
||||||
size of the destination buffer, which must be at least 0.1% larger than
|
|
||||||
sourceLen plus 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.
|
|
||||||
compress returns Z_OK if success, Z_MEM_ERROR if there was not
|
|
||||||
enough memory, Z_BUF_ERROR if there was not enough room in the output
|
|
||||||
buffer.
|
|
||||||
*/
|
|
||||||
|
|
||||||
extern int EXPORT uncompress OF((Bytef *dest, uLongf *destLen,
|
|
||||||
const Bytef *source, uLong sourceLen));
|
|
||||||
/*
|
|
||||||
Decompresses the source buffer into the destination buffer. sourceLen is
|
|
||||||
the byte length of the source buffer. Upon entry, destLen is the total
|
|
||||||
size of the destination buffer, which must be large enough to hold the
|
|
||||||
entire uncompressed data. (The size of the uncompressed data must have
|
|
||||||
been saved previously by the compressor and transmitted to the decompressor
|
|
||||||
by some mechanism outside the scope of this compression library.)
|
|
||||||
Upon exit, destLen is the actual size of the compressed buffer.
|
|
||||||
This function can be used to decompress a whole file at once if the
|
|
||||||
input file is mmap'ed.
|
|
||||||
|
|
||||||
uncompress returns Z_OK if success, Z_MEM_ERROR if there was not
|
|
||||||
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.
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
typedef voidp gzFile;
|
|
||||||
|
|
||||||
extern gzFile EXPORT gzopen OF((const char *path, const char *mode));
|
|
||||||
/*
|
|
||||||
Opens a gzip (.gz) file for reading or writing. The mode parameter
|
|
||||||
is as in fopen ("rb" or "wb") but can also include a compression level
|
|
||||||
("wb9"). gzopen can be used to read a file which is not in gzip format;
|
|
||||||
in this case gzread will directly read from the file without decompression.
|
|
||||||
gzopen returns NULL if the file could not be opened or if there was
|
|
||||||
insufficient memory to allocate the (de)compression state; errno
|
|
||||||
can be checked to distinguish the two cases (if errno is zero, the
|
|
||||||
zlib error is Z_MEM_ERROR).
|
|
||||||
*/
|
|
||||||
|
|
||||||
extern gzFile EXPORT gzdopen OF((int fd, const char *mode));
|
|
||||||
/*
|
|
||||||
gzdopen() associates a gzFile with the file descriptor fd. File
|
|
||||||
descriptors are obtained from calls like open, dup, creat, pipe or
|
|
||||||
fileno (in the file has been previously opened with fopen).
|
|
||||||
The mode parameter is as in gzopen.
|
|
||||||
The next call of gzclose on the returned gzFile will also close the
|
|
||||||
file descriptor fd, just like fclose(fdopen(fd), mode) closes the file
|
|
||||||
descriptor fd. If you want to keep fd open, use gzdopen(dup(fd), mode).
|
|
||||||
gzdopen returns NULL if there was insufficient memory to allocate
|
|
||||||
the (de)compression state.
|
|
||||||
*/
|
|
||||||
|
|
||||||
extern int EXPORT gzread OF((gzFile file, voidp buf, unsigned len));
|
|
||||||
/*
|
|
||||||
Reads the given number of uncompressed bytes from the compressed file.
|
|
||||||
If the input file was not in gzip format, gzread copies the given number
|
|
||||||
of bytes into the buffer.
|
|
||||||
gzread returns the number of uncompressed bytes actually read (0 for
|
|
||||||
end of file, -1 for error). */
|
|
||||||
|
|
||||||
extern int EXPORT gzwrite OF((gzFile file, const voidp buf, unsigned len));
|
|
||||||
/*
|
|
||||||
Writes the given number of uncompressed bytes into the compressed file.
|
|
||||||
gzwrite returns the number of uncompressed bytes actually written
|
|
||||||
(0 in case of error).
|
|
||||||
*/
|
|
||||||
|
|
||||||
extern int EXPORT gzflush OF((gzFile file, int flush));
|
|
||||||
/*
|
|
||||||
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). gzflush returns Z_OK if
|
|
||||||
the flush parameter is Z_FINISH and all output could be flushed.
|
|
||||||
gzflush should be called only when strictly necessary because it can
|
|
||||||
degrade compression.
|
|
||||||
*/
|
|
||||||
|
|
||||||
extern int EXPORT gzclose OF((gzFile file));
|
|
||||||
/*
|
|
||||||
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 gzerror below).
|
|
||||||
*/
|
|
||||||
|
|
||||||
extern const char * EXPORT gzerror OF((gzFile file, int *errnum));
|
|
||||||
/*
|
|
||||||
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.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* checksum functions */
|
|
||||||
|
|
||||||
/*
|
|
||||||
These functions are not related to compression but are exported
|
|
||||||
anyway because they might be useful in applications using the
|
|
||||||
compression library.
|
|
||||||
*/
|
|
||||||
|
|
||||||
extern uLong EXPORT adler32 OF((uLong adler, const Bytef *buf, uInt len));
|
|
||||||
|
|
||||||
/*
|
|
||||||
Update a running Adler-32 checksum with the bytes buf[0..len-1] and
|
|
||||||
return the updated checksum. If buf is NULL, this function returns
|
|
||||||
the required initial value for the checksum.
|
|
||||||
An Adler-32 checksum is almost as reliable as a CRC32 but can be computed
|
|
||||||
much faster. Usage example:
|
|
||||||
|
|
||||||
uLong adler = adler32(0L, Z_NULL, 0);
|
|
||||||
|
|
||||||
while (read_buffer(buffer, length) != EOF) {
|
|
||||||
adler = adler32(adler, buffer, length);
|
|
||||||
}
|
|
||||||
if (adler != original_adler) error();
|
|
||||||
*/
|
|
||||||
|
|
||||||
extern uLong EXPORT crc32 OF((uLong crc, const Bytef *buf, uInt len));
|
|
||||||
/*
|
|
||||||
Update a running crc with the bytes buf[0..len-1] and return the updated
|
|
||||||
crc. If buf is NULL, this function returns the required initial value
|
|
||||||
for the crc. Pre- and post-conditioning (one's complement) is performed
|
|
||||||
within this function so it shouldn't be done by the application.
|
|
||||||
Usage example:
|
|
||||||
|
|
||||||
uLong crc = crc32(0L, Z_NULL, 0);
|
|
||||||
|
|
||||||
while (read_buffer(buffer, length) != EOF) {
|
|
||||||
crc = crc32(crc, buffer, length);
|
|
||||||
}
|
|
||||||
if (crc != original_crc) error();
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
/* various hacks, don't look :) */
|
|
||||||
|
|
||||||
/* deflateInit and inflateInit are macros to allow checking the zlib version
|
|
||||||
* and the compiler's view of z_stream:
|
|
||||||
*/
|
|
||||||
extern int EXPORT deflateInit_ OF((z_streamp strm, int level,
|
|
||||||
const char *version, int stream_size));
|
|
||||||
extern int EXPORT inflateInit_ OF((z_streamp strm,
|
|
||||||
const char *version, int stream_size));
|
|
||||||
extern int EXPORT deflateInit2_ OF((z_streamp strm, int level, int method,
|
|
||||||
int windowBits, int memLevel, int strategy,
|
|
||||||
const char *version, int stream_size));
|
|
||||||
extern int EXPORT inflateInit2_ OF((z_streamp strm, int windowBits,
|
|
||||||
const char *version, int stream_size));
|
|
||||||
#define deflateInit(strm, level) \
|
|
||||||
deflateInit_((strm), (level), ZLIB_VERSION, sizeof(z_stream))
|
|
||||||
#define inflateInit(strm) \
|
|
||||||
inflateInit_((strm), ZLIB_VERSION, sizeof(z_stream))
|
|
||||||
#define deflateInit2(strm, level, method, windowBits, memLevel, strategy) \
|
|
||||||
deflateInit2_((strm),(level),(method),(windowBits),(memLevel),\
|
|
||||||
(strategy), ZLIB_VERSION, sizeof(z_stream))
|
|
||||||
#define inflateInit2(strm, windowBits) \
|
|
||||||
inflateInit2_((strm), (windowBits), ZLIB_VERSION, sizeof(z_stream))
|
|
||||||
|
|
||||||
#if !defined(_Z_UTIL_H) && !defined(NO_DUMMY_DECL)
|
|
||||||
struct internal_state {int dummy;}; /* hack for buggy compilers */
|
|
||||||
#endif
|
|
||||||
|
|
||||||
uLongf *get_crc_table OF((void)); /* can be used by asm versions of crc32() */
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* _ZLIB_H */
|
|
Loading…
x
Reference in New Issue
Block a user