Compare commits
	
		
			5 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 23c69f1069 | ||
|   | 6b834a58bd | ||
|   | bdde4e09d2 | ||
|   | 1c71d8b13b | ||
|   | 64b2e89203 | 
							
								
								
									
										56
									
								
								ChangeLog
									
									
									
									
									
								
							
							
						
						
									
										56
									
								
								ChangeLog
									
									
									
									
									
								
							| @@ -1,10 +1,66 @@ | |||||||
|  |  | ||||||
| 		ChangeLog file for zlib | 		ChangeLog file for zlib | ||||||
|  |  | ||||||
|  | Changes in 0.94 (13 Aug 95) | ||||||
|  | - support MSDOS medium model | ||||||
|  | - fix deflate with flush (could sometimes generate bad output) | ||||||
|  | - fix deflateReset (zlib header was incorrectly suppressed) | ||||||
|  | - added support for VMS | ||||||
|  | - allow a compression level in gzopen() | ||||||
|  | - gzflush now calls fflush | ||||||
|  | - For deflate with flush, flush even if no more input is provided. | ||||||
|  | - rename libgz.a as libz.a | ||||||
|  | - work around a problem with gcc on Alpha (in INSERT_STRING) | ||||||
|  | - don't use inline functions (problem with some gcc versions) | ||||||
|  | - allow renaming of Byte, uInt, etc... with #define. | ||||||
|  | - avoid warning about (unused) pointer before start of array in deflate.c | ||||||
|  | - avoid various warnings in gzio.c, example.c, infblock.c, adler32.c, zutil.c | ||||||
|  | - avoid reserved word 'new' in trees.c | ||||||
|  |  | ||||||
|  | Changes in 0.93 (25 June 95) | ||||||
|  | - temporarily disable inline functions | ||||||
|  | - make deflate deterministic | ||||||
|  | - give enough lookahead for PARTIAL_FLUSH | ||||||
|  | - Set binary mode for stdin/stdout in minigzip.c for OS/2 | ||||||
|  | - don't even use signed char in inflate (not portable enough) | ||||||
|  | - fix inflate memory leak for segmented architectures | ||||||
|  |  | ||||||
|  | Changes in 0.92 (3 May 95) | ||||||
|  | - don't assume that char is signed (problem on SGI) | ||||||
|  | - Clear bit buffer when starting a stored block | ||||||
|  | - no memcpy on Pyramid | ||||||
|  | - suppressed inftest.c | ||||||
|  | - optimized fill_window, put longest_match inline for gcc | ||||||
|  | - optimized inflate on stored blocks. | ||||||
|  | - untabify all sources to simplify patches | ||||||
|  |  | ||||||
|  | Changes in 0.91 (2 May 95) | ||||||
|  | - Default MEM_LEVEL is 8 (not 9 for Unix) as documented in zlib.h | ||||||
|  | - Document the memory requirements in zconf.h | ||||||
|  | - added "make install" | ||||||
|  | - fix sync search logic in inflateSync | ||||||
|  | - deflate(Z_FULL_FLUSH) now works even if output buffer too short | ||||||
|  | - after inflateSync, don't scare people with just "lo world" | ||||||
|  | - added support for DJGPP | ||||||
|  |  | ||||||
|  | Changes in 0.9 (1 May 95) | ||||||
|  | - don't assume that zalloc clears the allocated memory (the TurboC bug | ||||||
|  |   was Mark's bug after all :) | ||||||
|  | - let again gzread copy uncompressed data unchanged (was working in 0.71) | ||||||
|  | - deflate(Z_FULL_FLUSH), inflateReset and inflateSync are now fully implemented | ||||||
|  | - added a test of inflateSync in example.c | ||||||
|  | - moved MAX_WBITS to zconf.h because users might want to change that. | ||||||
|  | - document explicitly that zalloc(64K) on MSDOS must return a normalized | ||||||
|  |   pointer (zero offset) | ||||||
|  | - added Makefiles for Microsoft C, Turbo C, Borland C++ | ||||||
|  | - faster crc32() | ||||||
|  |  | ||||||
| Changes in 0.8 (29 April 95) | Changes in 0.8 (29 April 95) | ||||||
| - added fast inflate (inffast.c) | - added fast inflate (inffast.c) | ||||||
| - deflate(Z_FINISH) now returns Z_STREAM_END when done. Warning: this | - deflate(Z_FINISH) now returns Z_STREAM_END when done. Warning: this | ||||||
|   is incompatible with previous versions of zlib which returned Z_OK. |   is incompatible with previous versions of zlib which returned Z_OK. | ||||||
| - work around a TurboC compiler bug (bad code for b << 0, see infutil.h) | - work around a TurboC compiler bug (bad code for b << 0, see infutil.h) | ||||||
|  |   (actually that was not a compiler bug, see 0.81 above) | ||||||
| - gzread no longer reads one extra byte in certain cases | - gzread no longer reads one extra byte in certain cases | ||||||
| - In gzio destroy(), don't reference a freed structure | - In gzio destroy(), don't reference a freed structure | ||||||
| - avoid many warnings for MSDOS | - avoid many warnings for MSDOS | ||||||
|   | |||||||
							
								
								
									
										115
									
								
								Make_vms.com
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										115
									
								
								Make_vms.com
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,115 @@ | |||||||
|  | $! make libz under VMS | ||||||
|  | $! written by Martin P.J. Zinser <m.zinser@gsi.de> | ||||||
|  | $! | ||||||
|  | $! Look for the compiler used | ||||||
|  | $! | ||||||
|  | $ ccopt = "" | ||||||
|  | $ if f$trnlnm("HW_MODEL").ge.1024 | ||||||
|  | $ then | ||||||
|  | $  ccopt = "/prefix=all"+ccopt | ||||||
|  | $  comp  = "__decc__=1" | ||||||
|  | $  if f$trnlnm("SYS").eqs."" then define sys sys$library: | ||||||
|  | $ else | ||||||
|  | $  if f$search("SYS$SYSTEM:DECC$COMPILER.EXE").eqs."" | ||||||
|  | $   then | ||||||
|  | $    comp  = "__vaxc__=1" | ||||||
|  | $    if f$trnlnm("SYS").eqs."" then define sys sys$library: | ||||||
|  | $   else | ||||||
|  | $    if f$trnlnm("SYS").eqs."" then define sys decc$library_include: | ||||||
|  | $    ccopt = "/decc/prefix=all"+ccopt | ||||||
|  | $    comp  = "__decc__=1" | ||||||
|  | $  endif | ||||||
|  | $ endif | ||||||
|  | $! | ||||||
|  | $! Build the thing plain or with mms | ||||||
|  | $! | ||||||
|  | $ write sys$output "Compiling Zlib sources ..." | ||||||
|  | $ if f$search("SYS$SYSTEM:MMS.EXE").eqs."" | ||||||
|  | $  then | ||||||
|  | $   dele example.obj;*,minigzip.obj;* | ||||||
|  | $   CALL MAKE adler32.OBJ "CC ''CCOPT' adler32" - | ||||||
|  |                 adler32.c zutil.h zlib.h zconf.h | ||||||
|  | $   CALL MAKE compress.OBJ "CC ''CCOPT' compress" - | ||||||
|  |                 compress.c zlib.h zconf.h | ||||||
|  | $   CALL MAKE crc32.OBJ "CC ''CCOPT' crc32" - | ||||||
|  |                 crc32.c zutil.h zlib.h zconf.h | ||||||
|  | $   CALL MAKE deflate.OBJ "CC ''CCOPT' deflate" - | ||||||
|  |                 deflatec.c deflate.h zutil.h zlib.h zconf.h | ||||||
|  | $   CALL MAKE gzio.OBJ "CC ''CCOPT' gzio" - | ||||||
|  |                 gsio.c zutil.h zlib.h zconf.h | ||||||
|  | $   CALL MAKE infblock.OBJ "CC ''CCOPT' infblock" - | ||||||
|  |                 infblock.c zutil.h zlib.h zconf.h infblock.h | ||||||
|  | $   CALL MAKE infcodes.OBJ "CC ''CCOPT' infcodes" - | ||||||
|  |                 infcodes.c zutil.h zlib.h zconf.h inftrees.h | ||||||
|  | $   CALL MAKE inffast.OBJ "CC ''CCOPT' inffast" - | ||||||
|  |                 inffast.c zutil.h zlib.h zconf.h inffast.h | ||||||
|  | $   CALL MAKE inflate.OBJ "CC ''CCOPT' inflate" - | ||||||
|  |                 inflate.c zutil.h zlib.h zconf.h infblock.h | ||||||
|  | $   CALL MAKE inftrees.OBJ "CC ''CCOPT' inftrees" - | ||||||
|  |                 inftrees.c zutil.h zlib.h zconf.h inftrees.h | ||||||
|  | $   CALL MAKE infutil.OBJ "CC ''CCOPT' infutil" - | ||||||
|  |                 infutil.c zutil.h zlib.h zconf.h inftrees.h infutil.h | ||||||
|  | $   CALL MAKE trees.OBJ "CC ''CCOPT' trees" - | ||||||
|  |                 trees.c deflate.h zutil.h zlib.h zconf.h | ||||||
|  | $   CALL MAKE uncompr.OBJ "CC ''CCOPT' uncompr" - | ||||||
|  |                 uncompr.c zlib.h zconf.h | ||||||
|  | $   CALL MAKE zutil.OBJ "CC ''CCOPT' zutil" - | ||||||
|  |                 zutil.c zutil.h zlib.h zconf.h | ||||||
|  | $   write sys$output "Building Zlib ..." | ||||||
|  | $   CALL MAKE libz.OLB "lib/crea libz.olb *.obj" *.OBJ | ||||||
|  | $   write sys$output "Building example..." | ||||||
|  | $   CALL MAKE example.OBJ "CC ''CCOPT' example" - | ||||||
|  |                 example.c zlib.h zconf.h | ||||||
|  | $   call make example.exe "LINK example,libz.olb/lib" example.obj libz.olb | ||||||
|  | $   write sys$output "Building minigzip..." | ||||||
|  | $   CALL MAKE minigzip.OBJ "CC ''CCOPT' minigzip" - | ||||||
|  |                 minigzip.c zlib.h zconf.h | ||||||
|  | $   call make minigzip.exe -  | ||||||
|  |                 "LINK minigzip,libz.olb/lib,x11vms:xvmsutils.olb/lib" -  | ||||||
|  |                 minigzip.obj libz.olb | ||||||
|  | $  else | ||||||
|  | $   mms/macro=('comp') | ||||||
|  | $  endif | ||||||
|  | $ write sys$output "Zlib build completed" | ||||||
|  | $ exit | ||||||
|  | $! | ||||||
|  | $! | ||||||
|  | $MAKE: SUBROUTINE   !SUBROUTINE TO CHECK DEPENDENCIES | ||||||
|  | $ V = 'F$Verify(0) | ||||||
|  | $! P1 = What we are trying to make | ||||||
|  | $! P2 = Command to make it | ||||||
|  | $! P3 - P8  What it depends on | ||||||
|  | $ | ||||||
|  | $ If F$Search(P1) .Eqs. "" Then Goto Makeit | ||||||
|  | $ Time = F$CvTime(F$File(P1,"RDT")) | ||||||
|  | $arg=3 | ||||||
|  | $Loop: | ||||||
|  | $       Argument = P'arg | ||||||
|  | $       If Argument .Eqs. "" Then Goto Exit | ||||||
|  | $       El=0 | ||||||
|  | $Loop2: | ||||||
|  | $       File = F$Element(El," ",Argument) | ||||||
|  | $       If File .Eqs. " " Then Goto Endl | ||||||
|  | $       AFile = "" | ||||||
|  | $Loop3: | ||||||
|  | $       OFile = AFile | ||||||
|  | $       AFile = F$Search(File) | ||||||
|  | $       If AFile .Eqs. "" .Or. AFile .Eqs. OFile Then Goto NextEl | ||||||
|  | $       If F$CvTime(F$File(AFile,"RDT")) .Ges. Time Then Goto Makeit | ||||||
|  | $       Goto Loop3 | ||||||
|  | $NextEL: | ||||||
|  | $       El = El + 1 | ||||||
|  | $       Goto Loop2 | ||||||
|  | $EndL: | ||||||
|  | $ arg=arg+1 | ||||||
|  | $ If arg .Le. 8 Then Goto Loop | ||||||
|  | $ Goto Exit | ||||||
|  | $ | ||||||
|  | $Makeit: | ||||||
|  | $ VV=F$VERIFY(0) | ||||||
|  | $ write sys$output P2 | ||||||
|  | $ 'P2 | ||||||
|  | $ VV='F$Verify(VV) | ||||||
|  | $Exit: | ||||||
|  | $ If V Then Set Verify | ||||||
|  | $ENDSUBROUTINE | ||||||
							
								
								
									
										39
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										39
									
								
								Makefile
									
									
									
									
									
								
							| @@ -1,43 +1,57 @@ | |||||||
|  | # Makefile for zlib | ||||||
|  | # Copyright (C) 1995 Jean-loup Gailly. | ||||||
|  | # For conditions of distribution and use, see copyright notice in zlib.h  | ||||||
|  |  | ||||||
| CC=cc | CC=cc | ||||||
| CFLAGS=-O | CFLAGS=-O | ||||||
|  | #use -O3 for gcc to take advantage of inlining | ||||||
|  | #CFLAGS="-O -DMAX_WBITS=14 -DMAX_MEM_LEVEL=7" | ||||||
| #CFLAGS=-g -DDEBUG | #CFLAGS=-g -DDEBUG | ||||||
| LDFLAGS=-L. -lgz | LDFLAGS=-L. -lz | ||||||
|  |  | ||||||
| RANLIB=ranlib | RANLIB=ranlib | ||||||
|  |  | ||||||
|  | prefix=/usr/local | ||||||
|  |  | ||||||
| OBJS = adler32.o compress.o crc32.o gzio.o uncompr.o deflate.o trees.o \ | OBJS = adler32.o compress.o crc32.o gzio.o uncompr.o deflate.o trees.o \ | ||||||
|        zutil.o inflate.o infblock.o inftrees.o infcodes.o infutil.o inffast.o |        zutil.o inflate.o infblock.o inftrees.o infcodes.o infutil.o inffast.o | ||||||
|  |  | ||||||
| TEST_OBJS = example.o minigzip.o inftest.o | TEST_OBJS = example.o minigzip.o | ||||||
|  |  | ||||||
| all: example minigzip inftest | all: example minigzip | ||||||
|  |  | ||||||
| test: all | test: all | ||||||
| 	./example | 	./example | ||||||
| 	echo hello world | ./minigzip | ./minigzip -d  | 	echo hello world | ./minigzip | ./minigzip -d  | ||||||
|  |  | ||||||
| libgz.a: $(OBJS) | install: libz.a | ||||||
|  | 	-@mkdir $(prefix)/include | ||||||
|  | 	-@mkdir $(prefix)/lib | ||||||
|  | 	cp zlib.h zconf.h $(prefix)/include | ||||||
|  | 	chmod 644 $(prefix)/include/zlib.h $(prefix)/include/zconf.h | ||||||
|  | 	cp libz.a $(prefix)/lib | ||||||
|  | 	chmod 644 $(prefix)/lib/libz.a | ||||||
|  |  | ||||||
|  | libz.a: $(OBJS) | ||||||
| 	ar rc $@ $(OBJS) | 	ar rc $@ $(OBJS) | ||||||
| 	$(RANLIB) $@ | 	$(RANLIB) $@ | ||||||
|  |  | ||||||
| example: example.o libgz.a | example: example.o libz.a | ||||||
| 	$(CC) $(CFLAGS) -o $@ example.o $(LDFLAGS) | 	$(CC) $(CFLAGS) -o $@ example.o $(LDFLAGS) | ||||||
|  |  | ||||||
| minigzip: minigzip.o libgz.a | minigzip: minigzip.o libz.a | ||||||
| 	$(CC) $(CFLAGS) -o $@ minigzip.o $(LDFLAGS) | 	$(CC) $(CFLAGS) -o $@ minigzip.o $(LDFLAGS) | ||||||
|  |  | ||||||
| inftest: inftest.o libgz.a |  | ||||||
| 	$(CC) $(CFLAGS) -o $@ inftest.o $(LDFLAGS) |  | ||||||
|  |  | ||||||
| clean: | clean: | ||||||
| 	rm -f *.o example minigzip inftest libgz.a foo.gz | 	rm -f *.o example minigzip libz.a foo.gz | ||||||
|  |  | ||||||
| zip: | zip: | ||||||
| 	zip -ul9 zlib README ChangeLog Makefile *.[ch] | 	zip -ul9 zlib README ChangeLog Makefile Make????.??? Makefile.?? \ | ||||||
|  | 	  descrip.mms *.[ch] | ||||||
|  |  | ||||||
| tgz: | tgz: | ||||||
| 	cd ..; tar cfz zlib/zlib.tgz zlib/README zlib/ChangeLog zlib/Makefile \ | 	cd ..; tar cfz zlib/zlib.tgz zlib/README zlib/ChangeLog zlib/Makefile \ | ||||||
| 		zlib/*.[ch] | 	  zlib/Make????.??? zlib/Makefile.?? zlib/descrip.mms zlib/*.[ch] | ||||||
|  |  | ||||||
| # DO NOT DELETE THIS LINE -- make depend depends on it. | # DO NOT DELETE THIS LINE -- make depend depends on it. | ||||||
|  |  | ||||||
| @@ -51,7 +65,6 @@ infblock.o: zutil.h zlib.h zconf.h infblock.h inftrees.h infcodes.h infutil.h | |||||||
| infcodes.o: zutil.h zlib.h zconf.h inftrees.h infutil.h infcodes.h inffast.h | infcodes.o: zutil.h zlib.h zconf.h inftrees.h infutil.h infcodes.h inffast.h | ||||||
| inffast.o: zutil.h zlib.h zconf.h inftrees.h infutil.h inffast.h | inffast.o: zutil.h zlib.h zconf.h inftrees.h infutil.h inffast.h | ||||||
| inflate.o: zutil.h zlib.h zconf.h infblock.h | inflate.o: zutil.h zlib.h zconf.h infblock.h | ||||||
| inftest.o: zutil.h zlib.h zconf.h |  | ||||||
| inftrees.o: zutil.h zlib.h zconf.h inftrees.h | inftrees.o: zutil.h zlib.h zconf.h inftrees.h | ||||||
| infutil.o: zutil.h zlib.h zconf.h inftrees.h infutil.h | infutil.o: zutil.h zlib.h zconf.h inftrees.h infutil.h | ||||||
| minigzip.o: zlib.h zconf.h | minigzip.o: zlib.h zconf.h | ||||||
|   | |||||||
							
								
								
									
										104
									
								
								Makefile.bor
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										104
									
								
								Makefile.bor
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,104 @@ | |||||||
|  | # Makefile for zlib | ||||||
|  | # Borland C++   ************ UNTESTED *********** | ||||||
|  |  | ||||||
|  | # To use, do "make -fmakefile.bor" | ||||||
|  |  | ||||||
|  | # WARNING: the small model is supported but only for small values of | ||||||
|  | # MAX_WBITS and MAX_MEM_LEVEL. For example: | ||||||
|  | #    -DMAX_WBITS=11 -DDEF_WBITS=11 -DMAX_MEM_LEVEL=3 | ||||||
|  | # If you wish to reduce the memory requirements (default 256K for big | ||||||
|  | # objects plus a few K), you can add to CFLAGS below:  | ||||||
|  | #   -DMAX_MEM_LEVEL=7 -DMAX_WBITS=14 | ||||||
|  | # See zconf.h for details about the memory requirements. | ||||||
|  |  | ||||||
|  | # ------------- Turbo C++, Borland C++ ------------- | ||||||
|  | MODEL=-ml | ||||||
|  | CFLAGS=-O2 -Z $(MODEL) | ||||||
|  | CC=bcc | ||||||
|  | LD=bcc | ||||||
|  | LIB=tlib | ||||||
|  | #   replace bcc with tcc for Turbo C++ 1.0 | ||||||
|  | LDFLAGS=$(MODEL) | ||||||
|  | O=.obj | ||||||
|  |  | ||||||
|  | # variables | ||||||
|  | OBJ1 = adler32$(O) compress$(O) crc32$(O) gzio$(O) uncompr$(O) deflate$(O) \ | ||||||
|  |   trees$(O) | ||||||
|  | OBJP1 = adler32$(O)+compress$(O)+crc32$(O)+gzio$(O)+uncompr$(O)+deflate$(O)+\ | ||||||
|  |   trees$(O) | ||||||
|  | OBJ2 = zutil$(O) inflate$(O) infblock$(O) inftrees$(O) infcodes$(O) \ | ||||||
|  |   infutil$(O) inffast$(O) | ||||||
|  | OBJP2 = zutil$(O)+inflate$(O)+infblock$(O)+inftrees$(O)+infcodes$(O)+\ | ||||||
|  |   infutil$(O)+inffast$(O) | ||||||
|  |  | ||||||
|  | all: test | ||||||
|  |  | ||||||
|  | adler32.obj: adler32.c zutil.h zlib.h zconf.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | compress.obj: compress.c zlib.h zconf.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | crc32.obj: crc32.c zutil.h zlib.h zconf.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | deflate.obj: deflate.c deflate.h zutil.h zlib.h zconf.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | gzio.obj: gzio.c zutil.h zlib.h zconf.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | infblock.obj: infblock.c zutil.h zlib.h zconf.h infblock.h inftrees.h\ | ||||||
|  |    infcodes.h infutil.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | infcodes.obj: infcodes.c zutil.h zlib.h zconf.h inftrees.h infutil.h\ | ||||||
|  |    infcodes.h inffast.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | inflate.obj: inflate.c zutil.h zlib.h zconf.h infblock.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | inftrees.obj: inftrees.c zutil.h zlib.h zconf.h inftrees.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | infutil.obj: infutil.c zutil.h zlib.h zconf.h inftrees.h infutil.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | inffast.obj: inffast.c zutil.h zlib.h zconf.h inftrees.h infutil.h inffast.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | trees.obj: trees.c deflate.h zutil.h zlib.h zconf.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | uncompr.obj: uncompr.c zlib.h zconf.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | zutil.obj: zutil.c zutil.h zlib.h zconf.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | example.obj: example.c zlib.h zconf.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | minigzip.obj: minigzip.c zlib.h zconf.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | # we must cut the command line to fit in the MS/DOS 128 byte limit: | ||||||
|  | zlib.lib: $(OBJ1) $(OBJ2) | ||||||
|  | 	del zlib.lib | ||||||
|  | 	$(LIB) zlib +$(OBJP1) | ||||||
|  | 	$(LIB) zlib +$(OBJP2) | ||||||
|  |  | ||||||
|  | example.exe: example.obj zlib.lib | ||||||
|  | 	$(LD) $(LDFLAGS) example.obj zlib.lib | ||||||
|  |  | ||||||
|  | minigzip.exe: minigzip.obj zlib.lib | ||||||
|  | 	$(LD) $(LDFLAGS) minigzip.obj zlib.lib | ||||||
|  |  | ||||||
|  | test: example.exe minigzip.exe | ||||||
|  | 	example | ||||||
|  | 	echo hello world | minigzip | minigzip -d  | ||||||
|  |  | ||||||
|  | #clean: | ||||||
|  | #	del *.obj | ||||||
|  | #	del *.exe | ||||||
							
								
								
									
										98
									
								
								Makefile.msc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										98
									
								
								Makefile.msc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,98 @@ | |||||||
|  | # Makefile for zlib | ||||||
|  | # Microsoft C 5.1 or later | ||||||
|  |  | ||||||
|  | # To use, do "make makefile.msc" | ||||||
|  |  | ||||||
|  | # If you wish to reduce the memory requirements (default 256K for big | ||||||
|  | # objects plus a few K), you can add to CFLAGS below:  | ||||||
|  | #   -DMAX_MEM_LEVEL=7 -DMAX_WBITS=14 | ||||||
|  | # See zconf.h for details about the memory requirements. | ||||||
|  |  | ||||||
|  | # ------------- Microsoft C 5.1 and later ------------- | ||||||
|  | MODEL=-AL | ||||||
|  | CFLAGS=-Oait -Gs -nologo -W3 $(MODEL) | ||||||
|  | #-Ox generates bad code with MSC 5.1 | ||||||
|  | CC=cl | ||||||
|  | LD=link | ||||||
|  | LDFLAGS=/e/st:0x1000/noe | ||||||
|  | O=.obj | ||||||
|  |  | ||||||
|  | # variables | ||||||
|  | OBJ1 = adler32$(O) compress$(O) crc32$(O) gzio$(O) uncompr$(O) deflate$(O) \ | ||||||
|  |   trees$(O) | ||||||
|  | OBJP1 = adler32$(O)+compress$(O)+crc32$(O)+gzio$(O)+uncompr$(O)+deflate$(O)+\ | ||||||
|  |   trees$(O) | ||||||
|  | OBJ2 = zutil$(O) inflate$(O) infblock$(O) inftrees$(O) infcodes$(O) \ | ||||||
|  |   infutil$(O) inffast$(O) | ||||||
|  | OBJP2 = zutil$(O)+inflate$(O)+infblock$(O)+inftrees$(O)+infcodes$(O)+\ | ||||||
|  |   infutil$(O)+inffast$(O) | ||||||
|  |  | ||||||
|  | adler32.obj: adler32.c zutil.h zlib.h zconf.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | compress.obj: compress.c zlib.h zconf.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | crc32.obj: crc32.c zutil.h zlib.h zconf.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | deflate.obj: deflate.c deflate.h zutil.h zlib.h zconf.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | gzio.obj: gzio.c zutil.h zlib.h zconf.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | infblock.obj: infblock.c zutil.h zlib.h zconf.h infblock.h inftrees.h\ | ||||||
|  |    infcodes.h infutil.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | infcodes.obj: infcodes.c zutil.h zlib.h zconf.h inftrees.h infutil.h\ | ||||||
|  |    infcodes.h inffast.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | inflate.obj: inflate.c zutil.h zlib.h zconf.h infblock.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | inftrees.obj: inftrees.c zutil.h zlib.h zconf.h inftrees.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | infutil.obj: infutil.c zutil.h zlib.h zconf.h inftrees.h infutil.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | inffast.obj: inffast.c zutil.h zlib.h zconf.h inftrees.h infutil.h inffast.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | trees.obj: trees.c deflate.h zutil.h zlib.h zconf.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | uncompr.obj: uncompr.c zlib.h zconf.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | zutil.obj: zutil.c zutil.h zlib.h zconf.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | example.obj: example.c zlib.h zconf.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | minigzip.obj: minigzip.c zlib.h zconf.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | # we must cut the command line to fit in the MS/DOS 128 byte limit: | ||||||
|  | zlib.lib: $(OBJ1) $(OBJ2) | ||||||
|  |         del zlib.lib | ||||||
|  | 	lib zlib $(OBJ1); | ||||||
|  | 	lib zlib $(OBJ2); | ||||||
|  |  | ||||||
|  | example.exe: example.obj zlib.lib | ||||||
|  | 	$(LD) $(LDFLAGS) example.obj,,,zlib.lib; | ||||||
|  |  | ||||||
|  | minigzip.exe: minigzip.obj zlib.lib | ||||||
|  | 	$(LD) $(LDFLAGS) minigzip.obj,,,zlib.lib; | ||||||
|  |  | ||||||
|  | test: example.exe minigzip.exe | ||||||
|  | 	example | ||||||
|  | 	echo hello world | minigzip | minigzip -d  | ||||||
|  |  | ||||||
|  | #clean: | ||||||
|  | #	del *.obj | ||||||
|  | #	del *.exe | ||||||
							
								
								
									
										75
									
								
								Makefile.qnx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										75
									
								
								Makefile.qnx
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,75 @@ | |||||||
|  | # Makefile for zlib | ||||||
|  | # Copyright (C) 1995 Jean-loup Gailly. | ||||||
|  | # For conditions of distribution and use, see copyright notice in zlib.h  | ||||||
|  |  | ||||||
|  | # Modified slightly for QNX by Chris Herborth (chrish@qnx.com) | ||||||
|  |  | ||||||
|  | CC=cc | ||||||
|  | CFLAGS=-4 -O -Q | ||||||
|  | #use -O3 for gcc to take advantage of inlining | ||||||
|  | #CFLAGS="-O -DMAX_WBITS=14 -DMAX_MEM_LEVEL=7" | ||||||
|  | #CFLAGS=-g -DDEBUG | ||||||
|  | LDFLAGS=-L. -lz | ||||||
|  |  | ||||||
|  | #RANLIB=ranlib | ||||||
|  |  | ||||||
|  | prefix=/usr/local | ||||||
|  |  | ||||||
|  | OBJS = adler32.o compress.o crc32.o gzio.o uncompr.o deflate.o trees.o \ | ||||||
|  |        zutil.o inflate.o infblock.o inftrees.o infcodes.o infutil.o inffast.o | ||||||
|  |  | ||||||
|  | TEST_OBJS = example.o minigzip.o | ||||||
|  |  | ||||||
|  | all: example minigzip | ||||||
|  |  | ||||||
|  | test: all | ||||||
|  | 	./example | ||||||
|  | 	echo hello world | ./minigzip | ./minigzip -d  | ||||||
|  |  | ||||||
|  | install: zlib.lib | ||||||
|  | 	-@mkdir $(prefix)/include | ||||||
|  | 	-@mkdir $(prefix)/lib | ||||||
|  | 	cp zlib.h zconf.h $(prefix)/include | ||||||
|  | 	chmod 644 $(prefix)/include/zlib.h $(prefix)/include/zconf.h | ||||||
|  | 	cp zlib.lib $(prefix)/lib | ||||||
|  | 	chmod 644 $(prefix)/lib/zlib.lib | ||||||
|  |  | ||||||
|  | zlib.lib: $(OBJS) | ||||||
|  | 	cc -A $@ $(OBJS) | ||||||
|  | #	ar rc $@ $(OBJS) | ||||||
|  | #	$(RANLIB) $@ | ||||||
|  |  | ||||||
|  | example: example.o zlib.lib | ||||||
|  | 	$(CC) $(CFLAGS) -o $@ example.o $(LDFLAGS) | ||||||
|  |  | ||||||
|  | minigzip: minigzip.o zlib.lib | ||||||
|  | 	$(CC) $(CFLAGS) -o $@ minigzip.o $(LDFLAGS) | ||||||
|  |  | ||||||
|  | clean: | ||||||
|  | 	rm -f *.o example minigzip zlib.lib foo.gz | ||||||
|  |  | ||||||
|  | zip: | ||||||
|  | 	zip -ul9 zlib README ChangeLog Makefile Makefile.??? Makefile.?? *.[ch] | ||||||
|  |  | ||||||
|  | tgz: | ||||||
|  | 	cd ..; tar cfz zlib/zlib.tgz zlib/README zlib/ChangeLog zlib/Makefile \ | ||||||
|  | 		zlib/Makefile.??? zlib/Makefile.?? zlib/*.[ch] | ||||||
|  |  | ||||||
|  | # DO NOT DELETE THIS LINE -- make depend depends on it. | ||||||
|  |  | ||||||
|  | adler32.o: zutil.h zlib.h zconf.h | ||||||
|  | compress.o: zlib.h zconf.h | ||||||
|  | crc32.o: zutil.h zlib.h zconf.h | ||||||
|  | deflate.o: deflate.h zutil.h zlib.h zconf.h | ||||||
|  | example.o: zlib.h zconf.h | ||||||
|  | gzio.o: zutil.h zlib.h zconf.h | ||||||
|  | infblock.o: zutil.h zlib.h zconf.h infblock.h inftrees.h infcodes.h infutil.h | ||||||
|  | infcodes.o: zutil.h zlib.h zconf.h inftrees.h infutil.h infcodes.h inffast.h | ||||||
|  | inffast.o: zutil.h zlib.h zconf.h inftrees.h infutil.h inffast.h | ||||||
|  | inflate.o: zutil.h zlib.h zconf.h infblock.h | ||||||
|  | inftrees.o: zutil.h zlib.h zconf.h inftrees.h | ||||||
|  | infutil.o: zutil.h zlib.h zconf.h inftrees.h infutil.h | ||||||
|  | minigzip.o: zlib.h zconf.h | ||||||
|  | trees.o: deflate.h zutil.h zlib.h zconf.h | ||||||
|  | uncompr.o: zlib.h zconf.h | ||||||
|  | zutil.o: zutil.h zlib.h zconf.h | ||||||
							
								
								
									
										103
									
								
								Makefile.tc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										103
									
								
								Makefile.tc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,103 @@ | |||||||
|  | # Makefile for zlib | ||||||
|  | # TurboC 2.0 | ||||||
|  |  | ||||||
|  | # To use, do "make -fmakefile.tc" | ||||||
|  |  | ||||||
|  | # WARNING: the small model is supported but only for small values of | ||||||
|  | # MAX_WBITS and MAX_MEM_LEVEL. For example: | ||||||
|  | #    -DMAX_WBITS=11 -DDEF_WBITS=11 -DMAX_MEM_LEVEL=3 | ||||||
|  | # If you wish to reduce the memory requirements (default 256K for big | ||||||
|  | # objects plus a few K), you can add to CFLAGS below:  | ||||||
|  | #   -DMAX_MEM_LEVEL=7 -DMAX_WBITS=14 | ||||||
|  | # See zconf.h for details about the memory requirements. | ||||||
|  |  | ||||||
|  | # ------------- Turbo C 2.0 ------------- | ||||||
|  | MODEL=-ml | ||||||
|  | CFLAGS=-O2 -G -Z $(MODEL) | ||||||
|  | CC=tcc -I\tc\include | ||||||
|  | LD=tcc -L\tc\lib | ||||||
|  | LIB=tlib | ||||||
|  | LDFLAGS=$(MODEL) -f- | ||||||
|  | O=.obj | ||||||
|  |  | ||||||
|  | # variables | ||||||
|  | OBJ1 = adler32$(O) compress$(O) crc32$(O) gzio$(O) uncompr$(O) deflate$(O) \ | ||||||
|  |   trees$(O) | ||||||
|  | OBJP1 = adler32$(O)+compress$(O)+crc32$(O)+gzio$(O)+uncompr$(O)+deflate$(O)+\ | ||||||
|  |   trees$(O) | ||||||
|  | OBJ2 = zutil$(O) inflate$(O) infblock$(O) inftrees$(O) infcodes$(O) \ | ||||||
|  |   infutil$(O) inffast$(O) | ||||||
|  | OBJP2 = zutil$(O)+inflate$(O)+infblock$(O)+inftrees$(O)+infcodes$(O)+\ | ||||||
|  |   infutil$(O)+inffast$(O) | ||||||
|  |  | ||||||
|  | all: test | ||||||
|  |  | ||||||
|  | adler32.obj: adler32.c zutil.h zlib.h zconf.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | compress.obj: compress.c zlib.h zconf.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | crc32.obj: crc32.c zutil.h zlib.h zconf.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | deflate.obj: deflate.c deflate.h zutil.h zlib.h zconf.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | gzio.obj: gzio.c zutil.h zlib.h zconf.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | infblock.obj: infblock.c zutil.h zlib.h zconf.h infblock.h inftrees.h\ | ||||||
|  |    infcodes.h infutil.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | infcodes.obj: infcodes.c zutil.h zlib.h zconf.h inftrees.h infutil.h\ | ||||||
|  |    infcodes.h inffast.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | inflate.obj: inflate.c zutil.h zlib.h zconf.h infblock.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | inftrees.obj: inftrees.c zutil.h zlib.h zconf.h inftrees.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | infutil.obj: infutil.c zutil.h zlib.h zconf.h inftrees.h infutil.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | inffast.obj: inffast.c zutil.h zlib.h zconf.h inftrees.h infutil.h inffast.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | trees.obj: trees.c deflate.h zutil.h zlib.h zconf.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | uncompr.obj: uncompr.c zlib.h zconf.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | zutil.obj: zutil.c zutil.h zlib.h zconf.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | example.obj: example.c zlib.h zconf.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | minigzip.obj: minigzip.c zlib.h zconf.h | ||||||
|  | 	$(CC) -c $(CFLAGS) $*.c | ||||||
|  |  | ||||||
|  | # we must cut the command line to fit in the MS/DOS 128 byte limit: | ||||||
|  | zlib.lib: $(OBJ1) $(OBJ2) | ||||||
|  | 	del zlib.lib | ||||||
|  | 	$(LIB) zlib +$(OBJP1) | ||||||
|  | 	$(LIB) zlib +$(OBJP2) | ||||||
|  |  | ||||||
|  | example.exe: example.obj zlib.lib | ||||||
|  | 	$(LD) $(LDFLAGS) -eexample.exe example.obj zlib.lib | ||||||
|  |  | ||||||
|  | minigzip.exe: minigzip.obj zlib.lib | ||||||
|  | 	$(LD) $(LDFLAGS) -eminigzip.exe minigzip.obj zlib.lib | ||||||
|  |  | ||||||
|  | test: example.exe minigzip.exe | ||||||
|  | 	example | ||||||
|  | 	echo hello world | minigzip | minigzip -d  | ||||||
|  |  | ||||||
|  | #clean: | ||||||
|  | #	del *.obj | ||||||
|  | #	del *.exe | ||||||
							
								
								
									
										44
									
								
								README
									
									
									
									
									
								
							
							
						
						
									
										44
									
								
								README
									
									
									
									
									
								
							| @@ -1,31 +1,41 @@ | |||||||
| zlib 0.8 is a beta version of a general purpose compression library. | zlib 0.94 is a beta version of a general purpose compression library. | ||||||
| This is the first version with no known bugs. (There may still be | Unless new bugs are found it will be released again as the first official | ||||||
| problem on SGI, to be checked.) | version (1.0). This version has no known bugs. | ||||||
|  |  | ||||||
| The data format used by the zlib library is described in the | The data format used by the zlib library is described in the | ||||||
| file zlib-3.1.doc, deflate-1.1.doc and gzip-4.1.doc, available | files zlib-3.1.doc, deflate-1.1.doc and gzip-4.1.doc, available | ||||||
| in ftp.uu.net:/pub/archiving/zip/doc. | in ftp.uu.net:/pub/archiving/zip/doc. | ||||||
|  |  | ||||||
| All functions of the compression library are documented in the file | All functions of the compression library are documented in the file | ||||||
| zlib.h. A usage example of the library is given in the file example.c | zlib.h. A usage example of the library is given in the file example.c | ||||||
| which also tests that the library is working correctly. | which also tests that the library is working correctly. | ||||||
|  |  | ||||||
| To compile all files and run the test program, just type: make test | To compile all files and run the test program, just type: make test | ||||||
|  | (For MSDOS, use one of the special makefiles such as Makefile.msc.) | ||||||
|  | To install the zlib library (libz.a) in /usr/local/lib, type: make install | ||||||
|  | To install in a different directory, use for example: | ||||||
|  |   make install prefix=$HOME | ||||||
|  | This will install in $HOME/lib instead of /usr/local/lib. | ||||||
|  |  | ||||||
| The changes made in version 0.8 are documented in the file ChangeLog. | The changes made in version 0.94 are documented in the file ChangeLog. | ||||||
| The main changes since 0.71 are: | The main changes since 0.93 are: | ||||||
| - added fast inflate (inffast.c) | - support MSDOS small and medium model | ||||||
| - deflate(Z_FINISH) now returns Z_STREAM_END when done. Warning: this | - fix deflate with flush (could sometimes generate bad output) | ||||||
|   is incompatible with previous versions of zlib which returned Z_OK. | - fix deflateReset (zlib header was incorrectly suppressed) | ||||||
| - work around a nasty TurboC compiler bug | - added support for VMS | ||||||
|  | - allow a compression level in gzopen() | ||||||
|  | - gzflush now calls fflush | ||||||
|  | - For deflate with flush, flush even if no more input is provided. | ||||||
|  | - rename libgz.a as libz.a | ||||||
|  |  | ||||||
| On MSDOS, this version works in both large and small model. However | For MSDOS, the small and medium models are supported only for Microsoft C. | ||||||
| small model compression works only for small values of MEM_LEVEL and | (It should be easy to support them for Borland C also, but I don't have | ||||||
| WBITS (see zutil.h). Small model decompression should work up to WBITS=15. | a recent Borland compiler to test with.) The small model currently works | ||||||
| This version of zlib does not yet support small or medium model with | for Turbo/Borland C but only with reduced performance to avoid any far | ||||||
| far allocation of big objects. | allocation (tested with -DMAX_WBITS=11 -DDEF_WBITS=11 -DMAX_MEM_LEVEL=3). | ||||||
|  |  | ||||||
|  |  | ||||||
|   Copyright (C) 1995 Jean-loup Gailly and Mark Adler |  (C) 1995 Jean-loup Gailly and Mark Adler | ||||||
|  |  | ||||||
|   This software is provided 'as-is', without any express or implied |   This software is provided 'as-is', without any express or implied | ||||||
|   warranty.  In no event will the authors be held liable for any damages |   warranty.  In no event will the authors be held liable for any damages | ||||||
| @@ -44,7 +54,7 @@ far allocation of big objects. | |||||||
|   3. This notice may not be removed or altered from any source distribution. |   3. This notice may not be removed or altered from any source distribution. | ||||||
|  |  | ||||||
|   Jean-loup Gailly        Mark Adler |   Jean-loup Gailly        Mark Adler | ||||||
|   gzip@prep.ai.mit.edu    madler@cco.caltech.edu |   gzip@prep.ai.mit.edu    madler@alumni.caltech.edu | ||||||
|  |  | ||||||
| If you use the zlib library in a product, we would appreciate *not* | If you use the zlib library in a product, we would appreciate *not* | ||||||
| receiving lengthy legal documents to sign. The sources are provided | receiving lengthy legal documents to sign. The sources are provided | ||||||
|   | |||||||
							
								
								
									
										30
									
								
								adler32.c
									
									
									
									
									
								
							
							
						
						
									
										30
									
								
								adler32.c
									
									
									
									
									
								
							| @@ -3,11 +3,11 @@ | |||||||
|  * For conditions of distribution and use, see copyright notice in zlib.h  |  * For conditions of distribution and use, see copyright notice in zlib.h  | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| /* $Id: adler32.c,v 1.5 1995/04/14 14:49:51 jloup Exp $ */ | /* $Id: adler32.c,v 1.6 1995/05/03 17:27:08 jloup Exp $ */ | ||||||
|  |  | ||||||
| #include "zutil.h" | #include "zlib.h" | ||||||
|  |  | ||||||
| #define BASE 65521 /* largest prime smaller than 65536 */ | #define BASE 65521L /* largest prime smaller than 65536 */ | ||||||
| #define NMAX 5552 | #define NMAX 5552 | ||||||
| /* NMAX is the largest n such that 255n(n+1)/2 + (n+1)(BASE-1) <= 2^32-1 */ | /* NMAX is the largest n such that 255n(n+1)/2 + (n+1)(BASE-1) <= 2^32-1 */ | ||||||
|  |  | ||||||
| @@ -20,7 +20,7 @@ | |||||||
| /* ========================================================================= */ | /* ========================================================================= */ | ||||||
| uLong adler32(adler, buf, len) | uLong adler32(adler, buf, len) | ||||||
|     uLong adler; |     uLong adler; | ||||||
|     Byte *buf; |     Bytef *buf; | ||||||
|     uInt len; |     uInt len; | ||||||
| { | { | ||||||
|     unsigned long s1 = adler & 0xffff; |     unsigned long s1 = adler & 0xffff; | ||||||
| @@ -30,17 +30,17 @@ uLong adler32(adler, buf, len) | |||||||
|     if (buf == Z_NULL) return 1L; |     if (buf == Z_NULL) return 1L; | ||||||
|  |  | ||||||
|     while (len > 0) { |     while (len > 0) { | ||||||
| 	k = len < NMAX ? len : NMAX; |         k = len < NMAX ? len : NMAX; | ||||||
| 	len -= k; |         len -= k; | ||||||
| 	while (k >= 16) { |         while (k >= 16) { | ||||||
| 	    DO16(buf); |             DO16(buf); | ||||||
| 	    k -= 16; |             k -= 16; | ||||||
| 	} |         } | ||||||
| 	if (k != 0) do { |         if (k != 0) do { | ||||||
| 	    DO1(buf); |             DO1(buf); | ||||||
| 	} while (--k); |         } while (--k); | ||||||
| 	s1 %= BASE; |         s1 %= BASE; | ||||||
| 	s2 %= BASE; |         s2 %= BASE; | ||||||
|     } |     } | ||||||
|     return (s2 << 16) | s1; |     return (s2 << 16) | s1; | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										12
									
								
								compress.c
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								compress.c
									
									
									
									
									
								
							| @@ -3,7 +3,7 @@ | |||||||
|  * For conditions of distribution and use, see copyright notice in zlib.h  |  * For conditions of distribution and use, see copyright notice in zlib.h  | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| /* $Id: compress.c,v 1.5 1995/04/29 17:18:43 jloup Exp $ */ | /* $Id: compress.c,v 1.6 1995/05/03 17:27:08 jloup Exp $ */ | ||||||
|  |  | ||||||
| #include "zlib.h" | #include "zlib.h" | ||||||
|  |  | ||||||
| @@ -20,9 +20,9 @@ | |||||||
|    buffer. |    buffer. | ||||||
| */ | */ | ||||||
| int compress (dest, destLen, source, sourceLen) | int compress (dest, destLen, source, sourceLen) | ||||||
|     Byte *dest; |     Bytef *dest; | ||||||
|     uLong *destLen; |     uLongf *destLen; | ||||||
|     Byte *source; |     Bytef *source; | ||||||
|     uLong sourceLen; |     uLong sourceLen; | ||||||
| { | { | ||||||
|     z_stream stream; |     z_stream stream; | ||||||
| @@ -45,8 +45,8 @@ int compress (dest, destLen, source, sourceLen) | |||||||
|  |  | ||||||
|     err = deflate(&stream, Z_FINISH); |     err = deflate(&stream, Z_FINISH); | ||||||
|     if (err != Z_STREAM_END) { |     if (err != Z_STREAM_END) { | ||||||
| 	deflateEnd(&stream); |         deflateEnd(&stream); | ||||||
| 	return err == Z_OK ? Z_BUF_ERROR : err; |         return err == Z_OK ? Z_BUF_ERROR : err; | ||||||
|     } |     } | ||||||
|     *destLen = stream.total_out; |     *destLen = stream.total_out; | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										61
									
								
								crc32.c
									
									
									
									
									
								
							
							
						
						
									
										61
									
								
								crc32.c
									
									
									
									
									
								
							| @@ -7,47 +7,35 @@ | |||||||
|  |  | ||||||
| #include "zlib.h" | #include "zlib.h" | ||||||
|  |  | ||||||
| extern uLong crc_table[];   /* crc table, defined below */ | #define local static | ||||||
|  |  | ||||||
| /* ========================================================================= */ |  | ||||||
| uLong crc32(crc, buf, len) |  | ||||||
|     uLong crc; |  | ||||||
|     Byte *buf; |  | ||||||
|     uInt len; |  | ||||||
| { |  | ||||||
|     if (buf == Z_NULL) return 0L; |  | ||||||
|     crc = crc ^ 0xffffffffL; |  | ||||||
|     if (len) do { |  | ||||||
| 	crc = crc_table[((int)crc ^ (*buf++)) & 0xff] ^ (crc >> 8); |  | ||||||
|     } while (--len); |  | ||||||
|     return crc ^ 0xffffffffL; |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  | #ifdef DYNAMIC_CRC_TABLE | ||||||
| /* ========================================================================= | /* ========================================================================= | ||||||
|  * Make the crc table. This function is needed only if you want to compute |  * Make the crc table. This function is needed only if you want to compute | ||||||
|  * the table dynamically. |  * the table dynamically. | ||||||
|  */ |  */ | ||||||
| #ifdef DYNAMIC_CRC_TABLE | local int crc_table_empty = 1; | ||||||
|  | local uLong crc_table[256]; | ||||||
|  |  | ||||||
| void make_crc_table() | local void make_crc_table() | ||||||
| { | { | ||||||
|   uLong c; |   uLong c; | ||||||
|   int n, k; |   int n, k; | ||||||
|   |   | ||||||
|   for (n = 0; n < 256; n++) |   for (n = 0; n < 256; n++) | ||||||
|   { |   { | ||||||
|     c = (uLong)n; |     c = (uLong)n; | ||||||
|     for (k = 0; k < 8; k++) |     for (k = 0; k < 8; k++) | ||||||
|       c = c & 1 ? 0xedb88320L ^ (c >> 1) : c >> 1; |       c = c & 1 ? 0xedb88320L ^ (c >> 1) : c >> 1; | ||||||
|     crc_table[n] = c; |     crc_table[n] = c; | ||||||
|   } |   } | ||||||
|  |   crc_table_empty = 0; | ||||||
| } | } | ||||||
| #endif | #else | ||||||
|  |  | ||||||
| /* ======================================================================== | /* ======================================================================== | ||||||
|  * Table of CRC-32's of all single-byte values (made by make_crc_table) |  * Table of CRC-32's of all single-byte values (made by make_crc_table) | ||||||
|  */ |  */ | ||||||
| uLong crc_table[] = { | local uLong crc_table[] = { | ||||||
|   0x00000000L, 0x77073096L, 0xee0e612cL, 0x990951baL, 0x076dc419L, |   0x00000000L, 0x77073096L, 0xee0e612cL, 0x990951baL, 0x076dc419L, | ||||||
|   0x706af48fL, 0xe963a535L, 0x9e6495a3L, 0x0edb8832L, 0x79dcb8a4L, |   0x706af48fL, 0xe963a535L, 0x9e6495a3L, 0x0edb8832L, 0x79dcb8a4L, | ||||||
|   0xe0d5e91eL, 0x97d2d988L, 0x09b64c2bL, 0x7eb17cbdL, 0xe7b82d07L, |   0xe0d5e91eL, 0x97d2d988L, 0x09b64c2bL, 0x7eb17cbdL, 0xe7b82d07L, | ||||||
| @@ -101,3 +89,32 @@ uLong crc_table[] = { | |||||||
|   0x5d681b02L, 0x2a6f2b94L, 0xb40bbe37L, 0xc30c8ea1L, 0x5a05df1bL, |   0x5d681b02L, 0x2a6f2b94L, 0xb40bbe37L, 0xc30c8ea1L, 0x5a05df1bL, | ||||||
|   0x2d02ef8dL |   0x2d02ef8dL | ||||||
| }; | }; | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #define DO1(buf) crc = crc_table[((int)crc ^ (*buf++)) & 0xff] ^ (crc >> 8); | ||||||
|  | #define DO2(buf)  DO1(buf); DO1(buf); | ||||||
|  | #define DO4(buf)  DO2(buf); DO2(buf); | ||||||
|  | #define DO8(buf)  DO4(buf); DO4(buf); | ||||||
|  |  | ||||||
|  | /* ========================================================================= */ | ||||||
|  | uLong crc32(crc, buf, len) | ||||||
|  |     uLong crc; | ||||||
|  |     Bytef *buf; | ||||||
|  |     uInt len; | ||||||
|  | { | ||||||
|  |     if (buf == Z_NULL) return 0L; | ||||||
|  | #ifdef DYNAMIC_CRC_TABLE | ||||||
|  |     if (crc_table_empty) | ||||||
|  |       make_crc_table(); | ||||||
|  | #endif | ||||||
|  |     crc = crc ^ 0xffffffffL; | ||||||
|  |     while (len >= 8) | ||||||
|  |     { | ||||||
|  |       DO8(buf); | ||||||
|  |       len -= 8; | ||||||
|  |     } | ||||||
|  |     if (len) do { | ||||||
|  |       DO1(buf); | ||||||
|  |     } while (--len); | ||||||
|  |     return crc ^ 0xffffffffL; | ||||||
|  | } | ||||||
|   | |||||||
							
								
								
									
										358
									
								
								deflate.c
									
									
									
									
									
								
							
							
						
						
									
										358
									
								
								deflate.c
									
									
									
									
									
								
							| @@ -47,7 +47,7 @@ | |||||||
|  * |  * | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| /* $Id: deflate.c,v 1.5 1995/04/29 16:52:05 jloup Exp $ */ | /* $Id: deflate.c,v 1.8 1995/05/03 17:27:08 jloup Exp $ */ | ||||||
|  |  | ||||||
| #include "deflate.h" | #include "deflate.h" | ||||||
|  |  | ||||||
| @@ -113,21 +113,21 @@ struct static_tree_desc_s {int dummy;}; /* for buggy compilers */ | |||||||
|  *  Prototypes for local functions. |  *  Prototypes for local functions. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| local void fill_window   __P((deflate_state *s)); | local void fill_window   OF((deflate_state *s)); | ||||||
| local int  deflate_fast  __P((deflate_state *s, int flush)); | local int  deflate_fast  OF((deflate_state *s, int flush)); | ||||||
| local int  deflate_slow  __P((deflate_state *s, int flush)); | local int  deflate_slow  OF((deflate_state *s, int flush)); | ||||||
| local void lm_init       __P((deflate_state *s)); | local void lm_init       OF((deflate_state *s)); | ||||||
| local int  longest_match __P((deflate_state *s, IPos cur_match)); | local int longest_match  OF((deflate_state *s, IPos cur_match)); | ||||||
| local void putShortMSB   __P((deflate_state *s, uInt b)); | local void putShortMSB   OF((deflate_state *s, uInt b)); | ||||||
| local void flush_pending __P((z_stream *strm)); | local void flush_pending OF((z_stream *strm)); | ||||||
| local int read_buf       __P((z_stream *strm, char *buf, unsigned size)); | local int read_buf       OF((z_stream *strm, charf *buf, unsigned size)); | ||||||
| #ifdef ASMV | #ifdef ASMV | ||||||
|       void match_init __P((void)); /* asm code initialization */ |       void match_init OF((void)); /* asm code initialization */ | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #ifdef DEBUG | #ifdef DEBUG | ||||||
| local  void check_match __P((deflate_state *s, IPos start, IPos match, | local  void check_match OF((deflate_state *s, IPos start, IPos match, | ||||||
| 			     int length)); |                             int length)); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -139,6 +139,7 @@ local  void check_match __P((deflate_state *s, IPos start, IPos match, | |||||||
|  */ |  */ | ||||||
| #define UPDATE_HASH(s,h,c) (h = (((h)<<s->hash_shift) ^ (c)) & s->hash_mask) | #define UPDATE_HASH(s,h,c) (h = (((h)<<s->hash_shift) ^ (c)) & s->hash_mask) | ||||||
|  |  | ||||||
|  |  | ||||||
| /* =========================================================================== | /* =========================================================================== | ||||||
|  * Insert string str in the dictionary and set match_head to the previous head |  * Insert string str in the dictionary and set match_head to the previous head | ||||||
|  * of the hash chain (the most recent string with same hash key). Return |  * of the hash chain (the most recent string with same hash key). Return | ||||||
| @@ -148,16 +149,24 @@ local  void check_match __P((deflate_state *s, IPos start, IPos match, | |||||||
|  *    (except for the last MIN_MATCH-1 bytes of the input file). |  *    (except for the last MIN_MATCH-1 bytes of the input file). | ||||||
|  */ |  */ | ||||||
| #define INSERT_STRING(s, str, match_head) \ | #define INSERT_STRING(s, str, match_head) \ | ||||||
|    (UPDATE_HASH(s, s->ins_h, s->window[(str) + MIN_MATCH-1]), \ |    (UPDATE_HASH(s, s->ins_h, s->window[(str) + (MIN_MATCH-1)]), \ | ||||||
|     s->prev[(str) & s->w_mask] = match_head = s->head[s->ins_h], \ |     s->prev[(str) & s->w_mask] = match_head = s->head[s->ins_h], \ | ||||||
|     s->head[s->ins_h] = (str)) |     s->head[s->ins_h] = (str)) | ||||||
|  |  | ||||||
|  | /* =========================================================================== | ||||||
|  |  * Initialize the hash table (avoiding 64K overflow for 16 bit systems). | ||||||
|  |  * prev[] will be initialized on the fly. | ||||||
|  |  */ | ||||||
|  | #define CLEAR_HASH(s) \ | ||||||
|  |     s->head[s->hash_size-1] = NIL; \ | ||||||
|  |     zmemzero((charf *)s->head, (unsigned)(s->hash_size-1)*sizeof(*s->head)); | ||||||
|  |  | ||||||
| /* ========================================================================= */ | /* ========================================================================= */ | ||||||
| int deflateInit (strm, level) | int deflateInit (strm, level) | ||||||
|     z_stream *strm; |     z_stream *strm; | ||||||
|     int level; |     int level; | ||||||
| { | { | ||||||
|     return deflateInit2 (strm, level, DEFLATED, WBITS, MEM_LEVEL, 0); |     return deflateInit2 (strm, level, DEFLATED, MAX_WBITS, DEF_MEM_LEVEL, 0); | ||||||
|     /* To do: ignore strm->next_in if we use it as window */ |     /* To do: ignore strm->next_in if we use it as window */ | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -182,16 +191,16 @@ int deflateInit2 (strm, level, method, windowBits, memLevel, strategy) | |||||||
|     if (level == Z_DEFAULT_COMPRESSION) level = 6; |     if (level == Z_DEFAULT_COMPRESSION) level = 6; | ||||||
|  |  | ||||||
|     if (windowBits < 0) { /* undocumented feature: suppress zlib header */ |     if (windowBits < 0) { /* undocumented feature: suppress zlib header */ | ||||||
| 	noheader = 1; |         noheader = 1; | ||||||
| 	windowBits = -windowBits; |         windowBits = -windowBits; | ||||||
|     } |     } | ||||||
|     if (memLevel < 1 || memLevel > MAX_MEM_LEVEL || method != DEFLATED || |     if (memLevel < 1 || memLevel > MAX_MEM_LEVEL || method != DEFLATED || | ||||||
| 	windowBits < 8 || windowBits > 15 || level < 1 || level > 9) { |         windowBits < 8 || windowBits > 15 || level < 1 || level > 9) { | ||||||
| 	return Z_STREAM_ERROR; |         return Z_STREAM_ERROR; | ||||||
|     } |     } | ||||||
|     s = (deflate_state *) ZALLOC(strm, 1, sizeof(deflate_state)); |     s = (deflate_state *) ZALLOC(strm, 1, sizeof(deflate_state)); | ||||||
|     if (s == Z_NULL) return Z_MEM_ERROR; |     if (s == Z_NULL) return Z_MEM_ERROR; | ||||||
|     strm->state = (struct internal_state *)s; |     strm->state = (struct internal_state FAR *)s; | ||||||
|     s->strm = strm; |     s->strm = strm; | ||||||
|  |  | ||||||
|     s->noheader = noheader; |     s->noheader = noheader; | ||||||
| @@ -204,22 +213,22 @@ int deflateInit2 (strm, level, method, windowBits, memLevel, strategy) | |||||||
|     s->hash_mask = s->hash_size - 1; |     s->hash_mask = s->hash_size - 1; | ||||||
|     s->hash_shift =  ((s->hash_bits+MIN_MATCH-1)/MIN_MATCH); |     s->hash_shift =  ((s->hash_bits+MIN_MATCH-1)/MIN_MATCH); | ||||||
|  |  | ||||||
|     s->window = (Byte*) ZALLOC(strm, s->w_size, 2*sizeof(Byte)); |     s->window = (Bytef *) ZALLOC(strm, s->w_size, 2*sizeof(Byte)); | ||||||
|     s->prev   = (Pos*)  ZALLOC(strm, s->w_size, sizeof(Pos)); |     s->prev   = (Posf *)  ZALLOC(strm, s->w_size, sizeof(Pos)); | ||||||
|     s->head   = (Pos*)  ZALLOC(strm, s->hash_size, sizeof(Pos)); |     s->head   = (Posf *)  ZALLOC(strm, s->hash_size, sizeof(Pos)); | ||||||
|  |  | ||||||
|     s->lit_bufsize = 1 << (memLevel + 6); /* 16K elements by default */ |     s->lit_bufsize = 1 << (memLevel + 6); /* 16K elements by default */ | ||||||
|  |  | ||||||
|     s->pending_buf = (uch*) ZALLOC(strm, s->lit_bufsize, 2*sizeof(ush)); |     s->pending_buf = (uchf *) ZALLOC(strm, s->lit_bufsize, 2*sizeof(ush)); | ||||||
|  |  | ||||||
|     if (s->window == Z_NULL || s->prev == Z_NULL || s->head == Z_NULL || |     if (s->window == Z_NULL || s->prev == Z_NULL || s->head == Z_NULL || | ||||||
| 	s->pending_buf == Z_NULL) { |         s->pending_buf == Z_NULL) { | ||||||
| 	strm->msg = z_errmsg[1-Z_MEM_ERROR]; |         strm->msg = z_errmsg[1-Z_MEM_ERROR]; | ||||||
| 	deflateEnd (strm); |         deflateEnd (strm); | ||||||
| 	return Z_MEM_ERROR; |         return Z_MEM_ERROR; | ||||||
|     } |     } | ||||||
|     s->d_buf = (ush*) &(s->pending_buf[s->lit_bufsize]); |     s->d_buf = (ushf *) &(s->pending_buf[s->lit_bufsize]); | ||||||
|     s->l_buf = (uch*) &(s->pending_buf[3*s->lit_bufsize]); |     s->l_buf = (uchf *) &(s->pending_buf[3*s->lit_bufsize]); | ||||||
|     /* We overlay pending_buf and d_buf+l_buf. This works since the average |     /* We overlay pending_buf and d_buf+l_buf. This works since the average | ||||||
|      * output size for (length,distance) codes is <= 32 bits (worst case |      * output size for (length,distance) codes is <= 32 bits (worst case | ||||||
|      * is 15+15+13=33). |      * is 15+15+13=33). | ||||||
| @@ -239,7 +248,7 @@ int deflateReset (strm) | |||||||
|     deflate_state *s; |     deflate_state *s; | ||||||
|      |      | ||||||
|     if (strm == Z_NULL || strm->state == Z_NULL || |     if (strm == Z_NULL || strm->state == Z_NULL || | ||||||
| 	strm->zalloc == Z_NULL || strm->zfree == Z_NULL) return Z_STREAM_ERROR; |         strm->zalloc == Z_NULL || strm->zfree == Z_NULL) return Z_STREAM_ERROR; | ||||||
|  |  | ||||||
|     strm->total_in = strm->total_out = 0; |     strm->total_in = strm->total_out = 0; | ||||||
|     strm->msg = Z_NULL; /* use zfree if we ever allocate msg dynamically */ |     strm->msg = Z_NULL; /* use zfree if we ever allocate msg dynamically */ | ||||||
| @@ -249,6 +258,9 @@ int deflateReset (strm) | |||||||
|     s->pending = 0; |     s->pending = 0; | ||||||
|     s->pending_out = s->pending_buf; |     s->pending_out = s->pending_buf; | ||||||
|  |  | ||||||
|  |     if (s->noheader < 0) { | ||||||
|  |         s->noheader = 0; /* was set to -1 by deflate(..., Z_FINISH); */ | ||||||
|  |     } | ||||||
|     s->status = s->noheader ? BUSY_STATE : INIT_STATE; |     s->status = s->noheader ? BUSY_STATE : INIT_STATE; | ||||||
|     s->adler = 1; |     s->adler = 1; | ||||||
|  |  | ||||||
| @@ -259,9 +271,9 @@ int deflateReset (strm) | |||||||
| } | } | ||||||
|  |  | ||||||
| /* ========================================================================= | /* ========================================================================= | ||||||
|  * Put a short the pending_out buffer. The 16-bit value is put in MSB order. |  * Put a short in the pending buffer. The 16-bit value is put in MSB order. | ||||||
|  * IN assertion: the stream state is correct and there is enough room in |  * IN assertion: the stream state is correct and there is enough room in | ||||||
|  * the pending_out buffer. |  * pending_buf. | ||||||
|  */ |  */ | ||||||
| local void putShortMSB (s, b) | local void putShortMSB (s, b) | ||||||
|     deflate_state *s; |     deflate_state *s; | ||||||
| @@ -289,7 +301,7 @@ local void flush_pending(strm) | |||||||
|     strm->avail_out  -= len; |     strm->avail_out  -= len; | ||||||
|     strm->state->pending -= len; |     strm->state->pending -= len; | ||||||
|     if (strm->state->pending == 0) { |     if (strm->state->pending == 0) { | ||||||
| 	strm->state->pending_out = strm->state->pending_buf; |         strm->state->pending_out = strm->state->pending_buf; | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -300,8 +312,9 @@ int deflate (strm, flush) | |||||||
| { | { | ||||||
|     if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR; |     if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR; | ||||||
|      |      | ||||||
|     if (strm->next_out == Z_NULL || strm->next_in == Z_NULL) { |     if (strm->next_out == Z_NULL || | ||||||
| 	ERR_RETURN(strm, Z_STREAM_ERROR); |         (strm->next_in == Z_NULL && strm->avail_in != 0)) { | ||||||
|  |         ERR_RETURN(strm, Z_STREAM_ERROR); | ||||||
|     } |     } | ||||||
|     if (strm->avail_out == 0) ERR_RETURN(strm, Z_BUF_ERROR); |     if (strm->avail_out == 0) ERR_RETURN(strm, Z_BUF_ERROR); | ||||||
|  |  | ||||||
| @@ -310,41 +323,65 @@ int deflate (strm, flush) | |||||||
|     /* Write the zlib header */ |     /* Write the zlib header */ | ||||||
|     if (strm->state->status == INIT_STATE) { |     if (strm->state->status == INIT_STATE) { | ||||||
|  |  | ||||||
| 	uInt header = (DEFLATED + ((strm->state->w_bits-8)<<4)) << 8; |         uInt header = (DEFLATED + ((strm->state->w_bits-8)<<4)) << 8; | ||||||
|         uInt level_flags = (strm->state->level-1) >> 1; |         uInt level_flags = (strm->state->level-1) >> 1; | ||||||
|  |  | ||||||
| 	if (level_flags > 3) level_flags = 3; |         if (level_flags > 3) level_flags = 3; | ||||||
| 	header |= (level_flags << 6); |         header |= (level_flags << 6); | ||||||
| 	header += 31 - (header % 31); |         header += 31 - (header % 31); | ||||||
|  |  | ||||||
| 	strm->state->status = BUSY_STATE; |         strm->state->status = BUSY_STATE; | ||||||
| 	putShortMSB(strm->state, header); |         putShortMSB(strm->state, header); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /* Flush as much pending output as possible */ |     /* Flush as much pending output as possible */ | ||||||
|     if (strm->state->pending != 0) { |     if (strm->state->pending != 0) { | ||||||
| 	flush_pending(strm); |         flush_pending(strm); | ||||||
| 	if (strm->avail_out == 0) return Z_OK; |         if (strm->avail_out == 0) return Z_OK; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /* User must not provide more input after the first FINISH: */ |     /* User must not provide more input after the first FINISH: */ | ||||||
|     if (strm->state->status == FINISH_STATE && strm->avail_in != 0) { |     if (strm->state->status == FINISH_STATE && strm->avail_in != 0) { | ||||||
| 	ERR_RETURN(strm, Z_BUF_ERROR); |         ERR_RETURN(strm, Z_BUF_ERROR); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /* Start a new block or continue the current one. |     /* Start a new block or continue the current one. | ||||||
|      */ |      */ | ||||||
|     if (strm->avail_in != 0 || |     if (strm->avail_in != 0 || strm->state->lookahead != 0 || | ||||||
| 	(flush == Z_FINISH && strm->state->status != FINISH_STATE)) { |         (flush != Z_NO_FLUSH && strm->state->status != FINISH_STATE)) { | ||||||
| 	 |         int quit; | ||||||
| 	if (flush == Z_FINISH) { |  | ||||||
| 	    strm->state->status = FINISH_STATE; |         if (flush == Z_FINISH) { | ||||||
| 	} |             strm->state->status = FINISH_STATE; | ||||||
|  |         } | ||||||
|         if (strm->state->level <= 3) { |         if (strm->state->level <= 3) { | ||||||
| 	    if (deflate_fast(strm->state, flush)) return Z_OK; |             quit = deflate_fast(strm->state, flush); | ||||||
| 	} else { |         } else { | ||||||
| 	    if (deflate_slow(strm->state, flush)) return Z_OK; |             quit = deflate_slow(strm->state, flush); | ||||||
| 	} |         } | ||||||
|  |         if (quit || strm->avail_out == 0) return Z_OK; | ||||||
|  |         /* If flush != Z_NO_FLUSH && avail_out == 0, the next call | ||||||
|  |          * of deflate should use the same flush parameter to make sure | ||||||
|  |          * that the flush is complete. So we don't have to output an | ||||||
|  |          * empty block here, this will be done at next call. This also | ||||||
|  |          * ensures that for a very small output buffer, we emit at most | ||||||
|  |          * one empty block. | ||||||
|  |          */ | ||||||
|  |         if (flush != Z_OK && flush != Z_FINISH) { | ||||||
|  |             if (flush == Z_PARTIAL_FLUSH) { | ||||||
|  |                 ct_align(strm->state); | ||||||
|  |             } else { /* FULL_FLUSH or SYNC_FLUSH */ | ||||||
|  |                 ct_stored_block(strm->state, (char*)0, 0L, 0); | ||||||
|  |                 /* For a full flush, this empty block will be recognized | ||||||
|  |                  * as a special marker by inflate_sync(). | ||||||
|  |                  */ | ||||||
|  |                 if (flush == Z_FULL_FLUSH) { | ||||||
|  |                     CLEAR_HASH(strm->state);             /* forget history */ | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             flush_pending(strm); | ||||||
|  |             if (strm->avail_out == 0) return Z_OK; | ||||||
|  |         } | ||||||
|     } |     } | ||||||
|     Assert(strm->avail_out > 0, "bug2"); |     Assert(strm->avail_out > 0, "bug2"); | ||||||
|  |  | ||||||
| @@ -358,7 +395,7 @@ int deflate (strm, flush) | |||||||
|     /* If avail_out is zero, the application will call deflate again |     /* If avail_out is zero, the application will call deflate again | ||||||
|      * to flush the rest. |      * to flush the rest. | ||||||
|      */ |      */ | ||||||
|     strm->state->noheader = 1; /* write the trailer only once! */ |     strm->state->noheader = -1; /* write the trailer only once! */ | ||||||
|     return strm->state->pending != 0 ? Z_OK : Z_STREAM_END; |     return strm->state->pending != 0 ? Z_OK : Z_STREAM_END; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -385,13 +422,13 @@ int deflateCopy (dest, source) | |||||||
|     z_stream *source; |     z_stream *source; | ||||||
| { | { | ||||||
|     if (source == Z_NULL || dest == Z_NULL || source->state == Z_NULL) { |     if (source == Z_NULL || dest == Z_NULL || source->state == Z_NULL) { | ||||||
| 	return Z_STREAM_ERROR; |         return Z_STREAM_ERROR; | ||||||
|     } |     } | ||||||
|     *dest = *source; |     *dest = *source; | ||||||
|     return Z_STREAM_ERROR; /* to be implemented */ |     return Z_STREAM_ERROR; /* to be implemented */ | ||||||
| #if 0 | #if 0 | ||||||
|     dest->state = (struct internal_state *) |     dest->state = (struct internal_state FAR *) | ||||||
| 	(*dest->zalloc)(1, sizeof(deflate_state)); |         (*dest->zalloc)(1, sizeof(deflate_state)); | ||||||
|     if (dest->state == Z_NULL) return Z_MEM_ERROR; |     if (dest->state == Z_NULL) return Z_MEM_ERROR; | ||||||
|  |  | ||||||
|     *(dest->state) = *(source->state); |     *(dest->state) = *(source->state); | ||||||
| @@ -405,7 +442,7 @@ int deflateCopy (dest, source) | |||||||
|  */ |  */ | ||||||
| local int read_buf(strm, buf, size) | local int read_buf(strm, buf, size) | ||||||
|     z_stream *strm; |     z_stream *strm; | ||||||
|     char *buf; |     charf *buf; | ||||||
|     unsigned size; |     unsigned size; | ||||||
| { | { | ||||||
|     unsigned len = strm->avail_in; |     unsigned len = strm->avail_in; | ||||||
| @@ -416,7 +453,7 @@ local int read_buf(strm, buf, size) | |||||||
|     strm->avail_in  -= len; |     strm->avail_in  -= len; | ||||||
|  |  | ||||||
|     if (!strm->state->noheader) { |     if (!strm->state->noheader) { | ||||||
| 	strm->state->adler = adler32(strm->state->adler, strm->next_in, len); |         strm->state->adler = adler32(strm->state->adler, strm->next_in, len); | ||||||
|     } |     } | ||||||
|     zmemcpy(buf, strm->next_in, len); |     zmemcpy(buf, strm->next_in, len); | ||||||
|     strm->next_in  += len; |     strm->next_in  += len; | ||||||
| @@ -431,16 +468,9 @@ local int read_buf(strm, buf, size) | |||||||
| local void lm_init (s) | local void lm_init (s) | ||||||
|     deflate_state *s; |     deflate_state *s; | ||||||
| { | { | ||||||
|     register unsigned j; |  | ||||||
|  |  | ||||||
|     s->window_size = (ulg)2L*s->w_size; |     s->window_size = (ulg)2L*s->w_size; | ||||||
|  |  | ||||||
|  |     CLEAR_HASH(s); | ||||||
|     /* Initialize the hash table (avoiding 64K overflow for 16 bit systems). |  | ||||||
|      * prev[] will be initialized on the fly. |  | ||||||
|      */ |  | ||||||
|     s->head[s->hash_size-1] = NIL; |  | ||||||
|     zmemzero((char*)s->head, (unsigned)(s->hash_size-1)*sizeof(*s->head)); |  | ||||||
|  |  | ||||||
|     /* Set the default configuration parameters: |     /* Set the default configuration parameters: | ||||||
|      */ |      */ | ||||||
| @@ -454,15 +484,10 @@ local void lm_init (s) | |||||||
|     s->lookahead = 0; |     s->lookahead = 0; | ||||||
|     s->match_length = MIN_MATCH-1; |     s->match_length = MIN_MATCH-1; | ||||||
|     s->match_available = 0; |     s->match_available = 0; | ||||||
|  |     s->ins_h = 0; | ||||||
| #ifdef ASMV | #ifdef ASMV | ||||||
|     match_init(); /* initialize the asm code */ |     match_init(); /* initialize the asm code */ | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|     s->ins_h = 0; |  | ||||||
|     for (j=0; j<MIN_MATCH-1; j++) UPDATE_HASH(s, s->ins_h, s->window[j]); |  | ||||||
|     /* If lookahead < MIN_MATCH, ins_h is garbage, but this is |  | ||||||
|      * not important since only literal bytes will be emitted. |  | ||||||
|      */ |  | ||||||
| } | } | ||||||
|  |  | ||||||
| /* =========================================================================== | /* =========================================================================== | ||||||
| @@ -482,25 +507,27 @@ local int longest_match(s, cur_match) | |||||||
|     IPos cur_match;                             /* current match */ |     IPos cur_match;                             /* current match */ | ||||||
| { | { | ||||||
|     unsigned chain_length = s->max_chain_length;/* max hash chain length */ |     unsigned chain_length = s->max_chain_length;/* max hash chain length */ | ||||||
|     register Byte *scan = s->window + s->strstart; /* current string */ |     register Bytef *scan = s->window + s->strstart; /* current string */ | ||||||
|     register Byte *match;                       /* matched string */ |     register Bytef *match;                       /* matched string */ | ||||||
|     register int len;                           /* length of current match */ |     register int len;                           /* length of current match */ | ||||||
|     int best_len = s->prev_length;              /* best match length so far */ |     int best_len = s->prev_length;              /* best match length so far */ | ||||||
|     IPos limit = s->strstart > (IPos)MAX_DIST(s) ? |     IPos limit = s->strstart > (IPos)MAX_DIST(s) ? | ||||||
| 	s->strstart - (IPos)MAX_DIST(s) : NIL; |         s->strstart - (IPos)MAX_DIST(s) : NIL; | ||||||
|     /* Stop when cur_match becomes <= limit. To simplify the code, |     /* Stop when cur_match becomes <= limit. To simplify the code, | ||||||
|      * we prevent matches with the string of window index 0. |      * we prevent matches with the string of window index 0. | ||||||
|      */ |      */ | ||||||
|  |     Posf *prev = s->prev; | ||||||
|  |     uInt wmask = s->w_mask; | ||||||
|  |  | ||||||
| #ifdef UNALIGNED_OK | #ifdef UNALIGNED_OK | ||||||
|     /* Compare two bytes at a time. Note: this is not always beneficial. |     /* Compare two bytes at a time. Note: this is not always beneficial. | ||||||
|      * Try with and without -DUNALIGNED_OK to check. |      * Try with and without -DUNALIGNED_OK to check. | ||||||
|      */ |      */ | ||||||
|     register Byte *strend = s->window + s->strstart + MAX_MATCH - 1; |     register Bytef *strend = s->window + s->strstart + MAX_MATCH - 1; | ||||||
|     register ush scan_start = *(ush*)scan; |     register ush scan_start = *(ush*)scan; | ||||||
|     register ush scan_end   = *(ush*)(scan+best_len-1); |     register ush scan_end   = *(ush*)(scan+best_len-1); | ||||||
| #else | #else | ||||||
|     register Byte *strend = s->window + s->strstart + MAX_MATCH; |     register Bytef *strend = s->window + s->strstart + MAX_MATCH; | ||||||
|     register Byte scan_end1  = scan[best_len-1]; |     register Byte scan_end1  = scan[best_len-1]; | ||||||
|     register Byte scan_end   = scan[best_len]; |     register Byte scan_end   = scan[best_len]; | ||||||
| #endif | #endif | ||||||
| @@ -514,7 +541,7 @@ local int longest_match(s, cur_match) | |||||||
|     if (s->prev_length >= s->good_match) { |     if (s->prev_length >= s->good_match) { | ||||||
|         chain_length >>= 2; |         chain_length >>= 2; | ||||||
|     } |     } | ||||||
|     Assert(s->strstart <= s->window_size-MIN_LOOKAHEAD, "need lookahead"); |     Assert((ulg)s->strstart <= s->window_size-MIN_LOOKAHEAD, "need lookahead"); | ||||||
|  |  | ||||||
|     do { |     do { | ||||||
|         Assert(cur_match < s->strstart, "no future"); |         Assert(cur_match < s->strstart, "no future"); | ||||||
| @@ -539,6 +566,7 @@ local int longest_match(s, cur_match) | |||||||
|          * necessary to put more guard bytes at the end of the window, or |          * necessary to put more guard bytes at the end of the window, or | ||||||
|          * to check more often for insufficient lookahead. |          * to check more often for insufficient lookahead. | ||||||
|          */ |          */ | ||||||
|  |         Assert(scan[2] == match[2], "scan[2]?"); | ||||||
|         scan++, match++; |         scan++, match++; | ||||||
|         do { |         do { | ||||||
|         } while (*(ush*)(scan+=2) == *(ush*)(match+=2) && |         } while (*(ush*)(scan+=2) == *(ush*)(match+=2) && | ||||||
| @@ -569,6 +597,7 @@ local int longest_match(s, cur_match) | |||||||
|          * the hash keys are equal and that HASH_BITS >= 8. |          * the hash keys are equal and that HASH_BITS >= 8. | ||||||
|          */ |          */ | ||||||
|         scan += 2, match++; |         scan += 2, match++; | ||||||
|  |         Assert(*scan == *match, "match[2]?"); | ||||||
|  |  | ||||||
|         /* We check for insufficient lookahead only every 8th comparison; |         /* We check for insufficient lookahead only every 8th comparison; | ||||||
|          * the 256th check will be made at strstart+258. |          * the 256th check will be made at strstart+258. | ||||||
| @@ -598,7 +627,7 @@ local int longest_match(s, cur_match) | |||||||
|             scan_end   = scan[best_len]; |             scan_end   = scan[best_len]; | ||||||
| #endif | #endif | ||||||
|         } |         } | ||||||
|     } while ((cur_match = s->prev[cur_match & s->w_mask]) > limit |     } while ((cur_match = prev[cur_match & wmask]) > limit | ||||||
|              && --chain_length != 0); |              && --chain_length != 0); | ||||||
|  |  | ||||||
|     return best_len; |     return best_len; | ||||||
| @@ -615,16 +644,18 @@ local void check_match(s, start, match, length) | |||||||
|     int length; |     int length; | ||||||
| { | { | ||||||
|     /* check that the match is indeed a match */ |     /* check that the match is indeed a match */ | ||||||
|     if (memcmp((char*)s->window + match, |     if (memcmp((charf *)s->window + match, | ||||||
|                 (char*)s->window + start, length) != EQUAL) { |                 (charf *)s->window + start, length) != EQUAL) { | ||||||
|         fprintf(stderr, |         fprintf(stderr, | ||||||
|             " start %d, match %d, length %d\n", |             " start %u, match %u, length %d\n", | ||||||
|             start, match, length); |             start, match, length); | ||||||
|  |         do { fprintf(stderr, "%c%c", s->window[match++], | ||||||
|  |                      s->window[start++]); } while (--length != 0); | ||||||
|         z_error("invalid match"); |         z_error("invalid match"); | ||||||
|     } |     } | ||||||
|     if (verbose > 1) { |     if (verbose > 1) { | ||||||
| 	fprintf(stderr,"\\[%d,%d]", start-match, length); |         fprintf(stderr,"\\[%d,%d]", start-match, length); | ||||||
| 	do { putc(s->window[start++], stderr); } while (--length != 0); |         do { putc(s->window[start++], stderr); } while (--length != 0); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| #else | #else | ||||||
| @@ -645,14 +676,16 @@ local void fill_window(s) | |||||||
|     deflate_state *s; |     deflate_state *s; | ||||||
| { | { | ||||||
|     register unsigned n, m; |     register unsigned n, m; | ||||||
|  |     register Posf *p; | ||||||
|     unsigned more;    /* Amount of free space at the end of the window. */ |     unsigned more;    /* Amount of free space at the end of the window. */ | ||||||
|  |     uInt wsize = s->w_size; | ||||||
|  |  | ||||||
|     do { |     do { | ||||||
| 	more = (unsigned)(s->window_size -(ulg)s->lookahead -(ulg)s->strstart); |         more = (unsigned)(s->window_size -(ulg)s->lookahead -(ulg)s->strstart); | ||||||
|  |  | ||||||
| 	/* Deal with !@#$% 64K limit: */ |         /* Deal with !@#$% 64K limit: */ | ||||||
| 	if (more == 0 && s->strstart == 0 && s->lookahead == 0) { |         if (more == 0 && s->strstart == 0 && s->lookahead == 0) { | ||||||
| 	    more = s->w_size; |             more = wsize; | ||||||
|         } else if (more == (unsigned)(-1)) { |         } else if (more == (unsigned)(-1)) { | ||||||
|             /* Very unlikely, but possible on 16 bit machine if strstart == 0 |             /* Very unlikely, but possible on 16 bit machine if strstart == 0 | ||||||
|              * and lookahead == 1 (input done one byte at time) |              * and lookahead == 1 (input done one byte at time) | ||||||
| @@ -662,30 +695,39 @@ local void fill_window(s) | |||||||
|         /* If the window is almost full and there is insufficient lookahead, |         /* If the window is almost full and there is insufficient lookahead, | ||||||
|          * move the upper half to the lower one to make room in the upper half. |          * move the upper half to the lower one to make room in the upper half. | ||||||
|          */ |          */ | ||||||
|         } else if (s->strstart >= s->w_size+MAX_DIST(s)) { |         } else if (s->strstart >= wsize+MAX_DIST(s)) { | ||||||
|  |  | ||||||
|             /* By the IN assertion, the window is not empty so we can't confuse |             /* By the IN assertion, the window is not empty so we can't confuse | ||||||
|              * more == 0 with more == 64K on a 16 bit machine. |              * more == 0 with more == 64K on a 16 bit machine. | ||||||
|              */ |              */ | ||||||
|             memcpy((char*)s->window, (char*)s->window+s->w_size, |             zmemcpy((charf *)s->window, (charf *)s->window+wsize, | ||||||
| 		   (unsigned)s->w_size); |                    (unsigned)wsize); | ||||||
|             s->match_start -= s->w_size; |             s->match_start -= wsize; | ||||||
|             s->strstart    -= s->w_size; /* we now have strstart >= MAX_DIST */ |             s->strstart    -= wsize; /* we now have strstart >= MAX_DIST */ | ||||||
|  |  | ||||||
|             s->block_start -= (long) s->w_size; |             s->block_start -= (long) wsize; | ||||||
|  |  | ||||||
|             for (n = 0; n < s->hash_size; n++) { |             /* Slide the hash table (could be avoided with 32 bit values | ||||||
|                 m = s->head[n]; |                at the expense of memory usage): | ||||||
|                 s->head[n] = (Pos)(m >= s->w_size ? m-s->w_size : NIL); |              */ | ||||||
|             } |             n = s->hash_size; | ||||||
|             for (n = 0; n < s->w_size; n++) { |             p = &s->head[n]; | ||||||
|                 m = s->prev[n]; |             do { | ||||||
|                 s->prev[n] = (Pos)(m >= s->w_size ? m-s->w_size : NIL); |                 m = *--p; | ||||||
|  |                 *p = (Pos)(m >= wsize ? m-wsize : NIL); | ||||||
|  |             } while (--n); | ||||||
|  |  | ||||||
|  |             n = wsize; | ||||||
|  |             p = &s->prev[n]; | ||||||
|  |             do { | ||||||
|  |                 m = *--p; | ||||||
|  |                 *p = (Pos)(m >= wsize ? m-wsize : NIL); | ||||||
|                 /* If n is not on any hash chain, prev[n] is garbage but |                 /* If n is not on any hash chain, prev[n] is garbage but | ||||||
|                  * its value will never be used. |                  * its value will never be used. | ||||||
|                  */ |                  */ | ||||||
|             } |             } while (--n); | ||||||
|             more += s->w_size; |  | ||||||
|  |             more += wsize; | ||||||
|         } |         } | ||||||
|         if (s->strm->avail_in == 0) return; |         if (s->strm->avail_in == 0) return; | ||||||
|  |  | ||||||
| @@ -702,9 +744,21 @@ local void fill_window(s) | |||||||
|          */ |          */ | ||||||
|         Assert(more >= 2, "more < 2"); |         Assert(more >= 2, "more < 2"); | ||||||
|  |  | ||||||
|         n = read_buf(s->strm, (char*)s->window + s->strstart + s->lookahead, |         n = read_buf(s->strm, (charf *)s->window + s->strstart + s->lookahead, | ||||||
| 		     more); |                      more); | ||||||
| 	s->lookahead += n; |         s->lookahead += n; | ||||||
|  |  | ||||||
|  |         /* Initialize the hash value now that we have some input: */ | ||||||
|  |         if (s->lookahead >= MIN_MATCH) { | ||||||
|  |             s->ins_h = s->window[s->strstart]; | ||||||
|  |             UPDATE_HASH(s, s->ins_h, s->window[s->strstart+1]); | ||||||
|  | #if MIN_MATCH != 3 | ||||||
|  |             Call UPDATE_HASH() MIN_MATCH-3 more times | ||||||
|  | #endif | ||||||
|  |         } | ||||||
|  |         /* If the whole input has less than MIN_MATCH bytes, ins_h is garbage, | ||||||
|  |          * but this is not important since only literal bytes will be emitted. | ||||||
|  |          */ | ||||||
|  |  | ||||||
|     } while (s->lookahead < MIN_LOOKAHEAD && s->strm->avail_in != 0); |     } while (s->lookahead < MIN_LOOKAHEAD && s->strm->avail_in != 0); | ||||||
| } | } | ||||||
| @@ -715,10 +769,11 @@ local void fill_window(s) | |||||||
|  */ |  */ | ||||||
| #define FLUSH_BLOCK_ONLY(s, eof) { \ | #define FLUSH_BLOCK_ONLY(s, eof) { \ | ||||||
|    ct_flush_block(s, (s->block_start >= 0L ? \ |    ct_flush_block(s, (s->block_start >= 0L ? \ | ||||||
| 	       (char*)&s->window[(unsigned)s->block_start] : \ |                (charf *)&s->window[(unsigned)s->block_start] : \ | ||||||
|                (char*)Z_NULL), (long)s->strstart - s->block_start, (eof)); \ |                (charf *)Z_NULL), (long)s->strstart - s->block_start, (eof)); \ | ||||||
|    s->block_start = s->strstart; \ |    s->block_start = s->strstart; \ | ||||||
|    flush_pending(s->strm); \ |    flush_pending(s->strm); \ | ||||||
|  |    Tracev((stderr,"[FLUSH]")); \ | ||||||
| } | } | ||||||
|  |  | ||||||
| /* Same but force premature exit if necessary. */ | /* Same but force premature exit if necessary. */ | ||||||
| @@ -750,16 +805,18 @@ local int deflate_fast(s, flush) | |||||||
|          * string following the next match. |          * string following the next match. | ||||||
|          */ |          */ | ||||||
|         if (s->lookahead < MIN_LOOKAHEAD) { |         if (s->lookahead < MIN_LOOKAHEAD) { | ||||||
| 	    fill_window(s); |             fill_window(s); | ||||||
| 	    if (s->lookahead < MIN_LOOKAHEAD && flush == Z_NO_FLUSH) return 1; |             if (s->lookahead < MIN_LOOKAHEAD && flush == Z_NO_FLUSH) return 1; | ||||||
|  |  | ||||||
| 	    if (s->lookahead == 0) break; /* flush the current block */ |             if (s->lookahead == 0) break; /* flush the current block */ | ||||||
| 	} |         } | ||||||
|  |  | ||||||
|         /* Insert the string window[strstart .. strstart+2] in the |         /* Insert the string window[strstart .. strstart+2] in the | ||||||
|          * dictionary, and set hash_head to the head of the hash chain: |          * dictionary, and set hash_head to the head of the hash chain: | ||||||
|          */ |          */ | ||||||
|         INSERT_STRING(s, s->strstart, hash_head); |         if (s->lookahead >= MIN_MATCH) { | ||||||
|  |             INSERT_STRING(s, s->strstart, hash_head); | ||||||
|  |         } | ||||||
|  |  | ||||||
|         /* Find the longest match, discarding those <= prev_length. |         /* Find the longest match, discarding those <= prev_length. | ||||||
|          * At this point we have always match_length < MIN_MATCH |          * At this point we have always match_length < MIN_MATCH | ||||||
| @@ -769,9 +826,9 @@ local int deflate_fast(s, flush) | |||||||
|              * of window index 0 (in particular we have to avoid a match |              * of window index 0 (in particular we have to avoid a match | ||||||
|              * of the string with itself at the start of the input file). |              * of the string with itself at the start of the input file). | ||||||
|              */ |              */ | ||||||
| 	    if (s->strategy != Z_HUFFMAN_ONLY) { |             if (s->strategy != Z_HUFFMAN_ONLY) { | ||||||
| 		s->match_length = longest_match (s, hash_head); |                 s->match_length = longest_match (s, hash_head); | ||||||
| 	    } |             } | ||||||
|             /* longest_match() sets match_start */ |             /* longest_match() sets match_start */ | ||||||
|  |  | ||||||
|             if (s->match_length > s->lookahead) s->match_length = s->lookahead; |             if (s->match_length > s->lookahead) s->match_length = s->lookahead; | ||||||
| @@ -780,22 +837,21 @@ local int deflate_fast(s, flush) | |||||||
|             check_match(s, s->strstart, s->match_start, s->match_length); |             check_match(s, s->strstart, s->match_start, s->match_length); | ||||||
|  |  | ||||||
|             bflush = ct_tally(s, s->strstart - s->match_start, |             bflush = ct_tally(s, s->strstart - s->match_start, | ||||||
| 		 	      s->match_length - MIN_MATCH); |                               s->match_length - MIN_MATCH); | ||||||
|  |  | ||||||
|             s->lookahead -= s->match_length; |             s->lookahead -= s->match_length; | ||||||
|  |  | ||||||
|             /* Insert new strings in the hash table only if the match length |             /* Insert new strings in the hash table only if the match length | ||||||
|              * is not too large. This saves time but degrades compression. |              * is not too large. This saves time but degrades compression. | ||||||
|              */ |              */ | ||||||
|             if (s->match_length <= s->max_insert_length) { |             if (s->match_length <= s->max_insert_length && | ||||||
|  |                 s->lookahead >= MIN_MATCH) { | ||||||
|                 s->match_length--; /* string at strstart already in hash table */ |                 s->match_length--; /* string at strstart already in hash table */ | ||||||
|                 do { |                 do { | ||||||
|                     s->strstart++; |                     s->strstart++; | ||||||
|                     INSERT_STRING(s, s->strstart, hash_head); |                     INSERT_STRING(s, s->strstart, hash_head); | ||||||
|                     /* strstart never exceeds WSIZE-MAX_MATCH, so there are |                     /* strstart never exceeds WSIZE-MAX_MATCH, so there are | ||||||
|                      * always MIN_MATCH bytes ahead. If lookahead < MIN_MATCH |                      * always MIN_MATCH bytes ahead. | ||||||
|                      * these bytes are garbage, but it does not matter since |  | ||||||
|                      * the next lookahead bytes will be emitted as literals. |  | ||||||
|                      */ |                      */ | ||||||
|                 } while (--s->match_length != 0); |                 } while (--s->match_length != 0); | ||||||
|                 s->strstart++;  |                 s->strstart++;  | ||||||
| @@ -807,6 +863,9 @@ local int deflate_fast(s, flush) | |||||||
| #if MIN_MATCH != 3 | #if MIN_MATCH != 3 | ||||||
|                 Call UPDATE_HASH() MIN_MATCH-3 more times |                 Call UPDATE_HASH() MIN_MATCH-3 more times | ||||||
| #endif | #endif | ||||||
|  |                 /* If lookahead < MIN_MATCH, ins_h is garbage, but it does not | ||||||
|  |                  * matter since it will be recomputed at next deflate call. | ||||||
|  |                  */ | ||||||
|             } |             } | ||||||
|         } else { |         } else { | ||||||
|             /* No match, output a literal byte */ |             /* No match, output a literal byte */ | ||||||
| @@ -841,16 +900,18 @@ local int deflate_slow(s, flush) | |||||||
|          * string following the next match. |          * string following the next match. | ||||||
|          */ |          */ | ||||||
|         if (s->lookahead < MIN_LOOKAHEAD) { |         if (s->lookahead < MIN_LOOKAHEAD) { | ||||||
| 	    fill_window(s); |             fill_window(s); | ||||||
| 	    if (s->lookahead < MIN_LOOKAHEAD && flush == Z_NO_FLUSH) return 1; |             if (s->lookahead < MIN_LOOKAHEAD && flush == Z_NO_FLUSH) return 1; | ||||||
|  |  | ||||||
| 	    if (s->lookahead == 0) break; /* flush the current block */ |             if (s->lookahead == 0) break; /* flush the current block */ | ||||||
| 	} |         } | ||||||
|  |  | ||||||
|         /* Insert the string window[strstart .. strstart+2] in the |         /* Insert the string window[strstart .. strstart+2] in the | ||||||
|          * dictionary, and set hash_head to the head of the hash chain: |          * dictionary, and set hash_head to the head of the hash chain: | ||||||
|          */ |          */ | ||||||
|         INSERT_STRING(s, s->strstart, hash_head); |         if (s->lookahead >= MIN_MATCH) { | ||||||
|  |             INSERT_STRING(s, s->strstart, hash_head); | ||||||
|  |         } | ||||||
|  |  | ||||||
|         /* Find the longest match, discarding those <= prev_length. |         /* Find the longest match, discarding those <= prev_length. | ||||||
|          */ |          */ | ||||||
| @@ -863,15 +924,15 @@ local int deflate_slow(s, flush) | |||||||
|              * of window index 0 (in particular we have to avoid a match |              * of window index 0 (in particular we have to avoid a match | ||||||
|              * of the string with itself at the start of the input file). |              * of the string with itself at the start of the input file). | ||||||
|              */ |              */ | ||||||
| 	    if (s->strategy != Z_HUFFMAN_ONLY) { |             if (s->strategy != Z_HUFFMAN_ONLY) { | ||||||
| 		s->match_length = longest_match (s, hash_head); |                 s->match_length = longest_match (s, hash_head); | ||||||
| 	    } |             } | ||||||
|             /* longest_match() sets match_start */ |             /* longest_match() sets match_start */ | ||||||
|             if (s->match_length > s->lookahead) s->match_length = s->lookahead; |             if (s->match_length > s->lookahead) s->match_length = s->lookahead; | ||||||
|  |  | ||||||
|             if (s->match_length <= 5 && (s->strategy == Z_FILTERED || |             if (s->match_length <= 5 && (s->strategy == Z_FILTERED || | ||||||
| 	         (s->match_length == MIN_MATCH && |                  (s->match_length == MIN_MATCH && | ||||||
| 		  s->strstart - s->match_start > TOO_FAR))) { |                   s->strstart - s->match_start > TOO_FAR))) { | ||||||
|  |  | ||||||
|                 /* If prev_match is also MIN_MATCH, match_start is garbage |                 /* If prev_match is also MIN_MATCH, match_start is garbage | ||||||
|                  * but we will ignore the current match anyway. |                  * but we will ignore the current match anyway. | ||||||
| @@ -883,25 +944,25 @@ local int deflate_slow(s, flush) | |||||||
|          * match is not better, output the previous match: |          * match is not better, output the previous match: | ||||||
|          */ |          */ | ||||||
|         if (s->prev_length >= MIN_MATCH && s->match_length <= s->prev_length) { |         if (s->prev_length >= MIN_MATCH && s->match_length <= s->prev_length) { | ||||||
|  |             uInt max_insert = s->strstart + s->lookahead - MIN_MATCH; | ||||||
|  |             /* Do not insert strings in hash table beyond this. */ | ||||||
|  |  | ||||||
|             check_match(s, s->strstart-1, s->prev_match, s->prev_length); |             check_match(s, s->strstart-1, s->prev_match, s->prev_length); | ||||||
|  |  | ||||||
|             bflush = ct_tally(s, s->strstart -1 - s->prev_match, |             bflush = ct_tally(s, s->strstart -1 - s->prev_match, | ||||||
| 			      s->prev_length - MIN_MATCH); |                               s->prev_length - MIN_MATCH); | ||||||
|  |  | ||||||
|             /* Insert in hash table all strings up to the end of the match. |             /* Insert in hash table all strings up to the end of the match. | ||||||
|              * strstart-1 and strstart are already inserted. |              * strstart-1 and strstart are already inserted. If there is not | ||||||
|  |              * enough lookahead, the last two strings are not inserted in | ||||||
|  |              * the hash table. | ||||||
|              */ |              */ | ||||||
|             s->lookahead -= s->prev_length-1; |             s->lookahead -= s->prev_length-1; | ||||||
|             s->prev_length -= 2; |             s->prev_length -= 2; | ||||||
|             do { |             do { | ||||||
|                 s->strstart++; |                 if (++s->strstart <= max_insert) { | ||||||
|                 INSERT_STRING(s, s->strstart, hash_head); |                     INSERT_STRING(s, s->strstart, hash_head); | ||||||
|                 /* strstart never exceeds WSIZE-MAX_MATCH, so there are |                 } | ||||||
|                  * always MIN_MATCH bytes ahead. If lookahead < MIN_MATCH |  | ||||||
|                  * these bytes are garbage, but it does not matter since the |  | ||||||
|                  * next lookahead bytes will always be emitted as literals. |  | ||||||
|                  */ |  | ||||||
|             } while (--s->prev_length != 0); |             } while (--s->prev_length != 0); | ||||||
|             s->match_available = 0; |             s->match_available = 0; | ||||||
|             s->match_length = MIN_MATCH-1; |             s->match_length = MIN_MATCH-1; | ||||||
| @@ -916,11 +977,11 @@ local int deflate_slow(s, flush) | |||||||
|              */ |              */ | ||||||
|             Tracevv((stderr,"%c", s->window[s->strstart-1])); |             Tracevv((stderr,"%c", s->window[s->strstart-1])); | ||||||
|             if (ct_tally (s, 0, s->window[s->strstart-1])) { |             if (ct_tally (s, 0, s->window[s->strstart-1])) { | ||||||
| 	        FLUSH_BLOCK_ONLY(s, 0); |                 FLUSH_BLOCK_ONLY(s, 0); | ||||||
|             } |             } | ||||||
|             s->strstart++; |             s->strstart++; | ||||||
|             s->lookahead--; |             s->lookahead--; | ||||||
| 	    if (s->strm->avail_out == 0) return 1; |             if (s->strm->avail_out == 0) return 1; | ||||||
|         } else { |         } else { | ||||||
|             /* There is no previous match to compare with, wait for |             /* There is no previous match to compare with, wait for | ||||||
|              * the next step to decide. |              * the next step to decide. | ||||||
| @@ -930,8 +991,13 @@ local int deflate_slow(s, flush) | |||||||
|             s->lookahead--; |             s->lookahead--; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     if (s->match_available) ct_tally (s, 0, s->window[s->strstart-1]); |     Assert (flush != Z_NO_FLUSH, "no flush?"); | ||||||
|  |     if (s->match_available) { | ||||||
|  |         Tracevv((stderr,"%c", s->window[s->strstart-1])); | ||||||
|  |         ct_tally (s, 0, s->window[s->strstart-1]); | ||||||
|  |         s->match_available = 0; | ||||||
|  |     } | ||||||
|     FLUSH_BLOCK(s, flush == Z_FINISH); |     FLUSH_BLOCK(s, flush == Z_FINISH); | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										54
									
								
								deflate.h
									
									
									
									
									
								
							
							
						
						
									
										54
									
								
								deflate.h
									
									
									
									
									
								
							| @@ -8,7 +8,7 @@ | |||||||
|    subject to change. Applications should only use zlib.h. |    subject to change. Applications should only use zlib.h. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| /* $Id: deflate.h,v 1.3 1995/04/14 12:39:45 jloup Exp $ */ | /* $Id: deflate.h,v 1.5 1995/05/03 17:27:09 jloup Exp $ */ | ||||||
|  |  | ||||||
| #include "zutil.h" | #include "zutil.h" | ||||||
|  |  | ||||||
| @@ -58,7 +58,7 @@ typedef struct ct_data_s { | |||||||
|         ush  dad;        /* father node in Huffman tree */ |         ush  dad;        /* father node in Huffman tree */ | ||||||
|         ush  len;        /* length of bit string */ |         ush  len;        /* length of bit string */ | ||||||
|     } dl; |     } dl; | ||||||
| } ct_data; | } FAR ct_data; | ||||||
|  |  | ||||||
| #define Freq fc.freq | #define Freq fc.freq | ||||||
| #define Code fc.code | #define Code fc.code | ||||||
| @@ -71,10 +71,12 @@ typedef struct tree_desc_s { | |||||||
|     ct_data *dyn_tree;           /* the dynamic tree */ |     ct_data *dyn_tree;           /* the dynamic tree */ | ||||||
|     int     max_code;            /* largest code with non zero frequency */ |     int     max_code;            /* largest code with non zero frequency */ | ||||||
|     static_tree_desc *stat_desc; /* the corresponding static tree */ |     static_tree_desc *stat_desc; /* the corresponding static tree */ | ||||||
| } tree_desc; | } FAR tree_desc; | ||||||
|  |  | ||||||
| typedef ush Pos; | typedef ush Pos; | ||||||
|  | typedef Pos FAR Posf; | ||||||
| typedef unsigned IPos; | typedef unsigned IPos; | ||||||
|  |  | ||||||
| /* A Pos is an index in the character window. We use short instead of int to | /* A Pos is an index in the character window. We use short instead of int to | ||||||
|  * save space in the various tables. IPos is used only for parameter passing. |  * save space in the various tables. IPos is used only for parameter passing. | ||||||
|  */ |  */ | ||||||
| @@ -82,21 +84,21 @@ typedef unsigned IPos; | |||||||
| typedef struct internal_state { | typedef struct internal_state { | ||||||
|     z_stream *strm;      /* pointer back to this zlib stream */ |     z_stream *strm;      /* pointer back to this zlib stream */ | ||||||
|     int   status;        /* as the name implies */ |     int   status;        /* as the name implies */ | ||||||
|     Byte *pending_buf;   /* output still pending */ |     Bytef *pending_buf;  /* output still pending */ | ||||||
|     Byte *pending_out;   /* next pending byte to output to the stream */ |     Bytef *pending_out;  /* next pending byte to output to the stream */ | ||||||
|     int   pending;       /* nb of bytes in the pending buffer */ |     int   pending;       /* nb of bytes in the pending buffer */ | ||||||
|     uLong adler;         /* adler32 of uncompressed data */ |     uLong adler;         /* adler32 of uncompressed data */ | ||||||
|     int   noheader;      /* suppress zlib header and adler32 */ |     int   noheader;      /* suppress zlib header and adler32 */ | ||||||
|     Byte  data_type;     /* UNKNOWN, BINARY or ASCII */ |     Byte  data_type;     /* UNKNOWN, BINARY or ASCII */ | ||||||
|     Byte  method;        /* STORED (for zip only) or DEFLATED */ |     Byte  method;        /* STORED (for zip only) or DEFLATED */ | ||||||
|  |  | ||||||
|     		/* used by deflate.c: */ |                 /* used by deflate.c: */ | ||||||
|  |  | ||||||
|     uInt  w_size;        /* LZ77 window size (32K by default) */ |     uInt  w_size;        /* LZ77 window size (32K by default) */ | ||||||
|     uInt  w_bits;        /* log2(w_size)  (8..16) */ |     uInt  w_bits;        /* log2(w_size)  (8..16) */ | ||||||
|     uInt  w_mask;        /* w_size - 1 */ |     uInt  w_mask;        /* w_size - 1 */ | ||||||
|  |  | ||||||
|     Byte *window; |     Bytef *window; | ||||||
|     /* Sliding window. Input bytes are read into the second half of the window, |     /* Sliding window. Input bytes are read into the second half of the window, | ||||||
|      * and move to the first half later to keep a dictionary of at least wSize |      * and move to the first half later to keep a dictionary of at least wSize | ||||||
|      * bytes. With this organization, matches are limited to a distance of |      * bytes. With this organization, matches are limited to a distance of | ||||||
| @@ -111,13 +113,13 @@ typedef struct internal_state { | |||||||
|      * is directly used as sliding window. |      * is directly used as sliding window. | ||||||
|      */ |      */ | ||||||
|  |  | ||||||
|     Pos *prev; |     Posf *prev; | ||||||
|     /* Link to older string with same hash index. To limit the size of this |     /* Link to older string with same hash index. To limit the size of this | ||||||
|      * array to 64K, this link is maintained only for the last 32K strings. |      * array to 64K, this link is maintained only for the last 32K strings. | ||||||
|      * An index in this array is thus a window index modulo 32K. |      * An index in this array is thus a window index modulo 32K. | ||||||
|      */ |      */ | ||||||
|  |  | ||||||
|     Pos *head; /* Heads of the hash chains or NIL. */ |     Posf *head; /* Heads of the hash chains or NIL. */ | ||||||
|  |  | ||||||
|     uInt  ins_h;          /* hash index of string to be inserted */ |     uInt  ins_h;          /* hash index of string to be inserted */ | ||||||
|     uInt  hash_size;      /* number of elements in hash table */ |     uInt  hash_size;      /* number of elements in hash table */ | ||||||
| @@ -173,15 +175,15 @@ typedef struct internal_state { | |||||||
|  |  | ||||||
|      int nice_match; /* Stop searching when current match exceeds this */ |      int nice_match; /* Stop searching when current match exceeds this */ | ||||||
|  |  | ||||||
|     		/* used by trees.c: */ |                 /* used by trees.c: */ | ||||||
|  |     /* Didn't use ct_data typedef below to supress compiler warning */ | ||||||
|  |     struct ct_data_s dyn_ltree[HEAP_SIZE];   /* literal and length tree */ | ||||||
|  |     struct ct_data_s dyn_dtree[2*D_CODES+1]; /* distance tree */ | ||||||
|  |     struct ct_data_s bl_tree[2*BL_CODES+1];  /* Huffman tree for bit lengths */ | ||||||
|  |  | ||||||
|     ct_data dyn_ltree[HEAP_SIZE];   /* literal and length tree */ |     struct tree_desc_s l_desc;               /* desc. for literal tree */ | ||||||
|     ct_data dyn_dtree[2*D_CODES+1]; /* distance tree */ |     struct tree_desc_s d_desc;               /* desc. for distance tree */ | ||||||
|     ct_data bl_tree[2*BL_CODES+1];  /* Huffman tree for the bit lengths */ |     struct tree_desc_s bl_desc;              /* desc. for bit length tree */ | ||||||
|  |  | ||||||
|     tree_desc l_desc;               /* descriptor for literal tree */ |  | ||||||
|     tree_desc d_desc;               /* descriptor for distance tree */ |  | ||||||
|     tree_desc bl_desc;              /* descriptor for bit length tree */ |  | ||||||
|  |  | ||||||
|     ush bl_count[MAX_BITS+1]; |     ush bl_count[MAX_BITS+1]; | ||||||
|     /* number of codes at each bit length for an optimal tree */ |     /* number of codes at each bit length for an optimal tree */ | ||||||
| @@ -197,7 +199,7 @@ typedef struct internal_state { | |||||||
|     /* Depth of each subtree used as tie breaker for trees of equal frequency |     /* Depth of each subtree used as tie breaker for trees of equal frequency | ||||||
|      */ |      */ | ||||||
|  |  | ||||||
|     uch *l_buf;           /* buffer for literals or lengths */ |     uchf *l_buf;          /* buffer for literals or lengths */ | ||||||
|  |  | ||||||
|     uInt  lit_bufsize; |     uInt  lit_bufsize; | ||||||
|     /* Size of match buffer for literals/lengths.  There are 4 reasons for |     /* Size of match buffer for literals/lengths.  There are 4 reasons for | ||||||
| @@ -221,7 +223,7 @@ typedef struct internal_state { | |||||||
|  |  | ||||||
|     uInt last_lit;      /* running index in l_buf */ |     uInt last_lit;      /* running index in l_buf */ | ||||||
|  |  | ||||||
|     ush *d_buf; |     ushf *d_buf; | ||||||
|     /* Buffer for distances. To simplify the code, d_buf and l_buf have |     /* Buffer for distances. To simplify the code, d_buf and l_buf have | ||||||
|      * the same number of elements. To use different lengths, an extra flag |      * the same number of elements. To use different lengths, an extra flag | ||||||
|      * array would be necessary. |      * array would be necessary. | ||||||
| @@ -245,8 +247,7 @@ typedef struct internal_state { | |||||||
|      * are always zero. |      * are always zero. | ||||||
|      */ |      */ | ||||||
|  |  | ||||||
| } deflate_state; | } FAR deflate_state; | ||||||
|  |  | ||||||
|  |  | ||||||
| /* Output a byte on the stream. | /* Output a byte on the stream. | ||||||
|  * IN assertion: there is enough room in pending_buf. |  * IN assertion: there is enough room in pending_buf. | ||||||
| @@ -264,7 +265,10 @@ typedef struct internal_state { | |||||||
|  * distances are limited to MAX_DIST instead of WSIZE. |  * distances are limited to MAX_DIST instead of WSIZE. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| 	/* in trees.c */ |         /* in trees.c */ | ||||||
| void ct_init       __P((deflate_state *s)); | void ct_init       OF((deflate_state *s)); | ||||||
| int  ct_tally      __P((deflate_state *s, int dist, int lc)); | int  ct_tally      OF((deflate_state *s, int dist, int lc)); | ||||||
| ulg ct_flush_block __P((deflate_state *s, char *buf, ulg stored_len, int eof)); | ulg ct_flush_block OF((deflate_state *s, charf *buf, ulg stored_len, int eof)); | ||||||
|  | void ct_align      OF((deflate_state *s)); | ||||||
|  | void ct_stored_block OF((deflate_state *s, charf *buf, ulg stored_len, | ||||||
|  |                           int eof)); | ||||||
|   | |||||||
							
								
								
									
										48
									
								
								descrip.mms
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										48
									
								
								descrip.mms
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,48 @@ | |||||||
|  | # descrip.mms: MMS description file for building zlib on VMS | ||||||
|  | # written by Martin P.J. Zinser <m.zinser@gsi.de> | ||||||
|  |  | ||||||
|  | cc_defs =  | ||||||
|  | c_deb =  | ||||||
|  |  | ||||||
|  | .ifdef __DECC__ | ||||||
|  | pref = /prefix=all | ||||||
|  | .endif | ||||||
|  |  | ||||||
|  | OBJS = adler32.obj, compress.obj, crc32.obj, gzio.obj, uncompr.obj,\ | ||||||
|  |        deflate.obj, trees.obj, zutil.obj, inflate.obj, infblock.obj,\ | ||||||
|  |        inftrees.obj, infcodes.obj, infutil.obj, inffast.obj | ||||||
|  |  | ||||||
|  | CFLAGS= $(C_DEB) $(CC_DEFS) $(PREF) | ||||||
|  |  | ||||||
|  | all : example.exe minigzip.exe | ||||||
|  |         @ write sys$output " Example applications available" | ||||||
|  | libz.olb : libz.olb($(OBJS)) | ||||||
|  | 	@ write sys$output " libz available" | ||||||
|  |  | ||||||
|  | example.exe : example.obj libz.olb | ||||||
|  |               link example,libz.olb/lib | ||||||
|  |  | ||||||
|  | minigzip.exe : minigzip.obj libz.olb | ||||||
|  |               link minigzip,libz.olb/lib,x11vms:xvmsutils.olb/lib | ||||||
|  |  | ||||||
|  | clean :  | ||||||
|  | 	delete *.obj;*,libz.olb;* | ||||||
|  |  | ||||||
|  |  | ||||||
|  | # Other dependencies. | ||||||
|  | adler32.obj : zutil.h zlib.h zconf.h | ||||||
|  | compress.obj : zlib.h zconf.h | ||||||
|  | crc32.obj : zutil.h zlib.h zconf.h | ||||||
|  | deflate.obj : deflate.h zutil.h zlib.h zconf.h | ||||||
|  | example.obj : zlib.h zconf.h | ||||||
|  | gzio.obj : zutil.h zlib.h zconf.h | ||||||
|  | infblock.obj : zutil.h zlib.h zconf.h infblock.h inftrees.h infcodes.h infutil.h | ||||||
|  | infcodes.obj : zutil.h zlib.h zconf.h inftrees.h infutil.h infcodes.h inffast.h | ||||||
|  | inffast.obj : zutil.h zlib.h zconf.h inftrees.h infutil.h inffast.h | ||||||
|  | inflate.obj : zutil.h zlib.h zconf.h infblock.h | ||||||
|  | inftrees.obj : zutil.h zlib.h zconf.h inftrees.h | ||||||
|  | infutil.obj : zutil.h zlib.h zconf.h inftrees.h infutil.h | ||||||
|  | minigzip.obj : zlib.h zconf.h | ||||||
|  | trees.obj : deflate.h zutil.h zlib.h zconf.h | ||||||
|  | uncompr.obj : zlib.h zconf.h | ||||||
|  | zutil.obj : zutil.h zlib.h zconf.h | ||||||
							
								
								
									
										161
									
								
								example.c
									
									
									
									
									
								
							
							
						
						
									
										161
									
								
								example.c
									
									
									
									
									
								
							| @@ -3,7 +3,7 @@ | |||||||
|  * For conditions of distribution and use, see copyright notice in zlib.h  |  * For conditions of distribution and use, see copyright notice in zlib.h  | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| /* $Id: example.c,v 1.6 1995/04/29 16:53:46 jloup Exp $ */ | /* $Id: example.c,v 1.9 1995/05/03 17:27:09 jloup Exp $ */ | ||||||
|  |  | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #include "zlib.h" | #include "zlib.h" | ||||||
| @@ -12,7 +12,9 @@ | |||||||
| #  include <string.h> | #  include <string.h> | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| extern void exit  __P((int)); | #ifndef __GO32__ | ||||||
|  | extern void exit  OF((int)); | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #define BUFLEN 4096 | #define BUFLEN 4096 | ||||||
|  |  | ||||||
| @@ -25,17 +27,22 @@ extern void exit  __P((int)); | |||||||
| #define CHECK_ERR(err, msg) { \ | #define CHECK_ERR(err, msg) { \ | ||||||
|     if (err != Z_OK) { \ |     if (err != Z_OK) { \ | ||||||
|         fprintf(stderr, "%s error: %d\n", msg, err); \ |         fprintf(stderr, "%s error: %d\n", msg, err); \ | ||||||
| 	exit(1); \ |         exit(1); \ | ||||||
|     } \ |     } \ | ||||||
| } | } | ||||||
|  |  | ||||||
| char *hello = "hello world"; | char *hello = "hello, hello!"; | ||||||
|  | /* "hello world" would be more standard, but the repeated "hello" | ||||||
|  |  * stresses the compression code better, sorry... | ||||||
|  |  */ | ||||||
|  |  | ||||||
| void test_compress __P((void)); | void test_compress OF((void)); | ||||||
| void test_gzio     __P((char *out, char *in)); | void test_gzio     OF((char *out, char *in)); | ||||||
| void test_deflate  __P((Byte compr[])); | void test_deflate  OF((Byte compr[])); | ||||||
| void test_inflate  __P((Byte compr[])); | void test_inflate  OF((Byte compr[])); | ||||||
| void main          __P((int argc, char *argv[])); | void test_flush    OF((Byte compr[])); | ||||||
|  | void test_sync     OF((Byte compr[])); | ||||||
|  | int  main          OF((int argc, char *argv[])); | ||||||
|  |  | ||||||
| /* =========================================================================== | /* =========================================================================== | ||||||
|  * Test compress() and uncompress() |  * Test compress() and uncompress() | ||||||
| @@ -58,9 +65,9 @@ void test_compress() | |||||||
|     CHECK_ERR(err, "uncompress"); |     CHECK_ERR(err, "uncompress"); | ||||||
|  |  | ||||||
|     if (strcmp((char*)uncompr, hello)) { |     if (strcmp((char*)uncompr, hello)) { | ||||||
| 	fprintf(stderr, "bad uncompress\n"); |         fprintf(stderr, "bad uncompress\n"); | ||||||
|     } else { |     } else { | ||||||
| 	printf("uncompress(): %s\n", uncompr); |         printf("uncompress(): %s\n", uncompr); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -79,31 +86,31 @@ void test_gzio(out, in) | |||||||
|  |  | ||||||
|     file = gzopen(out, "wb"); |     file = gzopen(out, "wb"); | ||||||
|     if (file == NULL) { |     if (file == NULL) { | ||||||
| 	fprintf(stderr, "gzopen error\n"); |         fprintf(stderr, "gzopen error\n"); | ||||||
| 	exit(1); |         exit(1); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     if (gzwrite(file, hello, len) != len) { |     if (gzwrite(file, hello, len) != len) { | ||||||
| 	fprintf(stderr, "gzwrite err: %s\n", gzerror(file, &err)); |         fprintf(stderr, "gzwrite err: %s\n", gzerror(file, &err)); | ||||||
|     } |     } | ||||||
|     gzclose(file); |     gzclose(file); | ||||||
|  |  | ||||||
|     file = gzopen(in, "rb"); |     file = gzopen(in, "rb"); | ||||||
|     if (file == NULL) { |     if (file == NULL) { | ||||||
| 	fprintf(stderr, "gzopen error\n"); |         fprintf(stderr, "gzopen error\n"); | ||||||
|     } |     } | ||||||
|     strcpy((char*)uncompr, "garbage"); |     strcpy((char*)uncompr, "garbage"); | ||||||
|  |  | ||||||
|     uncomprLen = gzread(file, uncompr, uncomprLen); |     uncomprLen = gzread(file, uncompr, uncomprLen); | ||||||
|     if (uncomprLen != len) { |     if (uncomprLen != len) { | ||||||
| 	fprintf(stderr, "gzread err: %s\n", gzerror(file, &err)); |         fprintf(stderr, "gzread err: %s\n", gzerror(file, &err)); | ||||||
|     } |     } | ||||||
|     gzclose(file); |     gzclose(file); | ||||||
|  |  | ||||||
|     if (strcmp((char*)uncompr, hello)) { |     if (strcmp((char*)uncompr, hello)) { | ||||||
| 	fprintf(stderr, "bad gzread\n"); |         fprintf(stderr, "bad gzread\n"); | ||||||
|     } else { |     } else { | ||||||
| 	printf("gzread(): %s\n", uncompr); |         printf("gzread(): %s\n", uncompr); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -127,16 +134,16 @@ void test_deflate(compr) | |||||||
|     c_stream.next_out = compr; |     c_stream.next_out = compr; | ||||||
|  |  | ||||||
|     while (c_stream.total_in != (uLong)len) { |     while (c_stream.total_in != (uLong)len) { | ||||||
| 	c_stream.avail_in = c_stream.avail_out = 1; /* force small buffers */ |         c_stream.avail_in = c_stream.avail_out = 1; /* force small buffers */ | ||||||
| 	err = deflate(&c_stream, Z_NO_FLUSH); |         err = deflate(&c_stream, Z_NO_FLUSH); | ||||||
| 	CHECK_ERR(err, "deflate"); |         CHECK_ERR(err, "deflate"); | ||||||
|     } |     } | ||||||
|     /* Finish the stream, still forcing small buffers: */ |     /* Finish the stream, still forcing small buffers: */ | ||||||
|     for (;;) { |     for (;;) { | ||||||
| 	c_stream.avail_out = 1; |         c_stream.avail_out = 1; | ||||||
| 	err = deflate(&c_stream, Z_FINISH); |         err = deflate(&c_stream, Z_FINISH); | ||||||
| 	if (err == Z_STREAM_END) break; |         if (err == Z_STREAM_END) break; | ||||||
| 	CHECK_ERR(err, "deflate"); |         CHECK_ERR(err, "deflate"); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     err = deflateEnd(&c_stream); |     err = deflateEnd(&c_stream); | ||||||
| @@ -165,47 +172,125 @@ void test_inflate(compr) | |||||||
|     d_stream.next_out = uncompr; |     d_stream.next_out = uncompr; | ||||||
|  |  | ||||||
|     for (;;) { |     for (;;) { | ||||||
| 	d_stream.avail_in = d_stream.avail_out = 1; /* force small buffers */ |         d_stream.avail_in = d_stream.avail_out = 1; /* force small buffers */ | ||||||
| 	err = inflate(&d_stream, Z_NO_FLUSH); |         err = inflate(&d_stream, Z_NO_FLUSH); | ||||||
| 	if (err == Z_STREAM_END) break; |         if (err == Z_STREAM_END) break; | ||||||
| 	CHECK_ERR(err, "inflate"); |         CHECK_ERR(err, "inflate"); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     err = inflateEnd(&d_stream); |     err = inflateEnd(&d_stream); | ||||||
|     CHECK_ERR(err, "inflateEnd"); |     CHECK_ERR(err, "inflateEnd"); | ||||||
|  |  | ||||||
|     if (strcmp((char*)uncompr, hello)) { |     if (strcmp((char*)uncompr, hello)) { | ||||||
| 	fprintf(stderr, "bad inflate\n"); |         fprintf(stderr, "bad inflate\n"); | ||||||
|     } else { |     } else { | ||||||
| 	printf("inflate(): %s\n", uncompr); |         printf("inflate(): %s\n", uncompr); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | /* =========================================================================== | ||||||
|  |  * Test deflate() with full flush | ||||||
|  |  */ | ||||||
|  | void test_flush(compr) | ||||||
|  |     Byte compr[]; | ||||||
|  | { | ||||||
|  |     z_stream c_stream; /* compression stream */ | ||||||
|  |     int err; | ||||||
|  |     int len = strlen(hello)+1; | ||||||
|  |  | ||||||
|  |     c_stream.zalloc = (alloc_func)0; | ||||||
|  |     c_stream.zfree = (free_func)0; | ||||||
|  |  | ||||||
|  |     err = deflateInit(&c_stream, Z_DEFAULT_COMPRESSION); | ||||||
|  |     CHECK_ERR(err, "deflateInit"); | ||||||
|  |  | ||||||
|  |     c_stream.next_in  = (Byte*)hello; | ||||||
|  |     c_stream.next_out = compr; | ||||||
|  |     c_stream.avail_in = 3; | ||||||
|  |     c_stream.avail_out = BUFLEN; | ||||||
|  |     err = deflate(&c_stream, Z_FULL_FLUSH); | ||||||
|  |     CHECK_ERR(err, "deflate"); | ||||||
|  |  | ||||||
|  |     compr[3]++; /* force an error in first compressed block */ | ||||||
|  |     c_stream.avail_in = len - 3; | ||||||
|  |  | ||||||
|  |     err = deflate(&c_stream, Z_FINISH); | ||||||
|  |     if (err != Z_STREAM_END) { | ||||||
|  |         CHECK_ERR(err, "deflate"); | ||||||
|  |     } | ||||||
|  |     err = deflateEnd(&c_stream); | ||||||
|  |     CHECK_ERR(err, "deflateEnd"); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /* =========================================================================== | ||||||
|  |  * Test inflateSync() | ||||||
|  |  */ | ||||||
|  | void test_sync(compr) | ||||||
|  |     Byte compr[]; | ||||||
|  | { | ||||||
|  |     local Byte uncompr[BUFLEN]; | ||||||
|  |     int err; | ||||||
|  |     z_stream d_stream; /* decompression stream */ | ||||||
|  |  | ||||||
|  |     strcpy((char*)uncompr, "garbage"); | ||||||
|  |  | ||||||
|  |     d_stream.zalloc = (alloc_func)0; | ||||||
|  |     d_stream.zfree = (free_func)0; | ||||||
|  |  | ||||||
|  |     err = inflateInit(&d_stream); | ||||||
|  |     CHECK_ERR(err, "inflateInit"); | ||||||
|  |  | ||||||
|  |     d_stream.next_in  = compr; | ||||||
|  |     d_stream.next_out = uncompr; | ||||||
|  |     d_stream.avail_in = 2; /* just read the zlib header */ | ||||||
|  |     d_stream.avail_out = sizeof(uncompr); | ||||||
|  |  | ||||||
|  |     inflate(&d_stream, Z_NO_FLUSH); | ||||||
|  |     CHECK_ERR(err, "inflate"); | ||||||
|  |  | ||||||
|  |     d_stream.avail_in = BUFLEN-2; /* let inflate read all compressed data */ | ||||||
|  |     err = inflateSync(&d_stream); /* skip the damaged part */ | ||||||
|  |     CHECK_ERR(err, "inflateSync"); | ||||||
|  |  | ||||||
|  |     err = inflate(&d_stream, Z_FINISH); | ||||||
|  |     if (err != Z_DATA_ERROR) { | ||||||
|  |         fprintf(stderr, "inflate should report DATA_ERROR\n"); | ||||||
|  |         /* Because of incorrect adler32 */ | ||||||
|  |     } | ||||||
|  |     err = inflateEnd(&d_stream); | ||||||
|  |     CHECK_ERR(err, "inflateEnd"); | ||||||
|  |  | ||||||
|  |     printf("after inflateSync(): hel%s\n", uncompr); | ||||||
|  | } | ||||||
|  |  | ||||||
| /* =========================================================================== | /* =========================================================================== | ||||||
|  * Usage:  example [output.gz  [input.gz]] |  * Usage:  example [output.gz  [input.gz]] | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| void main(argc, argv) | int main(argc, argv) | ||||||
|     int argc; |     int argc; | ||||||
|     char *argv[]; |     char *argv[]; | ||||||
| { | { | ||||||
|     local Byte compr[BUFLEN]; |     local Byte compr[BUFLEN]; | ||||||
|  |  | ||||||
|     if (zlib_version[0] != ZLIB_VERSION[0]) { |     if (zlib_version[0] != ZLIB_VERSION[0]) { | ||||||
| 	fprintf(stderr, "incompatible zlib version\n"); |         fprintf(stderr, "incompatible zlib version\n"); | ||||||
| 	exit(1); |         exit(1); | ||||||
|  |  | ||||||
|     } else if (strcmp(zlib_version, ZLIB_VERSION) != 0) { |     } else if (zstrcmp(zlib_version, ZLIB_VERSION) != 0) { | ||||||
| 	fprintf(stderr, "warning: different zlib version\n"); |         fprintf(stderr, "warning: different zlib version\n"); | ||||||
|     } |     } | ||||||
|     test_compress(); |     test_compress(); | ||||||
|  |  | ||||||
|     test_gzio((argc > 1 ? argv[1] : "foo.gz"), |     test_gzio((argc > 1 ? argv[1] : "foo.gz"), | ||||||
| 	      (argc > 2 ? argv[2] : "foo.gz")); |               (argc > 2 ? argv[2] : "foo.gz")); | ||||||
|  |  | ||||||
|     test_deflate(compr); |     test_deflate(compr); | ||||||
|  |  | ||||||
|     test_inflate(compr); |     test_inflate(compr); | ||||||
|  |  | ||||||
|  |     test_flush(compr); | ||||||
|  |     test_sync(compr); | ||||||
|  |  | ||||||
|     exit(0); |     exit(0); | ||||||
|  |     return 0; /* to avoid warning */ | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										304
									
								
								gzio.c
									
									
									
									
									
								
							
							
						
						
									
										304
									
								
								gzio.c
									
									
									
									
									
								
							| @@ -3,7 +3,7 @@ | |||||||
|  * For conditions of distribution and use, see copyright notice in zlib.h |  * For conditions of distribution and use, see copyright notice in zlib.h | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| /* $Id: gzio.c,v 1.5 1995/04/29 17:13:56 jloup Exp $ */ | /* $Id: gzio.c,v 1.8 1995/05/03 17:27:09 jloup Exp $ */ | ||||||
|  |  | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
|  |  | ||||||
| @@ -13,8 +13,8 @@ struct internal_state {int dummy;}; /* for buggy compilers */ | |||||||
|  |  | ||||||
| #define Z_BUFSIZE 4096 | #define Z_BUFSIZE 4096 | ||||||
|  |  | ||||||
| #define ALLOC(size) zcalloc((voidp)0, 1, size) | #define ALLOC(size) malloc(size) | ||||||
| #define TRYFREE(p) {if (p) zcfree((voidp)0, p);} | #define TRYFREE(p) {if (p) free(p);} | ||||||
|  |  | ||||||
| #define GZ_MAGIC_1 0x1f | #define GZ_MAGIC_1 0x1f | ||||||
| #define GZ_MAGIC_2 0x8b | #define GZ_MAGIC_2 0x8b | ||||||
| @@ -46,10 +46,10 @@ typedef struct gz_stream { | |||||||
| } gz_stream; | } gz_stream; | ||||||
|  |  | ||||||
|  |  | ||||||
| local int    destroy __P((gz_stream *s)); | local int    destroy OF((gz_stream *s)); | ||||||
| local gzFile gz_open __P((char *path, char *mode, int  fd)); | local gzFile gz_open OF((char *path, char *mode, int  fd)); | ||||||
| local void   putLong __P((FILE *file, uLong x)); | local void   putLong OF((FILE *file, uLong x)); | ||||||
| local uLong  getLong __P((Byte *buf)); | local uLong  getLong OF((Bytef *buf)); | ||||||
|  |  | ||||||
|  /* =========================================================================== |  /* =========================================================================== | ||||||
|  * Cleanup then free the given gz_stream. Return a zlib error code. |  * Cleanup then free the given gz_stream. Return a zlib error code. | ||||||
| @@ -68,16 +68,16 @@ local int destroy (s) | |||||||
|  |  | ||||||
|     if (s->stream.state != NULL) { |     if (s->stream.state != NULL) { | ||||||
|        if (s->mode == 'w') { |        if (s->mode == 'w') { | ||||||
| 	   err = deflateEnd(&(s->stream)); |            err = deflateEnd(&(s->stream)); | ||||||
|        } else if (s->mode == 'r') { |        } else if (s->mode == 'r') { | ||||||
| 	   err = inflateEnd(&(s->stream)); |            err = inflateEnd(&(s->stream)); | ||||||
|        } |        } | ||||||
|     } |     } | ||||||
|     if (s->file != NULL && fclose(s->file)) { |     if (s->file != NULL && fclose(s->file)) { | ||||||
| 	err = Z_ERRNO; |         err = Z_ERRNO; | ||||||
|     } |     } | ||||||
|     if (s->z_err < 0) err = s->z_err; |     if (s->z_err < 0) err = s->z_err; | ||||||
|     zcfree((voidp)0, s); |     TRYFREE(s); | ||||||
|     return err; |     return err; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -96,6 +96,7 @@ local gzFile gz_open (path, mode, fd) | |||||||
|     int  fd; |     int  fd; | ||||||
| { | { | ||||||
|     int err; |     int err; | ||||||
|  |     int level = Z_DEFAULT_COMPRESSION; /* compression level */ | ||||||
|     char *p = mode; |     char *p = mode; | ||||||
|     gz_stream *s = (gz_stream *)ALLOC(sizeof(gz_stream)); |     gz_stream *s = (gz_stream *)ALLOC(sizeof(gz_stream)); | ||||||
|  |  | ||||||
| @@ -115,34 +116,35 @@ local gzFile gz_open (path, mode, fd) | |||||||
|  |  | ||||||
|     s->path = (char*)ALLOC(strlen(path)+1); |     s->path = (char*)ALLOC(strlen(path)+1); | ||||||
|     if (s->path == NULL) { |     if (s->path == NULL) { | ||||||
| 	return destroy(s), (gzFile)Z_NULL; |         return destroy(s), (gzFile)Z_NULL; | ||||||
|     } |     } | ||||||
|     strcpy(s->path, path); /* do this early for debugging */ |     strcpy(s->path, path); /* do this early for debugging */ | ||||||
|  |  | ||||||
|     s->mode = '\0'; |     s->mode = '\0'; | ||||||
|     do { |     do { | ||||||
| 	if (*p == 'r') s->mode = 'r'; |         if (*p == 'r') s->mode = 'r'; | ||||||
| 	if (*p == 'w') s->mode = 'w'; |         if (*p == 'w') s->mode = 'w'; | ||||||
|  |         if (*p >= '1' && *p <= '9') level = *p - '0'; | ||||||
|     } while (*p++); |     } while (*p++); | ||||||
|     if (s->mode == '\0') return destroy(s), (gzFile)Z_NULL; |     if (s->mode == '\0') return destroy(s), (gzFile)Z_NULL; | ||||||
|      |      | ||||||
|     if (s->mode == 'w') { |     if (s->mode == 'w') { | ||||||
| 	err = deflateInit2(&(s->stream), Z_DEFAULT_COMPRESSION, |         err = deflateInit2(&(s->stream), level, | ||||||
| 			   DEFLATED, -WBITS, MEM_LEVEL, 0); |                            DEFLATED, -MAX_WBITS, DEF_MEM_LEVEL, 0); | ||||||
| 	/* windowBits is passed < 0 to suppress zlib header */ |         /* windowBits is passed < 0 to suppress zlib header */ | ||||||
|  |  | ||||||
| 	s->stream.next_out = s->outbuf = ALLOC(Z_BUFSIZE); |         s->stream.next_out = s->outbuf = (Byte*)ALLOC(Z_BUFSIZE); | ||||||
|  |  | ||||||
| 	if (err != Z_OK || s->outbuf == Z_NULL) { |         if (err != Z_OK || s->outbuf == Z_NULL) { | ||||||
| 	    return destroy(s), (gzFile)Z_NULL; |             return destroy(s), (gzFile)Z_NULL; | ||||||
| 	} |         } | ||||||
|     } else { |     } else { | ||||||
| 	err = inflateInit2(&(s->stream), -WBITS); |         err = inflateInit2(&(s->stream), -MAX_WBITS); | ||||||
| 	s->stream.next_in  = s->inbuf = ALLOC(Z_BUFSIZE); |         s->stream.next_in  = s->inbuf = (Byte*)ALLOC(Z_BUFSIZE); | ||||||
|  |  | ||||||
| 	if (err != Z_OK || s->inbuf == Z_NULL) { |         if (err != Z_OK || s->inbuf == Z_NULL) { | ||||||
| 	    return destroy(s), (gzFile)Z_NULL; |             return destroy(s), (gzFile)Z_NULL; | ||||||
| 	} |         } | ||||||
|     } |     } | ||||||
|     s->stream.avail_out = Z_BUFSIZE; |     s->stream.avail_out = Z_BUFSIZE; | ||||||
|  |  | ||||||
| @@ -150,55 +152,55 @@ local gzFile gz_open (path, mode, fd) | |||||||
|     s->file = fd < 0 ? FOPEN(path, mode) : fdopen(fd, mode); |     s->file = fd < 0 ? FOPEN(path, mode) : fdopen(fd, mode); | ||||||
|  |  | ||||||
|     if (s->file == NULL) { |     if (s->file == NULL) { | ||||||
| 	return destroy(s), (gzFile)Z_NULL; |         return destroy(s), (gzFile)Z_NULL; | ||||||
|     } |     } | ||||||
|     if (s->mode == 'w') { |     if (s->mode == 'w') { | ||||||
| 	/* Write a very simple .gz header: |         /* Write a very simple .gz header: | ||||||
| 	 */ |  | ||||||
| 	fprintf(s->file, "%c%c%c%c%c%c%c%c%c%c", GZ_MAGIC_1, GZ_MAGIC_2, |  | ||||||
| 	       DEFLATED, 0 /*flags*/, 0,0,0,0 /*time*/, 0 /*xflags*/, OS_CODE); |  | ||||||
|     } else { |  | ||||||
| 	/* Check and skip the header: |  | ||||||
|          */ |          */ | ||||||
| 	Byte c1 = 0, c2 = 0; |         fprintf(s->file, "%c%c%c%c%c%c%c%c%c%c", GZ_MAGIC_1, GZ_MAGIC_2, | ||||||
| 	Byte method = 0; |                DEFLATED, 0 /*flags*/, 0,0,0,0 /*time*/, 0 /*xflags*/, OS_CODE); | ||||||
| 	Byte flags = 0; |     } else { | ||||||
| 	Byte xflags = 0; |         /* Check and skip the header: | ||||||
| 	Byte time[4]; |          */ | ||||||
| 	Byte osCode; |         Byte c1 = 0, c2 = 0; | ||||||
| 	int c; |         Byte method = 0; | ||||||
|  |         Byte flags = 0; | ||||||
|  |         Byte xflags = 0; | ||||||
|  |         Byte time[4]; | ||||||
|  |         Byte osCode; | ||||||
|  |         int c; | ||||||
|  |  | ||||||
| 	s->stream.avail_in = fread(s->inbuf, 1, 2, s->file); |         s->stream.avail_in = fread(s->inbuf, 1, 2, s->file); | ||||||
| 	if (s->stream.avail_in != 2 || s->inbuf[0] != GZ_MAGIC_1 |         if (s->stream.avail_in != 2 || s->inbuf[0] != GZ_MAGIC_1 | ||||||
| 	    || s->inbuf[1] != GZ_MAGIC_2) { |             || s->inbuf[1] != GZ_MAGIC_2) { | ||||||
| 	    s->transparent = 1; |             s->transparent = 1; | ||||||
| 	    return (gzFile)s; |             return (gzFile)s; | ||||||
| 	} |         } | ||||||
| 	s->stream.avail_in = 0; |         s->stream.avail_in = 0; | ||||||
| 	fscanf(s->file,"%c%c%4c%c%c", &method, &flags, time, &xflags, &osCode); |         fscanf(s->file,"%c%c%4c%c%c", &method, &flags, time, &xflags, &osCode); | ||||||
|  |  | ||||||
| 	if (method != DEFLATED || feof(s->file) || (flags & RESERVED) != 0) { |         if (method != DEFLATED || feof(s->file) || (flags & RESERVED) != 0) { | ||||||
| 	    s->z_err = Z_DATA_ERROR; |             s->z_err = Z_DATA_ERROR; | ||||||
| 	    return (gzFile)s; |             return (gzFile)s; | ||||||
| 	} |         } | ||||||
| 	if ((flags & EXTRA_FIELD) != 0) { /* skip the extra field */ |         if ((flags & EXTRA_FIELD) != 0) { /* skip the extra field */ | ||||||
| 	    long len; |             long len; | ||||||
| 	    fscanf(s->file, "%c%c", &c1, &c2); |             fscanf(s->file, "%c%c", &c1, &c2); | ||||||
| 	    len = c1 + ((long)c2<<8); |             len = c1 + ((long)c2<<8); | ||||||
| 	    fseek(s->file, len, SEEK_CUR); |             fseek(s->file, len, SEEK_CUR); | ||||||
| 	} |         } | ||||||
| 	if ((flags & ORIG_NAME) != 0) { /* skip the original file name */ |         if ((flags & ORIG_NAME) != 0) { /* skip the original file name */ | ||||||
| 	    while ((c = getc(s->file)) != 0 && c != EOF) ; |             while ((c = getc(s->file)) != 0 && c != EOF) ; | ||||||
| 	} |         } | ||||||
| 	if ((flags & COMMENT) != 0) {   /* skip the .gz file comment */ |         if ((flags & COMMENT) != 0) {   /* skip the .gz file comment */ | ||||||
| 	    while ((c = getc(s->file)) != 0 && c != EOF) ; |             while ((c = getc(s->file)) != 0 && c != EOF) ; | ||||||
| 	} |         } | ||||||
| 	if ((flags & HEAD_CRC) != 0) {  /* skip the header crc */ |         if ((flags & HEAD_CRC) != 0) {  /* skip the header crc */ | ||||||
| 	    fscanf(s->file, "%c%c", &c1, &c2); |             fscanf(s->file, "%c%c", &c1, &c2); | ||||||
| 	} |         } | ||||||
| 	if (feof(s->file)) { |         if (feof(s->file)) { | ||||||
| 	    s->z_err = Z_DATA_ERROR; |             s->z_err = Z_DATA_ERROR; | ||||||
| 	} |         } | ||||||
|     } |     } | ||||||
|     return (gzFile)s; |     return (gzFile)s; | ||||||
| } | } | ||||||
| @@ -221,7 +223,7 @@ gzFile gzdopen (fd, mode) | |||||||
|     char *mode; |     char *mode; | ||||||
| { | { | ||||||
|     char name[20]; |     char name[20]; | ||||||
|     sprintf(name, "_fd:%d_", fd); /* for debugging */ |     sprintf(name, "<fd:%d>", fd); /* for debugging */ | ||||||
|  |  | ||||||
|     return gz_open (name, mode, fd); |     return gz_open (name, mode, fd); | ||||||
| } | } | ||||||
| @@ -232,7 +234,7 @@ gzFile gzdopen (fd, mode) | |||||||
| */ | */ | ||||||
| int gzread (file, buf, len) | int gzread (file, buf, len) | ||||||
|     gzFile file; |     gzFile file; | ||||||
|     voidp buf; |     voidnp buf; | ||||||
|     unsigned len; |     unsigned len; | ||||||
| { | { | ||||||
|     gz_stream *s = (gz_stream*)file; |     gz_stream *s = (gz_stream*)file; | ||||||
| @@ -240,16 +242,16 @@ int gzread (file, buf, len) | |||||||
|     if (s == NULL || s->mode != 'r') return Z_STREAM_ERROR; |     if (s == NULL || s->mode != 'r') return Z_STREAM_ERROR; | ||||||
|  |  | ||||||
|     if (s->transparent) { |     if (s->transparent) { | ||||||
| 	unsigned n = 0; |         int n = 0; | ||||||
| 	Byte *b = (Byte*)buf; |         Byte *b = (Byte*)buf; | ||||||
| 	/* Copy the first two (non-magic) bytes if not done already */ |         /* Copy the first two (non-magic) bytes if not done already */ | ||||||
| 	while (s->stream.avail_in > 0 && len > 0) { |         while (s->stream.avail_in > 0 && len > 0) { | ||||||
| 	    *b++ = *s->stream.next_in++; |             *b++ = *s->stream.next_in++; | ||||||
| 	    s->stream.avail_in--; |             s->stream.avail_in--; | ||||||
| 	    len--; n++; |             len--; n++; | ||||||
| 	} |         } | ||||||
| 	if (len == 0) return n; |         if (len == 0) return n; | ||||||
| 	return n + fread(buf, 1, len, s->file); |         return n + fread(b, 1, len, s->file); | ||||||
|     } |     } | ||||||
|     if (s->z_err == Z_DATA_ERROR) return -1; /* bad .gz file */ |     if (s->z_err == Z_DATA_ERROR) return -1; /* bad .gz file */ | ||||||
|     if (s->z_err == Z_STREAM_END) return 0;  /* don't read crc as data */ |     if (s->z_err == Z_STREAM_END) return 0;  /* don't read crc as data */ | ||||||
| @@ -259,29 +261,29 @@ int gzread (file, buf, len) | |||||||
|  |  | ||||||
|     while (s->stream.avail_out != 0) { |     while (s->stream.avail_out != 0) { | ||||||
|  |  | ||||||
| 	if (s->stream.avail_in == 0 && !s->z_eof) { |         if (s->stream.avail_in == 0 && !s->z_eof) { | ||||||
|  |  | ||||||
| 	    errno = 0; |             errno = 0; | ||||||
| 	    s->stream.avail_in = |             s->stream.avail_in = | ||||||
| 		fread(s->inbuf, 1, Z_BUFSIZE, s->file); |                 fread(s->inbuf, 1, Z_BUFSIZE, s->file); | ||||||
| 	    if (s->stream.avail_in == 0) { |             if (s->stream.avail_in == 0) { | ||||||
| 		s->z_eof = 1; |                 s->z_eof = 1; | ||||||
| 	    } else if (s->stream.avail_in == (uInt)EOF) { |             } else if (s->stream.avail_in == (uInt)EOF) { | ||||||
| 		s->stream.avail_in = 0; |                 s->stream.avail_in = 0; | ||||||
| 		s->z_eof = 1; |                 s->z_eof = 1; | ||||||
| 		s->z_err = Z_ERRNO; |                 s->z_err = Z_ERRNO; | ||||||
| 		break; |                 break; | ||||||
| 	    } |             } | ||||||
| 	    s->stream.next_in = s->inbuf; |             s->stream.next_in = s->inbuf; | ||||||
| 	} |         } | ||||||
| 	s->z_err = inflate(&(s->stream), Z_NO_FLUSH); |         s->z_err = inflate(&(s->stream), Z_NO_FLUSH); | ||||||
|  |  | ||||||
| 	if (s->z_err == Z_STREAM_END || |         if (s->z_err == Z_STREAM_END || | ||||||
|             s->z_err != Z_OK  || s->z_eof) break; |             s->z_err != Z_OK  || s->z_eof) break; | ||||||
|     } |     } | ||||||
|     len -= s->stream.avail_out; |     len -= s->stream.avail_out; | ||||||
|     s->crc = crc32(s->crc, buf, len); |     s->crc = crc32(s->crc, buf, len); | ||||||
|     return len; |     return (int)len; | ||||||
| } | } | ||||||
|  |  | ||||||
| /* =========================================================================== | /* =========================================================================== | ||||||
| @@ -290,7 +292,7 @@ int gzread (file, buf, len) | |||||||
| */ | */ | ||||||
| int gzwrite (file, buf, len) | int gzwrite (file, buf, len) | ||||||
|     gzFile file; |     gzFile file; | ||||||
|     voidp buf; |     voidnp buf; | ||||||
|     unsigned len; |     unsigned len; | ||||||
| { | { | ||||||
|     gz_stream *s = (gz_stream*)file; |     gz_stream *s = (gz_stream*)file; | ||||||
| @@ -302,22 +304,21 @@ int gzwrite (file, buf, len) | |||||||
|  |  | ||||||
|     while (s->stream.avail_in != 0) { |     while (s->stream.avail_in != 0) { | ||||||
|  |  | ||||||
| 	if (s->stream.avail_out == 0) { |         if (s->stream.avail_out == 0) { | ||||||
|  |  | ||||||
| 	    s->stream.next_out = s->outbuf; |             s->stream.next_out = s->outbuf; | ||||||
| 	    if (fwrite(s->outbuf, 1, Z_BUFSIZE, s->file) != Z_BUFSIZE) { |             if (fwrite(s->outbuf, 1, Z_BUFSIZE, s->file) != Z_BUFSIZE) { | ||||||
| 		s->z_err = Z_ERRNO; |                 s->z_err = Z_ERRNO; | ||||||
| 		break; |                 break; | ||||||
| 	    } |             } | ||||||
| 	    s->stream.avail_out = Z_BUFSIZE; |             s->stream.avail_out = Z_BUFSIZE; | ||||||
| 	} |         } | ||||||
| 	s->z_err = deflate(&(s->stream), Z_NO_FLUSH); |         s->z_err = deflate(&(s->stream), Z_NO_FLUSH); | ||||||
|  |         if (s->z_err != Z_OK) break; | ||||||
| 	if (s->z_err != Z_OK) break; |  | ||||||
|     } |     } | ||||||
|     s->crc = crc32(s->crc, buf, len); |     s->crc = crc32(s->crc, buf, len); | ||||||
|  |  | ||||||
|     return len - s->stream.avail_in; |     return (int)(len - s->stream.avail_in); | ||||||
| } | } | ||||||
|  |  | ||||||
| /* =========================================================================== | /* =========================================================================== | ||||||
| @@ -339,26 +340,27 @@ int gzflush (file, flush) | |||||||
|     s->stream.avail_in = 0; /* should be zero already anyway */ |     s->stream.avail_in = 0; /* should be zero already anyway */ | ||||||
|  |  | ||||||
|     for (;;) { |     for (;;) { | ||||||
| 	len = Z_BUFSIZE - s->stream.avail_out; |         len = Z_BUFSIZE - s->stream.avail_out; | ||||||
|  |  | ||||||
| 	if (len != 0) { |         if (len != 0) { | ||||||
| 	    if (fwrite(s->outbuf, 1, len, s->file) != len) { |             if (fwrite(s->outbuf, 1, len, s->file) != len) { | ||||||
| 		s->z_err = Z_ERRNO; |                 s->z_err = Z_ERRNO; | ||||||
| 		return Z_ERRNO; |                 return Z_ERRNO; | ||||||
| 	    } |             } | ||||||
| 	    s->stream.next_out = s->outbuf; |             s->stream.next_out = s->outbuf; | ||||||
| 	    s->stream.avail_out = Z_BUFSIZE; |             s->stream.avail_out = Z_BUFSIZE; | ||||||
| 	} |         } | ||||||
| 	if (done) break; |         if (done) break; | ||||||
| 	s->z_err = deflate(&(s->stream), flush); |         s->z_err = deflate(&(s->stream), flush); | ||||||
|  |  | ||||||
|         /* deflate has finished flushing only when it hasn't used up |         /* deflate has finished flushing only when it hasn't used up | ||||||
|          * all the available space in the output buffer:  |          * all the available space in the output buffer:  | ||||||
|          */ |          */ | ||||||
|         done = (s->stream.avail_out != 0 || s->z_err == Z_STREAM_END); |         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; |         if (s->z_err != Z_OK && s->z_err != Z_STREAM_END) break; | ||||||
|     } |     } | ||||||
|  |     fflush(s->file); | ||||||
|     return  s->z_err == Z_STREAM_END ? Z_OK : s->z_err; |     return  s->z_err == Z_STREAM_END ? Z_OK : s->z_err; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -371,8 +373,8 @@ local void putLong (file, x) | |||||||
| { | { | ||||||
|     int n; |     int n; | ||||||
|     for (n = 0; n < 4; n++) { |     for (n = 0; n < 4; n++) { | ||||||
| 	fputc((int)(x & 0xff), file); |         fputc((int)(x & 0xff), file); | ||||||
| 	x >>= 8; |         x >>= 8; | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -380,14 +382,14 @@ local void putLong (file, x) | |||||||
|    Reads a long in LSB order from the given buffer |    Reads a long in LSB order from the given buffer | ||||||
| */ | */ | ||||||
| local uLong getLong (buf) | local uLong getLong (buf) | ||||||
|     Byte *buf; |     Bytef *buf; | ||||||
| { | { | ||||||
|     uLong x = 0; |     uLong x = 0; | ||||||
|     Byte *p = buf+4; |     Bytef *p = buf+4; | ||||||
|  |  | ||||||
|     do { |     do { | ||||||
| 	x <<= 8; |         x <<= 8; | ||||||
| 	x |= *--p;  |         x |= *--p;  | ||||||
|     } while (p != buf); |     } while (p != buf); | ||||||
|     return x; |     return x; | ||||||
| } | } | ||||||
| @@ -406,31 +408,31 @@ int gzclose (file) | |||||||
|     if (s == NULL) return Z_STREAM_ERROR; |     if (s == NULL) return Z_STREAM_ERROR; | ||||||
|  |  | ||||||
|     if (s->mode == 'w') { |     if (s->mode == 'w') { | ||||||
| 	err = gzflush (file, Z_FINISH); |         err = gzflush (file, Z_FINISH); | ||||||
| 	if (err != Z_OK) return destroy(file); |         if (err != Z_OK) return destroy(file); | ||||||
|  |  | ||||||
| 	putLong (s->file, s->crc); |         putLong (s->file, s->crc); | ||||||
| 	putLong (s->file, s->stream.total_in); |         putLong (s->file, s->stream.total_in); | ||||||
|  |  | ||||||
|     } else if (s->mode == 'r' && s->z_err == Z_STREAM_END) { |     } else if (s->mode == 'r' && s->z_err == Z_STREAM_END) { | ||||||
|  |  | ||||||
| 	/* slide CRC and original size if they are at the end of inbuf */ |         /* slide CRC and original size if they are at the end of inbuf */ | ||||||
| 	if ((n = s->stream.avail_in) < 8  && !s->z_eof) { |         if ((n = s->stream.avail_in) < 8  && !s->z_eof) { | ||||||
| 	    Byte *p = s->inbuf; |             Byte *p = s->inbuf; | ||||||
| 	    Byte *q = s->stream.next_in; | 	    Bytef *q = s->stream.next_in; | ||||||
| 	    while (n--) { *p++ = *q++; }; |             while (n--) { *p++ = *q++; }; | ||||||
|  |  | ||||||
| 	    n = s->stream.avail_in; |             n = s->stream.avail_in; | ||||||
| 	    n += fread(p, 1, 8, s->file); |             n += fread(p, 1, 8, s->file); | ||||||
| 	    s->stream.next_in = s->inbuf; |             s->stream.next_in = s->inbuf; | ||||||
| 	} |         } | ||||||
| 	/* check CRC and original size */ |         /* check CRC and original size */ | ||||||
| 	if (n < 8 || |         if (n < 8 || | ||||||
| 	    getLong(s->stream.next_in) != s->crc || |             getLong(s->stream.next_in) != s->crc || | ||||||
| 	    getLong(s->stream.next_in + 4) != s->stream.total_out) { |             getLong(s->stream.next_in + 4) != s->stream.total_out) { | ||||||
|  |  | ||||||
| 	    s->z_err = Z_DATA_ERROR; |             s->z_err = Z_DATA_ERROR; | ||||||
| 	} |         } | ||||||
|     } |     } | ||||||
|     return destroy(file); |     return destroy(file); | ||||||
| } | } | ||||||
| @@ -450,8 +452,8 @@ char*  gzerror (file, errnum) | |||||||
|     gz_stream *s = (gz_stream*)file; |     gz_stream *s = (gz_stream*)file; | ||||||
|  |  | ||||||
|     if (s == NULL) { |     if (s == NULL) { | ||||||
| 	*errnum = Z_STREAM_ERROR; |         *errnum = Z_STREAM_ERROR; | ||||||
| 	return z_errmsg[1-Z_STREAM_ERROR]; |         return z_errmsg[1-Z_STREAM_ERROR]; | ||||||
|     } |     } | ||||||
|     *errnum = s->z_err; |     *errnum = s->z_err; | ||||||
|     if (*errnum == Z_OK) return ""; |     if (*errnum == Z_OK) return ""; | ||||||
|   | |||||||
							
								
								
									
										334
									
								
								infblock.c
									
									
									
									
									
								
							
							
						
						
									
										334
									
								
								infblock.c
									
									
									
									
									
								
							| @@ -12,7 +12,7 @@ | |||||||
| struct inflate_codes_state {int dummy;}; /* for buggy compilers */ | struct inflate_codes_state {int dummy;}; /* for buggy compilers */ | ||||||
|  |  | ||||||
| /* Table for deflate from PKZIP's appnote.txt. */ | /* Table for deflate from PKZIP's appnote.txt. */ | ||||||
| local uInt border[] = {	/* Order of the bit length code lengths */ | local uInt border[] = { /* Order of the bit length code lengths */ | ||||||
|         16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15}; |         16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15}; | ||||||
|  |  | ||||||
| /* | /* | ||||||
| @@ -60,44 +60,68 @@ local uInt border[] = {	/* Order of the bit length code lengths */ | |||||||
|       the two sets of lengths. |       the two sets of lengths. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| struct inflate_blocks_state *inflate_blocks_new(z, c, w) |  | ||||||
|  | void inflate_blocks_reset(s, z, c) | ||||||
|  | inflate_blocks_statef *s; | ||||||
|  | z_stream *z; | ||||||
|  | uLongf *c; | ||||||
|  | { | ||||||
|  |   if (s->checkfn != Z_NULL) | ||||||
|  |     *c = s->check; | ||||||
|  |   if (s->mode == BTREE || s->mode == DTREE) | ||||||
|  |     ZFREE(z, s->sub.trees.blens); | ||||||
|  |   if (s->mode == CODES) | ||||||
|  |   { | ||||||
|  |     inflate_codes_free(s->sub.decode.codes, z); | ||||||
|  |     inflate_trees_free(s->sub.decode.td, z); | ||||||
|  |     inflate_trees_free(s->sub.decode.tl, z); | ||||||
|  |   } | ||||||
|  |   s->mode = TYPE; | ||||||
|  |   s->bitk = 0; | ||||||
|  |   s->bitb = 0; | ||||||
|  |   s->read = s->write = s->window; | ||||||
|  |   if (s->checkfn != Z_NULL) | ||||||
|  |     s->check = (*s->checkfn)(0L, Z_NULL, 0); | ||||||
|  |   Trace((stderr, "inflate:   blocks reset\n")); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | inflate_blocks_statef *inflate_blocks_new(z, c, w) | ||||||
| z_stream *z; | z_stream *z; | ||||||
| check_func c; | check_func c; | ||||||
| uInt w; | uInt w; | ||||||
| { | { | ||||||
|   struct inflate_blocks_state *s; |   inflate_blocks_statef *s; | ||||||
|  |  | ||||||
|   if ((s = (struct inflate_blocks_state *)ZALLOC |   if ((s = (inflate_blocks_statef *)ZALLOC | ||||||
|        (z,1,sizeof(struct inflate_blocks_state))) == Z_NULL) |        (z,1,sizeof(struct inflate_blocks_state))) == Z_NULL) | ||||||
|     return s; |     return s; | ||||||
|   if ((s->window = (Byte *)ZALLOC(z, 1, w)) == Z_NULL) |   if ((s->window = (Bytef *)ZALLOC(z, 1, w)) == Z_NULL) | ||||||
|   { |   { | ||||||
|     ZFREE(z, s); |     ZFREE(z, s); | ||||||
|     return Z_NULL; |     return Z_NULL; | ||||||
|   } |   } | ||||||
|   s->mode = TYPE; |  | ||||||
|   s->bitk = 0; |  | ||||||
|   s->read = s->write = s->window; |  | ||||||
|   s->end = s->window + w; |   s->end = s->window + w; | ||||||
|   s->checkfn = c; |   s->checkfn = c; | ||||||
|   if (s->checkfn != Z_NULL) |   s->mode = TYPE; | ||||||
|     s->check = (*s->checkfn)(0L, Z_NULL, 0); |   Trace((stderr, "inflate:   blocks allocated\n")); | ||||||
|  |   inflate_blocks_reset(s, z, &s->check); | ||||||
|   return s; |   return s; | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| int inflate_blocks(s, z, r) | int inflate_blocks(s, z, r) | ||||||
| struct inflate_blocks_state *s; | inflate_blocks_statef *s; | ||||||
| z_stream *z; | z_stream *z; | ||||||
| int r; | int r; | ||||||
| { | { | ||||||
|   uInt t;		/* temporary storage */ |   uInt t;               /* temporary storage */ | ||||||
|   uLong b;		/* bit buffer */ |   uLong b;              /* bit buffer */ | ||||||
|   uInt k;		/* bits in bit buffer */ |   uInt k;               /* bits in bit buffer */ | ||||||
|   Byte *p;		/* input data pointer */ |   Bytef *p;             /* input data pointer */ | ||||||
|   uInt n;		/* bytes available there */ |   uInt n;               /* bytes available there */ | ||||||
|   Byte *q;		/* output window write pointer */ |   Bytef *q;             /* output window write pointer */ | ||||||
|   uInt m;		/* bytes to end of window or read pointer */ |   uInt m;               /* bytes to end of window or read pointer */ | ||||||
|  |  | ||||||
|   /* copy input/output information to locals (UPDATE macro restores) */ |   /* copy input/output information to locals (UPDATE macro restores) */ | ||||||
|   LOAD |   LOAD | ||||||
| @@ -111,59 +135,77 @@ int r; | |||||||
|       s->last = t & 1; |       s->last = t & 1; | ||||||
|       switch (t >> 1) |       switch (t >> 1) | ||||||
|       { |       { | ||||||
|         case 0:				/* stored */ |         case 0:                         /* stored */ | ||||||
| 	  DUMPBITS(3) |           Trace((stderr, "inflate:     stored block%s\n", | ||||||
| 	  t = k & 7;			/* go to byte boundary */ |                  s->last ? " (last)" : "")); | ||||||
| 	  DUMPBITS(t) |           DUMPBITS(3) | ||||||
| 	  s->mode = LENS;		/* get length of stored block */ |           t = k & 7;                    /* go to byte boundary */ | ||||||
| 	  break; |           DUMPBITS(t) | ||||||
| 	case 1:				/* fixed */ |           s->mode = LENS;               /* get length of stored block */ | ||||||
| 	  { |           break; | ||||||
| 	    uInt bl, bd; |         case 1:                         /* fixed */ | ||||||
| 	    inflate_huft *tl, *td; |           Trace((stderr, "inflate:     fixed codes block%s\n", | ||||||
|  |                  s->last ? " (last)" : "")); | ||||||
|  |           { | ||||||
|  |             uInt bl, bd; | ||||||
|  |             inflate_huft *tl, *td; | ||||||
|  |  | ||||||
| 	    inflate_trees_fixed(&bl, &bd, &tl, &td); |             inflate_trees_fixed(&bl, &bd, &tl, &td); | ||||||
| 	    s->sub.codes = inflate_codes_new(bl, bd, tl, td, z); |             s->sub.decode.codes = inflate_codes_new(bl, bd, tl, td, z); | ||||||
| 	    if (s->sub.codes == Z_NULL) |             if (s->sub.decode.codes == Z_NULL) | ||||||
| 	    { |             { | ||||||
| 	      r = Z_MEM_ERROR; |               r = Z_MEM_ERROR; | ||||||
| 	      LEAVE |               LEAVE | ||||||
| 	    } |             } | ||||||
| 	  } |             s->sub.decode.tl = Z_NULL;  /* don't try to free these */ | ||||||
| 	  DUMPBITS(3) |             s->sub.decode.td = Z_NULL; | ||||||
| 	  s->mode = CODES; |           } | ||||||
| 	  break; |           DUMPBITS(3) | ||||||
| 	case 2:				/* dynamic */ |           s->mode = CODES; | ||||||
| 	  DUMPBITS(3) |           break; | ||||||
| 	  s->mode = TABLE; |         case 2:                         /* dynamic */ | ||||||
| 	  break; |           Trace((stderr, "inflate:     dynamic codes block%s\n", | ||||||
| 	case 3:				/* illegal */ |                  s->last ? " (last)" : "")); | ||||||
| 	  DUMPBITS(3) |           DUMPBITS(3) | ||||||
| 	  s->mode = INF_ERROR; |           s->mode = TABLE; | ||||||
| 	  z->msg = "invalid block type"; |           break; | ||||||
| 	  r = Z_DATA_ERROR; |         case 3:                         /* illegal */ | ||||||
| 	  LEAVE |           DUMPBITS(3) | ||||||
|  |           s->mode = BAD; | ||||||
|  |           z->msg = "invalid block type"; | ||||||
|  |           r = Z_DATA_ERROR; | ||||||
|  |           LEAVE | ||||||
|       } |       } | ||||||
|       break; |       break; | ||||||
|     case LENS: |     case LENS: | ||||||
|       NEEDBITS(32) |       NEEDBITS(32) | ||||||
|       if ((~b) >> 16 != (b & 0xffff)) |       if (((~b) >> 16) != (b & 0xffff)) | ||||||
|       { |       { | ||||||
|         s->mode = INF_ERROR; |         s->mode = BAD; | ||||||
| 	z->msg = "invalid stored block lengths"; |         z->msg = "invalid stored block lengths"; | ||||||
| 	r = Z_DATA_ERROR; |         r = Z_DATA_ERROR; | ||||||
| 	LEAVE |         LEAVE | ||||||
|       } |       } | ||||||
|       k = 0;				/* dump bits */ |  | ||||||
|       s->sub.left = (uInt)b & 0xffff; |       s->sub.left = (uInt)b & 0xffff; | ||||||
|  |       b = k = 0;                      /* dump bits */ | ||||||
|  |       Tracev((stderr, "inflate:       stored length %u\n", s->sub.left)); | ||||||
|       s->mode = s->sub.left ? STORED : TYPE; |       s->mode = s->sub.left ? STORED : TYPE; | ||||||
|       break; |       break; | ||||||
|     case STORED: |     case STORED: | ||||||
|       do { |       if (n == 0) | ||||||
|         NEEDBYTE |         LEAVE | ||||||
| 	NEEDOUT |       NEEDOUT | ||||||
| 	OUTBYTE(NEXTBYTE) |       t = s->sub.left; | ||||||
|       } while (--s->sub.left); |       if (t > n) t = n; | ||||||
|  |       if (t > m) t = m; | ||||||
|  |       zmemcpy(q, p, t); | ||||||
|  |       p += t;  n -= t; | ||||||
|  |       q += t;  m -= t; | ||||||
|  |       if ((s->sub.left -= t) != 0) | ||||||
|  |         break; | ||||||
|  |       Tracev((stderr, "inflate:       stored end, %lu total out\n", | ||||||
|  |               z->total_out + (q >= s->read ? q - s->read : | ||||||
|  |               (s->end - s->read) + (q - s->window)))); | ||||||
|       s->mode = s->last ? DRY : TYPE; |       s->mode = s->last ? DRY : TYPE; | ||||||
|       break; |       break; | ||||||
|     case TABLE: |     case TABLE: | ||||||
| @@ -172,134 +214,144 @@ int r; | |||||||
| #ifndef PKZIP_BUG_WORKAROUND | #ifndef PKZIP_BUG_WORKAROUND | ||||||
|       if ((t & 0x1f) > 29 || ((t >> 5) & 0x1f) > 29) |       if ((t & 0x1f) > 29 || ((t >> 5) & 0x1f) > 29) | ||||||
|       { |       { | ||||||
|         s->mode = INF_ERROR; |         s->mode = BAD; | ||||||
|         z->msg = "too many length or distance symbols"; |         z->msg = "too many length or distance symbols"; | ||||||
| 	r = Z_DATA_ERROR; |         r = Z_DATA_ERROR; | ||||||
| 	LEAVE |         LEAVE | ||||||
|       } |       } | ||||||
| #endif | #endif | ||||||
|       t = 258 + (t & 0x1f) + ((t >> 5) & 0x1f); |       t = 258 + (t & 0x1f) + ((t >> 5) & 0x1f); | ||||||
|       if (t < 19) |       if (t < 19) | ||||||
|         t = 19; |         t = 19; | ||||||
|       if ((s->sub.trees.blens = (uInt*)ZALLOC(z, t, sizeof(uInt))) == Z_NULL) |       if ((s->sub.trees.blens = (uIntf*)ZALLOC(z, t, sizeof(uInt))) == Z_NULL) | ||||||
|       { |       { | ||||||
|         r = Z_MEM_ERROR; |         r = Z_MEM_ERROR; | ||||||
| 	LEAVE |         LEAVE | ||||||
|       } |       } | ||||||
|       DUMPBITS(14) |       DUMPBITS(14) | ||||||
|       s->sub.trees.index = 0; |       s->sub.trees.index = 0; | ||||||
|  |       Tracev((stderr, "inflate:       table sizes ok\n")); | ||||||
|       s->mode = BTREE; |       s->mode = BTREE; | ||||||
|     case BTREE: |     case BTREE: | ||||||
|       while (s->sub.trees.index < 4 + (s->sub.trees.table >> 10)) |       while (s->sub.trees.index < 4 + (s->sub.trees.table >> 10)) | ||||||
|       { |       { | ||||||
|         NEEDBITS(3) |         NEEDBITS(3) | ||||||
| 	s->sub.trees.blens[border[s->sub.trees.index++]] = (uInt)b & 7; |         s->sub.trees.blens[border[s->sub.trees.index++]] = (uInt)b & 7; | ||||||
| 	DUMPBITS(3) |         DUMPBITS(3) | ||||||
|       } |       } | ||||||
|       while (s->sub.trees.index < 19) |       while (s->sub.trees.index < 19) | ||||||
|         s->sub.trees.blens[border[s->sub.trees.index++]] = 0; |         s->sub.trees.blens[border[s->sub.trees.index++]] = 0; | ||||||
|       s->sub.trees.bb = 7; |       s->sub.trees.bb = 7; | ||||||
|       t = inflate_trees_bits(s->sub.trees.blens, &s->sub.trees.bb, |       t = inflate_trees_bits(s->sub.trees.blens, &s->sub.trees.bb, | ||||||
| 			     &s->sub.trees.tb, z); |                              &s->sub.trees.tb, z); | ||||||
|       if (t != Z_OK) |       if (t != Z_OK) | ||||||
|       { |       { | ||||||
|         r = t; |         r = t; | ||||||
| 	if (r == Z_DATA_ERROR) |         if (r == Z_DATA_ERROR) | ||||||
| 	  s->mode = INF_ERROR; |           s->mode = BAD; | ||||||
| 	LEAVE |         LEAVE | ||||||
|       } |       } | ||||||
|       s->sub.trees.index = 0; |       s->sub.trees.index = 0; | ||||||
|  |       Tracev((stderr, "inflate:       bits tree ok\n")); | ||||||
|       s->mode = DTREE; |       s->mode = DTREE; | ||||||
|     case DTREE: |     case DTREE: | ||||||
|       while (t = s->sub.trees.table, |       while (t = s->sub.trees.table, | ||||||
|       	     s->sub.trees.index < 258 + (t & 0x1f) + ((t >> 5) & 0x1f)) |              s->sub.trees.index < 258 + (t & 0x1f) + ((t >> 5) & 0x1f)) | ||||||
|       { |       { | ||||||
|         inflate_huft *h; |         inflate_huft *h; | ||||||
| 	uInt i, j, c; |         uInt i, j, c; | ||||||
|  |  | ||||||
|         t = s->sub.trees.bb; |         t = s->sub.trees.bb; | ||||||
|         NEEDBITS(t) |         NEEDBITS(t) | ||||||
| 	h = s->sub.trees.tb + ((uInt)b & inflate_mask[t]); |         h = s->sub.trees.tb + ((uInt)b & inflate_mask[t]); | ||||||
| 	t = h->word.what.Bits; |         t = h->word.what.Bits; | ||||||
| 	c = h->more.Base; |         c = h->more.Base; | ||||||
| 	if (c < 16) |         if (c < 16) | ||||||
| 	{ |         { | ||||||
| 	  DUMPBITS(t) |           DUMPBITS(t) | ||||||
| 	  s->sub.trees.blens[s->sub.trees.index++] = c; |           s->sub.trees.blens[s->sub.trees.index++] = c; | ||||||
| 	} |         } | ||||||
| 	else /* c == 16..18 */ |         else /* c == 16..18 */ | ||||||
| 	{ |         { | ||||||
| 	  i = c == 18 ? 7 : c - 14; |           i = c == 18 ? 7 : c - 14; | ||||||
| 	  j = c == 18 ? 11 : 3; |           j = c == 18 ? 11 : 3; | ||||||
| 	  NEEDBITS(t + i) |           NEEDBITS(t + i) | ||||||
| 	  DUMPBITS(t) |           DUMPBITS(t) | ||||||
| 	  j += (uInt)b & inflate_mask[i]; |           j += (uInt)b & inflate_mask[i]; | ||||||
| 	  DUMPBITS(i) |           DUMPBITS(i) | ||||||
| 	  i = s->sub.trees.index; |           i = s->sub.trees.index; | ||||||
| 	  t = s->sub.trees.table; |           t = s->sub.trees.table; | ||||||
| 	  if (i + j > 258 + (t & 0x1f) + ((t >> 5) & 0x1f) || |           if (i + j > 258 + (t & 0x1f) + ((t >> 5) & 0x1f) || | ||||||
| 	      (c == 16 && i < 1)) |               (c == 16 && i < 1)) | ||||||
| 	  { |           { | ||||||
| 	    s->mode = INF_ERROR; |             s->mode = BAD; | ||||||
| 	    z->msg = "invalid bit length repeat"; |             z->msg = "invalid bit length repeat"; | ||||||
| 	    r = Z_DATA_ERROR; |             r = Z_DATA_ERROR; | ||||||
| 	    LEAVE |             LEAVE | ||||||
| 	  } |           } | ||||||
| 	  c = c == 16 ? s->sub.trees.blens[i - 1] : 0; |           c = c == 16 ? s->sub.trees.blens[i - 1] : 0; | ||||||
| 	  do { |           do { | ||||||
| 	    s->sub.trees.blens[i++] = c; |             s->sub.trees.blens[i++] = c; | ||||||
| 	  } while (--j); |           } while (--j); | ||||||
| 	  s->sub.trees.index = i; |           s->sub.trees.index = i; | ||||||
| 	} |         } | ||||||
|       } |       } | ||||||
|       inflate_trees_free(s->sub.trees.tb, z); |       inflate_trees_free(s->sub.trees.tb, z); | ||||||
|       s->sub.trees.tb = Z_NULL; |       s->sub.trees.tb = Z_NULL; | ||||||
|       { |       { | ||||||
| 	uInt bl, bd; |         uInt bl, bd; | ||||||
| 	inflate_huft *tl, *td; |         inflate_huft *tl, *td; | ||||||
| 	struct inflate_codes_state *c; |         inflate_codes_statef *c; | ||||||
|  |  | ||||||
| 	bl = 9; |         bl = 9;         /* must be <= 9 for lookahead assumptions */ | ||||||
| 	bd = 6; |         bd = 6;         /* must be <= 9 for lookahead assumptions */ | ||||||
| 	t = s->sub.trees.table; |         t = s->sub.trees.table; | ||||||
| 	t = inflate_trees_dynamic(257 + (t & 0x1f), 1 + ((t >> 5) & 0x1f), |         t = inflate_trees_dynamic(257 + (t & 0x1f), 1 + ((t >> 5) & 0x1f), | ||||||
| 				  s->sub.trees.blens, &bl, &bd, &tl, &td, z); |                                   s->sub.trees.blens, &bl, &bd, &tl, &td, z); | ||||||
| 	if (t != Z_OK) |         if (t != Z_OK) | ||||||
| 	{ |         { | ||||||
| 	  if (t == (uInt)Z_DATA_ERROR) |           if (t == (uInt)Z_DATA_ERROR) | ||||||
| 	    s->mode = INF_ERROR; |             s->mode = BAD; | ||||||
| 	  r = t; |           r = t; | ||||||
| 	  LEAVE |           LEAVE | ||||||
| 	} |         } | ||||||
| 	if ((c = inflate_codes_new(bl, bd, tl, td, z)) == Z_NULL) |         Tracev((stderr, "inflate:       trees ok\n")); | ||||||
| 	{ |         if ((c = inflate_codes_new(bl, bd, tl, td, z)) == Z_NULL) | ||||||
| 	  inflate_trees_free(td, z); |         { | ||||||
| 	  inflate_trees_free(tl, z); |           inflate_trees_free(td, z); | ||||||
| 	  r = Z_MEM_ERROR; |           inflate_trees_free(tl, z); | ||||||
| 	  LEAVE |           r = Z_MEM_ERROR; | ||||||
| 	} |           LEAVE | ||||||
| 	ZFREE(z, s->sub.trees.blens); |         } | ||||||
| 	s->sub.codes = c; |         ZFREE(z, s->sub.trees.blens); | ||||||
|  |         s->sub.decode.codes = c; | ||||||
|  |         s->sub.decode.tl = tl; | ||||||
|  |         s->sub.decode.td = td; | ||||||
|       } |       } | ||||||
|       s->mode = CODES; |       s->mode = CODES; | ||||||
|     case CODES: |     case CODES: | ||||||
|       UPDATE |       UPDATE | ||||||
|       if ((r = inflate_codes(s, z, r)) != Z_STREAM_END) |       if ((r = inflate_codes(s, z, r)) != Z_STREAM_END) | ||||||
| 	return inflate_flush(s, z, r); |         return inflate_flush(s, z, r); | ||||||
|       r = Z_OK; |       r = Z_OK; | ||||||
|       inflate_codes_free(s->sub.codes, z); |       inflate_codes_free(s->sub.decode.codes, z); | ||||||
|  |       inflate_trees_free(s->sub.decode.td, z); | ||||||
|  |       inflate_trees_free(s->sub.decode.tl, z); | ||||||
|       LOAD |       LOAD | ||||||
|  |       Tracev((stderr, "inflate:       codes end, %lu total out\n", | ||||||
|  |               z->total_out + (q >= s->read ? q - s->read : | ||||||
|  |               (s->end - s->read) + (q - s->window)))); | ||||||
|       if (!s->last) |       if (!s->last) | ||||||
|       { |       { | ||||||
|         s->mode = TYPE; |         s->mode = TYPE; | ||||||
|       break; |         break; | ||||||
|       } |       } | ||||||
|       if (k > 7)              /* return unused byte, if any */ |       if (k > 7)              /* return unused byte, if any */ | ||||||
|       { |       { | ||||||
|         Assert(k < 16, "inflate_codes grabbed too many bytes") |         Assert(k < 16, "inflate_codes grabbed too many bytes") | ||||||
|         k -= 8; |         k -= 8; | ||||||
|       n++; |         n++; | ||||||
|       p--;                    /* can always return one */ |         p--;                    /* can always return one */ | ||||||
|       } |       } | ||||||
|       s->mode = DRY; |       s->mode = DRY; | ||||||
|     case DRY: |     case DRY: | ||||||
| @@ -310,7 +362,7 @@ int r; | |||||||
|     case DONE: |     case DONE: | ||||||
|       r = Z_STREAM_END; |       r = Z_STREAM_END; | ||||||
|       LEAVE |       LEAVE | ||||||
|     case INF_ERROR: |     case BAD: | ||||||
|       r = Z_DATA_ERROR; |       r = Z_DATA_ERROR; | ||||||
|       LEAVE |       LEAVE | ||||||
|     default: |     default: | ||||||
| @@ -321,17 +373,13 @@ int r; | |||||||
|  |  | ||||||
|  |  | ||||||
| int inflate_blocks_free(s, z, c) | int inflate_blocks_free(s, z, c) | ||||||
| struct inflate_blocks_state *s; | inflate_blocks_statef *s; | ||||||
| z_stream *z; | z_stream *z; | ||||||
| uLong *c; | uLongf *c; | ||||||
| { | { | ||||||
|   if (s->checkfn != Z_NULL) |   inflate_blocks_reset(s, z, c); | ||||||
|     *c = s->check; |  | ||||||
|   if (s->mode == BTREE || s->mode == DTREE) |  | ||||||
|     ZFREE(z, s->sub.trees.blens); |  | ||||||
|   if (s->mode == CODES) |  | ||||||
|     inflate_codes_free(s->sub.codes, z); |  | ||||||
|   ZFREE(z, s->window); |   ZFREE(z, s->window); | ||||||
|   ZFREE(z, s); |   ZFREE(z, s); | ||||||
|  |   Trace((stderr, "inflate:   blocks freed\n")); | ||||||
|   return Z_OK; |   return Z_OK; | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										20
									
								
								infblock.h
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								infblock.h
									
									
									
									
									
								
							| @@ -9,18 +9,24 @@ | |||||||
|  */ |  */ | ||||||
|  |  | ||||||
| struct inflate_blocks_state; | struct inflate_blocks_state; | ||||||
|  | typedef struct inflate_blocks_state FAR inflate_blocks_statef; | ||||||
|  |  | ||||||
| extern struct inflate_blocks_state * inflate_blocks_new __P(( | extern inflate_blocks_statef * inflate_blocks_new OF(( | ||||||
|     z_stream *z, |     z_stream *z, | ||||||
|     check_func c,               /* check function */ |     check_func c,               /* check function */ | ||||||
|     uInt w));                   /* window size */ |     uInt w));                   /* window size */ | ||||||
|  |  | ||||||
| extern int inflate_blocks __P(( | extern int inflate_blocks OF(( | ||||||
|     struct inflate_blocks_state *, |     inflate_blocks_statef *, | ||||||
|     z_stream *, |     z_stream *, | ||||||
|     int));			/* initial return code */ |     int));                      /* initial return code */ | ||||||
|  |  | ||||||
| extern int inflate_blocks_free __P(( | extern void inflate_blocks_reset OF(( | ||||||
|     struct inflate_blocks_state *, |     inflate_blocks_statef *, | ||||||
|     z_stream *, |     z_stream *, | ||||||
|     uLong *));                        /* check value on output */ |     uLongf *));                  /* check value on output */ | ||||||
|  |  | ||||||
|  | extern int inflate_blocks_free OF(( | ||||||
|  |     inflate_blocks_statef *, | ||||||
|  |     z_stream *, | ||||||
|  |     uLongf *));                  /* check value on output */ | ||||||
|   | |||||||
							
								
								
									
										226
									
								
								infcodes.c
									
									
									
									
									
								
							
							
						
						
									
										226
									
								
								infcodes.c
									
									
									
									
									
								
							| @@ -5,9 +5,10 @@ | |||||||
|  |  | ||||||
| #include "zutil.h" | #include "zutil.h" | ||||||
| #include "inftrees.h" | #include "inftrees.h" | ||||||
|  | #include "infblock.h" | ||||||
|  | #include "infcodes.h" | ||||||
| #include "infutil.h" | #include "infutil.h" | ||||||
| #include "inffast.h" | #include "inffast.h" | ||||||
| #include "infcodes.h" |  | ||||||
|  |  | ||||||
| /* simplify the use of the inflate_huft type with some defines */ | /* simplify the use of the inflate_huft type with some defines */ | ||||||
| #define base more.Base | #define base more.Base | ||||||
| @@ -19,50 +20,50 @@ | |||||||
| struct inflate_codes_state { | struct inflate_codes_state { | ||||||
|  |  | ||||||
|   /* mode */ |   /* mode */ | ||||||
|   enum {	/* waiting for "i:"=input, "o:"=output, "x:"=nothing */ |   enum {        /* waiting for "i:"=input, "o:"=output, "x:"=nothing */ | ||||||
|       START,	/* x: set up for LEN */ |       START,    /* x: set up for LEN */ | ||||||
|       LEN,	/* i: get length/literal/eob next */ |       LEN,      /* i: get length/literal/eob next */ | ||||||
|       LENEXT,	/* i: getting length extra (have base) */ |       LENEXT,   /* i: getting length extra (have base) */ | ||||||
|       DIST,	/* i: get distance next */ |       DIST,     /* i: get distance next */ | ||||||
|       DISTEXT,	/* i: getting distance extra */ |       DISTEXT,  /* i: getting distance extra */ | ||||||
|       COPY,	/* o: copying bytes in window, waiting for space */ |       COPY,     /* o: copying bytes in window, waiting for space */ | ||||||
|       LIT,	/* o: got literal, waiting for output space */ |       LIT,      /* o: got literal, waiting for output space */ | ||||||
|       WASH,	/* o: got eob, possibly still output waiting */ |       WASH,     /* o: got eob, possibly still output waiting */ | ||||||
|       END,	/* x: got eob and all data flushed */ |       END,      /* x: got eob and all data flushed */ | ||||||
|       BAD}	/* x: got error */ |       BADCODE}  /* x: got error */ | ||||||
|     mode;		/* current inflate_codes mode */ |     mode;               /* current inflate_codes mode */ | ||||||
|  |  | ||||||
|   /* mode dependent information */ |   /* mode dependent information */ | ||||||
|   uInt len; |   uInt len; | ||||||
|   union { |   union { | ||||||
|     struct { |     struct { | ||||||
|       inflate_huft *tree;	/* pointer into tree */ |       inflate_huft *tree;       /* pointer into tree */ | ||||||
|       uInt need;		/* bits needed */ |       uInt need;                /* bits needed */ | ||||||
|     } code;		/* if LEN or DIST, where in tree */ |     } code;             /* if LEN or DIST, where in tree */ | ||||||
|     uInt lit;		/* if LIT, literal */ |     uInt lit;           /* if LIT, literal */ | ||||||
|     struct { |     struct { | ||||||
|       uInt get;			/* bits to get for extra */ |       uInt get;                 /* bits to get for extra */ | ||||||
|       uInt dist;		/* distance back to copy from */ |       uInt dist;                /* distance back to copy from */ | ||||||
|     } copy;		/* if EXT or COPY, where and how much */ |     } copy;             /* if EXT or COPY, where and how much */ | ||||||
|   } sub;		/* submode */ |   } sub;                /* submode */ | ||||||
|  |  | ||||||
|   /* mode independent information */ |   /* mode independent information */ | ||||||
|   Byte lbits;		/* ltree bits decoded per branch */ |   Byte lbits;           /* ltree bits decoded per branch */ | ||||||
|   Byte dbits;		/* dtree bits decoder per branch */ |   Byte dbits;           /* dtree bits decoder per branch */ | ||||||
|   inflate_huft *ltree;		/* literal/length/eob tree */ |   inflate_huft *ltree;          /* literal/length/eob tree */ | ||||||
|   inflate_huft *dtree;		/* distance tree */ |   inflate_huft *dtree;          /* distance tree */ | ||||||
|  |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| struct inflate_codes_state *inflate_codes_new(bl, bd, tl, td, z) | inflate_codes_statef *inflate_codes_new(bl, bd, tl, td, z) | ||||||
| uInt bl, bd; | uInt bl, bd; | ||||||
| inflate_huft *tl, *td; | inflate_huft *tl, *td; | ||||||
| z_stream *z; | z_stream *z; | ||||||
| { | { | ||||||
|   struct inflate_codes_state *c; |   inflate_codes_statef *c; | ||||||
|  |  | ||||||
|   if ((c = (struct inflate_codes_state *) |   if ((c = (inflate_codes_statef *) | ||||||
|        ZALLOC(z,1,sizeof(struct inflate_codes_state))) != Z_NULL) |        ZALLOC(z,1,sizeof(struct inflate_codes_state))) != Z_NULL) | ||||||
|   { |   { | ||||||
|     c->mode = START; |     c->mode = START; | ||||||
| @@ -70,139 +71,155 @@ z_stream *z; | |||||||
|     c->dbits = (Byte)bd; |     c->dbits = (Byte)bd; | ||||||
|     c->ltree = tl; |     c->ltree = tl; | ||||||
|     c->dtree = td; |     c->dtree = td; | ||||||
|  |     Tracev((stderr, "inflate:       codes new\n")); | ||||||
|   } |   } | ||||||
|   return c; |   return c; | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| int inflate_codes(s, z, r) | int inflate_codes(s, z, r) | ||||||
| struct inflate_blocks_state *s; | inflate_blocks_statef *s; | ||||||
| z_stream *z; | z_stream *z; | ||||||
| int r; | int r; | ||||||
| { | { | ||||||
|   uInt j;		/* temporary storage */ |   uInt j;               /* temporary storage */ | ||||||
|   inflate_huft *t;	/* temporary pointer */ |   inflate_huft *t;      /* temporary pointer */ | ||||||
|   int e;		/* extra bits or operation */ |   uInt e;               /* extra bits or operation */ | ||||||
|   uLong b;		/* bit buffer */ |   uLong b;              /* bit buffer */ | ||||||
|   uInt k;		/* bits in bit buffer */ |   uInt k;               /* bits in bit buffer */ | ||||||
|   Byte *p;		/* input data pointer */ |   Bytef *p;             /* input data pointer */ | ||||||
|   uInt n;		/* bytes available there */ |   uInt n;               /* bytes available there */ | ||||||
|   Byte *q;		/* output window write pointer */ |   Bytef *q;             /* output window write pointer */ | ||||||
|   uInt m;		/* bytes to end of window or read pointer */ |   uInt m;               /* bytes to end of window or read pointer */ | ||||||
|   Byte *f;		/* pointer to copy strings from */ |   Bytef *f;             /* pointer to copy strings from */ | ||||||
|   struct inflate_codes_state *c = s->sub.codes;	/* codes state */ |   inflate_codes_statef *c = s->sub.decode.codes;  /* codes state */ | ||||||
|  |  | ||||||
|   /* copy input/output information to locals (UPDATE macro restores) */ |   /* copy input/output information to locals (UPDATE macro restores) */ | ||||||
|   LOAD |   LOAD | ||||||
|  |  | ||||||
|   /* process input and output based on current state */ |   /* process input and output based on current state */ | ||||||
|   while (1) switch (c->mode) |   while (1) switch (c->mode) | ||||||
|   {		/* waiting for "i:"=input, "o:"=output, "x:"=nothing */ |   {             /* waiting for "i:"=input, "o:"=output, "x:"=nothing */ | ||||||
|     case START:		/* x: set up for LEN */ |     case START:         /* x: set up for LEN */ | ||||||
| #ifndef SLOW | #ifndef SLOW | ||||||
|       if (m >= 258 && n >= 10) |       if (m >= 258 && n >= 10) | ||||||
|       { |       { | ||||||
|         UPDATE |         UPDATE | ||||||
| 	r = inflate_fast(c->lbits, c->dbits, c->ltree, c->dtree, s, z); |         r = inflate_fast(c->lbits, c->dbits, c->ltree, c->dtree, s, z); | ||||||
| 	LOAD |         LOAD | ||||||
| 	if (r != Z_OK) |         if (r != Z_OK) | ||||||
| 	{ |         { | ||||||
| 	  c->mode = r == Z_STREAM_END ? WASH : BAD; |           c->mode = r == Z_STREAM_END ? WASH : BADCODE; | ||||||
| 	  break; |           break; | ||||||
| 	} |         } | ||||||
|       } |       } | ||||||
| #endif /* !SLOW */ | #endif /* !SLOW */ | ||||||
|       c->sub.code.need = c->lbits; |       c->sub.code.need = c->lbits; | ||||||
|       c->sub.code.tree = c->ltree; |       c->sub.code.tree = c->ltree; | ||||||
|       c->mode = LEN; |       c->mode = LEN; | ||||||
|     case LEN:		/* i: get length/literal/eob next */ |     case LEN:           /* i: get length/literal/eob next */ | ||||||
|       j = c->sub.code.need; |       j = c->sub.code.need; | ||||||
|       NEEDBITS(j) |       NEEDBITS(j) | ||||||
|       t = c->sub.code.tree + ((uInt)b & inflate_mask[j]); |       t = c->sub.code.tree + ((uInt)b & inflate_mask[j]); | ||||||
|       DUMPBITS(t->bits) |       DUMPBITS(t->bits) | ||||||
|       if ((e = (int)(t->exop)) < 0) |       e = (uInt)(t->exop); | ||||||
|  |       if (e == 0)               /* literal */ | ||||||
|       { |       { | ||||||
|         if (e == -128)		/* invalid code */ |         c->sub.lit = t->base; | ||||||
| 	{ |         Tracevv((stderr, t->base >= 0x20 && t->base < 0x7f ? | ||||||
| 	  c->mode = BAD; |                  "inflate:         literal '%c'\n" : | ||||||
| 	  z->msg = "invalid literal/length code"; |                  "inflate:         literal 0x%02x\n", t->base)); | ||||||
| 	  r = Z_DATA_ERROR; |         c->mode = LIT; | ||||||
| 	  LEAVE |         break; | ||||||
| 	} |  | ||||||
| 	e = -e; |  | ||||||
| 	if (e & 64)		/* end of block */ |  | ||||||
| 	{ |  | ||||||
| 	  c->mode = WASH; |  | ||||||
| 	  break; |  | ||||||
| 	} |  | ||||||
| 	c->sub.code.need = e; |  | ||||||
| 	c->sub.code.tree = t->next; |  | ||||||
| 	break; |  | ||||||
|       } |       } | ||||||
|       if (e & 16)		/* literal */ |       if (e & 16)               /* length */ | ||||||
|       { |       { | ||||||
| 	c->sub.lit = t->base; |         c->sub.copy.get = e & 15; | ||||||
| 	c->mode = LIT; |         c->len = t->base; | ||||||
| 	break; |         c->mode = LENEXT; | ||||||
|  |         break; | ||||||
|       } |       } | ||||||
|       c->sub.copy.get = e; |       if ((e & 64) == 0)        /* next table */ | ||||||
|       c->len = t->base; |       { | ||||||
|       c->mode = LENEXT; |         c->sub.code.need = e; | ||||||
|     case LENEXT:	/* i: getting length extra (have base) */ |         c->sub.code.tree = t->next; | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |       if (e & 32)               /* end of block */ | ||||||
|  |       { | ||||||
|  |         Tracevv((stderr, "inflate:         end of block\n")); | ||||||
|  |         c->mode = WASH; | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |       c->mode = BADCODE;        /* invalid code */ | ||||||
|  |       z->msg = "invalid literal/length code"; | ||||||
|  |       r = Z_DATA_ERROR; | ||||||
|  |       LEAVE | ||||||
|  |     case LENEXT:        /* i: getting length extra (have base) */ | ||||||
|       j = c->sub.copy.get; |       j = c->sub.copy.get; | ||||||
|       NEEDBITS(j) |       NEEDBITS(j) | ||||||
|       c->len += (uInt)b & inflate_mask[j]; |       c->len += (uInt)b & inflate_mask[j]; | ||||||
|       DUMPBITS(j) |       DUMPBITS(j) | ||||||
|       c->sub.code.need = c->dbits; |       c->sub.code.need = c->dbits; | ||||||
|       c->sub.code.tree = c->dtree; |       c->sub.code.tree = c->dtree; | ||||||
|  |       Tracevv((stderr, "inflate:         length %u\n", c->len)); | ||||||
|       c->mode = DIST; |       c->mode = DIST; | ||||||
|     case DIST:		/* i: get distance next */ |     case DIST:          /* i: get distance next */ | ||||||
|       j = c->sub.code.need; |       j = c->sub.code.need; | ||||||
|       NEEDBITS(j) |       NEEDBITS(j) | ||||||
|       t = c->sub.code.tree + ((uInt)b & inflate_mask[j]); |       t = c->sub.code.tree + ((uInt)b & inflate_mask[j]); | ||||||
|       DUMPBITS(t->bits) |       DUMPBITS(t->bits) | ||||||
|       if ((e = (int)(t->exop)) < 0) |       e = (uInt)(t->exop); | ||||||
|  |       if (e & 16)               /* distance */ | ||||||
|       { |       { | ||||||
|         if (e == -128) |         c->sub.copy.get = e & 15; | ||||||
| 	{ |         c->sub.copy.dist = t->base; | ||||||
| 	  c->mode = BAD; |         c->mode = DISTEXT; | ||||||
| 	  z->msg = "invalid distance code"; |         break; | ||||||
| 	  r = Z_DATA_ERROR; |  | ||||||
| 	  LEAVE |  | ||||||
| 	} |  | ||||||
| 	c->sub.code.need = -e; |  | ||||||
| 	c->sub.code.tree = t->next; |  | ||||||
| 	break; |  | ||||||
|       } |       } | ||||||
|       c->sub.copy.dist = t->base; |       if ((e & 64) == 0)        /* next table */ | ||||||
|       c->sub.copy.get = e; |       { | ||||||
|       c->mode = DISTEXT; |         c->sub.code.need = e; | ||||||
|     case DISTEXT:	/* i: getting distance extra */ |         c->sub.code.tree = t->next; | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |       c->mode = BADCODE;        /* invalid code */ | ||||||
|  |       z->msg = "invalid distance code"; | ||||||
|  |       r = Z_DATA_ERROR; | ||||||
|  |       LEAVE | ||||||
|  |     case DISTEXT:       /* i: getting distance extra */ | ||||||
|       j = c->sub.copy.get; |       j = c->sub.copy.get; | ||||||
|       NEEDBITS(j) |       NEEDBITS(j) | ||||||
|       c->sub.copy.dist += (uInt)b & inflate_mask[j]; |       c->sub.copy.dist += (uInt)b & inflate_mask[j]; | ||||||
|       DUMPBITS(j) |       DUMPBITS(j) | ||||||
|  |       Tracevv((stderr, "inflate:         distance %u\n", c->sub.copy.dist)); | ||||||
|       c->mode = COPY; |       c->mode = COPY; | ||||||
|     case COPY:		/* o: copying bytes in window, waiting for space */ |     case COPY:          /* o: copying bytes in window, waiting for space */ | ||||||
|  | #ifndef __TURBOC__ /* Turbo C bug for following expression */ | ||||||
|       f = (uInt)(q - s->window) < c->sub.copy.dist ? |       f = (uInt)(q - s->window) < c->sub.copy.dist ? | ||||||
| 	  s->end - (c->sub.copy.dist - (q - s->window)) : |           s->end - (c->sub.copy.dist - (q - s->window)) : | ||||||
| 	  q - c->sub.copy.dist; |           q - c->sub.copy.dist; | ||||||
|  | #else | ||||||
|  |       f = q - c->sub.copy.dist; | ||||||
|  |       if ((uInt)(q - s->window) < c->sub.copy.dist) | ||||||
|  |         f = s->end - (c->sub.copy.dist - (q - s->window)); | ||||||
|  | #endif | ||||||
|       while (c->len) |       while (c->len) | ||||||
|       { |       { | ||||||
| 	NEEDOUT |         NEEDOUT | ||||||
| 	OUTBYTE(*f++) |         OUTBYTE(*f++) | ||||||
| 	if (f == s->end) |         if (f == s->end) | ||||||
| 	  f = s->window; |           f = s->window; | ||||||
| 	c->len--; |         c->len--; | ||||||
|       } |       } | ||||||
|       c->mode = START; |       c->mode = START; | ||||||
|       break; |       break; | ||||||
|     case LIT:		/* o: got literal, waiting for output space */ |     case LIT:           /* o: got literal, waiting for output space */ | ||||||
|       NEEDOUT |       NEEDOUT | ||||||
|       OUTBYTE(c->sub.lit) |       OUTBYTE(c->sub.lit) | ||||||
|       c->mode = START; |       c->mode = START; | ||||||
|       break; |       break; | ||||||
|     case WASH:		/* o: got eob, possibly more output */ |     case WASH:          /* o: got eob, possibly more output */ | ||||||
|       FLUSH |       FLUSH | ||||||
|       if (s->read != s->write) |       if (s->read != s->write) | ||||||
|         LEAVE |         LEAVE | ||||||
| @@ -210,7 +227,7 @@ int r; | |||||||
|     case END: |     case END: | ||||||
|       r = Z_STREAM_END; |       r = Z_STREAM_END; | ||||||
|       LEAVE |       LEAVE | ||||||
|     case BAD:		/* x: got error */ |     case BADCODE:       /* x: got error */ | ||||||
|       r = Z_DATA_ERROR; |       r = Z_DATA_ERROR; | ||||||
|       LEAVE |       LEAVE | ||||||
|     default: |     default: | ||||||
| @@ -221,10 +238,9 @@ int r; | |||||||
|  |  | ||||||
|  |  | ||||||
| void inflate_codes_free(c, z) | void inflate_codes_free(c, z) | ||||||
| struct inflate_codes_state *c; | inflate_codes_statef *c; | ||||||
| z_stream *z; | z_stream *z; | ||||||
| { | { | ||||||
|   inflate_trees_free(c->dtree, z); |  | ||||||
|   inflate_trees_free(c->ltree, z); |  | ||||||
|   ZFREE(z, c); |   ZFREE(z, c); | ||||||
|  |   Tracev((stderr, "inflate:       codes free\n")); | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										12
									
								
								infcodes.h
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								infcodes.h
									
									
									
									
									
								
							| @@ -9,17 +9,19 @@ | |||||||
|  */ |  */ | ||||||
|  |  | ||||||
| struct inflate_codes_state; | struct inflate_codes_state; | ||||||
|  | typedef struct inflate_codes_state FAR inflate_codes_statef; | ||||||
|  |  | ||||||
| extern struct inflate_codes_state *inflate_codes_new __P(( | extern inflate_codes_statef *inflate_codes_new OF(( | ||||||
|     uInt, uInt, |     uInt, uInt, | ||||||
|     inflate_huft *, inflate_huft *, |     inflate_huft *, inflate_huft *, | ||||||
|     z_stream *)); |     z_stream *)); | ||||||
|  |  | ||||||
| extern int inflate_codes __P(( | extern int inflate_codes OF(( | ||||||
|     struct inflate_blocks_state *, |     inflate_blocks_statef *, | ||||||
|     z_stream *, |     z_stream *, | ||||||
|     int)); |     int)); | ||||||
|  |  | ||||||
| extern void inflate_codes_free __P(( | extern void inflate_codes_free OF(( | ||||||
|     struct inflate_codes_state *, |     inflate_codes_statef *, | ||||||
|     z_stream *)); |     z_stream *)); | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										207
									
								
								inffast.c
									
									
									
									
									
								
							
							
						
						
									
										207
									
								
								inffast.c
									
									
									
									
									
								
							| @@ -5,6 +5,8 @@ | |||||||
|  |  | ||||||
| #include "zutil.h" | #include "zutil.h" | ||||||
| #include "inftrees.h" | #include "inftrees.h" | ||||||
|  | #include "infblock.h" | ||||||
|  | #include "infcodes.h" | ||||||
| #include "infutil.h" | #include "infutil.h" | ||||||
| #include "inffast.h" | #include "inffast.h" | ||||||
|  |  | ||||||
| @@ -17,10 +19,6 @@ struct inflate_codes_state {int dummy;}; /* for buggy compilers */ | |||||||
| #define bits word.what.Bits | #define bits word.what.Bits | ||||||
|  |  | ||||||
| /* macros for bit input with no checking and for returning unused bytes */ | /* macros for bit input with no checking and for returning unused bytes */ | ||||||
| #ifdef DEBUG |  | ||||||
| #  undef NEXTBYTE |  | ||||||
| #  define NEXTBYTE (n--?0:fprintf(stderr,"inffast underrun\n"),*p++) |  | ||||||
| #endif |  | ||||||
| #define GRABBITS(j) {while(k<(j)){b|=((uLong)NEXTBYTE)<<k;k+=8;}} | #define GRABBITS(j) {while(k<(j)){b|=((uLong)NEXTBYTE)<<k;k+=8;}} | ||||||
| #define UNGRAB {n+=(c=k>>3);p-=c;k&=7;} | #define UNGRAB {n+=(c=k>>3);p-=c;k&=7;} | ||||||
|  |  | ||||||
| @@ -32,115 +30,134 @@ struct inflate_codes_state {int dummy;}; /* for buggy compilers */ | |||||||
| int inflate_fast(bl, bd, tl, td, s, z) | int inflate_fast(bl, bd, tl, td, s, z) | ||||||
| uInt bl, bd; | uInt bl, bd; | ||||||
| inflate_huft *tl, *td; | inflate_huft *tl, *td; | ||||||
| struct inflate_blocks_state *s; | inflate_blocks_statef *s; | ||||||
| z_stream *z; | z_stream *z; | ||||||
| { | { | ||||||
|   inflate_huft *t;	/* temporary pointer */ |   inflate_huft *t;      /* temporary pointer */ | ||||||
|   int e;		/* extra bits or operation */ |   uInt e;               /* extra bits or operation */ | ||||||
|   uLong b;		/* bit buffer */ |   uLong b;              /* bit buffer */ | ||||||
|   uInt k;		/* bits in bit buffer */ |   uInt k;               /* bits in bit buffer */ | ||||||
|   Byte *p;		/* input data pointer */ |   Bytef *p;             /* input data pointer */ | ||||||
|   uInt n;		/* bytes available there */ |   uInt n;               /* bytes available there */ | ||||||
|   Byte *q;		/* output window write pointer */ |   Bytef *q;             /* output window write pointer */ | ||||||
|   uInt m;		/* bytes to end of window or read pointer */ |   uInt m;               /* bytes to end of window or read pointer */ | ||||||
|   uInt ml;		/* mask for literal/length tree */ |   uInt ml;              /* mask for literal/length tree */ | ||||||
|   uInt md;		/* mask for distance tree */ |   uInt md;              /* mask for distance tree */ | ||||||
|   uInt c;		/* bytes to copy */ |   uInt c;               /* bytes to copy */ | ||||||
|   uInt d;		/* distance back to copy from */ |   uInt d;               /* distance back to copy from */ | ||||||
|   Byte *r;		/* copy source pointer */ |   Bytef *r;             /* copy source pointer */ | ||||||
|  |  | ||||||
|   /* load input, output, bit values */ |   /* load input, output, bit values */ | ||||||
|   LOAD |   LOAD | ||||||
|  |  | ||||||
|   /* initialize masks in registers */ |   /* initialize masks */ | ||||||
|   ml = inflate_mask[bl]; |   ml = inflate_mask[bl]; | ||||||
|   md = inflate_mask[bd]; |   md = inflate_mask[bd]; | ||||||
|  |  | ||||||
|   /* do until not enough input or output space for fast loop */ |   /* do until not enough input or output space for fast loop */ | ||||||
|   do {				/* assume called with m >= 258 && n >= 10 */ |   do {                          /* assume called with m >= 258 && n >= 10 */ | ||||||
|     /* get literal/length code */ |     /* get literal/length code */ | ||||||
|     GRABBITS(20)		/* max bits for literal/length code */ |     GRABBITS(20)                /* max bits for literal/length code */ | ||||||
|     if ((e = (t = tl + ((uInt)b & ml))->exop) < 0) |     if ((e = (t = tl + ((uInt)b & ml))->exop) == 0) | ||||||
|       do { |  | ||||||
| 	if (e == -128) |  | ||||||
| 	{ |  | ||||||
| 	  z->msg = "invalid literal/length code"; |  | ||||||
|           UNGRAB |  | ||||||
| 	  UPDATE |  | ||||||
| 	  return Z_DATA_ERROR; |  | ||||||
| 	} |  | ||||||
| 	DUMPBITS(t->bits) |  | ||||||
| 	e = -e; |  | ||||||
| 	if (e & 64)		/* end of block */ |  | ||||||
| 	{ |  | ||||||
|           UNGRAB |  | ||||||
| 	  UPDATE |  | ||||||
| 	  return Z_STREAM_END; |  | ||||||
| 	} |  | ||||||
|       } while ((e = (t = t->next + ((uInt)b & inflate_mask[e]))->exop) < 0); |  | ||||||
|     DUMPBITS(t->bits) |  | ||||||
|  |  | ||||||
|     /* process literal or length (end of block already trapped) */ |  | ||||||
|     if (e & 16)			/* then it's a literal */ |  | ||||||
|     { |     { | ||||||
|  |       DUMPBITS(t->bits) | ||||||
|  |       Tracevv((stderr, t->base >= 0x20 && t->base < 0x7f ? | ||||||
|  |                 "inflate:         * literal '%c'\n" : | ||||||
|  |                 "inflate:         * literal 0x%02x\n", t->base)); | ||||||
|       *q++ = (Byte)t->base; |       *q++ = (Byte)t->base; | ||||||
|       m--; |       m--; | ||||||
|  |       continue; | ||||||
|     } |     } | ||||||
|     else			/* it's a length */ |     do { | ||||||
|     { |  | ||||||
|       /* get length of block to copy (already have extra bits) */ |  | ||||||
|       c = t->base + ((uInt)b & inflate_mask[e]); |  | ||||||
|       DUMPBITS(e); |  | ||||||
|  |  | ||||||
|       /* decode distance base of block to copy */ |  | ||||||
|       GRABBITS(15);		/* max bits for distance code */ |  | ||||||
|       if ((e = (t = td + ((uInt)b & md))->exop) < 0) |  | ||||||
| 	do { |  | ||||||
| 	  if (e == -128) |  | ||||||
| 	  { |  | ||||||
| 	    z->msg = "invalid distance code"; |  | ||||||
| 	    UNGRAB |  | ||||||
| 	    UPDATE |  | ||||||
| 	    return Z_DATA_ERROR; |  | ||||||
| 	  } |  | ||||||
| 	  DUMPBITS(t->bits) |  | ||||||
| 	  e = -e; |  | ||||||
| 	} while ((e = (t = t->next + ((uInt)b & inflate_mask[e]))->exop) < 0); |  | ||||||
|       DUMPBITS(t->bits) |       DUMPBITS(t->bits) | ||||||
|  |       if (e & 16) | ||||||
|       /* get extra bits to add to distance base */ |  | ||||||
|       GRABBITS(e)           /* get extra bits (up to 13) */ |  | ||||||
|       d = t->base + ((uInt)b & inflate_mask[e]); |  | ||||||
|       DUMPBITS(e) |  | ||||||
|  |  | ||||||
|       /* do the copy */ |  | ||||||
|       m -= c; |  | ||||||
|       if (q - s->window >= d)		/* if offset before destination, */ |  | ||||||
|       {					/*  just copy */ |  | ||||||
| 	r = q - d; |  | ||||||
| 	*q++ = *r++;  c--;		/* minimum count is three, */ |  | ||||||
| 	*q++ = *r++;  c--;		/*  so unroll loop a little */ |  | ||||||
| 	do { |  | ||||||
| 	  *q++ = *r++; |  | ||||||
| 	} while (--c); |  | ||||||
|       } |  | ||||||
|       else				/* else offset after destination */ |  | ||||||
|       { |       { | ||||||
| 	e = d - (q - s->window);	/* bytes from offset to end */ |         /* get extra bits for length */ | ||||||
| 	r = s->end - e;			/* pointer to offset */ |         e &= 15; | ||||||
| 	if (c > e)			/* if source crosses, */ |         c = t->base + ((uInt)b & inflate_mask[e]); | ||||||
| 	{ |         DUMPBITS(e) | ||||||
| 	  c -= e;			/* copy to end of window */ |         Tracevv((stderr, "inflate:         * length %u\n", c)); | ||||||
| 	  do { |  | ||||||
| 	    *q++ = *r++; |         /* decode distance base of block to copy */ | ||||||
| 	  } while (--e); |         GRABBITS(15);           /* max bits for distance code */ | ||||||
| 	  r = s->window;		/* copy rest from start of window */ |         e = (t = td + ((uInt)b & md))->exop; | ||||||
| 	} |         do { | ||||||
| 	do {				/* copy all or what's left */ |           DUMPBITS(t->bits) | ||||||
| 	  *q++ = *r++; |           if (e & 16) | ||||||
| 	} while (--c); |           { | ||||||
|  |             /* get extra bits to add to distance base */ | ||||||
|  |             e &= 15; | ||||||
|  |             GRABBITS(e)         /* get extra bits (up to 13) */ | ||||||
|  |             d = t->base + ((uInt)b & inflate_mask[e]); | ||||||
|  |             DUMPBITS(e) | ||||||
|  |             Tracevv((stderr, "inflate:         * distance %u\n", d)); | ||||||
|  |  | ||||||
|  |             /* do the copy */ | ||||||
|  |             m -= c; | ||||||
|  |             if ((uInt)(q - s->window) >= d)     /* offset before dest */ | ||||||
|  |             {                                   /*  just copy */ | ||||||
|  |               r = q - d; | ||||||
|  |               *q++ = *r++;  c--;        /* minimum count is three, */ | ||||||
|  |               *q++ = *r++;  c--;        /*  so unroll loop a little */ | ||||||
|  |             } | ||||||
|  |             else                        /* else offset after destination */ | ||||||
|  |             { | ||||||
|  |               e = d - (q - s->window);  /* bytes from offset to end */ | ||||||
|  |               r = s->end - e;           /* pointer to offset */ | ||||||
|  |               if (c > e)                /* if source crosses, */ | ||||||
|  |               { | ||||||
|  |                 c -= e;                 /* copy to end of window */ | ||||||
|  |                 do { | ||||||
|  |                   *q++ = *r++; | ||||||
|  |                 } while (--e); | ||||||
|  |                 r = s->window;          /* copy rest from start of window */ | ||||||
|  |               } | ||||||
|  |             } | ||||||
|  |             do {                        /* copy all or what's left */ | ||||||
|  |               *q++ = *r++; | ||||||
|  |             } while (--c); | ||||||
|  |             break; | ||||||
|  |           } | ||||||
|  |           else if ((e & 64) == 0) | ||||||
|  |             e = (t = t->next + ((uInt)b & inflate_mask[e]))->exop; | ||||||
|  |           else | ||||||
|  |           { | ||||||
|  |             z->msg = "invalid distance code"; | ||||||
|  |             UNGRAB | ||||||
|  |             UPDATE | ||||||
|  |             return Z_DATA_ERROR; | ||||||
|  |           } | ||||||
|  |         } while (1); | ||||||
|  |         break; | ||||||
|       } |       } | ||||||
|     } |       if ((e & 64) == 0) | ||||||
|  |       { | ||||||
|  |         if ((e = (t = t->next + ((uInt)b & inflate_mask[e]))->exop) == 0) | ||||||
|  |         { | ||||||
|  |           DUMPBITS(t->bits) | ||||||
|  |           Tracevv((stderr, t->base >= 0x20 && t->base < 0x7f ? | ||||||
|  |                     "inflate:         * literal '%c'\n" : | ||||||
|  |                     "inflate:         * literal 0x%02x\n", t->base)); | ||||||
|  |           *q++ = (Byte)t->base; | ||||||
|  |           m--; | ||||||
|  |           break; | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |       else if (e & 32) | ||||||
|  |       { | ||||||
|  |         Tracevv((stderr, "inflate:         * end of block\n")); | ||||||
|  |         UNGRAB | ||||||
|  |         UPDATE | ||||||
|  |         return Z_STREAM_END; | ||||||
|  |       } | ||||||
|  |       else | ||||||
|  |       { | ||||||
|  |         z->msg = "invalid literal/length code"; | ||||||
|  |         UNGRAB | ||||||
|  |         UPDATE | ||||||
|  |         return Z_DATA_ERROR; | ||||||
|  |       } | ||||||
|  |     } while (1); | ||||||
|   } while (m >= 258 && n >= 10); |   } while (m >= 258 && n >= 10); | ||||||
|  |  | ||||||
|   /* not enough input or output--restore pointers and return */ |   /* not enough input or output--restore pointers and return */ | ||||||
|   | |||||||
| @@ -8,10 +8,10 @@ | |||||||
|    subject to change. Applications should only use zlib.h. |    subject to change. Applications should only use zlib.h. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| extern int inflate_fast __P(( | extern int inflate_fast OF(( | ||||||
|     uInt, |     uInt, | ||||||
|     uInt, |     uInt, | ||||||
|     inflate_huft *, |     inflate_huft *, | ||||||
|     inflate_huft *, |     inflate_huft *, | ||||||
|     struct inflate_blocks_state *, |     inflate_blocks_statef *, | ||||||
|     z_stream *)); |     z_stream *)); | ||||||
|   | |||||||
							
								
								
									
										255
									
								
								inflate.c
									
									
									
									
									
								
							
							
						
						
									
										255
									
								
								inflate.c
									
									
									
									
									
								
							| @@ -13,40 +13,65 @@ struct internal_state { | |||||||
|  |  | ||||||
|   /* mode */ |   /* mode */ | ||||||
|   enum { |   enum { | ||||||
|       METHOD,	/* waiting for method byte */ |       METHOD,   /* waiting for method byte */ | ||||||
|       FLAG,	/* waiting for flag byte */ |       FLAG,     /* waiting for flag byte */ | ||||||
|       START,	/* make new blocks state */ |       BLOCKS,   /* decompressing blocks */ | ||||||
|       BLOCKS,	/* decompressing blocks */ |       CHECK4,   /* four check bytes to go */ | ||||||
|       CHECK4,	/* four check bytes to go */ |       CHECK3,   /* three check bytes to go */ | ||||||
|       CHECK3,	/* three check bytes to go */ |       CHECK2,   /* two check bytes to go */ | ||||||
|       CHECK2,	/* two check bytes to go */ |       CHECK1,   /* one check byte to go */ | ||||||
|       CHECK1,	/* one check byte to go */ |       DONE,     /* finished check, done */ | ||||||
|       DONE,	/* finished check, done */ |       BAD}      /* got an error--stay here */ | ||||||
|       INF_ERROR}/* got an error--stay here */ |     mode;               /* current inflate mode */ | ||||||
|     mode;		/* current inflate mode */ |  | ||||||
|  |  | ||||||
|   /* mode dependent information */ |   /* mode dependent information */ | ||||||
|   union { |   union { | ||||||
|     uInt method;	/* if FLAGS, method byte */ |     uInt method;        /* if FLAGS, method byte */ | ||||||
|     struct inflate_blocks_state |  | ||||||
|       *blocks;		/* if BLOCKS, current state */ |  | ||||||
|     struct { |     struct { | ||||||
|       uLong was;		/* computed check value */ |       uLong was;                /* computed check value */ | ||||||
|       uLong need;		/* stream check value */ |       uLong need;               /* stream check value */ | ||||||
|     } check;		/* if CHECK, check values to compare */ |     } check;            /* if CHECK, check values to compare */ | ||||||
|   } sub;	/* submode */ |     uInt marker;        /* if BAD, inflateSync's marker bytes count */ | ||||||
|  |   } sub;        /* submode */ | ||||||
|  |  | ||||||
|   /* mode independent information */ |   /* mode independent information */ | ||||||
|   int  nowrap;		/* flag for no wrapper */ |   int  nowrap;          /* flag for no wrapper */ | ||||||
|   uInt wbits;  		/* log2(window size)  (8..15, defaults to 15) */ |   uInt wbits;           /* log2(window size)  (8..15, defaults to 15) */ | ||||||
|  |   inflate_blocks_statef  | ||||||
|  |     *blocks;            /* current inflate_blocks state */ | ||||||
|  |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| int inflateInit(z) | int inflateReset(z) | ||||||
| z_stream *z; | z_stream *z; | ||||||
| { | { | ||||||
|     return inflateInit2(z, WBITS); |   uLong c; | ||||||
|  |  | ||||||
|  |   if (z == Z_NULL || z->state == Z_NULL) | ||||||
|  |     return Z_STREAM_ERROR; | ||||||
|  |   z->total_in = z->total_out = 0; | ||||||
|  |   z->msg = Z_NULL; | ||||||
|  |   z->state->mode = z->state->nowrap ? BLOCKS : METHOD; | ||||||
|  |   inflate_blocks_reset(z->state->blocks, z, &c); | ||||||
|  |   Trace((stderr, "inflate: reset\n")); | ||||||
|  |   return Z_OK; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | int inflateEnd(z) | ||||||
|  | z_stream *z; | ||||||
|  | { | ||||||
|  |   uLong c; | ||||||
|  |  | ||||||
|  |   if (z == Z_NULL || z->state == Z_NULL || z->zfree == Z_NULL) | ||||||
|  |     return Z_STREAM_ERROR; | ||||||
|  |   if (z->state->blocks != Z_NULL) | ||||||
|  |     inflate_blocks_free(z->state->blocks, z, &c); | ||||||
|  |   ZFREE(z, z->state); | ||||||
|  |   z->state = Z_NULL; | ||||||
|  |   Trace((stderr, "inflate: end\n")); | ||||||
|  |   return Z_OK; | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -59,12 +84,10 @@ int w; | |||||||
|     return Z_STREAM_ERROR; |     return Z_STREAM_ERROR; | ||||||
|   if (z->zalloc == Z_NULL) z->zalloc = zcalloc; |   if (z->zalloc == Z_NULL) z->zalloc = zcalloc; | ||||||
|   if (z->zfree == Z_NULL) z->zfree = zcfree; |   if (z->zfree == Z_NULL) z->zfree = zcfree; | ||||||
|   z->total_in = z->total_out = 0; |   if ((z->state = (struct internal_state FAR *) | ||||||
|   z->msg = Z_NULL; |  | ||||||
|   if ((z->state = (struct internal_state *) |  | ||||||
|        ZALLOC(z,1,sizeof(struct internal_state))) == Z_NULL) |        ZALLOC(z,1,sizeof(struct internal_state))) == Z_NULL) | ||||||
|     return Z_MEM_ERROR; |     return Z_MEM_ERROR; | ||||||
|   z->state->mode = METHOD; |   z->state->blocks = Z_NULL; | ||||||
|  |  | ||||||
|   /* handle undocumented nowrap option (no zlib header or check) */ |   /* handle undocumented nowrap option (no zlib header or check) */ | ||||||
|   z->state->nowrap = 0; |   z->state->nowrap = 0; | ||||||
| @@ -72,7 +95,6 @@ int w; | |||||||
|   { |   { | ||||||
|     w = - w; |     w = - w; | ||||||
|     z->state->nowrap = 1; |     z->state->nowrap = 1; | ||||||
|     z->state->mode = START; |  | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   /* set window size */ |   /* set window size */ | ||||||
| @@ -81,20 +103,40 @@ int w; | |||||||
|     inflateEnd(z); |     inflateEnd(z); | ||||||
|     return Z_STREAM_ERROR; |     return Z_STREAM_ERROR; | ||||||
|   } |   } | ||||||
|   z->state->wbits = w; |   z->state->wbits = (uInt)w; | ||||||
|  |  | ||||||
|  |   /* create inflate_blocks state */ | ||||||
|  |   if ((z->state->blocks = | ||||||
|  |        inflate_blocks_new(z, z->state->nowrap ? Z_NULL : adler32, 1 << w)) | ||||||
|  |       == Z_NULL) | ||||||
|  |   { | ||||||
|  |     inflateEnd(z); | ||||||
|  |     return Z_MEM_ERROR; | ||||||
|  |   } | ||||||
|  |   Trace((stderr, "inflate: allocated\n")); | ||||||
|  |  | ||||||
|  |   /* reset state */ | ||||||
|  |   inflateReset(z); | ||||||
|   return Z_OK; |   return Z_OK; | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | int inflateInit(z) | ||||||
|  | z_stream *z; | ||||||
|  | { | ||||||
|  |   return inflateInit2(z, DEF_WBITS); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #define NEEDBYTE {if(z->avail_in==0)return r;r=Z_OK;} | ||||||
| #define NEXTBYTE (z->avail_in--,z->total_in++,*z->next_in++) | #define NEXTBYTE (z->avail_in--,z->total_in++,*z->next_in++) | ||||||
|  |  | ||||||
| int inflate(z, f) | int inflate(z, f) | ||||||
| z_stream *z; | z_stream *z; | ||||||
| int f; | int f; | ||||||
| { | { | ||||||
|   int r = f; /* to avoid warning about unused f */ |   int r = f;    /* to avoid warning about unused f */ | ||||||
|   uInt b; |   uInt b; | ||||||
|   uLong c; |  | ||||||
|  |  | ||||||
|   if (z == Z_NULL || z->next_in == Z_NULL) |   if (z == Z_NULL || z->next_in == Z_NULL) | ||||||
|     return Z_STREAM_ERROR; |     return Z_STREAM_ERROR; | ||||||
| @@ -102,77 +144,86 @@ int f; | |||||||
|   while (1) switch (z->state->mode) |   while (1) switch (z->state->mode) | ||||||
|   { |   { | ||||||
|     case METHOD: |     case METHOD: | ||||||
|       if (z->avail_in == 0) return r;  r = Z_OK; |       NEEDBYTE | ||||||
|       if (((z->state->sub.method = NEXTBYTE) & 0xf != DEFLATED)) |       if (((z->state->sub.method = NEXTBYTE) & 0xf) != DEFLATED) | ||||||
|       { |       { | ||||||
|         z->state->mode = INF_ERROR; |         z->state->mode = BAD; | ||||||
| 	z->msg = "unknown compression method"; |         z->msg = "unknown compression method"; | ||||||
| 	return Z_DATA_ERROR; |         z->state->sub.marker = 5;       /* can't try inflateSync */ | ||||||
|  |         break; | ||||||
|       } |       } | ||||||
|       if ((z->state->sub.method >> 4) + 8 > z->state->wbits) |       if ((z->state->sub.method >> 4) + 8 > z->state->wbits) | ||||||
|       { |       { | ||||||
|         z->state->mode = INF_ERROR; |         z->state->mode = BAD; | ||||||
| 	z->msg = "invalid window size"; |         z->msg = "invalid window size"; | ||||||
| 	return Z_DATA_ERROR; |         z->state->sub.marker = 5;       /* can't try inflateSync */ | ||||||
|  |         break; | ||||||
|       } |       } | ||||||
|       z->state->mode = FLAG; |       z->state->mode = FLAG; | ||||||
|     case FLAG: |     case FLAG: | ||||||
|       if (z->avail_in == 0) return r;  r = Z_OK; |       NEEDBYTE | ||||||
|       if ((b = NEXTBYTE) & 0x20) |       if ((b = NEXTBYTE) & 0x20) | ||||||
|       { |       { | ||||||
|         z->state->mode = INF_ERROR; |         z->state->mode = BAD; | ||||||
| 	z->msg = "invalid reserved bit"; |         z->msg = "invalid reserved bit"; | ||||||
| 	return Z_DATA_ERROR; |         z->state->sub.marker = 5;       /* can't try inflateSync */ | ||||||
|  |         break; | ||||||
|       } |       } | ||||||
|       if (((z->state->sub.method << 8) + b) % 31) |       if (((z->state->sub.method << 8) + b) % 31) | ||||||
|       { |       { | ||||||
|         z->state->mode = INF_ERROR; |         z->state->mode = BAD; | ||||||
| 	z->msg = "incorrect header check"; |         z->msg = "incorrect header check"; | ||||||
| 	return Z_DATA_ERROR; |         z->state->sub.marker = 5;       /* can't try inflateSync */ | ||||||
|  |         break; | ||||||
|       } |       } | ||||||
|       z->state->mode = START; |       Trace((stderr, "inflate: zlib header ok\n")); | ||||||
|     case START: |  | ||||||
|       if ((z->state->sub.blocks = inflate_blocks_new(z, |  | ||||||
|          z->state->nowrap ? Z_NULL : adler32, |  | ||||||
|          1<< z->state->wbits)) == Z_NULL) |  | ||||||
|         return Z_MEM_ERROR; |  | ||||||
|       z->state->mode = BLOCKS; |       z->state->mode = BLOCKS; | ||||||
|     case BLOCKS: |     case BLOCKS: | ||||||
|       if ((r = inflate_blocks(z->state->sub.blocks, z, r)) != Z_STREAM_END) |       r = inflate_blocks(z->state->blocks, z, r); | ||||||
|  |       if (r == Z_DATA_ERROR) | ||||||
|  |       { | ||||||
|  |         z->state->mode = BAD; | ||||||
|  |         z->state->sub.marker = 0;       /* can try inflateSync */ | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |       if (r != Z_STREAM_END) | ||||||
|         return r; |         return r; | ||||||
|       inflate_blocks_free(z->state->sub.blocks, z, &c); |       r = Z_OK; | ||||||
|  |       inflate_blocks_reset(z->state->blocks, z, &z->state->sub.check.was); | ||||||
|       if (z->state->nowrap) |       if (z->state->nowrap) | ||||||
|       { |       { | ||||||
|       z->state->mode = DONE; |         z->state->mode = DONE; | ||||||
| 	break; |         break; | ||||||
|       } |       } | ||||||
|       z->state->sub.check.was = c; |  | ||||||
|       z->state->mode = CHECK4; |       z->state->mode = CHECK4; | ||||||
|     case CHECK4: |     case CHECK4: | ||||||
|       if (z->avail_in == 0) return r;  r = Z_OK; |       NEEDBYTE | ||||||
|       z->state->sub.check.need = (uLong)NEXTBYTE << 24; |       z->state->sub.check.need = (uLong)NEXTBYTE << 24; | ||||||
|       z->state->mode = CHECK3; |       z->state->mode = CHECK3; | ||||||
|     case CHECK3: |     case CHECK3: | ||||||
|       if (z->avail_in == 0) return r;  r = Z_OK; |       NEEDBYTE | ||||||
|       z->state->sub.check.need += (uLong)NEXTBYTE << 16; |       z->state->sub.check.need += (uLong)NEXTBYTE << 16; | ||||||
|       z->state->mode = CHECK2; |       z->state->mode = CHECK2; | ||||||
|     case CHECK2: |     case CHECK2: | ||||||
|       if (z->avail_in == 0) return r;  r = Z_OK; |       NEEDBYTE | ||||||
|       z->state->sub.check.need += (uLong)NEXTBYTE << 8; |       z->state->sub.check.need += (uLong)NEXTBYTE << 8; | ||||||
|       z->state->mode = CHECK1; |       z->state->mode = CHECK1; | ||||||
|     case CHECK1: |     case CHECK1: | ||||||
|       if (z->avail_in == 0) return r;  r = Z_OK; |       NEEDBYTE | ||||||
|       z->state->sub.check.need += (uLong)NEXTBYTE; |       z->state->sub.check.need += (uLong)NEXTBYTE; | ||||||
|  |  | ||||||
|       if (z->state->sub.check.was != z->state->sub.check.need) |       if (z->state->sub.check.was != z->state->sub.check.need) | ||||||
|       { |       { | ||||||
|         z->state->mode = INF_ERROR; |         z->state->mode = BAD; | ||||||
|         z->msg = "incorrect data check"; |         z->msg = "incorrect data check"; | ||||||
| 	return Z_DATA_ERROR; |         z->state->sub.marker = 5;       /* can't try inflateSync */ | ||||||
|  |         break; | ||||||
|       } |       } | ||||||
|  |       Trace((stderr, "inflate: zlib check ok\n")); | ||||||
|       z->state->mode = DONE; |       z->state->mode = DONE; | ||||||
|     case DONE: |     case DONE: | ||||||
|       return Z_STREAM_END; |       return Z_STREAM_END; | ||||||
|     case INF_ERROR: |     case BAD: | ||||||
|       return Z_DATA_ERROR; |       return Z_DATA_ERROR; | ||||||
|     default: |     default: | ||||||
|       return Z_STREAM_ERROR; |       return Z_STREAM_ERROR; | ||||||
| @@ -180,41 +231,51 @@ int f; | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| int inflateEnd(z) |  | ||||||
| z_stream *z; |  | ||||||
| { |  | ||||||
|   uLong c; |  | ||||||
|  |  | ||||||
|   if (z == Z_NULL || z->state == Z_NULL || z->zfree == Z_NULL) |  | ||||||
|     return Z_STREAM_ERROR; |  | ||||||
|   if (z->state->mode == BLOCKS) |  | ||||||
|     inflate_blocks_free(z->state->sub.blocks, z, &c); |  | ||||||
|   ZFREE(z, z->state); |  | ||||||
|   z->state = Z_NULL; |  | ||||||
|   return Z_OK; |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /* inflateSync not implemented yet--this just consumes input */ |  | ||||||
| int inflateSync(z) | int inflateSync(z) | ||||||
| z_stream *z; | z_stream *z; | ||||||
| { | { | ||||||
|   if (z == Z_NULL) return Z_STREAM_ERROR; |   uInt n;       /* number of bytes to look at */ | ||||||
|   if (z->avail_in == 0) return Z_BUF_ERROR; |   Bytef *p;     /* pointer to bytes */ | ||||||
|   do { |   uInt m;       /* number of marker bytes found in a row */ | ||||||
|     z->total_in++; |   uLong r, w;   /* temporaries to save total_in and total_out */ | ||||||
|   } while (--z->avail_in); |  | ||||||
|   return Z_DATA_ERROR; |   /* set up */ | ||||||
| } |   if (z == Z_NULL || z->state == Z_NULL) | ||||||
|  |     return Z_STREAM_ERROR; | ||||||
|  |   if (z->state->mode != BAD) | ||||||
| /* inflateReset not fully implemented yet--this frees and reallocates */ |   { | ||||||
| int inflateReset(z) |     z->state->mode = BAD; | ||||||
| z_stream *z; |     z->state->sub.marker = 0; | ||||||
| { |   } | ||||||
|   int r; |   if ((n = z->avail_in) == 0) | ||||||
|  |     return Z_BUF_ERROR; | ||||||
|   if ((r = inflateEnd(z)) != Z_OK) |   p = z->next_in; | ||||||
|     return r; |   m = z->state->sub.marker; | ||||||
|   return inflateInit(z); |  | ||||||
|  |   /* search */ | ||||||
|  |   while (n && m < 4) | ||||||
|  |   { | ||||||
|  |     if (*p == (Byte)(m < 2 ? 0 : 0xff)) | ||||||
|  |       m++; | ||||||
|  |     else if (*p) | ||||||
|  |       m = 0; | ||||||
|  |     else | ||||||
|  |       m = 4 - m; | ||||||
|  |     p++, n--; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* restore */ | ||||||
|  |   z->total_in += p - z->next_in; | ||||||
|  |   z->next_in = p; | ||||||
|  |   z->avail_in = n; | ||||||
|  |   z->state->sub.marker = m; | ||||||
|  |  | ||||||
|  |   /* return no joy or set up to restart on a new block */ | ||||||
|  |   if (m != 4) | ||||||
|  |     return Z_DATA_ERROR; | ||||||
|  |   r = z->total_in;  w = z->total_out; | ||||||
|  |   inflateReset(z); | ||||||
|  |   z->total_in = r;  z->total_out = w; | ||||||
|  |   z->state->mode = BLOCKS; | ||||||
|  |   return Z_OK; | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										69
									
								
								inftest.c
									
									
									
									
									
								
							
							
						
						
									
										69
									
								
								inftest.c
									
									
									
									
									
								
							| @@ -1,69 +0,0 @@ | |||||||
| #include <stdio.h> |  | ||||||
| #include <stdlib.h> |  | ||||||
| #include "zutil.h" |  | ||||||
|  |  | ||||||
| void main __P((void)); |  | ||||||
|  |  | ||||||
| /* This test is in honor of Ed Hamrick who suggested that the interface |  | ||||||
|    to inflate be a byte at a time--this implements that, and is, of course, |  | ||||||
|    monumentally slow.  It has the virtue though of stressing the push-pull |  | ||||||
|    interface for testing purposes. */ |  | ||||||
|  |  | ||||||
| void main() |  | ||||||
| { |  | ||||||
|   int a, r; |  | ||||||
|   char c; |  | ||||||
|   z_stream z; |  | ||||||
|  |  | ||||||
|   z.zalloc = Z_NULL; |  | ||||||
|   z.zfree = Z_NULL; |  | ||||||
|   r = inflateInit(&z); |  | ||||||
|   if (r != Z_OK) |  | ||||||
|     fprintf(stderr, "init error: %s\n", z_errmsg[1 - r]); |  | ||||||
|   while ((a = getchar()) != EOF) |  | ||||||
|   { |  | ||||||
|     /* feed one byte of input */ |  | ||||||
|     z.avail_out = 0; |  | ||||||
|     c = (char)a; |  | ||||||
|     z.next_in = (Byte*)&c; |  | ||||||
|     z.avail_in = 1; |  | ||||||
|     r = inflate(&z, 0); |  | ||||||
|     if (r == Z_STREAM_END) |  | ||||||
|       break; |  | ||||||
|     if (r != Z_OK) |  | ||||||
|     { |  | ||||||
|       fprintf(stderr, "inflate error: %s\n", z_errmsg[1 - r]); |  | ||||||
|       break; |  | ||||||
|     } |  | ||||||
|     if (z.avail_in != 0) |  | ||||||
|     { |  | ||||||
|       fprintf(stderr, "inflate didn't eat byte and didn't say buf err!\n"); |  | ||||||
|       break; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /* empty output one byte at a time */ |  | ||||||
|     while (1) |  | ||||||
|     { |  | ||||||
|       z.next_out = (Byte*)&c; |  | ||||||
|       z.avail_out = 1; |  | ||||||
|       r = inflate(&z, 0); |  | ||||||
|       if (r == Z_STREAM_END) |  | ||||||
| 	break; |  | ||||||
|       if (r != Z_OK && r != Z_BUF_ERROR) |  | ||||||
|       { |  | ||||||
| 	fprintf(stderr, "inflate error: %s\n", z_errmsg[1 - r]); |  | ||||||
| 	break; |  | ||||||
|       } |  | ||||||
|       if (z.avail_out == 0) |  | ||||||
|         putchar(c); |  | ||||||
|       else |  | ||||||
|         break; |  | ||||||
|     } |  | ||||||
|     if (r != Z_OK && r != Z_BUF_ERROR) |  | ||||||
|       break; |  | ||||||
|   } |  | ||||||
|   inflateEnd(&z); |  | ||||||
|   fprintf(stderr, "%ld bytes in, %ld bytes out\n", z.total_in, z.total_out); |  | ||||||
|   if (z.msg != NULL) |  | ||||||
|     fprintf(stderr, "msg is <%s>\n", z.msg); |  | ||||||
| } |  | ||||||
							
								
								
									
										187
									
								
								inftrees.c
									
									
									
									
									
								
							
							
						
						
									
										187
									
								
								inftrees.c
									
									
									
									
									
								
							| @@ -15,38 +15,38 @@ struct internal_state  {int dummy;}; /* for buggy compilers */ | |||||||
| #define bits word.what.Bits | #define bits word.what.Bits | ||||||
|  |  | ||||||
|  |  | ||||||
| local int huft_build __P(( | local int huft_build OF(( | ||||||
|     uInt *,		/* code lengths in bits */ |     uIntf *,            /* code lengths in bits */ | ||||||
|     uInt,		/* number of codes */ |     uInt,               /* number of codes */ | ||||||
|     uInt,		/* number of "simple" codes */ |     uInt,               /* number of "simple" codes */ | ||||||
|     uInt *,		/* list of base values for non-simple codes */ |     uIntf *,            /* list of base values for non-simple codes */ | ||||||
|     uInt *,		/* list of extra bits for non-simple codes */ |     uIntf *,            /* list of extra bits for non-simple codes */ | ||||||
|     inflate_huft **,	/* result: starting table */ |     inflate_huft * FAR*,/* result: starting table */ | ||||||
|     uInt *,		/* maximum lookup bits (returns actual) */ |     uIntf *,            /* maximum lookup bits (returns actual) */ | ||||||
|     z_stream *));	/* for zalloc function */ |     z_stream *));       /* for zalloc function */ | ||||||
|  |  | ||||||
| local voidp falloc __P(( | local voidp falloc OF(( | ||||||
|     voidp,		/* opaque pointer (not used) */ |     voidp,              /* opaque pointer (not used) */ | ||||||
|     uInt,		/* number of items */ |     uInt,               /* number of items */ | ||||||
|     uInt));		/* size of item */ |     uInt));             /* size of item */ | ||||||
|  |  | ||||||
| local void ffree __P(( | local void ffree OF(( | ||||||
|     voidp q,		/* opaque pointer (not used) */ |     voidp q,            /* opaque pointer (not used) */ | ||||||
|     voidp p));		/* what to free (not used) */ |     voidp p));          /* what to free (not used) */ | ||||||
|  |  | ||||||
| /* Tables for deflate from PKZIP's appnote.txt. */ | /* Tables for deflate from PKZIP's appnote.txt. */ | ||||||
| local uInt cplens[] = {	/* Copy lengths for literal codes 257..285 */ | local uInt cplens[] = { /* Copy lengths for literal codes 257..285 */ | ||||||
|         3, 4, 5, 6, 7, 8, 9, 10, 11, 13, 15, 17, 19, 23, 27, 31, |         3, 4, 5, 6, 7, 8, 9, 10, 11, 13, 15, 17, 19, 23, 27, 31, | ||||||
|         35, 43, 51, 59, 67, 83, 99, 115, 131, 163, 195, 227, 258, 0, 0}; |         35, 43, 51, 59, 67, 83, 99, 115, 131, 163, 195, 227, 258, 0, 0}; | ||||||
|         /* actually lengths - 2; also see note #13 above about 258 */ |         /* actually lengths - 2; also see note #13 above about 258 */ | ||||||
| local uInt cplext[] = {	/* Extra bits for literal codes 257..285 */ | local uInt cplext[] = { /* Extra bits for literal codes 257..285 */ | ||||||
|         0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 2, 2, 2, 2, |         0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 2, 2, 2, 2, | ||||||
|         3, 3, 3, 3, 4, 4, 4, 4, 5, 5, 5, 5, 0, 128, 128}; /* 128==invalid */ |         3, 3, 3, 3, 4, 4, 4, 4, 5, 5, 5, 5, 0, 192, 192}; /* 192==invalid */ | ||||||
| local uInt cpdist[] = {	/* Copy offsets for distance codes 0..29 */ | local uInt cpdist[] = { /* Copy offsets for distance codes 0..29 */ | ||||||
|         1, 2, 3, 4, 5, 7, 9, 13, 17, 25, 33, 49, 65, 97, 129, 193, |         1, 2, 3, 4, 5, 7, 9, 13, 17, 25, 33, 49, 65, 97, 129, 193, | ||||||
|         257, 385, 513, 769, 1025, 1537, 2049, 3073, 4097, 6145, |         257, 385, 513, 769, 1025, 1537, 2049, 3073, 4097, 6145, | ||||||
|         8193, 12289, 16385, 24577}; |         8193, 12289, 16385, 24577}; | ||||||
| local uInt cpdext[] = {	/* Extra bits for distance codes */ | local uInt cpdext[] = { /* Extra bits for distance codes */ | ||||||
|         0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, |         0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, | ||||||
|         7, 7, 8, 8, 9, 9, 10, 10, 11, 11, |         7, 7, 8, 8, 9, 9, 10, 10, 11, 11, | ||||||
|         12, 12, 13, 13}; |         12, 12, 13, 13}; | ||||||
| @@ -93,39 +93,40 @@ local uInt cpdext[] = {	/* Extra bits for distance codes */ | |||||||
| #endif | #endif | ||||||
|  |  | ||||||
| local int huft_build(b, n, s, d, e, t, m, zs) | local int huft_build(b, n, s, d, e, t, m, zs) | ||||||
| uInt *b;                /* code lengths in bits (all assumed <= BMAX) */ | uIntf *b;               /* code lengths in bits (all assumed <= BMAX) */ | ||||||
| uInt n;                 /* number of codes (assumed <= N_MAX) */ | uInt n;                 /* number of codes (assumed <= N_MAX) */ | ||||||
| uInt s;                 /* number of simple-valued codes (0..s-1) */ | uInt s;                 /* number of simple-valued codes (0..s-1) */ | ||||||
| uInt *d;                /* list of base values for non-simple codes */ | uIntf *d;               /* list of base values for non-simple codes */ | ||||||
| uInt *e;                /* list of extra bits for non-simple codes */ | uIntf *e;               /* list of extra bits for non-simple codes */   | ||||||
| inflate_huft **t;       /* result: starting table */ | inflate_huft * FAR *t;  /* result: starting table */ | ||||||
| uInt *m;                /* maximum lookup bits, returns actual */ | uIntf *m;               /* maximum lookup bits, returns actual */ | ||||||
| z_stream *zs;		/* for zalloc function */ | z_stream *zs;           /* for zalloc function */ | ||||||
| /* Given a list of code lengths and a maximum table size, make a set of | /* Given a list of code lengths and a maximum table size, make a set of | ||||||
|    tables to decode that set of codes.  Return Z_OK on success, Z_BUF_ERROR |    tables to decode that set of codes.  Return Z_OK on success, Z_BUF_ERROR | ||||||
|    if the given code set is incomplete (the tables are still built in this |    if the given code set is incomplete (the tables are still built in this | ||||||
|    case), Z_DATA_ERROR if the input is invalid (all zero length codes or an |    case), Z_DATA_ERROR if the input is invalid (all zero length codes or an | ||||||
|    over-subscribed set of lengths), or Z_MEM_ERROR if not enough memory. */ |    over-subscribed set of lengths), or Z_MEM_ERROR if not enough memory. */ | ||||||
| { | { | ||||||
|   uInt a;			/* counter for codes of length k */ |  | ||||||
|   uInt c[BMAX+1];		/* bit length count table */ |   uInt a;                       /* counter for codes of length k */ | ||||||
|   uInt f;			/* i repeats in table every f entries */ |   uInt c[BMAX+1];               /* bit length count table */ | ||||||
|   int g;			/* maximum code length */ |   uInt f;                       /* i repeats in table every f entries */ | ||||||
|   int h;			/* table level */ |   int g;                        /* maximum code length */ | ||||||
|   register uInt i;		/* counter, current code */ |   int h;                        /* table level */ | ||||||
|   register uInt j;		/* counter */ |   register uInt i;              /* counter, current code */ | ||||||
|   register int k;		/* number of bits in current code */ |   register uInt j;              /* counter */ | ||||||
|   int l;			/* bits per table (returned in m) */ |   register int k;               /* number of bits in current code */ | ||||||
|   register uInt *p;		/* pointer into c[], b[], or v[] */ |   int l;                        /* bits per table (returned in m) */ | ||||||
|   register inflate_huft *q;	/* points to current table */ |   register uIntf *p;            /* pointer into c[], b[], or v[] */ | ||||||
|   inflate_huft r;		/* table entry for structure assignment */ |   inflate_huft *q;              /* points to current table */ | ||||||
|   inflate_huft *u[BMAX];	/* table stack */ |   struct inflate_huft_s r;      /* table entry for structure assignment */ | ||||||
|   uInt v[N_MAX];		/* values in order of bit length */ |   inflate_huft *u[BMAX];        /* table stack */ | ||||||
|   register int w;		/* bits before this table == (l * h) */ |   uInt v[N_MAX];                /* values in order of bit length */ | ||||||
|   uInt x[BMAX+1];		/* bit offsets, then code stack */ |   register int w;               /* bits before this table == (l * h) */ | ||||||
|   uInt *xp;			/* pointer into x */ |   uInt x[BMAX+1];               /* bit offsets, then code stack */ | ||||||
|   int y;			/* number of dummy codes added */ |   uIntf *xp;                    /* pointer into x */ | ||||||
|   uInt z;			/* number of entries in current table */ |   int y;                        /* number of dummy codes added */ | ||||||
|  |   uInt z;                       /* number of entries in current table */ | ||||||
|  |  | ||||||
|  |  | ||||||
|   /* Generate counts for each bit length */ |   /* Generate counts for each bit length */ | ||||||
| @@ -133,7 +134,7 @@ z_stream *zs;		/* for zalloc function */ | |||||||
| #define C0 *p++ = 0; | #define C0 *p++ = 0; | ||||||
| #define C2 C0 C0 C0 C0 | #define C2 C0 C0 C0 C0 | ||||||
| #define C4 C2 C2 C2 C2 | #define C4 C2 C2 C2 C2 | ||||||
|   C4				/* clear c[]--assume BMAX+1 is 16 */ |   C4                            /* clear c[]--assume BMAX+1 is 16 */ | ||||||
|   p = b;  i = n; |   p = b;  i = n; | ||||||
|   do { |   do { | ||||||
|     c[*p++]++;                  /* assume all entries <= BMAX */ |     c[*p++]++;                  /* assume all entries <= BMAX */ | ||||||
| @@ -193,8 +194,8 @@ z_stream *zs;		/* for zalloc function */ | |||||||
|   p = v;                        /* grab values in bit order */ |   p = v;                        /* grab values in bit order */ | ||||||
|   h = -1;                       /* no tables yet--level -1 */ |   h = -1;                       /* no tables yet--level -1 */ | ||||||
|   w = -l;                       /* bits decoded == (l * h) */ |   w = -l;                       /* bits decoded == (l * h) */ | ||||||
|   u[0] = (inflate_huft *)Z_NULL;	/* just to keep compilers happy */ |   u[0] = (inflate_huft *)Z_NULL;        /* just to keep compilers happy */ | ||||||
|   q = (inflate_huft *)Z_NULL;	/* ditto */ |   q = (inflate_huft *)Z_NULL;   /* ditto */ | ||||||
|   z = 0;                        /* ditto */ |   z = 0;                        /* ditto */ | ||||||
|  |  | ||||||
|   /* go through the bit lengths (k already is bits in shortest code) */ |   /* go through the bit lengths (k already is bits in shortest code) */ | ||||||
| @@ -217,36 +218,36 @@ z_stream *zs;		/* for zalloc function */ | |||||||
|           f -= a + 1;           /* deduct codes from patterns left */ |           f -= a + 1;           /* deduct codes from patterns left */ | ||||||
|           xp = c + k; |           xp = c + k; | ||||||
|           if (j < z) |           if (j < z) | ||||||
| 	    while (++j < z)	/* try smaller tables up to z bits */ |             while (++j < z)     /* try smaller tables up to z bits */ | ||||||
| 	    { |             { | ||||||
| 	      if ((f <<= 1) <= *++xp) |               if ((f <<= 1) <= *++xp) | ||||||
| 		break;		/* enough codes to use up j bits */ |                 break;          /* enough codes to use up j bits */ | ||||||
| 	      f -= *xp;		/* else deduct codes from patterns */ |               f -= *xp;         /* else deduct codes from patterns */ | ||||||
| 	    } |             } | ||||||
|         } |         } | ||||||
|         z = 1 << j;             /* table entries for j-bit table */ |         z = 1 << j;             /* table entries for j-bit table */ | ||||||
|  |  | ||||||
|         /* allocate and link in new table */ |         /* allocate and link in new table */ | ||||||
|         if ((q = (inflate_huft *)ZALLOC |         if ((q = (inflate_huft *)ZALLOC | ||||||
| 	     (zs,z + 1,sizeof(inflate_huft))) == Z_NULL) |              (zs,z + 1,sizeof(inflate_huft))) == Z_NULL) | ||||||
|         { |         { | ||||||
|           if (h) |           if (h) | ||||||
|             inflate_trees_free(u[0], zs); |             inflate_trees_free(u[0], zs); | ||||||
|           return Z_MEM_ERROR;	/* not enough memory */ |           return Z_MEM_ERROR;   /* not enough memory */ | ||||||
|         } |         } | ||||||
| #ifdef DEBUG | #ifdef DEBUG | ||||||
| 	inflate_hufts += z + 1; |         inflate_hufts += z + 1; | ||||||
| #endif | #endif | ||||||
|         *t = q + 1;             /* link to list for huft_free() */ |         *t = q + 1;             /* link to list for huft_free() */ | ||||||
|         *(t = &(q->next)) = (inflate_huft *)Z_NULL; |         *(t = &(q->next)) = Z_NULL; | ||||||
|         u[h] = ++q;             /* table starts after link */ |         u[h] = ++q;             /* table starts after link */ | ||||||
|  |  | ||||||
|         /* connect to last table, if there is one */ |         /* connect to last table, if there is one */ | ||||||
|         if (h) |         if (h) | ||||||
|         { |         { | ||||||
|           x[h] = i;             /* save pattern for backing up */ |           x[h] = i;             /* save pattern for backing up */ | ||||||
|           r.bits = (char)l;     /* bits to dump before this table */ |           r.bits = (Byte)l;     /* bits to dump before this table */ | ||||||
|           r.exop = -(char)j;    /* bits in this table */ |           r.exop = (Byte)j;     /* bits in this table */ | ||||||
|           r.next = q;           /* pointer to this table */ |           r.next = q;           /* pointer to this table */ | ||||||
|           j = i >> (w - l);     /* (get around Turbo C bug) */ |           j = i >> (w - l);     /* (get around Turbo C bug) */ | ||||||
|           u[h-1][j] = r;        /* connect to last table */ |           u[h-1][j] = r;        /* connect to last table */ | ||||||
| @@ -254,17 +255,17 @@ z_stream *zs;		/* for zalloc function */ | |||||||
|       } |       } | ||||||
|  |  | ||||||
|       /* set up table entry in r */ |       /* set up table entry in r */ | ||||||
|       r.bits = (char)(k - w); |       r.bits = (Byte)(k - w); | ||||||
|       if (p >= v + n) |       if (p >= v + n) | ||||||
|         r.exop = -128;          /* out of values--invalid code */ |         r.exop = 128 + 64;      /* out of values--invalid code */ | ||||||
|       else if (*p < s) |       else if (*p < s) | ||||||
|       { |       { | ||||||
|         r.exop = (char)(*p < 256 ? 16 : -64);   /* 256 is end-of-block code */ |         r.exop = (Byte)(*p < 256 ? 0 : 32 + 64);     /* 256 is end-of-block */ | ||||||
|         r.base = *p++;          /* simple code is just the value */ |         r.base = *p++;          /* simple code is just the value */ | ||||||
|       } |       } | ||||||
|       else |       else | ||||||
|       { |       { | ||||||
|         r.exop = (char)e[*p - s];       /* non-simple--look up in lists */ |         r.exop = (Byte)e[*p - s] + 16 + 64; /* non-simple--look up in lists */ | ||||||
|         r.base = d[*p++ - s]; |         r.base = d[*p++ - s]; | ||||||
|       } |       } | ||||||
|  |  | ||||||
| @@ -294,14 +295,14 @@ z_stream *zs;		/* for zalloc function */ | |||||||
|  |  | ||||||
|  |  | ||||||
| int inflate_trees_bits(c, bb, tb, z) | int inflate_trees_bits(c, bb, tb, z) | ||||||
| uInt *c;		/* 19 code lengths */ | uIntf *c;               /* 19 code lengths */ | ||||||
| uInt *bb;		/* bits tree desired/actual depth */ | uIntf *bb;              /* bits tree desired/actual depth */ | ||||||
| inflate_huft **tb;	/* bits tree result */ | inflate_huft * FAR *tb; /* bits tree result */ | ||||||
| z_stream *z;		/* for zfree function */ | z_stream *z;            /* for zfree function */ | ||||||
| { | { | ||||||
|   int r; |   int r; | ||||||
|  |  | ||||||
|   r = huft_build(c, 19, 19, (uInt*)Z_NULL, (uInt*)Z_NULL, tb, bb, z); |   r = huft_build(c, 19, 19, (uIntf*)Z_NULL, (uIntf*)Z_NULL, tb, bb, z); | ||||||
|   if (r == Z_DATA_ERROR) |   if (r == Z_DATA_ERROR) | ||||||
|     z->msg = "oversubscribed dynamic bit lengths tree"; |     z->msg = "oversubscribed dynamic bit lengths tree"; | ||||||
|   else if (r == Z_BUF_ERROR) |   else if (r == Z_BUF_ERROR) | ||||||
| @@ -315,14 +316,14 @@ z_stream *z;		/* for zfree function */ | |||||||
|  |  | ||||||
|  |  | ||||||
| int inflate_trees_dynamic(nl, nd, c, bl, bd, tl, td, z) | int inflate_trees_dynamic(nl, nd, c, bl, bd, tl, td, z) | ||||||
| uInt nl;		/* number of literal/length codes */ | uInt nl;                /* number of literal/length codes */ | ||||||
| uInt nd;		/* number of distance codes */ | uInt nd;                /* number of distance codes */ | ||||||
| uInt *c;		/* that many (total) code lengths */ | uIntf *c;               /* that many (total) code lengths */ | ||||||
| uInt *bl;		/* literal desired/actual bit depth */ | uIntf *bl;              /* literal desired/actual bit depth */ | ||||||
| uInt *bd;		/* distance desired/actual bit depth */ | uIntf *bd;              /* distance desired/actual bit depth */ | ||||||
| inflate_huft **tl;	/* literal/length tree result */ | inflate_huft * FAR *tl; /* literal/length tree result */ | ||||||
| inflate_huft **td;	/* distance tree result */ | inflate_huft * FAR *td; /* distance tree result */ | ||||||
| z_stream *z;		/* for zfree function */ | z_stream *z;            /* for zfree function */ | ||||||
| { | { | ||||||
|   int r; |   int r; | ||||||
|  |  | ||||||
| @@ -367,7 +368,7 @@ z_stream *z;		/* for zfree function */ | |||||||
| /* build fixed tables only once--keep them here */ | /* build fixed tables only once--keep them here */ | ||||||
| local int fixed_lock = 0; | local int fixed_lock = 0; | ||||||
| local int fixed_built = 0; | local int fixed_built = 0; | ||||||
| #define FIXEDH 530	/* number of hufts used by fixed tables */ | #define FIXEDH 530      /* number of hufts used by fixed tables */ | ||||||
| local uInt fixed_left = FIXEDH; | local uInt fixed_left = FIXEDH; | ||||||
| local inflate_huft fixed_mem[FIXEDH]; | local inflate_huft fixed_mem[FIXEDH]; | ||||||
| local uInt fixed_bl; | local uInt fixed_bl; | ||||||
| @@ -377,9 +378,9 @@ local inflate_huft *fixed_td; | |||||||
|  |  | ||||||
|  |  | ||||||
| local voidp falloc(q, n, s) | local voidp falloc(q, n, s) | ||||||
| voidp q;	/* opaque pointer (not used) */ | voidp q;        /* opaque pointer (not used) */ | ||||||
| uInt n;		/* number of items */ | uInt n;         /* number of items */ | ||||||
| uInt s;		/* size of item */ | uInt s;         /* size of item */ | ||||||
| { | { | ||||||
|   Assert(s == sizeof(inflate_huft) && n <= fixed_left, |   Assert(s == sizeof(inflate_huft) && n <= fixed_left, | ||||||
|          "inflate_trees falloc overflow"); |          "inflate_trees falloc overflow"); | ||||||
| @@ -399,19 +400,19 @@ voidp p; | |||||||
|  |  | ||||||
|  |  | ||||||
| int inflate_trees_fixed(bl, bd, tl, td) | int inflate_trees_fixed(bl, bd, tl, td) | ||||||
| uInt *bl;		/* literal desired/actual bit depth */ | uIntf *bl;               /* literal desired/actual bit depth */ | ||||||
| uInt *bd;		/* distance desired/actual bit depth */ | uIntf *bd;               /* distance desired/actual bit depth */ | ||||||
| inflate_huft **tl;	/* literal/length tree result */ | inflate_huft * FAR *tl;  /* literal/length tree result */ | ||||||
| inflate_huft **td;	/* distance tree result */ | inflate_huft * FAR *td;  /* distance tree result */ | ||||||
| { | { | ||||||
|   /* build fixed tables if not built already--lock out other instances */ |   /* build fixed tables if not built already--lock out other instances */ | ||||||
|   while (++fixed_lock > 1) |   while (++fixed_lock > 1) | ||||||
|     fixed_lock--; |     fixed_lock--; | ||||||
|   if (!fixed_built) |   if (!fixed_built) | ||||||
|   { |   { | ||||||
|     int k;		/* temporary variable */ |     int k;              /* temporary variable */ | ||||||
|     unsigned c[288];	/* length list for huft_build */ |     unsigned c[288];    /* length list for huft_build */ | ||||||
|     z_stream z;		/* for falloc function */ |     z_stream z;         /* for falloc function */ | ||||||
|  |  | ||||||
|     /* set up fake z_stream for memory routines */ |     /* set up fake z_stream for memory routines */ | ||||||
|     z.zalloc = falloc; |     z.zalloc = falloc; | ||||||
| @@ -449,18 +450,14 @@ inflate_huft **td;	/* distance tree result */ | |||||||
|  |  | ||||||
|  |  | ||||||
| int inflate_trees_free(t, z) | int inflate_trees_free(t, z) | ||||||
| inflate_huft *t;	/* table to free */ | inflate_huft *t;        /* table to free */ | ||||||
| z_stream *z;		/* for zfree function */ | z_stream *z;            /* for zfree function */ | ||||||
| /* Free the malloc'ed tables built by huft_build(), which makes a linked | /* Free the malloc'ed tables built by huft_build(), which makes a linked | ||||||
|    list of the tables it made, with the links in a dummy first entry of |    list of the tables it made, with the links in a dummy first entry of | ||||||
|    each table. */ |    each table. */ | ||||||
| { | { | ||||||
|   register inflate_huft *p, *q; |   register inflate_huft *p, *q; | ||||||
|  |  | ||||||
|   /* Don't free fixed trees */ |  | ||||||
|   if (t >= fixed_mem && t <= fixed_mem + FIXEDH) |  | ||||||
|     return Z_OK; |  | ||||||
|  |  | ||||||
|   /* Go through linked list, freeing from the malloced (t[-1]) address. */ |   /* Go through linked list, freeing from the malloced (t[-1]) address. */ | ||||||
|   p = t; |   p = t; | ||||||
|   while (p != Z_NULL) |   while (p != Z_NULL) | ||||||
|   | |||||||
							
								
								
									
										61
									
								
								inftrees.h
									
									
									
									
									
								
							
							
						
						
									
										61
									
								
								inftrees.h
									
									
									
									
									
								
							| @@ -9,21 +9,17 @@ | |||||||
|  */ |  */ | ||||||
|  |  | ||||||
| /* Huffman code lookup table entry--this entry is four bytes for machines | /* Huffman code lookup table entry--this entry is four bytes for machines | ||||||
|    that have 16-bit pointers (e.g. PC's in the small or medium model). |    that have 16-bit pointers (e.g. PC's in the small or medium model). */ | ||||||
|    Valid extra bits (exop) are 0..13.  exop == -64 is EOB (end of block), |  | ||||||
|    exop == 16 means that v is a literal, exop < 0 means that v is a pointer | typedef struct inflate_huft_s FAR inflate_huft; | ||||||
|    to the next table, which codes -exop bits, and lastly exop == -128 |  | ||||||
|    indicates an unused code.  If a code with exop == -128 is looked up, |  | ||||||
|    this implies an error in the data. */ |  | ||||||
|  |  | ||||||
| typedef struct inflate_huft_s inflate_huft; |  | ||||||
| struct inflate_huft_s { | struct inflate_huft_s { | ||||||
|   union { |   union { | ||||||
|     struct { |     struct { | ||||||
|       char Exop;        /* number of extra bits or operation */ |       Byte Exop;        /* number of extra bits or operation */ | ||||||
|       char Bits;        /* number of bits in this code or subcode */ |       Byte Bits;        /* number of bits in this code or subcode */ | ||||||
|     } what; |     } what; | ||||||
|     Byte *pad;          /* pad structure to a power of 2 (4 bytes for */ |     Bytef *pad;         /* pad structure to a power of 2 (4 bytes for */ | ||||||
|   } word;               /*  16-bit, 8 bytes for 32-bit machines) */ |   } word;               /*  16-bit, 8 bytes for 32-bit machines) */ | ||||||
|   union { |   union { | ||||||
|     uInt Base;          /* literal, length base, or distance base */ |     uInt Base;          /* literal, length base, or distance base */ | ||||||
| @@ -35,28 +31,29 @@ struct inflate_huft_s { | |||||||
|   extern uInt inflate_hufts; |   extern uInt inflate_hufts; | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| extern int inflate_trees_bits __P(( | extern int inflate_trees_bits OF(( | ||||||
|     uInt *,			/* 19 code lengths */ |     uIntf *,                    /* 19 code lengths */ | ||||||
|     uInt *,			/* bits tree desired/actual depth */ |     uIntf *,                    /* bits tree desired/actual depth */ | ||||||
|     inflate_huft **,		/* bits tree result */ |     inflate_huft * FAR *,       /* bits tree result */ | ||||||
|     z_stream *));		/* for zalloc, zfree functions */ |     z_stream *));               /* for zalloc, zfree functions */ | ||||||
|  |  | ||||||
| extern int inflate_trees_dynamic __P(( | extern int inflate_trees_dynamic OF(( | ||||||
|     uInt,			/* number of literal/length codes */ |     uInt,                       /* number of literal/length codes */ | ||||||
|     uInt,			/* number of distance codes */ |     uInt,                       /* number of distance codes */ | ||||||
|     uInt *,			/* that many (total) code lengths */ |     uIntf *,                    /* that many (total) code lengths */ | ||||||
|     uInt *,			/* literal desired/actual bit depth */ |     uIntf *,                    /* literal desired/actual bit depth */ | ||||||
|     uInt *,			/* distance desired/actual bit depth */ |     uIntf *,                    /* distance desired/actual bit depth */ | ||||||
|     inflate_huft **,		/* literal/length tree result */ |     inflate_huft * FAR *,       /* literal/length tree result */ | ||||||
|     inflate_huft **,		/* distance tree result */ |     inflate_huft * FAR *,       /* distance tree result */ | ||||||
|     z_stream *));		/* for zalloc, zfree functions */ |     z_stream *));               /* for zalloc, zfree functions */ | ||||||
|  |  | ||||||
| extern int inflate_trees_fixed __P(( | extern int inflate_trees_fixed OF(( | ||||||
|     uInt *,			/* literal desired/actual bit depth */ |     uIntf *,                    /* literal desired/actual bit depth */ | ||||||
|     uInt *,			/* distance desired/actual bit depth */ |     uIntf *,                    /* distance desired/actual bit depth */ | ||||||
|     inflate_huft **,		/* literal/length tree result */ |     inflate_huft * FAR *,       /* literal/length tree result */ | ||||||
|     inflate_huft **));		/* distance tree result */ |     inflate_huft * FAR *));     /* distance tree result */ | ||||||
|  |  | ||||||
|  | extern int inflate_trees_free OF(( | ||||||
|  |     inflate_huft *,             /* tables to free */ | ||||||
|  |     z_stream *));               /* for zfree function */ | ||||||
|  |  | ||||||
| extern int inflate_trees_free __P(( |  | ||||||
|     inflate_huft *,		/* tables to free */ |  | ||||||
|     z_stream *));		/* for zfree function */ |  | ||||||
|   | |||||||
							
								
								
									
										14
									
								
								infutil.c
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								infutil.c
									
									
									
									
									
								
							| @@ -4,7 +4,9 @@ | |||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #include "zutil.h" | #include "zutil.h" | ||||||
|  | #include "infblock.h" | ||||||
| #include "inftrees.h" | #include "inftrees.h" | ||||||
|  | #include "infcodes.h" | ||||||
| #include "infutil.h" | #include "infutil.h" | ||||||
|  |  | ||||||
| struct inflate_codes_state {int dummy;}; /* for buggy compilers */ | struct inflate_codes_state {int dummy;}; /* for buggy compilers */ | ||||||
| @@ -19,12 +21,12 @@ uInt inflate_mask[] = { | |||||||
|  |  | ||||||
| /* copy as much as possible from the sliding window to the output area */ | /* copy as much as possible from the sliding window to the output area */ | ||||||
| int inflate_flush(s, z, r) | int inflate_flush(s, z, r) | ||||||
| struct inflate_blocks_state *s; | inflate_blocks_statef *s; | ||||||
| z_stream *z; | z_stream *z; | ||||||
| int r; | int r; | ||||||
| { | { | ||||||
|   uInt n; |   uInt n; | ||||||
|   Byte *p, *q; |   Bytef *p, *q; | ||||||
|  |  | ||||||
|   /* local copies of source and destination pointers */ |   /* local copies of source and destination pointers */ | ||||||
|   p = z->next_out; |   p = z->next_out; | ||||||
| @@ -44,7 +46,9 @@ int r; | |||||||
|     s->check = (*s->checkfn)(s->check, q, n); |     s->check = (*s->checkfn)(s->check, q, n); | ||||||
|  |  | ||||||
|   /* copy as far as end of window */ |   /* copy as far as end of window */ | ||||||
|   while (n--) *p++ = *q++; |   zmemcpy(p, q, n); | ||||||
|  |   p += n; | ||||||
|  |   q += n; | ||||||
|  |  | ||||||
|   /* see if more to copy at beginning of window */ |   /* see if more to copy at beginning of window */ | ||||||
|   if (q == s->end) |   if (q == s->end) | ||||||
| @@ -68,7 +72,9 @@ int r; | |||||||
|       s->check = (*s->checkfn)(s->check, q, n); |       s->check = (*s->checkfn)(s->check, q, n); | ||||||
|  |  | ||||||
|     /* copy */ |     /* copy */ | ||||||
|     while (n--) *p++ = *q++; |     zmemcpy(p, q, n); | ||||||
|  |     p += n; | ||||||
|  |     q += n; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   /* update pointers */ |   /* update pointers */ | ||||||
|   | |||||||
							
								
								
									
										74
									
								
								infutil.h
									
									
									
									
									
								
							
							
						
						
									
										74
									
								
								infutil.h
									
									
									
									
									
								
							| @@ -13,45 +13,49 @@ struct inflate_blocks_state { | |||||||
|  |  | ||||||
|   /* mode */ |   /* mode */ | ||||||
|   enum { |   enum { | ||||||
|       TYPE,	/* get type bits (3, including end bit) */ |       TYPE,     /* get type bits (3, including end bit) */ | ||||||
|       LENS,	/* get lengths for stored */ |       LENS,     /* get lengths for stored */ | ||||||
|       STORED,	/* processing stored block */ |       STORED,   /* processing stored block */ | ||||||
|       TABLE,	/* get table lengths */ |       TABLE,    /* get table lengths */ | ||||||
|       BTREE,	/* get bit lengths tree for a dynamic block */ |       BTREE,    /* get bit lengths tree for a dynamic block */ | ||||||
|       DTREE,	/* get length, distance trees for a dynamic block */ |       DTREE,    /* get length, distance trees for a dynamic block */ | ||||||
|       CODES,	/* processing fixed or dynamic block */ |       CODES,    /* processing fixed or dynamic block */ | ||||||
|       DRY,	/* output remaining window bytes */ |       DRY,      /* output remaining window bytes */ | ||||||
|       DONE,	/* finished last block, done */ |       DONE,     /* finished last block, done */ | ||||||
|       INF_ERROR}/* got a data error--stuck here */ |       BAD}      /* got a data error--stuck here */ | ||||||
|     mode;		/* current inflate_block mode */ |     mode;               /* current inflate_block mode */ | ||||||
|  |  | ||||||
|   /* mode dependent information */ |   /* mode dependent information */ | ||||||
|   union { |   union { | ||||||
|     uInt left;		/* if STORED, bytes left to copy */ |     uInt left;          /* if STORED, bytes left to copy */ | ||||||
|     struct { |     struct { | ||||||
|       uInt table;		/* table lengths (14 bits) */ |       uInt table;               /* table lengths (14 bits) */ | ||||||
|       uInt index;		/* index into blens (or border) */ |       uInt index;               /* index into blens (or border) */ | ||||||
|       uInt *blens;		/* bit lengths of codes */ |       uIntf *blens;             /* bit lengths of codes */ | ||||||
|       uInt bb;			/* bit length tree depth */ |       uInt bb;                  /* bit length tree depth */ | ||||||
|       inflate_huft *tb;		/* bit length decoding tree */ |       inflate_huft *tb;         /* bit length decoding tree */ | ||||||
|     } trees;		/* if DTREE, decoding info for trees */ |     } trees;            /* if DTREE, decoding info for trees */ | ||||||
|     struct inflate_codes_state |     struct { | ||||||
|       *codes;		/* if CODES, current state */ |       inflate_huft *tl, *td;    /* trees to free */ | ||||||
|   } sub;		/* submode */ |       inflate_codes_statef  | ||||||
|   uInt last;		/* true if this block is the last block */ |          *codes; | ||||||
|  |     } decode;           /* if CODES, current state */ | ||||||
|  |   } sub;                /* submode */ | ||||||
|  |   uInt last;            /* true if this block is the last block */ | ||||||
|  |  | ||||||
|   /* mode independent information */ |   /* mode independent information */ | ||||||
|   uInt bitk;		/* bits in bit buffer */ |   uInt bitk;            /* bits in bit buffer */ | ||||||
|   uLong bitb;		/* bit buffer */ |   uLong bitb;           /* bit buffer */ | ||||||
|   Byte *window;		/* sliding window */ |   Bytef *window;        /* sliding window */ | ||||||
|   Byte *end;		/* one byte after sliding window */ |   Bytef *end;           /* one byte after sliding window */ | ||||||
|   Byte *read;		/* window read pointer */ |   Bytef *read;          /* window read pointer */ | ||||||
|   Byte *write;		/* window write pointer */ |   Bytef *write;         /* window write pointer */ | ||||||
|   check_func checkfn;   /* check function */ |   check_func checkfn;   /* check function */ | ||||||
|   uLong check;		/* check on output */ |   uLong check;          /* check on output */ | ||||||
|  |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| /* defines for inflate input/output */ | /* defines for inflate input/output */ | ||||||
| /*   update pointers and return */ | /*   update pointers and return */ | ||||||
| #define UPDBITS {s->bitb=b;s->bitk=k;} | #define UPDBITS {s->bitb=b;s->bitk=k;} | ||||||
| @@ -63,13 +67,7 @@ struct inflate_blocks_state { | |||||||
| #define LOADIN {p=z->next_in;n=z->avail_in;b=s->bitb;k=s->bitk;} | #define LOADIN {p=z->next_in;n=z->avail_in;b=s->bitb;k=s->bitk;} | ||||||
| #define NEEDBYTE {if(n)r=Z_OK;else LEAVE} | #define NEEDBYTE {if(n)r=Z_OK;else LEAVE} | ||||||
| #define NEXTBYTE (n--,*p++) | #define NEXTBYTE (n--,*p++) | ||||||
| #ifdef __TURBOC__ /* bug in TurboC compiler, bad code for b << 0 */ | #define NEEDBITS(j) {while(k<(j)){NEEDBYTE;b|=((uLong)NEXTBYTE)<<k;k+=8;}} | ||||||
| #  define NEEDBITS(j) {\ |  | ||||||
|   while(k<(j)){NEEDBYTE;b=k?b|(((uLong)NEXTBYTE)<<k):NEXTBYTE;k+=8;}\ |  | ||||||
| } |  | ||||||
| #else |  | ||||||
| #  define NEEDBITS(j) {while(k<(j)){NEEDBYTE;b|=((uLong)NEXTBYTE)<<k;k+=8;}} |  | ||||||
| #endif |  | ||||||
| #define DUMPBITS(j) {b>>=(j);k-=(j);} | #define DUMPBITS(j) {b>>=(j);k-=(j);} | ||||||
| /*   output bytes */ | /*   output bytes */ | ||||||
| #define WAVAIL (q<s->read?s->read-q-1:s->end-q) | #define WAVAIL (q<s->read?s->read-q-1:s->end-q) | ||||||
| @@ -85,8 +83,8 @@ struct inflate_blocks_state { | |||||||
| extern uInt inflate_mask[]; | extern uInt inflate_mask[]; | ||||||
|  |  | ||||||
| /* copy as much as possible from the sliding window to the output area */ | /* copy as much as possible from the sliding window to the output area */ | ||||||
| extern int inflate_flush __P(( | extern int inflate_flush OF(( | ||||||
|     struct inflate_blocks_state *, |     inflate_blocks_statef *, | ||||||
|     z_stream *, |     z_stream *, | ||||||
|     int)); |     int)); | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										124
									
								
								minigzip.c
									
									
									
									
									
								
							
							
						
						
									
										124
									
								
								minigzip.c
									
									
									
									
									
								
							| @@ -13,19 +13,21 @@ | |||||||
|  * or in pipe mode. |  * or in pipe mode. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| /* $Id: minigzip.c,v 1.3 1995/04/29 14:27:21 jloup Exp $ */ | /* $Id: minigzip.c,v 1.5 1995/05/03 17:27:11 jloup Exp $ */ | ||||||
|  |  | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #include "zlib.h" | #include "zlib.h" | ||||||
|  |  | ||||||
| extern void exit  __P((int)); | #ifndef __GO32__ | ||||||
| extern int unlink __P((const char *)); | extern void exit  OF((int)); | ||||||
|  | #endif | ||||||
|  | extern int unlink OF((const char *)); | ||||||
|  |  | ||||||
| #ifdef STDC | #ifdef STDC | ||||||
| #  include <string.h> | #  include <string.h> | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #ifdef MSDOS | #if defined(MSDOS) || defined(OS2) || defined(WIN32) | ||||||
| #  include <fcntl.h> | #  include <fcntl.h> | ||||||
| #  include <io.h> | #  include <io.h> | ||||||
| #  define SET_BINARY_MODE(file) setmode(fileno(file), O_BINARY) | #  define SET_BINARY_MODE(file) setmode(fileno(file), O_BINARY) | ||||||
| @@ -33,6 +35,13 @@ extern int unlink __P((const char *)); | |||||||
| #  define SET_BINARY_MODE(file) | #  define SET_BINARY_MODE(file) | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | #ifdef VMS | ||||||
|  | #  define GZ_SUFFIX "-gz" | ||||||
|  | #else | ||||||
|  | #  define GZ_SUFFIX ".gz" | ||||||
|  | #endif | ||||||
|  | #define SUFFIX_LEN sizeof(GZ_SUFFIX) | ||||||
|  |  | ||||||
| #define BUFLEN 4096 | #define BUFLEN 4096 | ||||||
| #define MAX_NAME_LEN 1024 | #define MAX_NAME_LEN 1024 | ||||||
|  |  | ||||||
| @@ -44,12 +53,12 @@ extern int unlink __P((const char *)); | |||||||
|  |  | ||||||
| char *prog; | char *prog; | ||||||
|  |  | ||||||
| void error           __P((char *msg)); | void error           OF((char *msg)); | ||||||
| void gz_compress     __P((FILE   *in, gzFile out)); | void gz_compress     OF((FILE   *in, gzFile out)); | ||||||
| void gz_uncompress   __P((gzFile in, FILE   *out)); | void gz_uncompress   OF((gzFile in, FILE   *out)); | ||||||
| void file_compress   __P((char  *file)); | void file_compress   OF((char  *file)); | ||||||
| void file_uncompress __P((char  *file)); | void file_uncompress OF((char  *file)); | ||||||
| void main            __P((int argc, char *argv[])); | int  main            OF((int argc, char *argv[])); | ||||||
|  |  | ||||||
| /* =========================================================================== | /* =========================================================================== | ||||||
|  * Display error message and exit |  * Display error message and exit | ||||||
| @@ -73,14 +82,14 @@ void gz_compress(in, out) | |||||||
|     int err; |     int err; | ||||||
|  |  | ||||||
|     for (;;) { |     for (;;) { | ||||||
| 	len = fread(buf, 1, sizeof(buf), in); |         len = fread(buf, 1, sizeof(buf), in); | ||||||
| 	if (ferror(in)) { |         if (ferror(in)) { | ||||||
| 	    perror("fread"); |             perror("fread"); | ||||||
| 	    exit(1); |             exit(1); | ||||||
| 	} |         } | ||||||
| 	if (len == 0) break; |         if (len == 0) break; | ||||||
|  |  | ||||||
| 	if (gzwrite(out, buf, len) != len) error(gzerror(out, &err)); |         if (gzwrite(out, buf, len) != len) error(gzerror(out, &err)); | ||||||
|     } |     } | ||||||
|     fclose(in); |     fclose(in); | ||||||
|     if (gzclose(out) != Z_OK) error("failed gzclose"); |     if (gzclose(out) != Z_OK) error("failed gzclose"); | ||||||
| @@ -98,11 +107,11 @@ void gz_uncompress(in, out) | |||||||
|     int err; |     int err; | ||||||
|  |  | ||||||
|     for (;;) { |     for (;;) { | ||||||
| 	len = gzread(in, buf, sizeof(buf)); |         len = gzread(in, buf, sizeof(buf)); | ||||||
| 	if (len < 0) error (gzerror(in, &err)); |         if (len < 0) error (gzerror(in, &err)); | ||||||
| 	if (len == 0) break; |         if (len == 0) break; | ||||||
|  |  | ||||||
| 	if (fwrite(buf, 1, len, out) != (uInt)len) error("failed fwrite"); |         if (fwrite(buf, 1, len, out) != (uInt)len) error("failed fwrite"); | ||||||
|     } |     } | ||||||
|     if (fclose(out)) error("failed fclose"); |     if (fclose(out)) error("failed fclose"); | ||||||
|  |  | ||||||
| @@ -122,17 +131,17 @@ void file_compress(file) | |||||||
|     gzFile out; |     gzFile out; | ||||||
|  |  | ||||||
|     strcpy(outfile, file); |     strcpy(outfile, file); | ||||||
|     strcat(outfile, ".gz"); |     strcat(outfile, GZ_SUFFIX); | ||||||
|  |  | ||||||
|     in = fopen(file, "rb"); |     in = fopen(file, "rb"); | ||||||
|     if (in == NULL) { |     if (in == NULL) { | ||||||
| 	perror(file); |         perror(file); | ||||||
| 	exit(1); |         exit(1); | ||||||
|     } |     } | ||||||
|     out = gzopen(outfile, "wb"); |     out = gzopen(outfile, "wb"); /* use "wb9" for maximal compression */ | ||||||
|     if (out == NULL) { |     if (out == NULL) { | ||||||
| 	fprintf(stderr, "%s: can't gzopen %s\n", prog, outfile); |         fprintf(stderr, "%s: can't gzopen %s\n", prog, outfile); | ||||||
| 	exit(1); |         exit(1); | ||||||
|     } |     } | ||||||
|     gz_compress(in, out); |     gz_compress(in, out); | ||||||
|  |  | ||||||
| @@ -154,24 +163,24 @@ void file_uncompress(file) | |||||||
|  |  | ||||||
|     strcpy(buf, file); |     strcpy(buf, file); | ||||||
|  |  | ||||||
|     if (len > 3 && strcmp(file+len-3, ".gz") == 0) { |     if (len > SUFFIX_LEN && strcmp(file+len-SUFFIX_LEN, GZ_SUFFIX) == 0) { | ||||||
| 	infile = file; |         infile = file; | ||||||
| 	outfile = buf; |         outfile = buf; | ||||||
| 	outfile[len-3] = '\0'; |         outfile[len-3] = '\0'; | ||||||
|     } else { |     } else { | ||||||
| 	outfile = file; |         outfile = file; | ||||||
| 	infile = buf; |         infile = buf; | ||||||
| 	strcat(infile, ".gz"); |         strcat(infile, GZ_SUFFIX); | ||||||
|     } |     } | ||||||
|     in = gzopen(infile, "rb"); |     in = gzopen(infile, "rb"); | ||||||
|     if (in == NULL) { |     if (in == NULL) { | ||||||
| 	fprintf(stderr, "%s: can't gzopen %s\n", prog, infile); |         fprintf(stderr, "%s: can't gzopen %s\n", prog, infile); | ||||||
| 	exit(1); |         exit(1); | ||||||
|     } |     } | ||||||
|     out = fopen(outfile, "wb"); |     out = fopen(outfile, "wb"); | ||||||
|     if (out == NULL) { |     if (out == NULL) { | ||||||
| 	perror(file); |         perror(file); | ||||||
| 	exit(1); |         exit(1); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     gz_uncompress(in, out); |     gz_uncompress(in, out); | ||||||
| @@ -184,7 +193,7 @@ void file_uncompress(file) | |||||||
|  * Usage:  minigzip [-d] [files...] |  * Usage:  minigzip [-d] [files...] | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| void main(argc, argv) | int main(argc, argv) | ||||||
|     int argc; |     int argc; | ||||||
|     char *argv[]; |     char *argv[]; | ||||||
| { | { | ||||||
| @@ -195,31 +204,32 @@ void main(argc, argv) | |||||||
|     argc--, argv++; |     argc--, argv++; | ||||||
|  |  | ||||||
|     if (argc > 0) { |     if (argc > 0) { | ||||||
| 	uncompr = (strcmp(*argv, "-d") == 0); |         uncompr = (strcmp(*argv, "-d") == 0); | ||||||
| 	if (uncompr) { |         if (uncompr) { | ||||||
| 	    argc--, argv++; |             argc--, argv++; | ||||||
| 	} |         } | ||||||
|     } |     } | ||||||
|     if (argc == 0) { |     if (argc == 0) { | ||||||
|         SET_BINARY_MODE(stdin); |         SET_BINARY_MODE(stdin); | ||||||
|         SET_BINARY_MODE(stdout); |         SET_BINARY_MODE(stdout); | ||||||
| 	if (uncompr) { |         if (uncompr) { | ||||||
| 	    file = gzdopen(fileno(stdin), "rb"); |             file = gzdopen(fileno(stdin), "rb"); | ||||||
|             if (file == NULL) error("can't gzdopen stdin"); |             if (file == NULL) error("can't gzdopen stdin"); | ||||||
| 	    gz_uncompress(file, stdout); |             gz_uncompress(file, stdout); | ||||||
| 	} else { |         } else { | ||||||
| 	    file = gzdopen(fileno(stdout), "wb"); |             file = gzdopen(fileno(stdout), "wb"); /* "wb9" for max compr. */ | ||||||
|             if (file == NULL) error("can't gzdopen stdout"); |             if (file == NULL) error("can't gzdopen stdout"); | ||||||
| 	    gz_compress(stdin, file); |             gz_compress(stdin, file); | ||||||
| 	} |         } | ||||||
|     } else { |     } else { | ||||||
| 	do { |         do { | ||||||
| 	    if (uncompr) { |             if (uncompr) { | ||||||
| 		file_uncompress(*argv); |                 file_uncompress(*argv); | ||||||
| 	    } else { |             } else { | ||||||
| 		file_compress(*argv); |                 file_compress(*argv); | ||||||
| 	    } |             } | ||||||
| 	} while (argv++, --argc); |         } while (argv++, --argc); | ||||||
|     } |     } | ||||||
|     exit(0); |     exit(0); | ||||||
|  |     return 0; /* to avoid warning */ | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										143
									
								
								trees.c
									
									
									
									
									
								
							
							
						
						
									
										143
									
								
								trees.c
									
									
									
									
									
								
							| @@ -29,7 +29,7 @@ | |||||||
|  *          Addison-Wesley, 1983. ISBN 0-201-06672-6. |  *          Addison-Wesley, 1983. ISBN 0-201-06672-6. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| /* $Id: trees.c,v 1.3 1995/04/29 13:49:46 jloup Exp $ */ | /* $Id: trees.c,v 1.5 1995/05/03 17:27:12 jloup Exp $ */ | ||||||
|  |  | ||||||
| #include "deflate.h" | #include "deflate.h" | ||||||
|  |  | ||||||
| @@ -110,7 +110,7 @@ local int base_dist[D_CODES]; | |||||||
|  |  | ||||||
| struct static_tree_desc_s { | struct static_tree_desc_s { | ||||||
|     ct_data *static_tree;        /* static tree or NULL */ |     ct_data *static_tree;        /* static tree or NULL */ | ||||||
|     int     *extra_bits;         /* extra bits for each code or NULL */ |     intf    *extra_bits;         /* extra bits for each code or NULL */ | ||||||
|     int     extra_base;          /* base index for extra_bits */ |     int     extra_base;          /* base index for extra_bits */ | ||||||
|     int     elems;               /* max number of elements in the tree */ |     int     elems;               /* max number of elements in the tree */ | ||||||
|     int     max_length;          /* max bit length for the codes */ |     int     max_length;          /* max bit length for the codes */ | ||||||
| @@ -129,25 +129,25 @@ local static_tree_desc  static_bl_desc = | |||||||
|  * Local (static) routines in this file. |  * Local (static) routines in this file. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| local void ct_static_init __P((void)); | local void ct_static_init OF((void)); | ||||||
| local void init_block     __P((deflate_state *s)); | local void init_block     OF((deflate_state *s)); | ||||||
| local void pqdownheap     __P((deflate_state *s, ct_data *tree, int k)); | local void pqdownheap     OF((deflate_state *s, ct_data *tree, int k)); | ||||||
| local void gen_bitlen     __P((deflate_state *s, tree_desc *desc)); | local void gen_bitlen     OF((deflate_state *s, tree_desc *desc)); | ||||||
| local void gen_codes      __P((ct_data *tree, int max_code, ush bl_count[])); | local void gen_codes      OF((ct_data *tree, int max_code, ushf *bl_count)); | ||||||
| local void build_tree     __P((deflate_state *s, tree_desc *desc)); | local void build_tree     OF((deflate_state *s, tree_desc *desc)); | ||||||
| local void scan_tree      __P((deflate_state *s, ct_data *tree, int max_code)); | local void scan_tree      OF((deflate_state *s, ct_data *tree, int max_code)); | ||||||
| local void send_tree      __P((deflate_state *s, ct_data *tree, int max_code)); | local void send_tree      OF((deflate_state *s, ct_data *tree, int max_code)); | ||||||
| local int  build_bl_tree  __P((deflate_state *s)); | local int  build_bl_tree  OF((deflate_state *s)); | ||||||
| local void send_all_trees __P((deflate_state *s, int lcodes, int dcodes, | local void send_all_trees OF((deflate_state *s, int lcodes, int dcodes, | ||||||
| 			      int blcodes)); |                               int blcodes)); | ||||||
| local void compress_block __P((deflate_state *s, ct_data *ltree, | local void compress_block OF((deflate_state *s, ct_data *ltree, | ||||||
| 			      ct_data *dtree)); |                               ct_data *dtree)); | ||||||
| local void set_data_type  __P((deflate_state *s)); | local void set_data_type  OF((deflate_state *s)); | ||||||
| local void send_bits      __P((deflate_state *s, int value, int length)); | local void send_bits      OF((deflate_state *s, int value, int length)); | ||||||
| local unsigned bi_reverse __P((unsigned value, int length)); | local unsigned bi_reverse OF((unsigned value, int length)); | ||||||
| local void bi_windup      __P((deflate_state *s)); | local void bi_windup      OF((deflate_state *s)); | ||||||
| local void copy_block     __P((deflate_state *s, char *buf, unsigned len, | local void copy_block     OF((deflate_state *s, charf *buf, unsigned len, | ||||||
| 			       int header)); |                               int header)); | ||||||
|  |  | ||||||
| #ifndef DEBUG | #ifndef DEBUG | ||||||
| #  define send_code(s, c, tree) send_bits(s, tree[c].Code, tree[c].Len) | #  define send_code(s, c, tree) send_bits(s, tree[c].Code, tree[c].Len) | ||||||
| @@ -243,7 +243,7 @@ void ct_init(s) | |||||||
|     deflate_state *s; |     deflate_state *s; | ||||||
| { | { | ||||||
|     if (static_dtree[0].Len == 0) { |     if (static_dtree[0].Len == 0) { | ||||||
| 	ct_static_init();              /* To do: at compile time */ |         ct_static_init();              /* To do: at compile time */ | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     s->compressed_len = 0L; |     s->compressed_len = 0L; | ||||||
| @@ -324,9 +324,9 @@ local void pqdownheap(s, tree, k) | |||||||
|     while (j <= s->heap_len) { |     while (j <= s->heap_len) { | ||||||
|         /* Set j to the smallest of the two sons: */ |         /* Set j to the smallest of the two sons: */ | ||||||
|         if (j < s->heap_len && |         if (j < s->heap_len && | ||||||
| 	    smaller(tree, s->heap[j+1], s->heap[j], s->depth)) { |             smaller(tree, s->heap[j+1], s->heap[j], s->depth)) { | ||||||
| 	    j++; |             j++; | ||||||
| 	} |         } | ||||||
|         /* Exit if v is smaller than both sons */ |         /* Exit if v is smaller than both sons */ | ||||||
|         if (smaller(tree, v, s->heap[j], s->depth)) break; |         if (smaller(tree, v, s->heap[j], s->depth)) break; | ||||||
|  |  | ||||||
| @@ -356,7 +356,7 @@ local void gen_bitlen(s, desc) | |||||||
|     ct_data *tree  = desc->dyn_tree; |     ct_data *tree  = desc->dyn_tree; | ||||||
|     int max_code   = desc->max_code; |     int max_code   = desc->max_code; | ||||||
|     ct_data *stree = desc->stat_desc->static_tree; |     ct_data *stree = desc->stat_desc->static_tree; | ||||||
|     int *extra     = desc->stat_desc->extra_bits; |     intf *extra    = desc->stat_desc->extra_bits; | ||||||
|     int base       = desc->stat_desc->extra_base; |     int base       = desc->stat_desc->extra_base; | ||||||
|     int max_length = desc->stat_desc->max_length; |     int max_length = desc->stat_desc->max_length; | ||||||
|     int h;              /* heap index */ |     int h;              /* heap index */ | ||||||
| @@ -420,7 +420,7 @@ local void gen_bitlen(s, desc) | |||||||
|             if (tree[m].Len != (unsigned) bits) { |             if (tree[m].Len != (unsigned) bits) { | ||||||
|                 Trace((stderr,"code %d bits %d->%d\n", m, tree[m].Len, bits)); |                 Trace((stderr,"code %d bits %d->%d\n", m, tree[m].Len, bits)); | ||||||
|                 s->opt_len += ((long)bits - (long)tree[m].Len) |                 s->opt_len += ((long)bits - (long)tree[m].Len) | ||||||
| 		              *(long)tree[m].Freq; |                               *(long)tree[m].Freq; | ||||||
|                 tree[m].Len = (ush)bits; |                 tree[m].Len = (ush)bits; | ||||||
|             } |             } | ||||||
|             n--; |             n--; | ||||||
| @@ -439,7 +439,7 @@ local void gen_bitlen(s, desc) | |||||||
| local void gen_codes (tree, max_code, bl_count) | local void gen_codes (tree, max_code, bl_count) | ||||||
|     ct_data *tree;             /* the tree to decorate */ |     ct_data *tree;             /* the tree to decorate */ | ||||||
|     int max_code;              /* largest code with non zero frequency */ |     int max_code;              /* largest code with non zero frequency */ | ||||||
|     ush bl_count[];            /* number of codes at each bit length */ |     ushf *bl_count;            /* number of codes at each bit length */ | ||||||
| { | { | ||||||
|     ush next_code[MAX_BITS+1]; /* next code value for each bit length */ |     ush next_code[MAX_BITS+1]; /* next code value for each bit length */ | ||||||
|     ush code = 0;              /* running code value */ |     ush code = 0;              /* running code value */ | ||||||
| @@ -487,8 +487,7 @@ local void build_tree(s, desc) | |||||||
|     int elems       = desc->stat_desc->elems; |     int elems       = desc->stat_desc->elems; | ||||||
|     int n, m;          /* iterate over heap elements */ |     int n, m;          /* iterate over heap elements */ | ||||||
|     int max_code = -1; /* largest code with non zero frequency */ |     int max_code = -1; /* largest code with non zero frequency */ | ||||||
|     int node = elems;  /* next internal node of the tree */ |     int node;          /* new node being created */ | ||||||
|     int new;           /* new node being created */ |  | ||||||
|  |  | ||||||
|     /* Construct the initial heap, with least frequent element in |     /* Construct the initial heap, with least frequent element in | ||||||
|      * heap[SMALLEST]. The sons of heap[n] are heap[2*n] and heap[2*n+1]. |      * heap[SMALLEST]. The sons of heap[n] are heap[2*n] and heap[2*n+1]. | ||||||
| @@ -511,11 +510,11 @@ local void build_tree(s, desc) | |||||||
|      * two codes of non zero frequency. |      * two codes of non zero frequency. | ||||||
|      */ |      */ | ||||||
|     while (s->heap_len < 2) { |     while (s->heap_len < 2) { | ||||||
|         new = s->heap[++(s->heap_len)] = (max_code < 2 ? ++max_code : 0); |         node = s->heap[++(s->heap_len)] = (max_code < 2 ? ++max_code : 0); | ||||||
|         tree[new].Freq = 1; |         tree[node].Freq = 1; | ||||||
|         s->depth[new] = 0; |         s->depth[node] = 0; | ||||||
|         s->opt_len--; if (stree) s->static_len -= stree[new].Len; |         s->opt_len--; if (stree) s->static_len -= stree[node].Len; | ||||||
|         /* new is 0 or 1 so it does not have extra bits */ |         /* node is 0 or 1 so it does not have extra bits */ | ||||||
|     } |     } | ||||||
|     desc->max_code = max_code; |     desc->max_code = max_code; | ||||||
|  |  | ||||||
| @@ -527,6 +526,7 @@ local void build_tree(s, desc) | |||||||
|     /* Construct the Huffman tree by repeatedly combining the least two |     /* Construct the Huffman tree by repeatedly combining the least two | ||||||
|      * frequent nodes. |      * frequent nodes. | ||||||
|      */ |      */ | ||||||
|  |     node = elems;              /* next internal node of the tree */ | ||||||
|     do { |     do { | ||||||
|         pqremove(s, tree, n);  /* n = node of least frequency */ |         pqremove(s, tree, n);  /* n = node of least frequency */ | ||||||
|         m = s->heap[SMALLEST]; /* m = node of next least frequency */ |         m = s->heap[SMALLEST]; /* m = node of next least frequency */ | ||||||
| @@ -686,7 +686,7 @@ local int build_bl_tree(s) | |||||||
|     /* Update opt_len to include the bit length tree and counts */ |     /* Update opt_len to include the bit length tree and counts */ | ||||||
|     s->opt_len += 3*(max_blindex+1) + 5+5+4; |     s->opt_len += 3*(max_blindex+1) + 5+5+4; | ||||||
|     Tracev((stderr, "\ndyn trees: dyn %ld, stat %ld", |     Tracev((stderr, "\ndyn trees: dyn %ld, stat %ld", | ||||||
| 	    s->opt_len, s->static_len)); |             s->opt_len, s->static_len)); | ||||||
|  |  | ||||||
|     return max_blindex; |     return max_blindex; | ||||||
| } | } | ||||||
| @@ -722,6 +722,33 @@ local void send_all_trees(s, lcodes, dcodes, blcodes) | |||||||
|     Tracev((stderr, "\ndist tree: sent %ld", s->bits_sent)); |     Tracev((stderr, "\ndist tree: sent %ld", s->bits_sent)); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | /* =========================================================================== | ||||||
|  |  * Send a stored block | ||||||
|  |  */ | ||||||
|  | void ct_stored_block(s, buf, stored_len, eof) | ||||||
|  |     deflate_state *s; | ||||||
|  |     charf *buf;       /* input block */ | ||||||
|  |     ulg stored_len;   /* length of input block */ | ||||||
|  |     int eof;          /* true if this is the last block for a file */ | ||||||
|  | { | ||||||
|  |     send_bits(s, (STORED_BLOCK<<1)+eof, 3);  /* send block type */ | ||||||
|  |     s->compressed_len = (s->compressed_len + 3 + 7) & ~7L; | ||||||
|  |     s->compressed_len += (stored_len + 4) << 3; | ||||||
|  |  | ||||||
|  |     copy_block(s, buf, (unsigned)stored_len, 1); /* with header */ | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /* =========================================================================== | ||||||
|  |  * Send one empty static block to give enough lookahead for inflate | ||||||
|  |  */ | ||||||
|  | void ct_align(s) | ||||||
|  |     deflate_state *s; | ||||||
|  | { | ||||||
|  |     send_bits(s, STATIC_TREES<<1, 3); | ||||||
|  |     send_code(s, END_BLOCK, static_ltree); | ||||||
|  |     s->compressed_len += 10L; /* 3 for block type, 7 for EOB */ | ||||||
|  | } | ||||||
|  |  | ||||||
| /* =========================================================================== | /* =========================================================================== | ||||||
|  * Determine the best encoding for the current block: dynamic trees, static |  * Determine the best encoding for the current block: dynamic trees, static | ||||||
|  * trees or store, and output the encoded block to the zip file. This function |  * trees or store, and output the encoded block to the zip file. This function | ||||||
| @@ -729,7 +756,7 @@ local void send_all_trees(s, lcodes, dcodes, blcodes) | |||||||
|  */ |  */ | ||||||
| ulg ct_flush_block(s, buf, stored_len, eof) | ulg ct_flush_block(s, buf, stored_len, eof) | ||||||
|     deflate_state *s; |     deflate_state *s; | ||||||
|     char *buf;        /* input block, or NULL if too old */ |     charf *buf;       /* input block, or NULL if too old */ | ||||||
|     ulg stored_len;   /* length of input block */ |     ulg stored_len;   /* length of input block */ | ||||||
|     int eof;          /* true if this is the last block for a file */ |     int eof;          /* true if this is the last block for a file */ | ||||||
| { | { | ||||||
| @@ -742,11 +769,11 @@ ulg ct_flush_block(s, buf, stored_len, eof) | |||||||
|     /* Construct the literal and distance trees */ |     /* Construct the literal and distance trees */ | ||||||
|     build_tree(s, (tree_desc *)(&(s->l_desc))); |     build_tree(s, (tree_desc *)(&(s->l_desc))); | ||||||
|     Tracev((stderr, "\nlit data: dyn %ld, stat %ld", s->opt_len, |     Tracev((stderr, "\nlit data: dyn %ld, stat %ld", s->opt_len, | ||||||
| 	    s->static_len)); |             s->static_len)); | ||||||
|  |  | ||||||
|     build_tree(s, (tree_desc *)(&(s->d_desc))); |     build_tree(s, (tree_desc *)(&(s->d_desc))); | ||||||
|     Tracev((stderr, "\ndist data: dyn %ld, stat %ld", s->opt_len, |     Tracev((stderr, "\ndist data: dyn %ld, stat %ld", s->opt_len, | ||||||
| 	    s->static_len)); |             s->static_len)); | ||||||
|     /* At this point, opt_len and static_len are the total bit lengths of |     /* At this point, opt_len and static_len are the total bit lengths of | ||||||
|      * the compressed block data, excluding the tree representations. |      * the compressed block data, excluding the tree representations. | ||||||
|      */ |      */ | ||||||
| @@ -771,13 +798,13 @@ ulg ct_flush_block(s, buf, stored_len, eof) | |||||||
|      * the whole file is transformed into a stored file: |      * the whole file is transformed into a stored file: | ||||||
|      */ |      */ | ||||||
| #ifdef STORED_FILE_OK | #ifdef STORED_FILE_OK | ||||||
| #  ifdef FORCE_METHOD | #  ifdef FORCE_STORED_FILE | ||||||
|     if (level == 1 && eof && compressed_len == 0L) { /* force stored file */ |     if (eof && compressed_len == 0L) { /* force stored file */ | ||||||
| #  else | #  else | ||||||
|     if (stored_len <= opt_lenb && eof && s->compressed_len==0L && seekable()) { |     if (stored_len <= opt_lenb && eof && s->compressed_len==0L && seekable()) { | ||||||
| #  endif | #  endif | ||||||
|         /* Since LIT_BUFSIZE <= 2*WSIZE, the input data must be there: */ |         /* Since LIT_BUFSIZE <= 2*WSIZE, the input data must be there: */ | ||||||
|         if (buf == (char*)0) error ("block vanished"); |         if (buf == (charf*)0) error ("block vanished"); | ||||||
|  |  | ||||||
|         copy_block(buf, (unsigned)stored_len, 0); /* without header */ |         copy_block(buf, (unsigned)stored_len, 0); /* without header */ | ||||||
|         s->compressed_len = stored_len << 3; |         s->compressed_len = stored_len << 3; | ||||||
| @@ -785,8 +812,8 @@ ulg ct_flush_block(s, buf, stored_len, eof) | |||||||
|     } else |     } else | ||||||
| #endif /* STORED_FILE_OK */ | #endif /* STORED_FILE_OK */ | ||||||
|  |  | ||||||
| #ifdef FORCE_METHOD | #ifdef FORCE_STORED | ||||||
|     if (level == 2 && buf != (char*)0) { /* force stored block */ |     if (buf != (char*)0) { /* force stored block */ | ||||||
| #else | #else | ||||||
|     if (stored_len+4 <= opt_lenb && buf != (char*)0) { |     if (stored_len+4 <= opt_lenb && buf != (char*)0) { | ||||||
|                        /* 4: two words for the lengths */ |                        /* 4: two words for the lengths */ | ||||||
| @@ -797,14 +824,10 @@ ulg ct_flush_block(s, buf, stored_len, eof) | |||||||
|          * successful. If LIT_BUFSIZE <= WSIZE, it is never too late to |          * successful. If LIT_BUFSIZE <= WSIZE, it is never too late to | ||||||
|          * transform a block into a stored block. |          * transform a block into a stored block. | ||||||
|          */ |          */ | ||||||
|         send_bits(s, (STORED_BLOCK<<1)+eof, 3);  /* send block type */ |         ct_stored_block(s, buf, stored_len, eof); | ||||||
|         s->compressed_len = (s->compressed_len + 3 + 7) & ~7L; |  | ||||||
|         s->compressed_len += (stored_len + 4) << 3; |  | ||||||
|  |  | ||||||
|         copy_block(s, buf, (unsigned)stored_len, 1); /* with header */ | #ifdef FORCE_STATIC | ||||||
|  |     } else if (static_lenb >= 0) { /* force static trees */ | ||||||
| #ifdef FORCE_METHOD |  | ||||||
|     } else if (level == 3) { /* force static trees */ |  | ||||||
| #else | #else | ||||||
|     } else if (static_lenb == opt_lenb) { |     } else if (static_lenb == opt_lenb) { | ||||||
| #endif | #endif | ||||||
| @@ -814,7 +837,7 @@ ulg ct_flush_block(s, buf, stored_len, eof) | |||||||
|     } else { |     } else { | ||||||
|         send_bits(s, (DYN_TREES<<1)+eof, 3); |         send_bits(s, (DYN_TREES<<1)+eof, 3); | ||||||
|         send_all_trees(s, s->l_desc.max_code+1, s->d_desc.max_code+1, |         send_all_trees(s, s->l_desc.max_code+1, s->d_desc.max_code+1, | ||||||
| 		       max_blindex+1); |                        max_blindex+1); | ||||||
|         compress_block(s, (ct_data *)s->dyn_ltree, (ct_data *)s->dyn_dtree); |         compress_block(s, (ct_data *)s->dyn_ltree, (ct_data *)s->dyn_dtree); | ||||||
|         s->compressed_len += 3 + s->opt_len; |         s->compressed_len += 3 + s->opt_len; | ||||||
|     } |     } | ||||||
| @@ -846,7 +869,7 @@ int ct_tally (s, dist, lc) | |||||||
|         /* lc is the unmatched char */ |         /* lc is the unmatched char */ | ||||||
|         s->dyn_ltree[lc].Freq++; |         s->dyn_ltree[lc].Freq++; | ||||||
|     } else { |     } else { | ||||||
| 	s->matches++; |         s->matches++; | ||||||
|         /* Here, lc is the match length - MIN_MATCH */ |         /* Here, lc is the match length - MIN_MATCH */ | ||||||
|         dist--;             /* dist = match distance - 1 */ |         dist--;             /* dist = match distance - 1 */ | ||||||
|         Assert((ush)dist < (ush)MAX_DIST(s) && |         Assert((ush)dist < (ush)MAX_DIST(s) && | ||||||
| @@ -865,7 +888,7 @@ int ct_tally (s, dist, lc) | |||||||
|         int dcode; |         int dcode; | ||||||
|         for (dcode = 0; dcode < D_CODES; dcode++) { |         for (dcode = 0; dcode < D_CODES; dcode++) { | ||||||
|             out_length += (ulg)s->dyn_dtree[dcode].Freq * |             out_length += (ulg)s->dyn_dtree[dcode].Freq * | ||||||
| 		(5L+extra_dbits[dcode]); |                 (5L+extra_dbits[dcode]); | ||||||
|         } |         } | ||||||
|         out_length >>= 3; |         out_length >>= 3; | ||||||
|         Tracev((stderr,"\nlast_lit %u, in %ld, out ~%ld(%ld%%) ", |         Tracev((stderr,"\nlast_lit %u, in %ld, out ~%ld(%ld%%) ", | ||||||
| @@ -895,7 +918,7 @@ local void compress_block(s, ltree, dtree) | |||||||
|     int extra;          /* number of extra bits to send */ |     int extra;          /* number of extra bits to send */ | ||||||
|  |  | ||||||
|     if (s->last_lit != 0) do { |     if (s->last_lit != 0) do { | ||||||
| 	dist = s->d_buf[lx]; |         dist = s->d_buf[lx]; | ||||||
|         lc = s->l_buf[lx++]; |         lc = s->l_buf[lx++]; | ||||||
|         if (dist == 0) { |         if (dist == 0) { | ||||||
|             send_code(s, lc, ltree); /* send a literal byte */ |             send_code(s, lc, ltree); /* send a literal byte */ | ||||||
| @@ -909,7 +932,7 @@ local void compress_block(s, ltree, dtree) | |||||||
|                 lc -= base_length[code]; |                 lc -= base_length[code]; | ||||||
|                 send_bits(s, lc, extra);       /* send the extra length bits */ |                 send_bits(s, lc, extra);       /* send the extra length bits */ | ||||||
|             } |             } | ||||||
| 	    dist--; /* dist is now the match distance - 1 */ |             dist--; /* dist is now the match distance - 1 */ | ||||||
|             code = d_code(dist); |             code = d_code(dist); | ||||||
|             Assert (code < D_CODES, "bad d_code"); |             Assert (code < D_CODES, "bad d_code"); | ||||||
|  |  | ||||||
| @@ -921,8 +944,8 @@ local void compress_block(s, ltree, dtree) | |||||||
|             } |             } | ||||||
|         } /* literal or match pair ? */ |         } /* literal or match pair ? */ | ||||||
|  |  | ||||||
| 	/* Check that the overlay between pending_buf and d_buf+l_buf is ok: */ |         /* Check that the overlay between pending_buf and d_buf+l_buf is ok: */ | ||||||
| 	Assert(s->pending < s->lit_bufsize + 2*lx, "pendingBuf overflow"); |         Assert(s->pending < s->lit_bufsize + 2*lx, "pendingBuf overflow"); | ||||||
|  |  | ||||||
|     } while (lx < s->last_lit); |     } while (lx < s->last_lit); | ||||||
|  |  | ||||||
| @@ -1026,7 +1049,7 @@ local void bi_windup(s) | |||||||
|  */ |  */ | ||||||
| local void copy_block(s, buf, len, header) | local void copy_block(s, buf, len, header) | ||||||
|     deflate_state *s; |     deflate_state *s; | ||||||
|     char     *buf;    /* the input data */ |     charf    *buf;    /* the input data */ | ||||||
|     unsigned len;     /* its length */ |     unsigned len;     /* its length */ | ||||||
|     int      header;  /* true if block header must be written */ |     int      header;  /* true if block header must be written */ | ||||||
| { | { | ||||||
| @@ -1043,6 +1066,6 @@ local void copy_block(s, buf, len, header) | |||||||
|     s->bits_sent += (ulg)len<<3; |     s->bits_sent += (ulg)len<<3; | ||||||
| #endif | #endif | ||||||
|     while (len--) { |     while (len--) { | ||||||
| 	put_byte(s, *buf++); |         put_byte(s, *buf++); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										12
									
								
								uncompr.c
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								uncompr.c
									
									
									
									
									
								
							| @@ -3,7 +3,7 @@ | |||||||
|  * For conditions of distribution and use, see copyright notice in zlib.h  |  * For conditions of distribution and use, see copyright notice in zlib.h  | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| /* $Id: uncompr.c,v 1.4 1995/04/10 16:22:22 jloup Exp $ */ | /* $Id: uncompr.c,v 1.5 1995/05/03 17:27:12 jloup Exp $ */ | ||||||
|  |  | ||||||
| #include "zlib.h" | #include "zlib.h" | ||||||
|  |  | ||||||
| @@ -23,9 +23,9 @@ | |||||||
|    buffer, or Z_DATA_ERROR if the input data was corrupted. |    buffer, or Z_DATA_ERROR if the input data was corrupted. | ||||||
| */ | */ | ||||||
| int uncompress (dest, destLen, source, sourceLen) | int uncompress (dest, destLen, source, sourceLen) | ||||||
|     Byte *dest; |     Bytef *dest; | ||||||
|     uLong *destLen; |     uLongf *destLen; | ||||||
|     Byte *source; |     Bytef *source; | ||||||
|     uLong sourceLen; |     uLong sourceLen; | ||||||
| { | { | ||||||
|     z_stream stream; |     z_stream stream; | ||||||
| @@ -48,8 +48,8 @@ int uncompress (dest, destLen, source, sourceLen) | |||||||
|  |  | ||||||
|     err = inflate(&stream, Z_FINISH); |     err = inflate(&stream, Z_FINISH); | ||||||
|     if (err != Z_STREAM_END) { |     if (err != Z_STREAM_END) { | ||||||
| 	inflateEnd(&stream); |         inflateEnd(&stream); | ||||||
| 	return err; |         return err; | ||||||
|     } |     } | ||||||
|     *destLen = stream.total_out; |     *destLen = stream.total_out; | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										112
									
								
								zconf.h
									
									
									
									
									
								
							
							
						
						
									
										112
									
								
								zconf.h
									
									
									
									
									
								
							| @@ -3,7 +3,7 @@ | |||||||
|  * For conditions of distribution and use, see copyright notice in zlib.h  |  * For conditions of distribution and use, see copyright notice in zlib.h  | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| /* $Id: zconf.h,v 1.9 1995/04/29 12:02:14 jloup Exp $ */ | /* $Id: zconf.h,v 1.12 1995/05/03 17:27:12 jloup Exp $ */ | ||||||
|  |  | ||||||
| #ifndef _ZCONF_H | #ifndef _ZCONF_H | ||||||
| #define _ZCONF_H | #define _ZCONF_H | ||||||
| @@ -28,41 +28,93 @@ | |||||||
| #if defined(MSDOS) && !defined(__32BIT__) | #if defined(MSDOS) && !defined(__32BIT__) | ||||||
| #  define MAXSEG_64K | #  define MAXSEG_64K | ||||||
| #endif | #endif | ||||||
| #if !defined(STDC) && (defined(MSDOS) || defined(__STDC__)) | #ifdef MSDOS | ||||||
| #  define STDC | #  define UNALIGNED_OK | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #ifdef MAXSEG_64K | #ifndef STDC | ||||||
| #  define MAX_MEM_LEVEL 8 | #  if defined(MSDOS) || defined(__STDC__) || defined(__cplusplus) | ||||||
|  | #    define STDC | ||||||
|  | #  endif | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #ifndef STDC | ||||||
|  | #  ifndef const | ||||||
|  | #    define const | ||||||
|  | #  endif | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #ifdef	__MWERKS__ /* Metrowerks CodeWarrior declares fileno() in unix.h */ | ||||||
|  | #  include <unix.h> | ||||||
|  | #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 | ||||||
|  |  | ||||||
|  | #if defined(M_I86SM) || defined(M_I86MM) /* model independent MSC functions */ | ||||||
|  | #   define zstrcpy _fstrcpy | ||||||
|  | #   define zstrcat _fstrcat | ||||||
|  | #   define zstrlen _fstrlen | ||||||
|  | #   define zstrcmp _fstrcmp | ||||||
|  | #   define FAR __far | ||||||
| #else | #else | ||||||
| #  define MAX_MEM_LEVEL 9 | #   define zstrcpy strcpy | ||||||
|  | #   define zstrcat strcat | ||||||
|  | #   define zstrlen strlen | ||||||
|  | #   define zstrcmp strcmp | ||||||
|  | #   define FAR | ||||||
| #endif | #endif | ||||||
|  |   | ||||||
|  | typedef unsigned char  Byte;  /* 8 bits */ | ||||||
|  | typedef unsigned int   uInt;  /* 16 bits or more */ | ||||||
|  | typedef unsigned long  uLong; /* 32 bits or more */ | ||||||
|  |  | ||||||
| 			/* Type declarations */ | typedef Byte FAR Bytef;   | ||||||
|  | typedef char FAR charf;   | ||||||
|  | typedef int FAR intf; | ||||||
|  | typedef uInt FAR uIntf; | ||||||
|  | typedef uLong FAR uLongf; | ||||||
|  |  | ||||||
| #ifndef __P /* function prototypes */ | #ifdef STDC | ||||||
| #  ifdef STDC |    typedef void FAR *voidp; | ||||||
| #    define __P(args)  args |    typedef void     *voidnp; | ||||||
| #  else | #else | ||||||
| #    define __P(args)  () |    typedef Byte FAR *voidp; | ||||||
| #  endif |    typedef Byte     *voidnp; | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #ifndef Byte |  | ||||||
|   typedef unsigned char  Byte;  /* 8 bits */ |  | ||||||
| #endif |  | ||||||
| #ifndef uInt |  | ||||||
|   typedef unsigned int   uInt;  /* may be 16 or 32 bits */ |  | ||||||
| #endif |  | ||||||
| #ifndef uLong |  | ||||||
|   typedef unsigned long  uLong; /* 32 bits or more */ |  | ||||||
| #endif |  | ||||||
| #ifndef voidp |  | ||||||
| #  ifdef STDC |  | ||||||
|      typedef void *voidp; |  | ||||||
| #  else |  | ||||||
|      typedef Byte *voidp; |  | ||||||
| #  endif |  | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #endif /* _ZCONF_H */ | #endif /* _ZCONF_H */ | ||||||
|   | |||||||
							
								
								
									
										144
									
								
								zlib.h
									
									
									
									
									
								
							
							
						
						
									
										144
									
								
								zlib.h
									
									
									
									
									
								
							| @@ -1,5 +1,5 @@ | |||||||
| /* zlib.h -- interface of the 'zlib' general purpose compression library | /* zlib.h -- interface of the 'zlib' general purpose compression library | ||||||
|   version 0.8 April 29th, 1995. |   version 0.94, Aug 13th, 1995. | ||||||
|  |  | ||||||
|   Copyright (C) 1995 Jean-loup Gailly and Mark Adler |   Copyright (C) 1995 Jean-loup Gailly and Mark Adler | ||||||
|  |  | ||||||
| @@ -20,7 +20,7 @@ | |||||||
|   3. This notice may not be removed or altered from any source distribution. |   3. This notice may not be removed or altered from any source distribution. | ||||||
|  |  | ||||||
|   Jean-loup Gailly        Mark Adler |   Jean-loup Gailly        Mark Adler | ||||||
|   gzip@prep.ai.mit.edu    madler@cco.caltech.edu |   gzip@prep.ai.mit.edu    madler@alumni.caltech.edu | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #ifndef _ZLIB_H | #ifndef _ZLIB_H | ||||||
| @@ -28,7 +28,7 @@ | |||||||
|  |  | ||||||
| #include "zconf.h" | #include "zconf.h" | ||||||
|  |  | ||||||
| #define ZLIB_VERSION "0.8" | #define ZLIB_VERSION "0.94" | ||||||
|  |  | ||||||
| /*  | /*  | ||||||
|      The 'zlib' compression library provides in-memory compression and |      The 'zlib' compression library provides in-memory compression and | ||||||
| @@ -49,22 +49,22 @@ | |||||||
|   (providing more output space) before each call. |   (providing more output space) before each call. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| typedef voidp (*alloc_func) __P((voidp opaque, uInt items, uInt size)); | typedef voidp (*alloc_func) OF((voidp opaque, uInt items, uInt size)); | ||||||
| typedef void  (*free_func)  __P((voidp opaque, voidp address)); | typedef void  (*free_func)  OF((voidp opaque, voidp address)); | ||||||
|  |  | ||||||
| struct internal_state; | struct internal_state; | ||||||
|  |  | ||||||
| typedef struct z_stream_s { | typedef struct z_stream_s { | ||||||
|     Byte     *next_in;  /* next input byte */ |     Bytef    *next_in;  /* next input byte */ | ||||||
|     uInt     avail_in;  /* number of bytes available at next_in */ |     uInt     avail_in;  /* number of bytes available at next_in */ | ||||||
|     uLong    total_in;  /* total nb of input bytes read so far */ |     uLong    total_in;  /* total nb of input bytes read so far */ | ||||||
|  |  | ||||||
|     Byte     *next_out; /* next output byte should be put there */ |     Bytef    *next_out; /* next output byte should be put there */ | ||||||
|     uInt     avail_out; /* remaining free space at next_out */ |     uInt     avail_out; /* remaining free space at next_out */ | ||||||
|     uLong    total_out; /* total nb of bytes output so far */ |     uLong    total_out; /* total nb of bytes output so far */ | ||||||
|  |  | ||||||
|     char     *msg;      /* last error message, NULL if no error */ |     char     *msg;      /* last error message, NULL if no error */ | ||||||
|     struct internal_state *state; /* not visible by applications */ |     struct internal_state FAR *state; /* not visible by applications */ | ||||||
|  |  | ||||||
|     alloc_func zalloc;  /* used to allocate the internal state */ |     alloc_func zalloc;  /* used to allocate the internal state */ | ||||||
|     free_func  zfree;   /* used to free the internal state */ |     free_func  zfree;   /* used to free the internal state */ | ||||||
| @@ -81,7 +81,7 @@ typedef struct z_stream_s { | |||||||
|    opaque before calling the init function. All other fields are set by the |    opaque before calling the init function. All other fields are set by the | ||||||
|    compression library and must not be updated by the application. |    compression library and must not be updated by the application. | ||||||
|  |  | ||||||
|    The opaque value provided by the application will be passed as first |    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 |    parameter for calls of zalloc and zfree. This can be useful for custom | ||||||
|    memory management. The compression library attaches no meaning to the |    memory management. The compression library attaches no meaning to the | ||||||
|    opaque value. |    opaque value. | ||||||
| @@ -89,7 +89,12 @@ typedef struct z_stream_s { | |||||||
|    zalloc must return Z_NULL if there is not enough memory for the object. |    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 |    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 |    exactly 65536 bytes, but will not be required to allocate more than this | ||||||
|    if the symbol MAXSEG_64K is defined (see zconf.h). |    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 |    The fields total_in and total_out can be used for statistics or | ||||||
|    progress reports. After compression, total_in holds the total size of |    progress reports. After compression, total_in holds the total size of | ||||||
| @@ -98,11 +103,12 @@ typedef struct z_stream_s { | |||||||
|    a single step). |    a single step). | ||||||
| */ | */ | ||||||
|  |  | ||||||
| 			/* constants */ |                         /* constants */ | ||||||
|  |  | ||||||
| #define Z_NO_FLUSH      0 | #define Z_NO_FLUSH      0 | ||||||
| #define Z_PARTIAL_FLUSH 1 | #define Z_PARTIAL_FLUSH 1 | ||||||
| #define Z_FULL_FLUSH    2 | #define Z_FULL_FLUSH    2 | ||||||
|  | #define Z_SYNC_FLUSH    3 /* experimental: partial_flush + byte align */ | ||||||
| #define Z_FINISH        4 | #define Z_FINISH        4 | ||||||
| /* See deflate() below for the usage of these constants */ | /* See deflate() below for the usage of these constants */ | ||||||
|  |  | ||||||
| @@ -137,9 +143,9 @@ extern char *zlib_version; | |||||||
|    not compatible with the zlib.h header file used by the application. |    not compatible with the zlib.h header file used by the application. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| 			/* basic functions */ |                         /* basic functions */ | ||||||
|  |  | ||||||
| extern int deflateInit __P((z_stream *strm, int level)); | extern int deflateInit OF((z_stream *strm, int level)); | ||||||
| /*  | /*  | ||||||
|      Initializes the internal stream state for compression. The fields |      Initializes the internal stream state for compression. The fields | ||||||
|    zalloc, zfree and opaque must be initialized before by the caller. |    zalloc, zfree and opaque must be initialized before by the caller. | ||||||
| @@ -158,7 +164,7 @@ extern int deflateInit __P((z_stream *strm, int level)); | |||||||
| */ | */ | ||||||
|  |  | ||||||
|  |  | ||||||
| extern int deflate __P((z_stream *strm, int flush)); | extern int deflate OF((z_stream *strm, int flush)); | ||||||
| /* | /* | ||||||
|   Performs one or both of the following actions: |   Performs one or both of the following actions: | ||||||
|  |  | ||||||
| @@ -189,7 +195,10 @@ extern int deflate __P((z_stream *strm, int flush)); | |||||||
|   is useful to allow the decompressor to synchronize if one compressed block |   is useful to allow the decompressor to synchronize if one compressed block | ||||||
|   has been damaged (see inflateSync below).  Flushing degrades compression and |   has been damaged (see inflateSync below).  Flushing degrades compression and | ||||||
|   so should be used only when necessary.  Using Z_FULL_FLUSH too often can |   so should be used only when necessary.  Using Z_FULL_FLUSH too often can | ||||||
|   seriously degrade the compression. |   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, all pending input is processed, |     If the parameter flush is set to Z_FINISH, all pending input is processed, | ||||||
|   all pending output is flushed and deflate returns with Z_STREAM_END if there |   all pending output is flushed and deflate returns with Z_STREAM_END if there | ||||||
| @@ -217,7 +226,7 @@ extern int deflate __P((z_stream *strm, int flush)); | |||||||
| */ | */ | ||||||
|  |  | ||||||
|  |  | ||||||
| extern int deflateEnd __P((z_stream *strm)); | extern int deflateEnd OF((z_stream *strm)); | ||||||
| /* | /* | ||||||
|      All dynamically allocated data structures for this stream are freed. |      All dynamically allocated data structures for this stream are freed. | ||||||
|    This function discards any unprocessed input and does not flush any |    This function discards any unprocessed input and does not flush any | ||||||
| @@ -229,11 +238,11 @@ extern int deflateEnd __P((z_stream *strm)); | |||||||
| */ | */ | ||||||
|  |  | ||||||
|  |  | ||||||
| extern int inflateInit __P((z_stream *strm)); | extern int inflateInit OF((z_stream *strm)); | ||||||
| /*  | /*  | ||||||
|      Initializes the internal stream state for decompression. The fields |      Initializes the internal stream state for decompression. The fields | ||||||
|    zalloc and zfree must be initialized before by the caller.  If zalloc and |    zalloc and zfree must be initialized before by the caller.  If zalloc and | ||||||
|    zfree are set to Z_NULL, deflateInit updates them to use default allocation |    zfree are set to Z_NULL, inflateInit updates them to use default allocation | ||||||
|    functions. |    functions. | ||||||
|  |  | ||||||
|      inflateInit returns Z_OK if success, Z_MEM_ERROR if there was not |      inflateInit returns Z_OK if success, Z_MEM_ERROR if there was not | ||||||
| @@ -243,7 +252,7 @@ extern int inflateInit __P((z_stream *strm)); | |||||||
| */ | */ | ||||||
|  |  | ||||||
|  |  | ||||||
| extern int inflate __P((z_stream *strm, int flush)); | extern int inflate OF((z_stream *strm, int flush)); | ||||||
| /* | /* | ||||||
|   Performs one or both of the following actions: |   Performs one or both of the following actions: | ||||||
|  |  | ||||||
| @@ -254,7 +263,7 @@ extern int inflate __P((z_stream *strm, int flush)); | |||||||
|  |  | ||||||
|   - Provide more output starting at next_out and update next_out and avail_out |   - Provide more output starting at next_out and update next_out and avail_out | ||||||
|     accordingly.  inflate() always provides as much output as possible |     accordingly.  inflate() always provides as much output as possible | ||||||
|     (until no more input data or no more space in the output buffer). |     (until there is no more input data or no more space in the output buffer). | ||||||
|  |  | ||||||
|   Before the call of inflate(), the application should ensure that at least |   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 |   one of the actions is possible, by providing more input and/or consuming | ||||||
| @@ -265,7 +274,7 @@ extern int inflate __P((z_stream *strm, int flush)); | |||||||
|  |  | ||||||
|     If the parameter flush is set to Z_PARTIAL_FLUSH, inflate flushes as much |     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 |   output as possible to the output buffer. The flushing behavior of inflate is | ||||||
|   not specified for values of the flush paramater other than Z_PARTIAL_FLUSH |   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 |   and Z_FINISH, but the current implementation actually flushes as much output | ||||||
|   as possible anyway. |   as possible anyway. | ||||||
|  |  | ||||||
| @@ -276,7 +285,9 @@ extern int inflate __P((z_stream *strm, int flush)); | |||||||
|   output is flushed; avail_out must be large enough to hold all the |   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 |   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 |   by the compressor for this purpose.) The next operation on this stream must | ||||||
|   be inflateEnd to deallocate the decompression state. |   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 |     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 |   processed or more output produced), Z_STREAM_END if the end of the | ||||||
| @@ -290,7 +301,7 @@ extern int inflate __P((z_stream *strm, int flush)); | |||||||
| */ | */ | ||||||
|  |  | ||||||
|  |  | ||||||
| extern int inflateEnd __P((z_stream *strm)); | extern int inflateEnd OF((z_stream *strm)); | ||||||
| /* | /* | ||||||
|      All dynamically allocated data structures for this stream are freed. |      All dynamically allocated data structures for this stream are freed. | ||||||
|    This function discards any unprocessed input and does not flush any |    This function discards any unprocessed input and does not flush any | ||||||
| @@ -307,12 +318,12 @@ extern int inflateEnd __P((z_stream *strm)); | |||||||
|     The following functions are needed only in some special applications. |     The following functions are needed only in some special applications. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| extern int deflateInit2 __P((z_stream *strm, | extern int deflateInit2 OF((z_stream *strm, | ||||||
| 			     int  level, |                             int  level, | ||||||
| 			     int  method, |                             int  method, | ||||||
|                              int  windowBits, |                             int  windowBits, | ||||||
|                              int  memLevel, |                             int  memLevel, | ||||||
|                              int  strategy)); |                             int  strategy)); | ||||||
| /*    | /*    | ||||||
|      This is another version of deflateInit with more compression options. The |      This is another version of deflateInit with more compression options. The | ||||||
|    fields next_in, zalloc and zfree must be initialized before by the caller. |    fields next_in, zalloc and zfree must be initialized before by the caller. | ||||||
| @@ -330,7 +341,8 @@ extern int deflateInit2 __P((z_stream *strm, | |||||||
|     The memLevel parameter specifies how much memory should be allocated |     The memLevel parameter specifies how much memory should be allocated | ||||||
|    for the internal compression state. memLevel=1 uses minimum memory but |    for the internal compression state. memLevel=1 uses minimum memory but | ||||||
|    is slow and reduces compression ratio; memLevel=9 uses maximum memory |    is slow and reduces compression ratio; memLevel=9 uses maximum memory | ||||||
|    for optimal speed. The default value is 8. |    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 strategy parameter is used to tune the compression algorithm. Use | ||||||
|    the value Z_DEFAULT_STRATEGY for normal data, Z_FILTERED for data |    the value Z_DEFAULT_STRATEGY for normal data, Z_FILTERED for data | ||||||
| @@ -361,13 +373,13 @@ extern int deflateInit2 __P((z_stream *strm, | |||||||
|    deflate(). |    deflate(). | ||||||
| */ | */ | ||||||
|                              |                              | ||||||
| extern int deflateCopy __P((z_stream *dest, | extern int deflateCopy OF((z_stream *dest, | ||||||
|                             z_stream *source)); |                            z_stream *source)); | ||||||
| /* | /* | ||||||
|      Sets the destination stream as a complete copy of the source stream.  If |      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 |    the source stream is using an application-supplied history buffer, a new | ||||||
|    buffer is allocated for the destination stream.  The compressed output |    buffer is allocated for the destination stream.  The compressed output | ||||||
|    buffer is always application-supplied. It's the responsability of the |    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 |    application to provide the correct values of next_out and avail_out for the | ||||||
|    next call of deflate. |    next call of deflate. | ||||||
|  |  | ||||||
| @@ -384,7 +396,7 @@ extern int deflateCopy __P((z_stream *dest, | |||||||
|    destination. |    destination. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| extern int deflateReset __P((z_stream *strm)); | extern int deflateReset OF((z_stream *strm)); | ||||||
| /* | /* | ||||||
|      This function is equivalent to deflateEnd followed by deflateInit, |      This function is equivalent to deflateEnd followed by deflateInit, | ||||||
|    but does not free and reallocate all the internal compression state. |    but does not free and reallocate all the internal compression state. | ||||||
| @@ -395,8 +407,8 @@ extern int deflateReset __P((z_stream *strm)); | |||||||
|    stream state was inconsistent (such as zalloc or state being NULL). |    stream state was inconsistent (such as zalloc or state being NULL). | ||||||
| */ | */ | ||||||
|  |  | ||||||
| extern int inflateInit2 __P((z_stream *strm, | extern int inflateInit2 OF((z_stream *strm, | ||||||
|                              int  windowBits)); |                             int  windowBits)); | ||||||
| /*    | /*    | ||||||
|      This is another version of inflateInit with more compression options. The |      This is another version of inflateInit with more compression options. The | ||||||
|    fields next_out, zalloc and zfree must be initialized before by the caller. |    fields next_out, zalloc and zfree must be initialized before by the caller. | ||||||
| @@ -424,25 +436,26 @@ extern int inflateInit2 __P((z_stream *strm, | |||||||
|       inflateInit2 returns Z_OK if success, Z_MEM_ERROR if there was |       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 |    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. |    windowBits < 8). msg is set to null if there is no error message. | ||||||
|    inflateInit2 does not perform any compression: this will be done by |    inflateInit2 does not perform any decompression: this will be done by | ||||||
|    inflate(). |    inflate(). | ||||||
| */ | */ | ||||||
|  |  | ||||||
| extern int inflateSync __P((z_stream *strm)); | extern int inflateSync OF((z_stream *strm)); | ||||||
| /*  | /*  | ||||||
|     Skips invalid compressed data until the special marker and a valid block |     Skips invalid compressed data until the special marker (see deflate() | ||||||
|   can be found, or until all available input is skipped. No output is provided. |   above) can be found, or until all available input is skipped. No output | ||||||
|  |   is provided. | ||||||
|  |  | ||||||
|     inflateSync returns Z_OK if a valid block has been found, Z_BUF_ERROR if |     inflateSync returns Z_OK if the special marker has been found, Z_BUF_ERROR | ||||||
|   no more input was provided, Z_DATA_ERROR if not valid block has been found, |   if no more input was provided, Z_DATA_ERROR if no marker has been found, | ||||||
|   Z_STREAM_ERROR if the stream structure was inconsistent. In the success |   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 |   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 |   indicates where valid compressed data was found. In the error case, the | ||||||
|   application may repeatedly call inflateSync, providing more input each time, |   application may repeatedly call inflateSync, providing more input each time, | ||||||
|   until success or end of the input data. |   until success or end of the input data. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| extern int inflateReset __P((z_stream *strm)); | extern int inflateReset OF((z_stream *strm)); | ||||||
| /* | /* | ||||||
|      This function is equivalent to inflateEnd followed by inflateInit, |      This function is equivalent to inflateEnd followed by inflateInit, | ||||||
|    but does not free and reallocate all the internal decompression state. |    but does not free and reallocate all the internal decompression state. | ||||||
| @@ -463,13 +476,13 @@ extern int inflateReset __P((z_stream *strm)); | |||||||
|    utility functions can easily be modified if you need special options. |    utility functions can easily be modified if you need special options. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| extern int compress __P((Byte *dest,   uLong *destLen, | extern int compress OF((Bytef *dest,   uLongf *destLen, | ||||||
|                          Byte *source, uLong sourceLen)); |                         Bytef *source, uLong sourceLen)); | ||||||
| /* | /* | ||||||
|      Compresses the source buffer into the destination buffer.  sourceLen is |      Compresses the source buffer into the destination buffer.  sourceLen is | ||||||
|    the byte length of the source buffer. Upon entry, destLen is the total |    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 |    size of the destination buffer, which must be at least 0.1% larger than | ||||||
|    sourceLen plus 8 bytes. Upon exit, destLen is the actual size of the |    sourceLen plus 12 bytes. Upon exit, destLen is the actual size of the | ||||||
|    compressed buffer. |    compressed buffer. | ||||||
|      This function can be used to compress a whole file at once if the |      This function can be used to compress a whole file at once if the | ||||||
|    input file is mmap'ed. |    input file is mmap'ed. | ||||||
| @@ -478,8 +491,8 @@ extern int compress __P((Byte *dest,   uLong *destLen, | |||||||
|    buffer. |    buffer. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| extern int uncompress __P((Byte *dest,   uLong *destLen, | extern int uncompress OF((Bytef *dest,   uLongf *destLen, | ||||||
|                            Byte *source, uLong sourceLen)); |                           Bytef *source, uLong sourceLen)); | ||||||
| /* | /* | ||||||
|      Decompresses the source buffer into the destination buffer.  sourceLen is |      Decompresses the source buffer into the destination buffer.  sourceLen is | ||||||
|    the byte length of the source buffer. Upon entry, destLen is the total |    the byte length of the source buffer. Upon entry, destLen is the total | ||||||
| @@ -497,30 +510,30 @@ extern int uncompress __P((Byte *dest,   uLong *destLen, | |||||||
| */ | */ | ||||||
|  |  | ||||||
|  |  | ||||||
| typedef voidp gzFile; | typedef voidnp gzFile; | ||||||
|  |  | ||||||
| extern gzFile gzopen  __P((char *path, char *mode)); | extern gzFile gzopen  OF((char *path, char *mode)); | ||||||
| /* | /* | ||||||
|      Opens a gzip (.gz) file for reading or writing. The mode parameter |      Opens a gzip (.gz) file for reading or writing. The mode parameter | ||||||
|    is as in fopen ("rb" or "wb"). gzopen can also be used to read a file |    is as in fopen ("rb" or "wb") but can also include a compression level | ||||||
|    which is not in gzip format; in this case gzread will directly read from |    ("wb9").  gzopen can be used to read a file which is not in gzip format; | ||||||
|    the file without decompression. |    in this case gzread will directly read from the file without decompression. | ||||||
|      gzopen return NULL if the file could not be opened or if there was |      gzopen returns NULL if the file could not be opened or if there was | ||||||
|    insufficient memory to allocate the (de)compression state; errno |    insufficient memory to allocate the (de)compression state; errno | ||||||
|    can be checked to distinguish the two cases (if errno is zero, the |    can be checked to distinguish the two cases (if errno is zero, the | ||||||
|    zlib error is Z_MEM_ERROR). |    zlib error is Z_MEM_ERROR). | ||||||
| */ | */ | ||||||
|  |  | ||||||
| extern gzFile gzdopen  __P((int fd, char *mode)); | extern gzFile gzdopen  OF((int fd, char *mode)); | ||||||
| /* | /* | ||||||
|      gzdopen() associates a gzFile with the file descriptor fd.  File |      gzdopen() associates a gzFile with the file descriptor fd.  File | ||||||
|    descriptors are obtained from calls like open, dup, creat, or pipe. |    descriptors are obtained from calls like open, dup, creat, or pipe. | ||||||
|    The mode parameter is as in fopen ("rb" or "wb"). |    The mode parameter is as in fopen ("rb" or "wb"). | ||||||
|      gzdopen return NULL if there was insufficient memory to allocate |      gzdopen returns NULL if there was insufficient memory to allocate | ||||||
|    the (de)compression state. |    the (de)compression state. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| extern int    gzread  __P((gzFile file, voidp buf, unsigned len)); | extern int    gzread  OF((gzFile file, voidnp buf, unsigned len)); | ||||||
| /* | /* | ||||||
|      Reads the given number of uncompressed bytes from the compressed file. |      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 |    If the input file was not in gzip format, gzread copies the given number | ||||||
| @@ -528,14 +541,14 @@ extern int    gzread  __P((gzFile file, voidp buf, unsigned len)); | |||||||
|      gzread returns the number of uncompressed bytes actually read (0 for |      gzread returns the number of uncompressed bytes actually read (0 for | ||||||
|    end of file, -1 for error). */ |    end of file, -1 for error). */ | ||||||
|  |  | ||||||
| extern int    gzwrite __P((gzFile file, voidp buf, unsigned len)); | extern int    gzwrite OF((gzFile file, voidnp buf, unsigned len)); | ||||||
| /* | /* | ||||||
|      Writes the given number of uncompressed bytes into the compressed file. |      Writes the given number of uncompressed bytes into the compressed file. | ||||||
|    gzwrite returns the number of uncompressed bytes actually written |    gzwrite returns the number of uncompressed bytes actually written | ||||||
|    (0 in case of error). |    (0 in case of error). | ||||||
| */ | */ | ||||||
|  |  | ||||||
| extern int    gzflush __P((gzFile file, int flush)); | extern int    gzflush OF((gzFile file, int flush)); | ||||||
| /* | /* | ||||||
|      Flushes all pending output into the compressed file. The parameter |      Flushes all pending output into the compressed file. The parameter | ||||||
|    flush is as in the deflate() function. The return value is the zlib |    flush is as in the deflate() function. The return value is the zlib | ||||||
| @@ -545,14 +558,14 @@ extern int    gzflush __P((gzFile file, int flush)); | |||||||
|    degrade compression. |    degrade compression. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| extern int    gzclose __P((gzFile file)); | extern int    gzclose OF((gzFile file)); | ||||||
| /* | /* | ||||||
|      Flushes all pending output if necessary, closes the compressed file |      Flushes all pending output if necessary, closes the compressed file | ||||||
|    and deallocates all the (de)compression state. The return value is the zlib |    and deallocates all the (de)compression state. The return value is the zlib | ||||||
|    error number (see function gzerror below). |    error number (see function gzerror below). | ||||||
| */ | */ | ||||||
|  |  | ||||||
| extern char*   gzerror __P((gzFile file, int *errnum)); | extern char*   gzerror OF((gzFile file, int *errnum)); | ||||||
| /* | /* | ||||||
|      Returns the error message for the last error which occurred on the |      Returns the error message for the last error which occurred on the | ||||||
|    given compressed file. errnum is set to zlib error number. If an |    given compressed file. errnum is set to zlib error number. If an | ||||||
| @@ -569,12 +582,13 @@ extern char*   gzerror __P((gzFile file, int *errnum)); | |||||||
|    compression library. |    compression library. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| extern uLong adler32 __P((uLong adler, Byte *buf, uInt len)); | extern uLong adler32 OF((uLong adler, Bytef *buf, uInt len)); | ||||||
|  |  | ||||||
| /* | /* | ||||||
|      Update a running Adler-32 checksum with the bytes buf[0..len-1] and |      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 |    return the updated checksum. If buf is NULL, this function returns | ||||||
|    the required initial value for the checksum. |    the required initial value for the checksum. | ||||||
|    An Adler-32 cheksum is almost as reliable as a CRC32 but can be computed |    An Adler-32 checksum is almost as reliable as a CRC32 but can be computed | ||||||
|    much faster. Usage example: |    much faster. Usage example: | ||||||
|  |  | ||||||
|      uLong adler = adler32(0L, Z_NULL, 0); |      uLong adler = adler32(0L, Z_NULL, 0); | ||||||
| @@ -585,7 +599,7 @@ extern uLong adler32 __P((uLong adler, Byte *buf, uInt len)); | |||||||
|      if (adler != original_adler) error(); |      if (adler != original_adler) error(); | ||||||
| */ | */ | ||||||
|  |  | ||||||
| extern uLong crc32   __P((uLong crc, Byte *buf, uInt len)); | extern uLong crc32   OF((uLong crc, Bytef *buf, uInt len)); | ||||||
| /* | /* | ||||||
|      Update a running crc with the bytes buf[0..len-1] and return the updated |      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 |    crc. If buf is NULL, this function returns the required initial value | ||||||
|   | |||||||
							
								
								
									
										59
									
								
								zutil.c
									
									
									
									
									
								
							
							
						
						
									
										59
									
								
								zutil.c
									
									
									
									
									
								
							| @@ -3,13 +3,17 @@ | |||||||
|  * For conditions of distribution and use, see copyright notice in zlib.h  |  * For conditions of distribution and use, see copyright notice in zlib.h  | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| /* $Id: zutil.c,v 1.6 1995/04/29 14:54:02 jloup Exp $ */ | /* $Id: zutil.c,v 1.8 1995/05/03 17:27:12 jloup Exp $ */ | ||||||
|  |  | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
|  |  | ||||||
| #include "zutil.h" | #include "zutil.h" | ||||||
|  |  | ||||||
| extern void exit __P((int)); | struct internal_state      {int dummy;}; /* for buggy compilers */ | ||||||
|  |  | ||||||
|  | #ifndef __GO32__ | ||||||
|  | extern void exit OF((int)); | ||||||
|  | #endif | ||||||
|  |  | ||||||
| char *zlib_version = ZLIB_VERSION; | char *zlib_version = ZLIB_VERSION; | ||||||
|  |  | ||||||
| @@ -40,7 +44,7 @@ void zmemcpy(dest, source, len) | |||||||
| { | { | ||||||
|     if (len == 0) return; |     if (len == 0) return; | ||||||
|     do { |     do { | ||||||
| 	*dest++ = *source++; /* ??? to be unrolled */ |         *dest++ = *source++; /* ??? to be unrolled */ | ||||||
|     } while (--len != 0); |     } while (--len != 0); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -50,13 +54,14 @@ void zmemzero(dest, len) | |||||||
| { | { | ||||||
|     if (len == 0) return; |     if (len == 0) return; | ||||||
|     do { |     do { | ||||||
| 	*dest++ = 0;  /* ??? to be unrolled */ |         *dest++ = 0;  /* ??? to be unrolled */ | ||||||
|     } while (--len != 0); |     } while (--len != 0); | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #if defined(MSDOS) && !defined(__SMALL__) && !defined(M_I86SM) | #if defined(__TURBOC__) && !defined(__SMALL__) | ||||||
| #  ifdef __TURBOC__ |  | ||||||
|  | #  define MY_ZCALLOC | ||||||
|  |  | ||||||
| /* Turbo C malloc() does not allow dynamic allocation of 64K bytes | /* Turbo C malloc() does not allow dynamic allocation of 64K bytes | ||||||
|  * and farmalloc(64K) returns a pointer with an offset of 8, so we |  * and farmalloc(64K) returns a pointer with an offset of 8, so we | ||||||
| @@ -88,10 +93,10 @@ voidp zcalloc (voidp opaque, unsigned items, unsigned size) | |||||||
|     ulg bsize = (ulg)items*size; |     ulg bsize = (ulg)items*size; | ||||||
|  |  | ||||||
|     if (bsize < 65536L) { |     if (bsize < 65536L) { | ||||||
| 	buf = farmalloc(bsize); |         buf = farmalloc(bsize); | ||||||
| 	if (*(ush*)&buf != 0) return buf; |         if (*(ush*)&buf != 0) return buf; | ||||||
|     } else { |     } else { | ||||||
| 	buf = farmalloc(bsize + 16L); |         buf = farmalloc(bsize + 16L); | ||||||
|     } |     } | ||||||
|     if (buf == NULL || next_ptr >= MAX_PTR) return NULL; |     if (buf == NULL || next_ptr >= MAX_PTR) return NULL; | ||||||
|     table[next_ptr].org_ptr = buf; |     table[next_ptr].org_ptr = buf; | ||||||
| @@ -107,25 +112,28 @@ void  zcfree (voidp opaque, voidp ptr) | |||||||
| { | { | ||||||
|     int n; |     int n; | ||||||
|     if (*(ush*)&ptr != 0) { /* object < 64K */ |     if (*(ush*)&ptr != 0) { /* object < 64K */ | ||||||
| 	farfree(ptr); |         farfree(ptr); | ||||||
| 	return; |         return; | ||||||
|     } |     } | ||||||
|     /* Find the original pointer */ |     /* Find the original pointer */ | ||||||
|     for (n = 0; n < next_ptr; n++) { |     for (n = 0; n < next_ptr; n++) { | ||||||
| 	if (ptr != table[n].new_ptr) continue; |         if (ptr != table[n].new_ptr) continue; | ||||||
|  |  | ||||||
| 	farfree(table[n].org_ptr); |         farfree(table[n].org_ptr); | ||||||
| 	while (++n < next_ptr) { |         while (++n < next_ptr) { | ||||||
| 	    table[n-1] = table[n]; |             table[n-1] = table[n]; | ||||||
| 	} |         } | ||||||
| 	next_ptr--; |         next_ptr--; | ||||||
| 	return; |         return; | ||||||
|     } |     } | ||||||
|     ptr = opaque; /* just to make some compilers happy */ |     ptr = opaque; /* just to make some compilers happy */ | ||||||
|     z_error("zcfree: ptr not found"); |     z_error("zcfree: ptr not found"); | ||||||
| } | } | ||||||
|  | #endif /* __TURBOC__ */ | ||||||
|  |  | ||||||
| #  else /* MSC */ | #if defined(MSDOS) && !defined(__TURBOC__)  /* MSC */ | ||||||
|  |  | ||||||
|  | #  define MY_ZCALLOC | ||||||
|  |  | ||||||
| #if (!defined(_MSC_VER) || (_MSC_VER < 600)) | #if (!defined(_MSC_VER) || (_MSC_VER < 600)) | ||||||
| #  define _halloc  halloc | #  define _halloc  halloc | ||||||
| @@ -144,12 +152,15 @@ void  zcfree (voidp opaque, voidp ptr) | |||||||
|     _hfree(ptr); |     _hfree(ptr); | ||||||
| } | } | ||||||
|  |  | ||||||
| #  endif /* __TURBOC__ ? */ | #endif /* MSC */ | ||||||
|  |  | ||||||
| #else /* !MSDOS */ |  | ||||||
|  |  | ||||||
| extern voidp calloc __P((uInt items, uInt size)); | #ifndef MY_ZCALLOC /* Any system without a special alloc function */ | ||||||
| extern void  free   __P((voidp ptr)); |  | ||||||
|  | #ifndef __GO32__ | ||||||
|  | extern voidp calloc OF((uInt items, uInt size)); | ||||||
|  | extern void  free   OF((voidp ptr)); | ||||||
|  | #endif | ||||||
|  |  | ||||||
| voidp zcalloc (opaque, items, size) | voidp zcalloc (opaque, items, size) | ||||||
|     voidp opaque; |     voidp opaque; | ||||||
| @@ -166,4 +177,4 @@ void  zcfree (opaque, ptr) | |||||||
|     free(ptr); |     free(ptr); | ||||||
| } | } | ||||||
|  |  | ||||||
| #endif /* MSDOS */ | #endif /* MY_ZCALLOC */ | ||||||
|   | |||||||
							
								
								
									
										53
									
								
								zutil.h
									
									
									
									
									
								
							
							
						
						
									
										53
									
								
								zutil.h
									
									
									
									
									
								
							| @@ -8,15 +8,16 @@ | |||||||
|    subject to change. Applications should only use zlib.h. |    subject to change. Applications should only use zlib.h. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| /* $Id: zutil.h,v 1.6 1995/04/29 15:52:16 jloup Exp $ */ | /* $Id: zutil.h,v 1.9 1995/05/03 17:27:12 jloup Exp $ */ | ||||||
|  |  | ||||||
| #ifndef _Z_UTIL_H | #ifndef _Z_UTIL_H | ||||||
| #define _Z_UTIL_H | #define _Z_UTIL_H | ||||||
|  |  | ||||||
| #include "zlib.h" | #include "zlib.h" | ||||||
|  |  | ||||||
| #ifdef MSDOS | #if defined(MSDOS) || defined(VMS) | ||||||
| #   include <stddef.h> | #   include <stddef.h> | ||||||
|  | #   include <errno.h> | ||||||
| #else | #else | ||||||
|     extern int errno; |     extern int errno; | ||||||
| #endif | #endif | ||||||
| @@ -30,7 +31,9 @@ | |||||||
| /* compile with -Dlocal if your debugger can't find static symbols */ | /* compile with -Dlocal if your debugger can't find static symbols */ | ||||||
|  |  | ||||||
| typedef unsigned char  uch; | typedef unsigned char  uch; | ||||||
|  | typedef uch FAR uchf; | ||||||
| typedef unsigned short ush; | typedef unsigned short ush; | ||||||
|  | typedef ush FAR ushf; | ||||||
| typedef unsigned long  ulg; | typedef unsigned long  ulg; | ||||||
|  |  | ||||||
| extern char *z_errmsg[]; /* indexed by 1-zlib_error */ | extern char *z_errmsg[]; /* indexed by 1-zlib_error */ | ||||||
| @@ -38,17 +41,21 @@ extern char *z_errmsg[]; /* indexed by 1-zlib_error */ | |||||||
| #define ERR_RETURN(strm,err) return (strm->msg=z_errmsg[1-err], err) | #define ERR_RETURN(strm,err) return (strm->msg=z_errmsg[1-err], err) | ||||||
| /* To be used only when the state is known to be valid */ | /* To be used only when the state is known to be valid */ | ||||||
|  |  | ||||||
| 	/* common constants */ |         /* common constants */ | ||||||
|  |  | ||||||
| #define DEFLATED   8 | #define DEFLATED   8 | ||||||
|  |  | ||||||
| #ifndef WBITS | #ifndef DEF_WBITS | ||||||
| # define WBITS   15 /* 32K window */ | #  define DEF_WBITS 15 | ||||||
| #endif | #endif | ||||||
|  | /* default windowBits for decompression. MAX_WBITS is for compression only */ | ||||||
|  |  | ||||||
| #ifndef MEM_LEVEL | #if MAX_MEM_LEVEL >= 8 | ||||||
| # define MEM_LEVEL  8 | #  define DEF_MEM_LEVEL 8 | ||||||
|  | #else | ||||||
|  | #  define DEF_MEM_LEVEL  MAX_MEM_LEVEL | ||||||
| #endif | #endif | ||||||
|  | /* default memLevel */ | ||||||
|  |  | ||||||
| #define STORED_BLOCK 0 | #define STORED_BLOCK 0 | ||||||
| #define STATIC_TREES 1 | #define STATIC_TREES 1 | ||||||
| @@ -59,7 +66,7 @@ extern char *z_errmsg[]; /* indexed by 1-zlib_error */ | |||||||
| #define MAX_MATCH  258 | #define MAX_MATCH  258 | ||||||
| /* The minimum and maximum match lengths */ | /* The minimum and maximum match lengths */ | ||||||
|  |  | ||||||
| 	/* target dependencies */ |         /* target dependencies */ | ||||||
|  |  | ||||||
| #ifdef MSDOS | #ifdef MSDOS | ||||||
| #  define OS_CODE  0x00 | #  define OS_CODE  0x00 | ||||||
| @@ -104,7 +111,7 @@ extern char *z_errmsg[]; /* indexed by 1-zlib_error */ | |||||||
| #  define OS_CODE  0x0a | #  define OS_CODE  0x0a | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| 	/* Common defaults */ |         /* Common defaults */ | ||||||
|  |  | ||||||
| #ifndef OS_CODE | #ifndef OS_CODE | ||||||
| #  define OS_CODE  0x03  /* assume Unix */ | #  define OS_CODE  0x03  /* assume Unix */ | ||||||
| @@ -117,21 +124,29 @@ extern char *z_errmsg[]; /* indexed by 1-zlib_error */ | |||||||
|          /* functions */ |          /* functions */ | ||||||
|  |  | ||||||
| #ifdef HAVE_STRERROR | #ifdef HAVE_STRERROR | ||||||
|    extern char *strerror __P((int)); |    extern char *strerror OF((int)); | ||||||
| #  define zstrerror(errnum) strerror(errnum) | #  define zstrerror(errnum) strerror(errnum) | ||||||
| #else | #else | ||||||
| #  define zstrerror(errnum) "" | #  define zstrerror(errnum) "" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #if defined(STDC) && !defined(HAVE_MEMCPY) | #if defined(pyr) && !defined(NO_MEMCPY) | ||||||
|  | #  define NO_MEMCPY | ||||||
|  | #endif | ||||||
|  | #if defined(STDC) && !defined(HAVE_MEMCPY) && !defined(NO_MEMCPY) | ||||||
| #  define HAVE_MEMCPY | #  define HAVE_MEMCPY | ||||||
| #endif | #endif | ||||||
| #ifdef HAVE_MEMCPY | #ifdef HAVE_MEMCPY | ||||||
| #  define zmemcpy memcpy | #  ifdef M_I86MM /* MSC medium model */ | ||||||
| #  define zmemzero(dest, len) memset(dest, 0, len) | #    define zmemcpy _fmemcpy | ||||||
|  | #    define zmemzero(dest, len) _fmemset(dest, 0, len) | ||||||
|  | #  else  | ||||||
|  | #    define zmemcpy memcpy | ||||||
|  | #    define zmemzero(dest, len) memset(dest, 0, len) | ||||||
|  | #  endif | ||||||
| #else | #else | ||||||
|    extern void zmemcpy  __P((Byte* dest, Byte* source, uInt len)); |    extern void zmemcpy  OF((Byte* dest, Byte* source, uInt len)); | ||||||
|    extern void zmemzero __P((Byte* dest, uInt len)); |    extern void zmemzero OF((Byte* dest, uInt len)); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| /* Diagnostic functions */ | /* Diagnostic functions */ | ||||||
| @@ -156,12 +171,12 @@ extern char *z_errmsg[]; /* indexed by 1-zlib_error */ | |||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| typedef uLong (*check_func) __P((uLong check, Byte *buf, uInt len)); | typedef uLong (*check_func) OF((uLong check, Bytef *buf, uInt len)); | ||||||
|  |  | ||||||
| extern void z_error    __P((char *m)); | extern void z_error    OF((char *m)); | ||||||
|  |  | ||||||
| voidp zcalloc __P((voidp opaque, unsigned items, unsigned size)); | voidp zcalloc OF((voidp opaque, unsigned items, unsigned size)); | ||||||
| void  zcfree  __P((voidp opaque, voidp ptr)); | void  zcfree  OF((voidp opaque, voidp ptr)); | ||||||
|  |  | ||||||
| #define ZALLOC(strm, items, size) \ | #define ZALLOC(strm, items, size) \ | ||||||
|            (*((strm)->zalloc))((strm)->opaque, (items), (size)) |            (*((strm)->zalloc))((strm)->opaque, (items), (size)) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user