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