[9] | 1 |
|
---|
| 2 | This directory contains a Pascal (Delphi, Kylix) interface to the
|
---|
| 3 | zlib data compression library.
|
---|
| 4 |
|
---|
| 5 |
|
---|
| 6 | Directory listing
|
---|
| 7 | =================
|
---|
| 8 |
|
---|
| 9 | zlibd32.mak makefile for Borland C++
|
---|
| 10 | example.pas usage example of zlib
|
---|
| 11 | zlibpas.pas the Pascal interface to zlib
|
---|
| 12 | readme.txt this file
|
---|
| 13 |
|
---|
| 14 |
|
---|
| 15 | Compatibility notes
|
---|
| 16 | ===================
|
---|
| 17 |
|
---|
| 18 | - Although the name "zlib" would have been more normal for the
|
---|
| 19 | zlibpas unit, this name is already taken by Borland's ZLib unit.
|
---|
| 20 | This is somehow unfortunate, because that unit is not a genuine
|
---|
| 21 | interface to the full-fledged zlib functionality, but a suite of
|
---|
| 22 | class wrappers around zlib streams. Other essential features,
|
---|
| 23 | such as checksums, are missing.
|
---|
| 24 | It would have been more appropriate for that unit to have a name
|
---|
| 25 | like "ZStreams", or something similar.
|
---|
| 26 |
|
---|
| 27 | - The C and zlib-supplied types int, uInt, long, uLong, etc. are
|
---|
| 28 | translated directly into Pascal types of similar sizes (Integer,
|
---|
| 29 | LongInt, etc.), to avoid namespace pollution. In particular,
|
---|
| 30 | there is no conversion of unsigned int into a Pascal unsigned
|
---|
| 31 | integer. The Word type is non-portable and has the same size
|
---|
| 32 | (16 bits) both in a 16-bit and in a 32-bit environment, unlike
|
---|
| 33 | Integer. Even if there is a 32-bit Cardinal type, there is no
|
---|
| 34 | real need for unsigned int in zlib under a 32-bit environment.
|
---|
| 35 |
|
---|
| 36 | - Except for the callbacks, the zlib function interfaces are
|
---|
| 37 | assuming the calling convention normally used in Pascal
|
---|
| 38 | (__pascal for DOS and Windows16, __fastcall for Windows32).
|
---|
| 39 | Since the cdecl keyword is used, the old Turbo Pascal does
|
---|
| 40 | not work with this interface.
|
---|
| 41 |
|
---|
| 42 | - The gz* function interfaces are not translated, to avoid
|
---|
| 43 | interfacing problems with the C runtime library. Besides,
|
---|
| 44 | gzprintf(gzFile file, const char *format, ...)
|
---|
| 45 | cannot be translated into Pascal.
|
---|
| 46 |
|
---|
| 47 |
|
---|
| 48 | Legal issues
|
---|
| 49 | ============
|
---|
| 50 |
|
---|
| 51 | The zlibpas interface is:
|
---|
| 52 | Copyright (C) 1995-2003 Jean-loup Gailly and Mark Adler.
|
---|
| 53 | Copyright (C) 1998 by Bob Dellaca.
|
---|
| 54 | Copyright (C) 2003 by Cosmin Truta.
|
---|
| 55 |
|
---|
| 56 | The example program is:
|
---|
| 57 | Copyright (C) 1995-2003 by Jean-loup Gailly.
|
---|
| 58 | Copyright (C) 1998,1999,2000 by Jacques Nomssi Nzali.
|
---|
| 59 | Copyright (C) 2003 by Cosmin Truta.
|
---|
| 60 |
|
---|
| 61 | This software is provided 'as-is', without any express or implied
|
---|
| 62 | warranty. In no event will the author be held liable for any damages
|
---|
| 63 | arising from the use of this software.
|
---|
| 64 |
|
---|
| 65 | Permission is granted to anyone to use this software for any purpose,
|
---|
| 66 | including commercial applications, and to alter it and redistribute it
|
---|
| 67 | freely, subject to the following restrictions:
|
---|
| 68 |
|
---|
| 69 | 1. The origin of this software must not be misrepresented; you must not
|
---|
| 70 | claim that you wrote the original software. If you use this software
|
---|
| 71 | in a product, an acknowledgment in the product documentation would be
|
---|
| 72 | appreciated but is not required.
|
---|
| 73 | 2. Altered source versions must be plainly marked as such, and must not be
|
---|
| 74 | misrepresented as being the original software.
|
---|
| 75 | 3. This notice may not be removed or altered from any source distribution.
|
---|
| 76 |
|
---|