2008-05-28 14:42 UTC+0100 Viktor Szakats (harbour.01 syenar hu)
* bin/bld.bat
* bin/bld_os2.cmd
+ Added hbzlib
+ Added hbpcre for OS/2.
- contrib/hbzlib
- Removed.
This commit is contained in:
@@ -8,6 +8,15 @@
|
||||
2008-12-31 13:59 UTC+0100 Foo Bar <foo.bar@foobar.org>
|
||||
*/
|
||||
|
||||
2008-05-28 14:42 UTC+0100 Viktor Szakats (harbour.01 syenar hu)
|
||||
* bin/bld.bat
|
||||
* bin/bld_os2.cmd
|
||||
+ Added hbzlib
|
||||
+ Added hbpcre for OS/2.
|
||||
|
||||
- contrib/hbzlib
|
||||
- Removed.
|
||||
|
||||
2008-05-28 14:33 UTC+0100 Viktor Szakats (harbour.01 syenar hu)
|
||||
* common.mak
|
||||
* include/Makefile
|
||||
|
||||
@@ -174,7 +174,7 @@ if "%HB_INC_INSTALL%" == "" set HB_INC_INSTALL=..\include
|
||||
|
||||
if not "%HB_COMPILER%" == "rsx32" GOTO A_DOS_RSX32_NOT
|
||||
|
||||
gcc %1.c -Zrsx32 %CFLAGS% -I%HB_INC_INSTALL% -L%HB_LIB_INSTALL% -lhbcpage -lhbdebug -lhbvm -lhbrtl -l%_HB_GT_LIB% -lhblang -lhbrdd -lhbrtl -lhbvm -lhbmacro -lhbpp -lrddfpt -lrddntx -lrddcdx -lhbsix -lhbcommon -lhbpcre
|
||||
gcc %1.c -Zrsx32 %CFLAGS% -I%HB_INC_INSTALL% -L%HB_LIB_INSTALL% -lhbcpage -lhbdebug -lhbvm -lhbrtl -l%_HB_GT_LIB% -lhblang -lhbrdd -lhbrtl -lhbvm -lhbmacro -lhbpp -lrddfpt -lrddntx -lrddcdx -lhbsix -lhbcommon -lhbpcre -lhbzlib
|
||||
goto END
|
||||
|
||||
:A_DOS_RSX32_NOT
|
||||
@@ -199,6 +199,7 @@ if "%HB_INC_INSTALL%" == "" set HB_INC_INSTALL=..\include
|
||||
echo LIB hbsix.lib >> build.tmp
|
||||
echo LIB hbcommon.lib >> build.tmp
|
||||
echo LIB hbpcre.lib >> build.tmp
|
||||
echo LIB hbzlib.lib >> build.tmp
|
||||
wlink @build.tmp
|
||||
del build.tmp
|
||||
goto END
|
||||
@@ -209,13 +210,13 @@ if not "%HB_ARCHITECTURE%" == "w32" goto A_OS2
|
||||
|
||||
if "%HB_GT_LIB%" == "" set _HB_GT_LIB=gtwin
|
||||
|
||||
if "%HB_COMPILER%" == "bcc32" bcc32 -O2 -d %CFLAGS% -I%HB_INC_INSTALL% -L%HB_LIB_INSTALL% %1.c %HB_USER_LIBS% hbcpage.lib hbdebug.lib hbvm.lib hbrtl.lib %_HB_GT_LIB%.lib hblang.lib hbrdd.lib hbmacro.lib hbpp.lib rddfpt.lib rddntx.lib rddcdx.lib hbsix.lib hbcommon.lib hbpcre.lib
|
||||
if "%HB_COMPILER%" == "bcc32" bcc32 -O2 -d %CFLAGS% -I%HB_INC_INSTALL% -L%HB_LIB_INSTALL% %1.c %HB_USER_LIBS% hbcpage.lib hbdebug.lib hbvm.lib hbrtl.lib %_HB_GT_LIB%.lib hblang.lib hbrdd.lib hbmacro.lib hbpp.lib rddfpt.lib rddntx.lib rddcdx.lib hbsix.lib hbcommon.lib hbpcre.lib hbzlib.lib
|
||||
|
||||
if "%HB_COMPILER%" == "gcc" gcc %1.c -o%1.exe %CFLAGS% -I%HB_INC_INSTALL% -L%HB_LIB_INSTALL% -lhbcpage -lhbdebug -lhbvm -lhbrtl -l%_HB_GT_LIB% -lhblang -lhbrdd -lhbrtl -lhbvm -lhbmacro -lhbpp -lrddfpt -lrddntx -lrddcdx -lhbsix -lhbcommon -lhbpcre
|
||||
if "%HB_COMPILER%" == "mingw32" gcc %1.c -o%1.exe %CFLAGS% -mno-cygwin -I%HB_INC_INSTALL% %HB_INC_TEMP% -L%HB_LIB_INSTALL% -lhbcpage -lhbdebug -lhbvm -lhbrtl -l%_HB_GT_LIB% -lhblang -lhbrdd -lhbrtl -lhbvm -lhbmacro -lhbpp -lrddfpt -lrddntx -lrddcdx -lhbsix -lhbcommon -lhbpcre
|
||||
if "%HB_COMPILER%" == "rsxnt" gcc %1.c -Zwin32 %CFLAGS% -I%HB_INC_INSTALL% -L%HB_LIB_INSTALL% -lhbcpage -lhbdebug -lhbvm -lhbrtl -l%_HB_GT_LIB% -lhblang -lhbrdd -lhbrtl -lhbvm -lhbmacro -lhbpp -lrddfpt -lrddntx -lrddcdx -lhbsix -lhbcommon -lhbpcre
|
||||
if "%HB_COMPILER%" == "gcc" gcc %1.c -o%1.exe %CFLAGS% -I%HB_INC_INSTALL% -L%HB_LIB_INSTALL% -lhbcpage -lhbdebug -lhbvm -lhbrtl -l%_HB_GT_LIB% -lhblang -lhbrdd -lhbrtl -lhbvm -lhbmacro -lhbpp -lrddfpt -lrddntx -lrddcdx -lhbsix -lhbcommon -lhbpcre -lhbzlib
|
||||
if "%HB_COMPILER%" == "mingw32" gcc %1.c -o%1.exe %CFLAGS% -mno-cygwin -I%HB_INC_INSTALL% %HB_INC_TEMP% -L%HB_LIB_INSTALL% -lhbcpage -lhbdebug -lhbvm -lhbrtl -l%_HB_GT_LIB% -lhblang -lhbrdd -lhbrtl -lhbvm -lhbmacro -lhbpp -lrddfpt -lrddntx -lrddcdx -lhbsix -lhbcommon -lhbpcre -lhbzlib
|
||||
if "%HB_COMPILER%" == "rsxnt" gcc %1.c -Zwin32 %CFLAGS% -I%HB_INC_INSTALL% -L%HB_LIB_INSTALL% -lhbcpage -lhbdebug -lhbvm -lhbrtl -l%_HB_GT_LIB% -lhblang -lhbrdd -lhbrtl -lhbvm -lhbmacro -lhbpp -lrddfpt -lrddntx -lrddcdx -lhbsix -lhbcommon -lhbpcre -lhbzlib
|
||||
|
||||
if "%HB_COMPILER%" == "msvc" cl -TP -W3 %CFLAGS% -I%HB_INC_INSTALL% %1.c /link /subsystem:CONSOLE /LIBPATH:%HB_LIB_INSTALL% %HB_USER_LIBS% hbcpage.lib hbdebug.lib hbvm.lib hbrtl.lib %_HB_GT_LIB%.lib hblang.lib hbrdd.lib hbmacro.lib hbpp.lib rddntx.lib rddcdx.lib rddfpt.lib hbsix.lib hbcommon.lib hbpcre.lib user32.lib winspool.lib
|
||||
if "%HB_COMPILER%" == "msvc" cl -TP -W3 %CFLAGS% -I%HB_INC_INSTALL% %1.c /link /subsystem:CONSOLE /LIBPATH:%HB_LIB_INSTALL% %HB_USER_LIBS% hbcpage.lib hbdebug.lib hbvm.lib hbrtl.lib %_HB_GT_LIB%.lib hblang.lib hbrdd.lib hbmacro.lib hbpp.lib rddntx.lib rddcdx.lib rddfpt.lib hbsix.lib hbcommon.lib hbpcre.lib hbzlib.lib user32.lib winspool.lib
|
||||
if "%HB_COMPILER%" == "msvc" echo Ignore LNK4033 warning
|
||||
|
||||
:C_WATCOM
|
||||
@@ -240,6 +241,7 @@ if not "%HB_ARCHITECTURE%" == "w32" goto A_OS2
|
||||
echo LIB hbrdd.lib >> build.tmp
|
||||
echo LIB hbcommon.lib >> build.tmp
|
||||
echo LIB hbpcre.lib >> build.tmp
|
||||
echo LIB hbzlib.lib >> build.tmp
|
||||
echo LIB kernel32.lib >> build.tmp
|
||||
echo LIB user32.lib >> build.tmp
|
||||
echo LIB winspool.lib >> build.tmp
|
||||
@@ -255,8 +257,8 @@ if not "%HB_ARCHITECTURE%" == "w32" goto A_OS2
|
||||
|
||||
if "%HB_GT_LIB%" == "" set _HB_GT_LIB=gtos2
|
||||
|
||||
if "%HB_COMPILER%" == "gcc" gcc %1.c %CFLAGS% -I%HB_INC_INSTALL% -L%HB_LIB_INSTALL% -lhbcpage -lhbdebug -lhbvm -lhbrtl -l%_HB_GT_LIB% -lhblang -lhbrdd -lhbrtl -lhbvm -lhbmacro -lhbpp -lrddfpt -lrddntx -lrddcdx -lhbsix -lhbcommon -lhbpcre
|
||||
if "%HB_COMPILER%" == "icc" icc /Gs+ /W2 /Se /Sd+ /Ti+ /C- /Tp %CFLAGS% -I%HB_INC_INSTALL% %1.c %HB_LIB_INSTALL%\hbcpage.lib %HB_LIB_INSTALL%\hbdebug.lib %HB_LIB_INSTALL%\hbvm.lib %HB_LIB_INSTALL%\hbrtl.lib %HB_LIB_INSTALL%\%_HB_GT_LIB%.lib %HB_LIB_INSTALL%\hblang.lib %HB_LIB_INSTALL%\hbrdd.lib %HB_LIB_INSTALL%\hbrtl.lib %HB_LIB_INSTALL%\hbvm.lib %HB_LIB_INSTALL%\hbmacro.lib %HB_LIB_INSTALL%\hbpp.lib %HB_LIB_INSTALL%\rddfpt.lib %HB_LIB_INSTALL%\rddntx.lib %HB_LIB_INSTALL%\rddcdx.lib %HB_LIB_INSTALL%\hbsix.lib %HB_LIB_INSTALL%\hbcommon.lib %HB_LIB_INSTALL%\hbpcre.lib
|
||||
if "%HB_COMPILER%" == "gcc" gcc %1.c %CFLAGS% -I%HB_INC_INSTALL% -L%HB_LIB_INSTALL% -lhbcpage -lhbdebug -lhbvm -lhbrtl -l%_HB_GT_LIB% -lhblang -lhbrdd -lhbrtl -lhbvm -lhbmacro -lhbpp -lrddfpt -lrddntx -lrddcdx -lhbsix -lhbcommon -lhbpcre -lhbzlib
|
||||
if "%HB_COMPILER%" == "icc" icc /Gs+ /W2 /Se /Sd+ /Ti+ /C- /Tp %CFLAGS% -I%HB_INC_INSTALL% %1.c %HB_LIB_INSTALL%\hbcpage.lib %HB_LIB_INSTALL%\hbdebug.lib %HB_LIB_INSTALL%\hbvm.lib %HB_LIB_INSTALL%\hbrtl.lib %HB_LIB_INSTALL%\%_HB_GT_LIB%.lib %HB_LIB_INSTALL%\hblang.lib %HB_LIB_INSTALL%\hbrdd.lib %HB_LIB_INSTALL%\hbrtl.lib %HB_LIB_INSTALL%\hbvm.lib %HB_LIB_INSTALL%\hbmacro.lib %HB_LIB_INSTALL%\hbpp.lib %HB_LIB_INSTALL%\rddfpt.lib %HB_LIB_INSTALL%\rddntx.lib %HB_LIB_INSTALL%\rddcdx.lib %HB_LIB_INSTALL%\hbsix.lib %HB_LIB_INSTALL%\hbcommon.lib %HB_LIB_INSTALL%\hbpcre.lib %HB_LIB_INSTALL%\hbzlib.lib
|
||||
goto END
|
||||
|
||||
:A_LINUX
|
||||
@@ -265,7 +267,7 @@ if not "%HB_ARCHITECTURE%" == "w32" goto A_OS2
|
||||
|
||||
if "%HB_GT_LIB%" == "" set _HB_GT_LIB=gtstd
|
||||
|
||||
if "%HB_COMPILER%" == "gcc" gcc %1.c %CFLAGS% -I%HB_INC_INSTALL% -L../lib -lhbcpage -lhbdebug -lhbvm -lhbrtl -l%_HB_GT_LIB% -lhblang -lhbrdd -lhbrtl -lhbvm -lhbmacro -lhbpp -lrddfpt -lrddntx -lrddcdx -lhbsix -lhbcommon -lhbpcre
|
||||
if "%HB_COMPILER%" == "gcc" gcc %1.c %CFLAGS% -I%HB_INC_INSTALL% -L../lib -lhbcpage -lhbdebug -lhbvm -lhbrtl -l%_HB_GT_LIB% -lhblang -lhbrdd -lhbrtl -lhbvm -lhbmacro -lhbpp -lrddfpt -lrddntx -lrddcdx -lhbsix -lhbcommon -lhbpcre -lhbzlib
|
||||
goto END
|
||||
|
||||
:CLEANUP
|
||||
|
||||
@@ -70,8 +70,8 @@ if "%HB_INC_INSTALL%" == "" set HB_INC_INSTALL=..\include
|
||||
set _HB_GT_LIB=%HB_GT_LIB%
|
||||
if "%_HB_GT_LIB%" == "" set _HB_GT_LIB=gtos2
|
||||
|
||||
if "%HB_COMPILER%" == "gcc" gcc %1.c %CFLAGS% -I%HB_INC_INSTALL% -L%HB_LIB_INSTALL% -lhbcpage -lhbdebug -lhbvm -lhbrtl -l%_HB_GT_LIB% -lhblang -lhbrdd -lhbrtl -lhbvm -lhbmacro -lhbpp -lrddfpt -lrddntx -lrddcdx -lhbsix -lhbcommon
|
||||
if "%HB_COMPILER%" == "icc" icc /Gs+ /W2 /Se /Sd+ /Ti+ /C- /Tp %CFLAGS% -I%HB_INC_INSTALL% %1.c %HB_LIB_INSTALL%\hbcpage.lib %HB_LIB_INSTALL%\hbdebug.lib %HB_LIB_INSTALL%\hbvm.lib %HB_LIB_INSTALL%\hbrtl.lib %HB_LIB_INSTALL%\%_HB_GT_LIB%.lib %HB_LIB_INSTALL%\hblang.lib %HB_LIB_INSTALL%\hbrdd.lib %HB_LIB_INSTALL%\hbrtl.lib %HB_LIB_INSTALL%\hbvm.lib %HB_LIB_INSTALL%\hbmacro.lib %HB_LIB_INSTALL%\hbpp.lib %HB_LIB_INSTALL%\rddfpt.lib %HB_LIB_INSTALL%\rddntx.lib %HB_LIB_INSTALL%\rddcdx.lib %HB_LIB_INSTALL%\hbsix.lib %HB_LIB_INSTALL%\hbcommon.lib
|
||||
if "%HB_COMPILER%" == "gcc" gcc %1.c %CFLAGS% -I%HB_INC_INSTALL% -L%HB_LIB_INSTALL% -lhbcpage -lhbdebug -lhbvm -lhbrtl -l%_HB_GT_LIB% -lhblang -lhbrdd -lhbrtl -lhbvm -lhbmacro -lhbpp -lrddfpt -lrddntx -lrddcdx -lhbsix -lhbcommon -lhbpcre -lhbzlib
|
||||
if "%HB_COMPILER%" == "icc" icc /Gs+ /W2 /Se /Sd+ /Ti+ /C- /Tp %CFLAGS% -I%HB_INC_INSTALL% %1.c %HB_LIB_INSTALL%\hbcpage.lib %HB_LIB_INSTALL%\hbdebug.lib %HB_LIB_INSTALL%\hbvm.lib %HB_LIB_INSTALL%\hbrtl.lib %HB_LIB_INSTALL%\%_HB_GT_LIB%.lib %HB_LIB_INSTALL%\hblang.lib %HB_LIB_INSTALL%\hbrdd.lib %HB_LIB_INSTALL%\hbrtl.lib %HB_LIB_INSTALL%\hbvm.lib %HB_LIB_INSTALL%\hbmacro.lib %HB_LIB_INSTALL%\hbpp.lib %HB_LIB_INSTALL%\rddfpt.lib %HB_LIB_INSTALL%\rddntx.lib %HB_LIB_INSTALL%\rddcdx.lib %HB_LIB_INSTALL%\hbsix.lib %HB_LIB_INSTALL%\hbcommon.lib %HB_LIB_INSTALL%\hbpcre.lib %HB_LIB_INSTALL%\hbzlib.lib
|
||||
goto END
|
||||
|
||||
:CLEANUP
|
||||
|
||||
@@ -1,19 +0,0 @@
|
||||
#
|
||||
# $Id$
|
||||
#
|
||||
|
||||
ROOT = ../../
|
||||
|
||||
C_SOURCES =\
|
||||
ioapi.c \
|
||||
zip.c \
|
||||
unzip.c \
|
||||
hbzlib.c \
|
||||
hbmzip.c
|
||||
|
||||
PRG_HEADERS=\
|
||||
hbzlib.ch
|
||||
|
||||
LIBNAME=hbzlib
|
||||
|
||||
include $(TOP)$(ROOT)config/lib.cf
|
||||
@@ -1,20 +0,0 @@
|
||||
#
|
||||
# $Id$
|
||||
#
|
||||
|
||||
LIBNAME = $(LIBPREF)hbzlib
|
||||
|
||||
LIB_PATH = $(LIB_DIR)$(LIBNAME)$(LIBEXT)
|
||||
|
||||
PRG_HEADERS = \
|
||||
hbzlib.ch \
|
||||
|
||||
LIB_OBJS = \
|
||||
$(OBJ_DIR)ioapi$(OBJEXT) \
|
||||
$(OBJ_DIR)zip$(OBJEXT) \
|
||||
$(OBJ_DIR)unzip$(OBJEXT) \
|
||||
$(OBJ_DIR)hbzlib$(OBJEXT) \
|
||||
$(OBJ_DIR)hbmzip$(OBJEXT) \
|
||||
|
||||
all: \
|
||||
$(LIB_PATH) \
|
||||
@@ -1,130 +0,0 @@
|
||||
/* crypt.h -- base code for crypt/uncrypt ZIPfile
|
||||
|
||||
|
||||
Version 1.01e, February 12th, 2005
|
||||
|
||||
Copyright (C) 1998-2005 Gilles Vollant
|
||||
|
||||
This code is a modified version of crypting code in Infozip distribution
|
||||
|
||||
The encryption/decryption parts of this source code (as opposed to the
|
||||
non-echoing password parts) were originally written in Europe. The
|
||||
whole source package can be freely distributed, including from the USA.
|
||||
(Prior to January 2000, re-export from the US was a violation of US law.)
|
||||
|
||||
This encryption code is a direct transcription of the algorithm from
|
||||
Roger Schlafly, described by Phil Katz in the file appnote.txt. This
|
||||
file (appnote.txt) is distributed with the PKZIP program (even in the
|
||||
version without encryption capabilities).
|
||||
|
||||
If you don't need crypting in your application, just define symbols
|
||||
NOCRYPT and NOUNCRYPT.
|
||||
|
||||
This code support the "Traditional PKWARE Encryption".
|
||||
|
||||
The new AES encryption added on Zip format by Winzip (see the page
|
||||
http://www.winzip.com/aes_info.htm ) and PKWare PKZip 5.x Strong
|
||||
Encryption is not supported.
|
||||
*/
|
||||
|
||||
#define CRC32(c, b) ((*(pcrc_32_tab+(((int)(c) ^ (b)) & 0xff))) ^ ((c) >> 8))
|
||||
|
||||
/***********************************************************************
|
||||
* Return the next byte in the pseudo-random sequence
|
||||
*/
|
||||
static int decrypt_byte(unsigned long* pkeys, const unsigned long* pcrc_32_tab)
|
||||
{
|
||||
unsigned temp; /* POTENTIAL BUG: temp*(temp^1) may overflow in an
|
||||
* unpredictable manner on 16-bit systems; not a problem
|
||||
* with any known compiler so far, though */
|
||||
|
||||
(void) pcrc_32_tab;
|
||||
|
||||
temp = ((unsigned)(*(pkeys+2)) & 0xffff) | 2;
|
||||
return (int)(((temp * (temp ^ 1)) >> 8) & 0xff);
|
||||
}
|
||||
|
||||
/***********************************************************************
|
||||
* Update the encryption keys with the next byte of plain text
|
||||
*/
|
||||
static int update_keys(unsigned long* pkeys,const unsigned long* pcrc_32_tab,int c)
|
||||
{
|
||||
(*(pkeys+0)) = CRC32((*(pkeys+0)), c);
|
||||
(*(pkeys+1)) += (*(pkeys+0)) & 0xff;
|
||||
(*(pkeys+1)) = (*(pkeys+1)) * 134775813L + 1;
|
||||
{
|
||||
register int keyshift = (int)((*(pkeys+1)) >> 24);
|
||||
(*(pkeys+2)) = CRC32((*(pkeys+2)), keyshift);
|
||||
}
|
||||
return c;
|
||||
}
|
||||
|
||||
|
||||
/***********************************************************************
|
||||
* Initialize the encryption keys and the random header according to
|
||||
* the given password.
|
||||
*/
|
||||
static void init_keys(const char* passwd,unsigned long* pkeys,const unsigned long* pcrc_32_tab)
|
||||
{
|
||||
*(pkeys+0) = 305419896L;
|
||||
*(pkeys+1) = 591751049L;
|
||||
*(pkeys+2) = 878082192L;
|
||||
while (*passwd != '\0') {
|
||||
update_keys(pkeys,pcrc_32_tab,(int)*passwd);
|
||||
passwd++;
|
||||
}
|
||||
}
|
||||
|
||||
#define zdecode(pkeys,pcrc_32_tab,c) \
|
||||
(update_keys(pkeys,pcrc_32_tab,c ^= decrypt_byte(pkeys,pcrc_32_tab)))
|
||||
|
||||
#define zencode(pkeys,pcrc_32_tab,c,t) \
|
||||
(t=decrypt_byte(pkeys,pcrc_32_tab), update_keys(pkeys,pcrc_32_tab,c), t^(c))
|
||||
|
||||
#ifdef INCLUDECRYPTINGCODE_IFCRYPTALLOWED
|
||||
|
||||
#define RAND_HEAD_LEN 12
|
||||
/* "last resort" source for second part of crypt seed pattern */
|
||||
# ifndef ZCR_SEED2
|
||||
# define ZCR_SEED2 3141592654UL /* use PI as default pattern */
|
||||
# endif
|
||||
|
||||
static int crypthead(const char * passwd, unsigned char * buf, int bufSize,
|
||||
unsigned long * pkeys, const unsigned long * pcrc_32_tab,
|
||||
unsigned long crcForCrypting)
|
||||
{
|
||||
int n; /* index in random header */
|
||||
int t; /* temporary */
|
||||
int c; /* random byte */
|
||||
unsigned char header[RAND_HEAD_LEN-2]; /* random header */
|
||||
static unsigned calls = 0; /* ensure different random header each time */
|
||||
|
||||
if (bufSize<RAND_HEAD_LEN)
|
||||
return 0;
|
||||
|
||||
/* First generate RAND_HEAD_LEN-2 random bytes. We encrypt the
|
||||
* output of rand() to get less predictability, since rand() is
|
||||
* often poorly implemented.
|
||||
*/
|
||||
if (++calls == 1)
|
||||
{
|
||||
srand((unsigned)(time(NULL) ^ ZCR_SEED2));
|
||||
}
|
||||
init_keys(passwd, pkeys, pcrc_32_tab);
|
||||
for (n = 0; n < RAND_HEAD_LEN-2; n++)
|
||||
{
|
||||
c = (rand() >> 7) & 0xff;
|
||||
header[n] = (unsigned char)zencode(pkeys, pcrc_32_tab, c, t);
|
||||
}
|
||||
/* Encrypt random header (last two bytes is high word of crc) */
|
||||
init_keys(passwd, pkeys, pcrc_32_tab);
|
||||
for (n = 0; n < RAND_HEAD_LEN-2; n++)
|
||||
{
|
||||
buf[n] = (unsigned char)zencode(pkeys, pcrc_32_tab, header[n], t);
|
||||
}
|
||||
buf[n++] = zencode(pkeys, pcrc_32_tab, (int)(crcForCrypting >> 16) & 0xff, t);
|
||||
buf[n++] = zencode(pkeys, pcrc_32_tab, (int)(crcForCrypting >> 24) & 0xff, t);
|
||||
return n;
|
||||
}
|
||||
|
||||
#endif
|
||||
@@ -1,779 +0,0 @@
|
||||
/*
|
||||
* $Id$
|
||||
*/
|
||||
|
||||
/*
|
||||
* Harbour Project source code:
|
||||
* Wrapper functions for minizip library
|
||||
* Some higher level zip archive functions
|
||||
*
|
||||
* Copyright 2008 Mindaugas Kavaliauskas <dbtopas.at.dbtopas.lt>
|
||||
* www - http://www.harbour-project.org
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; either version 2, or (at your option)
|
||||
* any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this software; see the file COPYING. If not, write to
|
||||
* the Free Software Foundation, Inc., 59 Temple Place, Suite 330,
|
||||
* Boston, MA 02111-1307 USA (or visit the web site http://www.gnu.org/).
|
||||
*
|
||||
* As a special exception, the Harbour Project gives permission for
|
||||
* additional uses of the text contained in its release of Harbour.
|
||||
*
|
||||
* The exception is that, if you link the Harbour libraries with other
|
||||
* files to produce an executable, this does not by itself cause the
|
||||
* resulting executable to be covered by the GNU General Public License.
|
||||
* Your use of that executable is in no way restricted on account of
|
||||
* linking the Harbour library code into it.
|
||||
*
|
||||
* This exception does not however invalidate any other reasons why
|
||||
* the executable file might be covered by the GNU General Public License.
|
||||
*
|
||||
* This exception applies only to the code released by the Harbour
|
||||
* Project under the name Harbour. If you copy code from other
|
||||
* Harbour Project or Free Software Foundation releases into a copy of
|
||||
* Harbour, as the General Public License permits, the exception does
|
||||
* not apply to the code that you add in this way. To avoid misleading
|
||||
* anyone as to the status of such modified files, you must delete
|
||||
* this exception notice from them.
|
||||
*
|
||||
* If you write modifications of your own for Harbour, it is your choice
|
||||
* whether to permit this exception to apply to your modifications.
|
||||
* If you do not wish that, delete this exception notice.
|
||||
*
|
||||
*/
|
||||
|
||||
|
||||
#include "hbapi.h"
|
||||
#include "hbapiitm.h"
|
||||
#include "hbapierr.h"
|
||||
#include "hbdate.h"
|
||||
#include "hbset.h"
|
||||
#include "zip.h"
|
||||
#include "unzip.h"
|
||||
|
||||
#if defined( HB_OS_WIN_32 )
|
||||
#include "windows.h"
|
||||
#elif defined( HB_OS_UNIX )
|
||||
#include <sys/types.h>
|
||||
#include <sys/stat.h>
|
||||
#include <unistd.h>
|
||||
#include <time.h>
|
||||
#include <utime.h>
|
||||
#endif
|
||||
|
||||
|
||||
static HB_GARBAGE_FUNC( hb_zipfile_destructor )
|
||||
{
|
||||
zipFile* phZip = (zipFile*) Cargo;
|
||||
|
||||
if( * phZip )
|
||||
{
|
||||
zipClose( * phZip, NULL );
|
||||
* phZip = NULL;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
static gzFile hb_zipfileParam( int iParam )
|
||||
{
|
||||
zipFile* phZip = ( zipFile* ) hb_parptrGC( hb_zipfile_destructor, iParam );
|
||||
|
||||
if( phZip && * phZip )
|
||||
return * phZip;
|
||||
|
||||
hb_errRT_BASE_SubstR( EG_ARG, 3012, NULL, &hb_errFuncName, HB_ERR_ARGS_BASEPARAMS );
|
||||
return NULL;
|
||||
}
|
||||
|
||||
|
||||
static HB_GARBAGE_FUNC( hb_unzipfile_destructor )
|
||||
{
|
||||
unzFile* phUnzip = (unzFile*) Cargo;
|
||||
|
||||
if( * phUnzip )
|
||||
{
|
||||
unzClose( * phUnzip );
|
||||
* phUnzip = NULL;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
static gzFile hb_unzipfileParam( int iParam )
|
||||
{
|
||||
unzFile* phUnzip = ( unzFile* ) hb_parptrGC( hb_unzipfile_destructor, iParam );
|
||||
|
||||
if( phUnzip && * phUnzip )
|
||||
return * phUnzip;
|
||||
|
||||
hb_errRT_BASE_SubstR( EG_ARG, 3012, NULL, &hb_errFuncName, HB_ERR_ARGS_BASEPARAMS );
|
||||
return NULL;
|
||||
}
|
||||
|
||||
|
||||
|
||||
/* HB_ZipOpen( cFileName, [ iMode = HB_ZIP_CREATE ] ) --> hZip */
|
||||
HB_FUNC( HB_ZIPOPEN )
|
||||
{
|
||||
char* szFileName = hb_parc( 1 );
|
||||
int iMode = APPEND_STATUS_CREATE;
|
||||
|
||||
if( ISNUM( 2 ) )
|
||||
iMode = hb_parni( 2 );
|
||||
|
||||
if( szFileName )
|
||||
{
|
||||
zipFile hZip = zipOpen( szFileName, iMode );
|
||||
if( hZip )
|
||||
{
|
||||
zipFile* phZip = (zipFile*) hb_gcAlloc( sizeof( zipFile ), hb_zipfile_destructor );
|
||||
|
||||
* phZip = hZip;
|
||||
hb_retptrGC( phZip );
|
||||
}
|
||||
}
|
||||
else
|
||||
hb_errRT_BASE_SubstR( EG_ARG, 3012, NULL, &hb_errFuncName, HB_ERR_ARGS_BASEPARAMS );
|
||||
}
|
||||
|
||||
|
||||
/* HB_ZipClose( hZip ) --> nError */
|
||||
HB_FUNC( HB_ZIPCLOSE )
|
||||
{
|
||||
zipFile* phZip = ( zipFile* ) hb_parptrGC( hb_zipfile_destructor, 1 );
|
||||
|
||||
if( phZip && * phZip )
|
||||
{
|
||||
zipFile hZip = * phZip;
|
||||
|
||||
* phZip = NULL;
|
||||
hb_retni( zipClose( hZip, NULL ) );
|
||||
}
|
||||
else
|
||||
hb_errRT_BASE_SubstR( EG_ARG, 3012, NULL, &hb_errFuncName, HB_ERR_ARGS_BASEPARAMS );
|
||||
}
|
||||
|
||||
|
||||
/* HB_ZipFileCreate( hZip, cZipName, dDate, cTime, nInternalAttr, nExternalAttr,
|
||||
[ nMethod = HB_ZLIB_METHOD_DEFLATE ],
|
||||
[ nLevel = HB_ZLIB_COMPRESSION_DEFAULT ],
|
||||
[ cPassword ] ) --> nError */
|
||||
HB_FUNC( HB_ZIPFILECREATE )
|
||||
{
|
||||
char* szZipName = hb_parc( 2 );
|
||||
int iMethod = Z_DEFLATED, iLevel = Z_DEFAULT_COMPRESSION, iY, iM, iD;
|
||||
|
||||
|
||||
if( szZipName )
|
||||
{
|
||||
zipFile hZip = hb_zipfileParam( 1 );
|
||||
zip_fileinfo zfi;
|
||||
|
||||
memset( &zfi, 0, sizeof( zfi ) );
|
||||
|
||||
hb_dateDecode( hb_pardl( 3 ), &iY, &iM, &iD );
|
||||
zfi.tmz_date.tm_year = iY;
|
||||
zfi.tmz_date.tm_mon = iM - 1;
|
||||
zfi.tmz_date.tm_mday = iD;
|
||||
|
||||
hb_timeStrGet( hb_parc( 4 ), &iY, &iM, &iD, NULL );
|
||||
zfi.tmz_date.tm_hour = iY;
|
||||
zfi.tmz_date.tm_min = iM;
|
||||
zfi.tmz_date.tm_sec = iD;
|
||||
|
||||
if( ISNUM( 7 ) )
|
||||
iMethod = hb_parni( 7 );
|
||||
|
||||
if( ISNUM( 8 ) )
|
||||
iLevel = hb_parni( 8 );
|
||||
|
||||
if( hZip )
|
||||
hb_retni( zipOpenNewFileInZip3( hZip, szZipName, &zfi,
|
||||
NULL, 0, NULL, 0, NULL, iMethod, iLevel, 0,
|
||||
-MAX_WBITS, DEF_MEM_LEVEL, Z_DEFAULT_STRATEGY,
|
||||
hb_parc( 9 ), 0 ) );
|
||||
}
|
||||
else
|
||||
hb_errRT_BASE_SubstR( EG_ARG, 3012, NULL, &hb_errFuncName, HB_ERR_ARGS_BASEPARAMS );
|
||||
}
|
||||
|
||||
|
||||
/* HB_ZipFileWrite( hZip, cData [, nLen ] ) --> nError */
|
||||
HB_FUNC( HB_ZIPFILEWRITE )
|
||||
{
|
||||
char* pData = hb_parc( 2 );
|
||||
|
||||
if( pData )
|
||||
{
|
||||
zipFile hZip = hb_zipfileParam( 1 );
|
||||
ULONG ulLen = hb_parclen( 2 );
|
||||
|
||||
if( ISNUM( 3 ) && (ULONG) hb_parnl( 3 ) < ulLen )
|
||||
ulLen = (ULONG) hb_parnl( 3 );
|
||||
|
||||
if( hZip )
|
||||
hb_retni( zipWriteInFileInZip( hZip, (void*) pData, ulLen ) );
|
||||
}
|
||||
else
|
||||
hb_errRT_BASE_SubstR( EG_ARG, 3012, NULL, &hb_errFuncName, HB_ERR_ARGS_BASEPARAMS );
|
||||
}
|
||||
|
||||
|
||||
/* HB_ZipFileClose( hZip ) --> nError */
|
||||
HB_FUNC( HB_ZIPFILECLOSE )
|
||||
{
|
||||
zipFile hZip = hb_zipfileParam( 1 );
|
||||
|
||||
if( hZip )
|
||||
hb_retni( zipCloseFileInZip( hZip ) );
|
||||
}
|
||||
|
||||
|
||||
/* HB_UnzipOpen( cFileName ) --> hUnzip */
|
||||
HB_FUNC( HB_UNZIPOPEN )
|
||||
{
|
||||
char* szFileName = hb_parc( 1 );
|
||||
|
||||
if( szFileName )
|
||||
{
|
||||
unzFile hUnzip = unzOpen( szFileName );
|
||||
if( hUnzip )
|
||||
{
|
||||
unzFile* phUnzip = (unzFile*) hb_gcAlloc( sizeof( unzFile ), hb_unzipfile_destructor );
|
||||
|
||||
* phUnzip = hUnzip;
|
||||
hb_retptrGC( phUnzip );
|
||||
}
|
||||
}
|
||||
else
|
||||
hb_errRT_BASE_SubstR( EG_ARG, 3012, NULL, &hb_errFuncName, HB_ERR_ARGS_BASEPARAMS );
|
||||
}
|
||||
|
||||
|
||||
/* HB_UnzipClose( hUnzip ) --> nError */
|
||||
HB_FUNC( HB_UNZIPCLOSE )
|
||||
{
|
||||
unzFile* phUnzip = ( unzFile* ) hb_parptrGC( hb_unzipfile_destructor, 1 );
|
||||
|
||||
if( phUnzip && * phUnzip )
|
||||
{
|
||||
unzFile hUnzip = * phUnzip;
|
||||
|
||||
* phUnzip = NULL;
|
||||
hb_retni( unzClose( hUnzip ) );
|
||||
}
|
||||
else
|
||||
hb_errRT_BASE_SubstR( EG_ARG, 3012, NULL, &hb_errFuncName, HB_ERR_ARGS_BASEPARAMS );
|
||||
}
|
||||
|
||||
|
||||
/* HB_UnzipFileFirst( hUnzip ) --> nError */
|
||||
HB_FUNC( HB_UNZIPFILEFIRST )
|
||||
{
|
||||
unzFile hUnzip = hb_unzipfileParam( 1 );
|
||||
|
||||
if( hUnzip )
|
||||
hb_retni( unzGoToFirstFile( hUnzip ) );
|
||||
}
|
||||
|
||||
|
||||
/* HB_UnzipFileNext( hUnzip ) --> nError */
|
||||
HB_FUNC( HB_UNZIPFILENEXT )
|
||||
{
|
||||
unzFile hUnzip = hb_unzipfileParam( 1 );
|
||||
|
||||
if( hUnzip )
|
||||
hb_retni( unzGoToNextFile( hUnzip ) );
|
||||
}
|
||||
|
||||
|
||||
/* HB_UnzipFilePos( hUnzip ) --> nPosition */
|
||||
HB_FUNC( HB_UNZIPFILEPOS )
|
||||
{
|
||||
unzFile hUnzip = hb_unzipfileParam( 1 );
|
||||
|
||||
if( hUnzip )
|
||||
hb_retnint( unzGetOffset( hUnzip ) );
|
||||
}
|
||||
|
||||
|
||||
/* HB_UnzipFileGoto( hUnzip, nPosition ) --> nError */
|
||||
HB_FUNC( HB_UNZIPFILEGOTO )
|
||||
{
|
||||
unzFile hUnzip = hb_unzipfileParam( 1 );
|
||||
|
||||
if( hUnzip )
|
||||
hb_retni( unzSetOffset( hUnzip, (ULONG) hb_parnint( 2 ) ) );
|
||||
}
|
||||
|
||||
|
||||
/* HB_UnzipFileInfo( hUnzip, @cZipName, @dDate, @cTime, @nInternalAttr, @nExternalAttr,
|
||||
@nMethod, @nSize, @nCompressedSize ) --> nError */
|
||||
HB_FUNC( HB_UNZIPFILEINFO )
|
||||
{
|
||||
unzFile hUnzip = hb_unzipfileParam( 1 );
|
||||
char szFileName[ _POSIX_PATH_MAX + 1 ];
|
||||
unz_file_info ufi;
|
||||
int iResult;
|
||||
PHB_ITEM pItem;
|
||||
char buf[ 16 ];
|
||||
|
||||
if( hUnzip )
|
||||
{
|
||||
iResult = unzGetCurrentFileInfo( hUnzip, &ufi, szFileName, _POSIX_PATH_MAX,
|
||||
NULL, 0, NULL, 0 );
|
||||
hb_retni( iResult );
|
||||
|
||||
if ( iResult == UNZ_OK )
|
||||
{
|
||||
hb_storc( szFileName, 2 );
|
||||
|
||||
pItem = hb_itemPutD( NULL, ufi.tmu_date.tm_year, ufi.tmu_date.tm_mon + 1,
|
||||
ufi.tmu_date.tm_mday );
|
||||
hb_itemParamStoreForward( 3, pItem );
|
||||
hb_itemRelease( pItem );
|
||||
|
||||
|
||||
snprintf( buf, sizeof( buf ), "%02d:%02d:%02d", ufi.tmu_date.tm_hour,
|
||||
ufi.tmu_date.tm_min, ufi.tmu_date.tm_sec );
|
||||
hb_storc( buf, 4 );
|
||||
hb_stornl( ufi.internal_fa, 5 );
|
||||
hb_stornl( ufi.external_fa, 6 );
|
||||
hb_stornl( ufi.compression_method, 7 );
|
||||
hb_stornl( ufi.uncompressed_size, 8 );
|
||||
hb_stornl( ufi.compressed_size, 9 );
|
||||
}
|
||||
else
|
||||
{
|
||||
hb_storc( "", 2 );
|
||||
|
||||
pItem = hb_itemPutDL( NULL, 0 );
|
||||
hb_itemParamStoreForward( 3, pItem );
|
||||
hb_itemRelease( pItem );
|
||||
|
||||
hb_storc( "", 4 );
|
||||
hb_stornl( 0, 5 );
|
||||
hb_stornl( 0, 6 );
|
||||
hb_stornl( 0, 7 );
|
||||
hb_stornl( 0, 8 );
|
||||
hb_stornl( 0, 9 );
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/* HB_UnzipFileOpen( hUnzip ) --> nError */
|
||||
HB_FUNC( HB_UNZIPFILEOPEN )
|
||||
{
|
||||
unzFile hUnzip = hb_unzipfileParam( 1 );
|
||||
|
||||
if( hUnzip )
|
||||
hb_retni( unzOpenCurrentFilePassword( hUnzip, hb_parc( 2 ) ) );
|
||||
}
|
||||
|
||||
|
||||
/* HB_UnzipFileRead( hUnzip, @cBuf [, nLen ] ) --> nRead */
|
||||
HB_FUNC( HB_UNZIPFILEREAD )
|
||||
{
|
||||
unzFile hUnzip = hb_unzipfileParam( 1 );
|
||||
PHB_ITEM pBuffer = hb_param( 2, HB_IT_STRING );
|
||||
ULONG ulRead, ulSize;
|
||||
int iResult;
|
||||
|
||||
if( pBuffer && ISBYREF( 2 ) )
|
||||
{
|
||||
if( hUnzip )
|
||||
{
|
||||
ulSize = hb_parclen( 2 );
|
||||
|
||||
if( ISNUM( 3 ) )
|
||||
{
|
||||
ulRead = (ULONG) hb_parnl( 3 );
|
||||
if( ulRead < ulSize )
|
||||
ulSize = ulRead;
|
||||
}
|
||||
|
||||
pBuffer = hb_itemUnShareString( pBuffer );
|
||||
iResult = unzReadCurrentFile( hUnzip, hb_itemGetCPtr( pBuffer ), ulSize );
|
||||
hb_retnl( iResult );
|
||||
}
|
||||
}
|
||||
else
|
||||
hb_errRT_BASE_SubstR( EG_ARG, 3012, NULL, &hb_errFuncName, HB_ERR_ARGS_BASEPARAMS );
|
||||
}
|
||||
|
||||
|
||||
/* HB_UnzipFileClose( hUnzip ) --> nError */
|
||||
HB_FUNC( HB_UNZIPFILECLOSE )
|
||||
{
|
||||
unzFile hUnzip = hb_unzipfileParam( 1 );
|
||||
|
||||
if( hUnzip )
|
||||
hb_retni( unzCloseCurrentFile( hUnzip ) );
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
*
|
||||
* Higher level functions - not a wrappers of minizip code
|
||||
*
|
||||
*/
|
||||
|
||||
static int hb_zipStoreFile( zipFile hZip, char* szFileName, char* szName, char* szPassword )
|
||||
{
|
||||
char * szZipName, * pString;
|
||||
FHANDLE hFile;
|
||||
ULONG ulLen, ulExtAttr;
|
||||
zip_fileinfo zfi;
|
||||
int iResult;
|
||||
BOOL fError;
|
||||
|
||||
|
||||
if( szName )
|
||||
{
|
||||
/* change path separators to '/' */
|
||||
szZipName = hb_strdup( szName );
|
||||
|
||||
ulLen = strlen( szZipName );
|
||||
pString = szZipName;
|
||||
while( ulLen-- )
|
||||
{
|
||||
if( pString[ ulLen ] == '\\' )
|
||||
pString[ ulLen ] = '/';
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
/* get file name */
|
||||
szZipName = hb_strdup( szFileName );
|
||||
|
||||
ulLen = strlen( szZipName );
|
||||
pString = szZipName;
|
||||
|
||||
while( ulLen-- )
|
||||
{
|
||||
if( pString[ ulLen ] == '/' || pString[ ulLen ] == '\\' )
|
||||
{
|
||||
memmove( szZipName, &pString[ ulLen + 1 ], strlen( szZipName ) - ulLen );
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
memset( &zfi, 0, sizeof( zfi ) );
|
||||
fError = FALSE;
|
||||
|
||||
#if defined( HB_OS_WIN_32 )
|
||||
{
|
||||
ulExtAttr = GetFileAttributesA( szFileName );
|
||||
|
||||
if( (LONG) ulExtAttr != -1 )
|
||||
{
|
||||
ulExtAttr = GetFileAttributesA( szFileName ) &
|
||||
( FILE_ATTRIBUTE_READONLY | FILE_ATTRIBUTE_HIDDEN |
|
||||
FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_DIRECTORY |
|
||||
FILE_ATTRIBUTE_ARCHIVE );
|
||||
|
||||
ulExtAttr |= 0x01B60000; /* rw-rw-rw- */
|
||||
|
||||
if( ulExtAttr & FILE_ATTRIBUTE_DIRECTORY )
|
||||
ulExtAttr |= 0x40000000;
|
||||
else
|
||||
ulExtAttr |= 0x80000000;
|
||||
|
||||
ulLen = strlen( szZipName );
|
||||
if( ulLen > 4 )
|
||||
{
|
||||
pString = &szZipName[ ulLen - 4 ];
|
||||
if( hb_stricmp( pString, ".exe" ) == 0 || hb_stricmp( pString, ".com" ) == 0 ||
|
||||
hb_stricmp( pString, ".bat" ) == 0 )
|
||||
{
|
||||
ulExtAttr |= 0x00490000; /* --x--x--x */
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
fError = TRUE;
|
||||
}
|
||||
#elif defined( HB_OS_UNIX )
|
||||
{
|
||||
struct stat statbuf;
|
||||
struct tm st;
|
||||
|
||||
ulExtAttr = 0;
|
||||
|
||||
if( stat( szFileName, &statbuf ) == 0 )
|
||||
{
|
||||
if( S_ISDIR( statbuf.st_mode ) )
|
||||
{
|
||||
ulExtAttr |= 0x40000000;
|
||||
ulExtAttr |= 0x10; /* FILE_ATTRIBUTE_DIRECTORY */
|
||||
}
|
||||
else
|
||||
{
|
||||
ulExtAttr |= 0x80000000;
|
||||
ulExtAttr |= 0x20; /* FILE_ATTRIBUTE_ARCHIVE */
|
||||
}
|
||||
|
||||
ulExtAttr |= ( statbuf.st_mode & S_IRWXO ) << 16;
|
||||
ulExtAttr |= ( statbuf.st_mode & S_IRWXG ) << 15;
|
||||
ulExtAttr |= ( statbuf.st_mode & S_IRWXU ) << 14;
|
||||
|
||||
#if defined( HB_OS_LINUX ) && !defined( __WATCOMC__ )
|
||||
localtime_r( &statbuf.st_mtime, &st );
|
||||
#else
|
||||
memcpy( &st, localtime( &statbuf.st_mtime ), sizeof( st ) );
|
||||
#endif
|
||||
|
||||
zfi.tmz_date.tm_sec = st.tm_sec;
|
||||
zfi.tmz_date.tm_min = st.tm_min;
|
||||
zfi.tmz_date.tm_hour = st.tm_hour;
|
||||
zfi.tmz_date.tm_mday = st.tm_mday;
|
||||
zfi.tmz_date.tm_mon = st.tm_mon - 1;
|
||||
zfi.tmz_date.tm_year = st.tm_year;
|
||||
}
|
||||
else
|
||||
fError = TRUE;
|
||||
}
|
||||
#else
|
||||
{
|
||||
int TODO; /* To force warning */
|
||||
|
||||
ulExtAttr = 0x81B60020; /* FILE_ATTRIBUTE_ARCHIVE | rw-rw-rw- */
|
||||
}
|
||||
#endif
|
||||
zfi.external_fa = ulExtAttr;
|
||||
|
||||
/* TODO: zip.exe test: 0 for binary file, 1 for text. Does not depend on
|
||||
extension. We should analyse content of file to determine this??? */
|
||||
zfi.internal_fa = 0;
|
||||
|
||||
if( fError )
|
||||
{
|
||||
hb_xfree( szZipName );
|
||||
return -200;
|
||||
}
|
||||
|
||||
if( ulExtAttr & 0x40000000 )
|
||||
{
|
||||
iResult = zipOpenNewFileInZip3( hZip, szZipName, &zfi, NULL, 0, NULL, 0, NULL,
|
||||
Z_DEFLATED, Z_DEFAULT_COMPRESSION, 0,
|
||||
-MAX_WBITS, DEF_MEM_LEVEL, Z_DEFAULT_STRATEGY,
|
||||
szPassword, 0 );
|
||||
if( iResult == 0 )
|
||||
zipCloseFileInZip( hZip );
|
||||
}
|
||||
else
|
||||
{
|
||||
hFile = hb_fsOpen( (BYTE*) szFileName, FO_READ );
|
||||
|
||||
if( hFile != FS_ERROR )
|
||||
{
|
||||
#if defined( HB_OS_WIN_32 )
|
||||
{
|
||||
FILETIME ftutc, ft;
|
||||
SYSTEMTIME st;
|
||||
|
||||
if( GetFileTime( ( HANDLE ) hb_fsGetOsHandle( hFile ), NULL, NULL, &ftutc ) &&
|
||||
FileTimeToLocalFileTime( &ftutc, &ft ) &
|
||||
FileTimeToSystemTime( &ft, &st ) )
|
||||
{
|
||||
zfi.tmz_date.tm_sec = st.wSecond;
|
||||
zfi.tmz_date.tm_min = st.wMinute;
|
||||
zfi.tmz_date.tm_hour = st.wHour;
|
||||
zfi.tmz_date.tm_mday = st.wDay;
|
||||
zfi.tmz_date.tm_mon = st.wMonth - 1;
|
||||
zfi.tmz_date.tm_year = st.wYear;
|
||||
}
|
||||
}
|
||||
#endif
|
||||
iResult = zipOpenNewFileInZip3( hZip, szZipName, &zfi, NULL, 0, NULL, 0, NULL,
|
||||
Z_DEFLATED, Z_DEFAULT_COMPRESSION, 0,
|
||||
-MAX_WBITS, DEF_MEM_LEVEL, Z_DEFAULT_STRATEGY,
|
||||
szPassword, 0 );
|
||||
if( iResult == 0 )
|
||||
{
|
||||
pString = (char*) hb_xgrab( 1024 * 16 );
|
||||
while ( ( ulLen = hb_fsReadLarge( hFile, (BYTE*) pString, 1024 * 16 ) ) > 0 )
|
||||
{
|
||||
zipWriteInFileInZip( hZip, pString, ulLen );
|
||||
}
|
||||
hb_xfree( pString );
|
||||
|
||||
zipCloseFileInZip( hZip );
|
||||
}
|
||||
hb_fsClose( hFile );
|
||||
}
|
||||
else
|
||||
{
|
||||
iResult = -200 - hb_fsError();
|
||||
}
|
||||
}
|
||||
hb_xfree( szZipName );
|
||||
return iResult;
|
||||
}
|
||||
|
||||
|
||||
/* HB_ZipStoreFile( hZip, cFileName, [ cZipName ], [ cPassword ] ) --> nError */
|
||||
HB_FUNC( HB_ZIPSTOREFILE )
|
||||
{
|
||||
char* szFileName = hb_parc( 2 );
|
||||
|
||||
if( szFileName )
|
||||
{
|
||||
zipFile hZip = hb_zipfileParam( 1 );
|
||||
|
||||
if( hZip )
|
||||
hb_retni( hb_zipStoreFile( hZip, szFileName, hb_parc( 3 ), hb_parc( 4 ) ) );
|
||||
}
|
||||
else
|
||||
hb_errRT_BASE_SubstR( EG_ARG, 3012, NULL, &hb_errFuncName, HB_ERR_ARGS_BASEPARAMS );
|
||||
}
|
||||
|
||||
|
||||
static int hb_unzipExtractCurrentFile( unzFile hUnzip, char* szFileName, char* szPassword )
|
||||
{
|
||||
char szName[ _POSIX_PATH_MAX + 1 ];
|
||||
ULONG ulPos, ulLen;
|
||||
char cSep, * pString;
|
||||
unz_file_info ufi;
|
||||
int iResult;
|
||||
FHANDLE hFile;
|
||||
|
||||
iResult = unzGetCurrentFileInfo( hUnzip, &ufi, szName, _POSIX_PATH_MAX,
|
||||
NULL, 0, NULL, 0 );
|
||||
if( iResult != 0 )
|
||||
return iResult;
|
||||
|
||||
iResult = unzOpenCurrentFilePassword( hUnzip, szPassword );
|
||||
|
||||
if( iResult != 0 )
|
||||
return iResult;
|
||||
|
||||
if( szFileName )
|
||||
{
|
||||
hb_strncpy( szName, szFileName, sizeof( szName ) - 1 );
|
||||
}
|
||||
|
||||
ulLen = strlen( szName );
|
||||
|
||||
/* Test shows that files in subfolders can be stored to zip file without
|
||||
explicitly adding folder. So, let's create a requred path */
|
||||
|
||||
ulPos = 1;
|
||||
while( ulPos < ulLen )
|
||||
{
|
||||
cSep = szName[ ulPos ];
|
||||
|
||||
/* allow both path separators, ignore terminating path separator */
|
||||
if( ( cSep == '\\' || cSep == '/' ) && ulPos < ulLen - 1 )
|
||||
{
|
||||
szName[ ulPos ] = '\0';
|
||||
hb_fsMkDir( (BYTE*) szName );
|
||||
szName[ ulPos ] = cSep;
|
||||
}
|
||||
ulPos++;
|
||||
}
|
||||
|
||||
if( ufi.external_fa & 0x40000000 ) /* DIRECTORY */
|
||||
{
|
||||
hb_fsMkDir( (BYTE*) szName );
|
||||
iResult = 0;
|
||||
}
|
||||
else
|
||||
{
|
||||
hFile = hb_fsCreate( (BYTE*) szName, 0 );
|
||||
|
||||
if( hFile != FS_ERROR )
|
||||
{
|
||||
pString = (char*) hb_xgrab( 1024 * 16 );
|
||||
|
||||
while ( ( iResult = unzReadCurrentFile( hUnzip, pString, 16 * 1024 ) ) > 0 )
|
||||
{
|
||||
hb_fsWriteLarge( hFile, (BYTE*) pString, (ULONG) iResult );
|
||||
}
|
||||
hb_xfree( pString );
|
||||
|
||||
#if defined( HB_OS_WIN_32 )
|
||||
{
|
||||
FILETIME ftutc, ft;
|
||||
SYSTEMTIME st;
|
||||
|
||||
st.wSecond = ufi.tmu_date.tm_sec;
|
||||
st.wMinute = ufi.tmu_date.tm_min;
|
||||
st.wHour = ufi.tmu_date.tm_hour;
|
||||
st.wDay = ufi.tmu_date.tm_mday;
|
||||
st.wMonth = ufi.tmu_date.tm_mon + 1;
|
||||
st.wYear = ufi.tmu_date.tm_year;
|
||||
st.wMilliseconds = 0;
|
||||
|
||||
if( SystemTimeToFileTime( &st, &ft ) &&
|
||||
LocalFileTimeToFileTime( &ft, &ftutc ) )
|
||||
{
|
||||
SetFileTime( ( HANDLE ) hb_fsGetOsHandle( hFile ), &ftutc, &ftutc, &ftutc );
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
hb_fsClose( hFile );
|
||||
}
|
||||
else
|
||||
{
|
||||
iResult = -200 - hb_fsError();
|
||||
}
|
||||
}
|
||||
unzCloseCurrentFile( hUnzip );
|
||||
|
||||
|
||||
#if defined( HB_OS_WIN_32 )
|
||||
{
|
||||
SetFileAttributesA( szName, ufi.external_fa & 0xFF );
|
||||
}
|
||||
#elif defined( HB_OS_UNIX )
|
||||
{
|
||||
struct utimbuf utim;
|
||||
struct tm st;
|
||||
|
||||
chmod( szName, ( ufi.external_fa & 0x00070000 ) >> 16 |
|
||||
( ufi.external_fa & 0x00380000 ) >> 15 |
|
||||
( ufi.external_fa & 0x01C00000 ) >> 13 );
|
||||
|
||||
st.tm_sec = ufi.tmu_date.tm_sec;
|
||||
st.tm_min = ufi.tmu_date.tm_min;
|
||||
st.tm_hour = ufi.tmu_date.tm_hour;
|
||||
st.tm_mday = ufi.tmu_date.tm_mday;
|
||||
st.tm_mon = ufi.tmu_date.tm_mon + 1;
|
||||
st.tm_year = ufi.tmu_date.tm_year;
|
||||
|
||||
utim.actime = mktime( &st );
|
||||
utim.modtime = utim.actime;
|
||||
|
||||
utime( szName, &utim );
|
||||
}
|
||||
#else
|
||||
{
|
||||
int TODO; /* To force warning */
|
||||
}
|
||||
#endif
|
||||
|
||||
return iResult;
|
||||
}
|
||||
|
||||
|
||||
/* HB_UnzipExtractCurrentFile( hZip, [ cFileName ], [ cPassword ] ) --> nError */
|
||||
HB_FUNC( HB_UNZIPEXTRACTCURRENTFILE )
|
||||
{
|
||||
unzFile hUnzip = hb_unzipfileParam( 1 );
|
||||
|
||||
if( hUnzip )
|
||||
hb_retni( hb_unzipExtractCurrentFile( hUnzip, hb_parc( 2 ), hb_parc( 3 ) ) );
|
||||
}
|
||||
|
||||
@@ -1,542 +0,0 @@
|
||||
/*
|
||||
* $Id$
|
||||
*/
|
||||
|
||||
/*
|
||||
* Harbour Project source code:
|
||||
* ZLIB functions wrapper
|
||||
*
|
||||
* Copyright 2007 Przemyslaw Czerpak <druzus / at / priv.onet.pl>
|
||||
* www - http://www.harbour-project.org
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; either version 2, or (at your option)
|
||||
* any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this software; see the file COPYING. If not, write to
|
||||
* the Free Software Foundation, Inc., 59 Temple Place, Suite 330,
|
||||
* Boston, MA 02111-1307 USA (or visit the web site http://www.gnu.org/).
|
||||
*
|
||||
* As a special exception, the Harbour Project gives permission for
|
||||
* additional uses of the text contained in its release of Harbour.
|
||||
*
|
||||
* The exception is that, if you link the Harbour libraries with other
|
||||
* files to produce an executable, this does not by itself cause the
|
||||
* resulting executable to be covered by the GNU General Public License.
|
||||
* Your use of that executable is in no way restricted on account of
|
||||
* linking the Harbour library code into it.
|
||||
*
|
||||
* This exception does not however invalidate any other reasons why
|
||||
* the executable file might be covered by the GNU General Public License.
|
||||
*
|
||||
* This exception applies only to the code released by the Harbour
|
||||
* Project under the name Harbour. If you copy code from other
|
||||
* Harbour Project or Free Software Foundation releases into a copy of
|
||||
* Harbour, as the General Public License permits, the exception does
|
||||
* not apply to the code that you add in this way. To avoid misleading
|
||||
* anyone as to the status of such modified files, you must delete
|
||||
* this exception notice from them.
|
||||
*
|
||||
* If you write modifications of your own for Harbour, it is your choice
|
||||
* whether to permit this exception to apply to your modifications.
|
||||
* If you do not wish that, delete this exception notice.
|
||||
*
|
||||
*/
|
||||
|
||||
#include "hbapi.h"
|
||||
#include "hbapiitm.h"
|
||||
#include "hbapierr.h"
|
||||
#include "zlib.h"
|
||||
|
||||
static ULONG hb_zlibUncompressedSize( const char * szSrc, ULONG ulLen )
|
||||
{
|
||||
Byte buffer[ 1024 ];
|
||||
z_stream stream;
|
||||
ULONG ulDest = 0;
|
||||
|
||||
memset( &stream, 0, sizeof( z_stream ) );
|
||||
|
||||
stream.next_in = ( Bytef * ) szSrc;
|
||||
stream.avail_in = ( uInt ) ulLen;
|
||||
/*
|
||||
stream.zalloc = Z_NULL;
|
||||
stream.zfree = Z_NULL;
|
||||
stream.opaque = NULL;
|
||||
*/
|
||||
if( inflateInit( &stream ) == Z_OK )
|
||||
{
|
||||
int iStatus;
|
||||
do
|
||||
{
|
||||
stream.next_out = buffer;
|
||||
stream.avail_out = sizeof( buffer );
|
||||
iStatus = inflate( &stream, Z_NO_FLUSH );
|
||||
}
|
||||
while( iStatus == Z_OK );
|
||||
if( iStatus == Z_STREAM_END )
|
||||
ulDest = stream.total_out;
|
||||
inflateEnd( &stream );
|
||||
}
|
||||
|
||||
return ulDest;
|
||||
}
|
||||
|
||||
/*
|
||||
* HB_ZLIBVERSION( [<nType>] ) -> <cZlibVersion>
|
||||
*/
|
||||
HB_FUNC( HB_ZLIBVERSION )
|
||||
{
|
||||
if( hb_parni( 1 ) == 1 )
|
||||
hb_retc( ZLIB_VERSION );
|
||||
else
|
||||
hb_retc( zlibVersion() );
|
||||
}
|
||||
|
||||
/*
|
||||
* HB_COMPRESSBOUND( <cData> | <nDataLen> ) -> <nMaxCompressLen>
|
||||
*/
|
||||
HB_FUNC( HB_COMPRESSBOUND )
|
||||
{
|
||||
if( ISCHAR( 1 ) )
|
||||
hb_retnint( compressBound( hb_parclen( 1 ) ) );
|
||||
else if( ISNUM( 1 ) )
|
||||
hb_retnint( compressBound( ( uLong ) hb_parnint( 1 ) ) );
|
||||
else
|
||||
hb_errRT_BASE_SubstR( EG_ARG, 3012, NULL, &hb_errFuncName, HB_ERR_ARGS_BASEPARAMS );
|
||||
}
|
||||
|
||||
/*
|
||||
* HB_UNCOMPRESSLEN( <cCompressedData> ) -> <nUnCompressedDataLen> or 0 on error
|
||||
*/
|
||||
HB_FUNC( HB_UNCOMPRESSLEN )
|
||||
{
|
||||
ULONG ulLen = hb_parclen( 1 );
|
||||
|
||||
hb_retnint( ulLen ? hb_zlibUncompressedSize( hb_parc( 1 ), ulLen ) : 0 );
|
||||
}
|
||||
|
||||
/*
|
||||
* HB_COMPRESS( <cData>, [<nDstBufLen>|<@cBuffer>], [<@nResult>], [<nLevel>] )
|
||||
* => <cCompressedData> or NIL on Error
|
||||
*/
|
||||
HB_FUNC( HB_COMPRESS )
|
||||
{
|
||||
char * szData = hb_parc( 1 );
|
||||
if( szData )
|
||||
{
|
||||
ULONG ulLen = hb_parclen( 1 );
|
||||
|
||||
if( ulLen )
|
||||
{
|
||||
PHB_ITEM pBuffer = ISBYREF( 2 ) ? hb_param( 2, HB_IT_STRING ) : NULL;
|
||||
uLong ulDstLen;
|
||||
char * pDest;
|
||||
int iResult;
|
||||
|
||||
if( pBuffer )
|
||||
{
|
||||
pBuffer = hb_itemUnShareString( pBuffer );
|
||||
ulDstLen = hb_itemGetCLen( pBuffer );
|
||||
pDest = hb_itemGetCPtr( pBuffer );
|
||||
}
|
||||
else
|
||||
{
|
||||
ulDstLen = ISNUM( 2 ) ? ( uLong ) hb_parnint( 2 ) :
|
||||
compressBound( ulLen );
|
||||
pDest = ( char * ) hb_xalloc( ulDstLen + 1 );
|
||||
}
|
||||
|
||||
if( pDest )
|
||||
{
|
||||
if( ISNUM( 4 ) )
|
||||
iResult = compress2( ( Bytef * ) pDest, &ulDstLen, ( Bytef * ) szData, ulLen, hb_parni( 4 ) );
|
||||
else
|
||||
iResult = compress( ( Bytef * ) pDest, &ulDstLen, ( Bytef * ) szData, ulLen );
|
||||
|
||||
if( !pBuffer )
|
||||
{
|
||||
if( iResult == Z_OK )
|
||||
hb_retclen_buffer( pDest, ulDstLen );
|
||||
else
|
||||
hb_xfree( pDest );
|
||||
}
|
||||
else if( iResult == Z_OK )
|
||||
hb_retclen( pDest, ulDstLen );
|
||||
}
|
||||
else
|
||||
iResult = Z_MEM_ERROR;
|
||||
|
||||
hb_storni( iResult, 3 );
|
||||
}
|
||||
else
|
||||
{
|
||||
hb_retc( NULL );
|
||||
hb_storni( Z_OK, 3 );
|
||||
}
|
||||
}
|
||||
else
|
||||
hb_errRT_BASE_SubstR( EG_ARG, 3012, NULL, &hb_errFuncName, HB_ERR_ARGS_BASEPARAMS );
|
||||
}
|
||||
|
||||
/*
|
||||
* HB_UNCOMPRESS( <cCompressedData>, [<nDstBufLen>|<@cBuffer>], [<@nResult>] )
|
||||
* => <cUnCompressedData> or NIL on Error
|
||||
*/
|
||||
HB_FUNC( HB_UNCOMPRESS )
|
||||
{
|
||||
PHB_ITEM pBuffer = ISBYREF( 2 ) ? hb_param( 2, HB_IT_STRING ) : NULL;
|
||||
char * szData = hb_parc( 1 );
|
||||
|
||||
if( szData )
|
||||
{
|
||||
ULONG ulLen = hb_parclen( 1 );
|
||||
|
||||
if( ulLen )
|
||||
{
|
||||
uLong ulDstLen;
|
||||
char * pDest;
|
||||
int iResult;
|
||||
|
||||
if( pBuffer )
|
||||
{
|
||||
pBuffer = hb_itemUnShareString( pBuffer );
|
||||
ulDstLen = hb_itemGetCLen( pBuffer );
|
||||
pDest = hb_itemGetCPtr( pBuffer );
|
||||
}
|
||||
else
|
||||
{
|
||||
ulDstLen = ISNUM( 2 ) ? ( uLong ) hb_parnint( 2 ) :
|
||||
hb_zlibUncompressedSize( szData, ulLen );
|
||||
pDest = ( char * ) hb_xalloc( ulDstLen + 1 );
|
||||
}
|
||||
|
||||
if( pDest )
|
||||
{
|
||||
iResult = uncompress( ( Bytef * ) pDest, &ulDstLen, ( Bytef * ) szData, ulLen );
|
||||
|
||||
if( !pBuffer )
|
||||
{
|
||||
if( iResult == Z_OK )
|
||||
hb_retclen_buffer( pDest, ulDstLen );
|
||||
else
|
||||
hb_xfree( pDest );
|
||||
}
|
||||
else if( iResult == Z_OK )
|
||||
hb_retclen( pDest, ulDstLen );
|
||||
}
|
||||
else
|
||||
iResult = Z_MEM_ERROR;
|
||||
|
||||
hb_storni( iResult, 3 );
|
||||
}
|
||||
else
|
||||
{
|
||||
hb_retc( NULL );
|
||||
hb_storni( Z_OK, 3 );
|
||||
}
|
||||
}
|
||||
else
|
||||
hb_errRT_BASE_SubstR( EG_ARG, 3012, NULL, &hb_errFuncName, HB_ERR_ARGS_BASEPARAMS );
|
||||
}
|
||||
|
||||
|
||||
/* GZIP stream destructor */
|
||||
static HB_GARBAGE_FUNC( hb_gz_Destructor )
|
||||
{
|
||||
gzFile * gz = ( gzFile * ) Cargo;
|
||||
if( * gz )
|
||||
{
|
||||
gzclose( * gz );
|
||||
* gz = NULL;
|
||||
}
|
||||
}
|
||||
|
||||
static gzFile hb_gzParam( int iParam )
|
||||
{
|
||||
gzFile * gzHolder = ( gzFile * ) hb_parptrGC( hb_gz_Destructor, iParam );
|
||||
|
||||
if( gzHolder && * gzHolder )
|
||||
return * gzHolder;
|
||||
|
||||
hb_errRT_BASE_SubstR( EG_ARG, 3012, NULL, &hb_errFuncName, HB_ERR_ARGS_BASEPARAMS );
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/*
|
||||
* HB_GZOPEN( <cFile>, <cMode> ) => <pGZipStram> or NIL on Error
|
||||
*/
|
||||
HB_FUNC( HB_GZOPEN )
|
||||
{
|
||||
char * cFile = hb_parc( 1 ), * cMode = hb_parc( 2 );
|
||||
if( cFile && cMode )
|
||||
{
|
||||
gzFile gz = gzopen( cFile, cMode );
|
||||
if( gz )
|
||||
{
|
||||
gzFile * gzHolder = ( gzFile * ) hb_gcAlloc( sizeof( gzFile ),
|
||||
hb_gz_Destructor );
|
||||
* gzHolder = gz;
|
||||
hb_retptrGC( gzHolder );
|
||||
}
|
||||
}
|
||||
else
|
||||
hb_errRT_BASE_SubstR( EG_ARG, 3012, NULL, &hb_errFuncName, HB_ERR_ARGS_BASEPARAMS );
|
||||
}
|
||||
|
||||
/*
|
||||
* HB_GZDOPEN( <hFile>, <cMode> ) => <pGZipStram> or NIL on Error
|
||||
*/
|
||||
HB_FUNC( HB_GZDOPEN )
|
||||
{
|
||||
char * cMode = hb_parc( 2 );
|
||||
if( ISNUM( 1 ) && cMode )
|
||||
{
|
||||
gzFile gz = gzdopen( hb_parni( 1 ), cMode );
|
||||
if( gz )
|
||||
{
|
||||
gzFile * gzHolder = ( gzFile * ) hb_gcAlloc( sizeof( gzFile ),
|
||||
hb_gz_Destructor );
|
||||
* gzHolder = gz;
|
||||
hb_retptrGC( gzHolder );
|
||||
}
|
||||
}
|
||||
else
|
||||
hb_errRT_BASE_SubstR( EG_ARG, 3012, NULL, &hb_errFuncName, HB_ERR_ARGS_BASEPARAMS );
|
||||
}
|
||||
|
||||
/*
|
||||
* HB_GZCLOSE( <pGZipStream> ) => <nResult>
|
||||
*/
|
||||
HB_FUNC( HB_GZCLOSE )
|
||||
{
|
||||
gzFile * gzHolder = ( gzFile * ) hb_parptrGC( hb_gz_Destructor, 1 );
|
||||
|
||||
if( gzHolder )
|
||||
{
|
||||
gzFile gz = * gzHolder;
|
||||
* gzHolder = NULL;
|
||||
hb_retni( gzclose( gz ) );
|
||||
}
|
||||
else
|
||||
hb_errRT_BASE_SubstR( EG_ARG, 3012, NULL, &hb_errFuncName, HB_ERR_ARGS_BASEPARAMS );
|
||||
}
|
||||
|
||||
/*
|
||||
* HB_GZSETPARAMS( <pGZipStream>, <nLevel>, <nStrategy> ) => <nResult>
|
||||
*/
|
||||
HB_FUNC( HB_GZSETPARAMS )
|
||||
{
|
||||
if( ISNUM( 2 ) && ISNUM( 3 ) )
|
||||
{
|
||||
gzFile gz = hb_gzParam( 1 );
|
||||
if( gz )
|
||||
hb_retni( gzsetparams( gz, hb_parni( 2 ), hb_parni( 3 ) ) );
|
||||
}
|
||||
else
|
||||
hb_errRT_BASE_SubstR( EG_ARG, 3012, NULL, &hb_errFuncName, HB_ERR_ARGS_BASEPARAMS );
|
||||
}
|
||||
|
||||
/*
|
||||
* HB_GZREAD( <pGZipStream>, <@cData>, [ <nLen> ] ) => <nResult>
|
||||
*/
|
||||
HB_FUNC( HB_GZREAD )
|
||||
{
|
||||
PHB_ITEM pBuffer = ISBYREF( 2 ) ? hb_param( 2, HB_IT_STRING ) : NULL;
|
||||
|
||||
if( pBuffer )
|
||||
{
|
||||
gzFile gz = hb_gzParam( 1 );
|
||||
if( gz )
|
||||
{
|
||||
pBuffer = hb_itemUnShareString( pBuffer );
|
||||
hb_retni( gzread( gz, hb_itemGetCPtr( pBuffer ), ISNUM( 3 ) ?
|
||||
( ULONG ) hb_parnl( 3 ) : hb_itemGetCLen( pBuffer ) ) );
|
||||
}
|
||||
}
|
||||
else
|
||||
hb_errRT_BASE_SubstR( EG_ARG, 3012, NULL, &hb_errFuncName, HB_ERR_ARGS_BASEPARAMS );
|
||||
}
|
||||
|
||||
/*
|
||||
* HB_GZWRITE( <pGZipStream>, <cData>, [ <nLen> ] ) => <nResult>
|
||||
*/
|
||||
HB_FUNC( HB_GZWRITE )
|
||||
{
|
||||
char * szData = hb_parc( 2 );
|
||||
if( szData )
|
||||
{
|
||||
gzFile gz = hb_gzParam( 1 );
|
||||
if( gz )
|
||||
hb_retni( gzwrite( gz, szData, ISNUM( 3 ) ?
|
||||
( ULONG ) hb_parnl( 3 ) : hb_parclen( 2 ) ) );
|
||||
}
|
||||
else
|
||||
hb_errRT_BASE_SubstR( EG_ARG, 3012, NULL, &hb_errFuncName, HB_ERR_ARGS_BASEPARAMS );
|
||||
}
|
||||
|
||||
/*
|
||||
* HB_GZGETS( <pGZipStream>, <nMaxBytes> ) => <cLine> or NIL on error
|
||||
*/
|
||||
HB_FUNC( HB_GZGETS )
|
||||
{
|
||||
int iLen = hb_parni( 2 );
|
||||
if( iLen > 0 )
|
||||
{
|
||||
gzFile gz = hb_gzParam( 1 );
|
||||
if( gz )
|
||||
{
|
||||
char * szBuffer = ( char * ) hb_xalloc( iLen + 1 );
|
||||
|
||||
if( szBuffer )
|
||||
{
|
||||
if( gzgets( gz, szBuffer, iLen ) != Z_NULL )
|
||||
hb_retc_buffer( szBuffer );
|
||||
else
|
||||
hb_xfree( szBuffer );
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
hb_errRT_BASE_SubstR( EG_ARG, 3012, NULL, &hb_errFuncName, HB_ERR_ARGS_BASEPARAMS );
|
||||
}
|
||||
|
||||
/*
|
||||
* HB_GZPUTS( <pGZipStream>, <cData> ) => <nResult>
|
||||
*/
|
||||
HB_FUNC( HB_GZPUTS )
|
||||
{
|
||||
char * szData = hb_parc( 2 );
|
||||
if( szData )
|
||||
{
|
||||
gzFile gz = hb_gzParam( 1 );
|
||||
if( gz )
|
||||
hb_retni( gzputs( gz, szData ) );
|
||||
}
|
||||
else
|
||||
hb_errRT_BASE_SubstR( EG_ARG, 3012, NULL, &hb_errFuncName, HB_ERR_ARGS_BASEPARAMS );
|
||||
}
|
||||
|
||||
/*
|
||||
* HB_GZGETC( <pGZipStream> ) => <nByte>
|
||||
*/
|
||||
HB_FUNC( HB_GZGETC )
|
||||
{
|
||||
gzFile gz = hb_gzParam( 1 );
|
||||
if( gz )
|
||||
hb_retni( gzgetc( gz ) );
|
||||
}
|
||||
|
||||
/*
|
||||
* HB_GZUNGETC( <nByte>, <pGZipStream> ) => <nByte>
|
||||
*/
|
||||
HB_FUNC( HB_GZUNGETC )
|
||||
{
|
||||
if( ISNUM( 1 ) )
|
||||
{
|
||||
gzFile gz = hb_gzParam( 2 );
|
||||
if( gz )
|
||||
hb_retni( gzungetc( hb_parni( 1 ), gz ) );
|
||||
}
|
||||
else
|
||||
hb_errRT_BASE_SubstR( EG_ARG, 3012, NULL, &hb_errFuncName, HB_ERR_ARGS_BASEPARAMS );
|
||||
}
|
||||
|
||||
/*
|
||||
* HB_GZFLUSH( <pGZipStream>, [ <nFlush> ] ) => <nResult>
|
||||
*/
|
||||
HB_FUNC( HB_GZFLUSH )
|
||||
{
|
||||
gzFile gz = hb_gzParam( 1 );
|
||||
if( gz )
|
||||
hb_retni( gzflush( gz, ISNUM( 2 ) ? hb_parni( 2 ) : Z_SYNC_FLUSH ) );
|
||||
}
|
||||
|
||||
/*
|
||||
* HB_GZSEEK( <pGZipStream>, <nOffset>, [ <nWhence> ] ) => <nOffset>
|
||||
*/
|
||||
HB_FUNC( HB_GZSEEK )
|
||||
{
|
||||
if( ISNUM( 2 ) )
|
||||
{
|
||||
gzFile gz = hb_gzParam( 1 );
|
||||
if( gz )
|
||||
hb_retnint( gzseek( gz, ( z_off_t ) hb_parnint( 2 ), ISNUM( 3 ) ?
|
||||
hb_parni( 3 ) : SEEK_SET ) );
|
||||
}
|
||||
else
|
||||
hb_errRT_BASE_SubstR( EG_ARG, 3012, NULL, &hb_errFuncName, HB_ERR_ARGS_BASEPARAMS );
|
||||
}
|
||||
|
||||
/*
|
||||
* HB_GZREWIND( <pGZipStream> ) => <nResult>
|
||||
*/
|
||||
HB_FUNC( HB_GZREWIND )
|
||||
{
|
||||
gzFile gz = hb_gzParam( 1 );
|
||||
if( gz )
|
||||
hb_retni( gzrewind( gz ) );
|
||||
}
|
||||
|
||||
/*
|
||||
* HB_GZTELL( <pGZipStream> ) => <lResult>
|
||||
*/
|
||||
HB_FUNC( HB_GZTELL )
|
||||
{
|
||||
gzFile gz = hb_gzParam( 1 );
|
||||
if( gz )
|
||||
hb_retnint( gztell( gz ) );
|
||||
}
|
||||
|
||||
/*
|
||||
* HB_GZEOF( <pGZipStream> ) => <lResult>
|
||||
*/
|
||||
HB_FUNC( HB_GZEOF )
|
||||
{
|
||||
gzFile gz = hb_gzParam( 1 );
|
||||
if( gz )
|
||||
hb_retl( gzeof( gz ) != 0 );
|
||||
}
|
||||
|
||||
#if ZLIB_VERNUM >= 0x1230
|
||||
/*
|
||||
* HB_GZDIRECT( <pGZipStream> ) => <lResult>
|
||||
*/
|
||||
HB_FUNC( HB_GZDIRECT )
|
||||
{
|
||||
gzFile gz = hb_gzParam( 1 );
|
||||
if( gz )
|
||||
hb_retl( gzdirect( gz ) != 0 );
|
||||
}
|
||||
#endif
|
||||
|
||||
/*
|
||||
* HB_GZERROR( <pGZipStream>, [ <@nError> ] ) => <cError>
|
||||
*/
|
||||
HB_FUNC( HB_GZERROR )
|
||||
{
|
||||
gzFile gz = hb_gzParam( 1 );
|
||||
if( gz )
|
||||
{
|
||||
int iErrNum = 0;
|
||||
|
||||
hb_retc( gzerror( gz, &iErrNum ) );
|
||||
hb_storni( iErrNum, 2 );
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* HB_GZCLEARERR( <pGZipStream> ) => NIL
|
||||
*/
|
||||
HB_FUNC( HB_GZCLEARERR )
|
||||
{
|
||||
gzFile gz = hb_gzParam( 1 );
|
||||
if( gz )
|
||||
gzclearerr( gz );
|
||||
}
|
||||
@@ -1,70 +0,0 @@
|
||||
/*
|
||||
* $Id$
|
||||
*/
|
||||
|
||||
/*
|
||||
* Harbour Project source code:
|
||||
* ZLIB and ZIP header file
|
||||
*
|
||||
* Copyright 2008 Mindaugas Kavaliauskas <dbtopas.at.dbtopas.lt>
|
||||
* www - http://www.harbour-project.org
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; either version 2, or (at your option)
|
||||
* any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this software; see the file COPYING. If not, write to
|
||||
* the Free Software Foundation, Inc., 59 Temple Place, Suite 330,
|
||||
* Boston, MA 02111-1307 USA (or visit the web site http://www.gnu.org/).
|
||||
*
|
||||
* As a special exception, the Harbour Project gives permission for
|
||||
* additional uses of the text contained in its release of Harbour.
|
||||
*
|
||||
* The exception is that, if you link the Harbour libraries with other
|
||||
* files to produce an executable, this does not by itself cause the
|
||||
* resulting executable to be covered by the GNU General Public License.
|
||||
* Your use of that executable is in no way restricted on account of
|
||||
* linking the Harbour library code into it.
|
||||
*
|
||||
* This exception does not however invalidate any other reasons why
|
||||
* the executable file might be covered by the GNU General Public License.
|
||||
*
|
||||
* This exception applies only to the code released by the Harbour
|
||||
* Project under the name Harbour. If you copy code from other
|
||||
* Harbour Project or Free Software Foundation releases into a copy of
|
||||
* Harbour, as the General Public License permits, the exception does
|
||||
* not apply to the code that you add in this way. To avoid misleading
|
||||
* anyone as to the status of such modified files, you must delete
|
||||
* this exception notice from them.
|
||||
*
|
||||
* If you write modifications of your own for Harbour, it is your choice
|
||||
* whether to permit this exception to apply to your modifications.
|
||||
* If you do not wish that, delete this exception notice.
|
||||
*
|
||||
*/
|
||||
|
||||
|
||||
#ifndef HB_ZLIB_CH_
|
||||
#define HB_ZLIB_CH_
|
||||
|
||||
#define HB_ZLIB_METHOD_STORE 0
|
||||
#define HB_ZLIB_METHOD_DEFLATED 8
|
||||
|
||||
#define HB_ZLIB_COMPRESSION_NONE 0
|
||||
#define HB_ZLIB_COMPRESSION_SPEED 1
|
||||
#define HB_ZLIB_COMPRESSION_SIZE 9
|
||||
#define HB_ZLIB_COMPRESSION_DEFAULT (-1)
|
||||
|
||||
#define HB_ZIP_OPEN_CREATE 0
|
||||
#define HB_ZIP_OPEN_CREATEAFTER 1
|
||||
#define HB_ZIP_OPEN_ADDINZIP 2
|
||||
|
||||
#endif
|
||||
|
||||
@@ -1,198 +0,0 @@
|
||||
/* ioapi.c -- IO base function header for compress/uncompress .zip
|
||||
files using zlib + zip or unzip API
|
||||
|
||||
Version 1.01e, February 12th, 2005
|
||||
|
||||
Copyright (C) 1998-2005 Gilles Vollant
|
||||
*/
|
||||
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
|
||||
#include "zlib.h"
|
||||
#include "ioapi.h"
|
||||
|
||||
|
||||
|
||||
/* I've found an old Unix (a SunOS 4.1.3_U1) without all SEEK_* defined.... */
|
||||
|
||||
#ifndef SEEK_CUR
|
||||
#define SEEK_CUR 1
|
||||
#endif
|
||||
|
||||
#ifndef SEEK_END
|
||||
#define SEEK_END 2
|
||||
#endif
|
||||
|
||||
#ifndef SEEK_SET
|
||||
#define SEEK_SET 0
|
||||
#endif
|
||||
|
||||
voidpf ZCALLBACK fopen_file_func OF((
|
||||
voidpf opaque,
|
||||
const char* filename,
|
||||
int mode));
|
||||
|
||||
uLong ZCALLBACK fread_file_func OF((
|
||||
voidpf opaque,
|
||||
voidpf stream,
|
||||
void* buf,
|
||||
uLong size));
|
||||
|
||||
uLong ZCALLBACK fwrite_file_func OF((
|
||||
voidpf opaque,
|
||||
voidpf stream,
|
||||
const void* buf,
|
||||
uLong size));
|
||||
|
||||
long ZCALLBACK ftell_file_func OF((
|
||||
voidpf opaque,
|
||||
voidpf stream));
|
||||
|
||||
long ZCALLBACK fseek_file_func OF((
|
||||
voidpf opaque,
|
||||
voidpf stream,
|
||||
uLong offset,
|
||||
int origin));
|
||||
|
||||
int ZCALLBACK fclose_file_func OF((
|
||||
voidpf opaque,
|
||||
voidpf stream));
|
||||
|
||||
int ZCALLBACK ferror_file_func OF((
|
||||
voidpf opaque,
|
||||
voidpf stream));
|
||||
|
||||
|
||||
voidpf ZCALLBACK fopen_file_func (
|
||||
voidpf opaque,
|
||||
const char* filename,
|
||||
int mode)
|
||||
{
|
||||
FILE* file = NULL;
|
||||
const char* mode_fopen = NULL;
|
||||
|
||||
(void) opaque;
|
||||
|
||||
if ((mode & ZLIB_FILEFUNC_MODE_READWRITEFILTER)==ZLIB_FILEFUNC_MODE_READ)
|
||||
mode_fopen = "rb";
|
||||
else
|
||||
if (mode & ZLIB_FILEFUNC_MODE_EXISTING)
|
||||
mode_fopen = "r+b";
|
||||
else
|
||||
if (mode & ZLIB_FILEFUNC_MODE_CREATE)
|
||||
mode_fopen = "wb";
|
||||
|
||||
if ((filename!=NULL) && (mode_fopen != NULL))
|
||||
file = fopen(filename, mode_fopen);
|
||||
return file;
|
||||
}
|
||||
|
||||
|
||||
uLong ZCALLBACK fread_file_func (
|
||||
voidpf opaque,
|
||||
voidpf stream,
|
||||
void* buf,
|
||||
uLong size)
|
||||
{
|
||||
uLong ret;
|
||||
|
||||
(void) opaque;
|
||||
|
||||
ret = (uLong)fread(buf, 1, (size_t)size, (FILE *)stream);
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
||||
uLong ZCALLBACK fwrite_file_func (
|
||||
voidpf opaque,
|
||||
voidpf stream,
|
||||
const void* buf,
|
||||
uLong size)
|
||||
{
|
||||
uLong ret;
|
||||
|
||||
(void) opaque;
|
||||
|
||||
ret = (uLong)fwrite(buf, 1, (size_t)size, (FILE *)stream);
|
||||
return ret;
|
||||
}
|
||||
|
||||
long ZCALLBACK ftell_file_func (
|
||||
voidpf opaque,
|
||||
voidpf stream)
|
||||
{
|
||||
long ret;
|
||||
|
||||
(void) opaque;
|
||||
|
||||
ret = ftell((FILE *)stream);
|
||||
return ret;
|
||||
}
|
||||
|
||||
long ZCALLBACK fseek_file_func (
|
||||
voidpf opaque,
|
||||
voidpf stream,
|
||||
uLong offset,
|
||||
int origin)
|
||||
{
|
||||
int fseek_origin;
|
||||
long ret;
|
||||
|
||||
(void) opaque;
|
||||
|
||||
switch (origin)
|
||||
{
|
||||
case ZLIB_FILEFUNC_SEEK_CUR :
|
||||
fseek_origin = SEEK_CUR;
|
||||
break;
|
||||
case ZLIB_FILEFUNC_SEEK_END :
|
||||
fseek_origin = SEEK_END;
|
||||
break;
|
||||
case ZLIB_FILEFUNC_SEEK_SET :
|
||||
fseek_origin = SEEK_SET;
|
||||
break;
|
||||
default: return -1;
|
||||
}
|
||||
ret = 0;
|
||||
fseek((FILE *)stream, offset, fseek_origin);
|
||||
return ret;
|
||||
}
|
||||
|
||||
int ZCALLBACK fclose_file_func (
|
||||
voidpf opaque,
|
||||
voidpf stream)
|
||||
{
|
||||
int ret;
|
||||
|
||||
(void) opaque;
|
||||
|
||||
ret = fclose((FILE *)stream);
|
||||
return ret;
|
||||
}
|
||||
|
||||
int ZCALLBACK ferror_file_func (
|
||||
voidpf opaque,
|
||||
voidpf stream)
|
||||
{
|
||||
int ret;
|
||||
|
||||
(void) opaque;
|
||||
|
||||
ret = ferror((FILE *)stream);
|
||||
return ret;
|
||||
}
|
||||
|
||||
void fill_fopen_filefunc (
|
||||
zlib_filefunc_def* pzlib_filefunc_def)
|
||||
{
|
||||
pzlib_filefunc_def->zopen_file = fopen_file_func;
|
||||
pzlib_filefunc_def->zread_file = fread_file_func;
|
||||
pzlib_filefunc_def->zwrite_file = fwrite_file_func;
|
||||
pzlib_filefunc_def->ztell_file = ftell_file_func;
|
||||
pzlib_filefunc_def->zseek_file = fseek_file_func;
|
||||
pzlib_filefunc_def->zclose_file = fclose_file_func;
|
||||
pzlib_filefunc_def->zerror_file = ferror_file_func;
|
||||
pzlib_filefunc_def->opaque = NULL;
|
||||
}
|
||||
@@ -1,75 +0,0 @@
|
||||
/* ioapi.h -- IO base function header for compress/uncompress .zip
|
||||
files using zlib + zip or unzip API
|
||||
|
||||
Version 1.01e, February 12th, 2005
|
||||
|
||||
Copyright (C) 1998-2005 Gilles Vollant
|
||||
*/
|
||||
|
||||
#ifndef _ZLIBIOAPI_H
|
||||
#define _ZLIBIOAPI_H
|
||||
|
||||
|
||||
#define ZLIB_FILEFUNC_SEEK_CUR (1)
|
||||
#define ZLIB_FILEFUNC_SEEK_END (2)
|
||||
#define ZLIB_FILEFUNC_SEEK_SET (0)
|
||||
|
||||
#define ZLIB_FILEFUNC_MODE_READ (1)
|
||||
#define ZLIB_FILEFUNC_MODE_WRITE (2)
|
||||
#define ZLIB_FILEFUNC_MODE_READWRITEFILTER (3)
|
||||
|
||||
#define ZLIB_FILEFUNC_MODE_EXISTING (4)
|
||||
#define ZLIB_FILEFUNC_MODE_CREATE (8)
|
||||
|
||||
|
||||
#ifndef ZCALLBACK
|
||||
|
||||
#if (defined(WIN32) || defined (WINDOWS) || defined (_WINDOWS)) && defined(CALLBACK) && defined (USEWINDOWS_CALLBACK)
|
||||
#define ZCALLBACK CALLBACK
|
||||
#else
|
||||
#define ZCALLBACK
|
||||
#endif
|
||||
#endif
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
typedef voidpf (ZCALLBACK *open_file_func) OF((voidpf opaque, const char* filename, int mode));
|
||||
typedef uLong (ZCALLBACK *read_file_func) OF((voidpf opaque, voidpf stream, void* buf, uLong size));
|
||||
typedef uLong (ZCALLBACK *write_file_func) OF((voidpf opaque, voidpf stream, const void* buf, uLong size));
|
||||
typedef long (ZCALLBACK *tell_file_func) OF((voidpf opaque, voidpf stream));
|
||||
typedef long (ZCALLBACK *seek_file_func) OF((voidpf opaque, voidpf stream, uLong offset, int origin));
|
||||
typedef int (ZCALLBACK *close_file_func) OF((voidpf opaque, voidpf stream));
|
||||
typedef int (ZCALLBACK *testerror_file_func) OF((voidpf opaque, voidpf stream));
|
||||
|
||||
typedef struct zlib_filefunc_def_s
|
||||
{
|
||||
open_file_func zopen_file;
|
||||
read_file_func zread_file;
|
||||
write_file_func zwrite_file;
|
||||
tell_file_func ztell_file;
|
||||
seek_file_func zseek_file;
|
||||
close_file_func zclose_file;
|
||||
testerror_file_func zerror_file;
|
||||
voidpf opaque;
|
||||
} zlib_filefunc_def;
|
||||
|
||||
|
||||
|
||||
void fill_fopen_filefunc OF((zlib_filefunc_def* pzlib_filefunc_def));
|
||||
|
||||
#define ZREAD(filefunc,filestream,buf,size) ((*((filefunc).zread_file))((filefunc).opaque,filestream,buf,size))
|
||||
#define ZWRITE(filefunc,filestream,buf,size) ((*((filefunc).zwrite_file))((filefunc).opaque,filestream,buf,size))
|
||||
#define ZTELL(filefunc,filestream) ((*((filefunc).ztell_file))((filefunc).opaque,filestream))
|
||||
#define ZSEEK(filefunc,filestream,pos,mode) ((*((filefunc).zseek_file))((filefunc).opaque,filestream,pos,mode))
|
||||
#define ZCLOSE(filefunc,filestream) ((*((filefunc).zclose_file))((filefunc).opaque,filestream))
|
||||
#define ZERROR(filefunc,filestream) ((*((filefunc).zerror_file))((filefunc).opaque,filestream))
|
||||
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
|
||||
@@ -1,61 +0,0 @@
|
||||
@echo off
|
||||
rem
|
||||
rem $Id$
|
||||
rem
|
||||
|
||||
if not "%ZLIB_DIR%" == "" goto DIR_OK
|
||||
|
||||
echo ---------------------------------------------------------------
|
||||
echo IMPORTANT: You'll need ZLIB headers and lib and this envvar
|
||||
echo to be set to successfully build this library:
|
||||
echo set ZLIB_DIR=C:\zlib-dll
|
||||
echo ---------------------------------------------------------------
|
||||
goto POST_EXIT
|
||||
|
||||
:DIR_OK
|
||||
|
||||
set CFLAGS=-I"%ZLIB_DIR%\include"
|
||||
set HB_DLL_NAME=zlib1
|
||||
set HB_DLL_DIR=%ZLIB_DIR%
|
||||
|
||||
rem ---------------------------------------------------------------
|
||||
|
||||
call ..\mtpl_b32.bat %1 %2 %3 %4 %5 %6 %7 %8 %9
|
||||
|
||||
rem ---------------------------------------------------------------
|
||||
|
||||
set _HB_INSTALL_PREFIX=%HB_INSTALL_PREFIX%
|
||||
if "%_HB_INSTALL_PREFIX%" == "" set _HB_INSTALL_PREFIX=..\..
|
||||
set _HB_LIB_INSTALL=%HB_LIB_INSTALL%
|
||||
if "%_HB_LIB_INSTALL%" == "" set _HB_LIB_INSTALL=%_HB_INSTALL_PREFIX%\lib
|
||||
|
||||
if "%1" == "clean" goto POST_CLEAN
|
||||
if "%1" == "Clean" goto POST_CLEAN
|
||||
if "%1" == "CLEAN" goto POST_CLEAN
|
||||
if "%1" == "install" goto POST_INSTALL
|
||||
if "%1" == "Install" goto POST_INSTALL
|
||||
if "%1" == "INSTALL" goto POST_INSTALL
|
||||
|
||||
:POST_BUILD
|
||||
|
||||
implib -a ..\..\lib\%_HB_CC_NAME%\%HB_DLL_NAME%.lib "%HB_DLL_DIR%\%HB_DLL_NAME%.dll" >> %_HB_MAKELOG%
|
||||
goto POST_EXIT
|
||||
|
||||
:POST_CLEAN
|
||||
|
||||
if exist ..\..\lib\%_HB_CC_NAME%\%HB_DLL_NAME%.lib del ..\..\lib\%_HB_CC_NAME%\%HB_DLL_NAME%.lib > nul
|
||||
if exist ..\..\lib\%_HB_CC_NAME%\%HB_DLL_NAME%.exp del ..\..\lib\%_HB_CC_NAME%\%HB_DLL_NAME%.exp > nul
|
||||
if exist %_HB_LIB_INSTALL%\%HB_DLL_NAME%.lib del %_HB_LIB_INSTALL%\%HB_DLL_NAME%.lib > nul
|
||||
goto POST_EXIT
|
||||
|
||||
:POST_INSTALL
|
||||
|
||||
if exist %_HB_LIB_INSTALL%\%HB_DLL_NAME%.lib del %_HB_LIB_INSTALL%\%HB_DLL_NAME%.lib
|
||||
if exist ..\..\lib\%_HB_CC_NAME%\%HB_DLL_NAME%.lib copy ..\..\lib\%_HB_CC_NAME%\%HB_DLL_NAME%.lib %_HB_LIB_INSTALL%
|
||||
goto POST_EXIT
|
||||
|
||||
:POST_EXIT
|
||||
|
||||
set CFLAGS=
|
||||
set HB_DLL_NAME=
|
||||
set HB_DLL_DIR=
|
||||
@@ -1,24 +0,0 @@
|
||||
#!/bin/sh
|
||||
|
||||
#
|
||||
# $Id$
|
||||
#
|
||||
|
||||
if [ "${ZLIB_INC}" == "" ]
|
||||
then
|
||||
echo "---------------------------------------------------------------"
|
||||
echo "IMPORTANT: You will need ZLib package installed and this"
|
||||
echo " envvar to be set to successfully build this library:"
|
||||
echo " export ZLIB_INC=C:/Zlib/include"
|
||||
echo " or"
|
||||
echo " export ZLIB_INC=/usr/include"
|
||||
echo "---------------------------------------------------------------"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
export CFLAGS=""
|
||||
for I in ${ZLIB_INC}; do
|
||||
CFLAGS="${CFLAGS} -I${I}"
|
||||
done
|
||||
../mtpl_gcc.sh $1 $2 $3 $4 $5 $6 $7 $8 $9
|
||||
unset CFLAGS
|
||||
@@ -1,62 +0,0 @@
|
||||
@echo off
|
||||
rem
|
||||
rem $Id$
|
||||
rem
|
||||
|
||||
if not "%ZLIB_DIR%" == "" goto DIR_OK
|
||||
|
||||
echo ---------------------------------------------------------------
|
||||
echo IMPORTANT: You'll need ZLIB headers and lib and this envvar
|
||||
echo to be set to successfully build this library:
|
||||
echo set ZLIB_DIR=C:\zlib-dll
|
||||
echo ---------------------------------------------------------------
|
||||
goto POST_EXIT
|
||||
|
||||
:DIR_OK
|
||||
|
||||
set CFLAGS=-I"%ZLIB_DIR%\include"
|
||||
set HB_DLL_NAME=zlib1
|
||||
set HB_DLL_DIR=%ZLIB_DIR%
|
||||
|
||||
rem ---------------------------------------------------------------
|
||||
|
||||
call ..\mtpl_vc.bat %1 %2 %3 %4 %5 %6 %7 %8 %9
|
||||
|
||||
rem ---------------------------------------------------------------
|
||||
|
||||
set _HB_INSTALL_PREFIX=%HB_INSTALL_PREFIX%
|
||||
if "%_HB_INSTALL_PREFIX%" == "" set _HB_INSTALL_PREFIX=..\..
|
||||
set _HB_LIB_INSTALL=%HB_LIB_INSTALL%
|
||||
if "%_HB_LIB_INSTALL%" == "" set _HB_LIB_INSTALL=%_HB_INSTALL_PREFIX%\lib
|
||||
|
||||
if "%1" == "clean" goto POST_CLEAN
|
||||
if "%1" == "Clean" goto POST_CLEAN
|
||||
if "%1" == "CLEAN" goto POST_CLEAN
|
||||
if "%1" == "install" goto POST_INSTALL
|
||||
if "%1" == "Install" goto POST_INSTALL
|
||||
if "%1" == "INSTALL" goto POST_INSTALL
|
||||
|
||||
:POST_BUILD
|
||||
|
||||
rem Use supplied .lib file.
|
||||
if not exist ..\..\lib\%_HB_CC_NAME%\%HB_DLL_NAME%.lib copy "%ZLIB_DIR%\lib\zdll.lib" ..\..\lib\%_HB_CC_NAME%\%HB_DLL_NAME%.lib > nul
|
||||
goto POST_EXIT
|
||||
|
||||
:POST_CLEAN
|
||||
|
||||
if exist ..\..\lib\%_HB_CC_NAME%\%HB_DLL_NAME%.lib del ..\..\lib\%_HB_CC_NAME%\%HB_DLL_NAME%.lib > nul
|
||||
if exist ..\..\lib\%_HB_CC_NAME%\%HB_DLL_NAME%.exp del ..\..\lib\%_HB_CC_NAME%\%HB_DLL_NAME%.exp > nul
|
||||
if exist %_HB_LIB_INSTALL%\%HB_DLL_NAME%.lib del %_HB_LIB_INSTALL%\%HB_DLL_NAME%.lib > nul
|
||||
goto POST_EXIT
|
||||
|
||||
:POST_INSTALL
|
||||
|
||||
if exist %_HB_LIB_INSTALL%\%HB_DLL_NAME%.lib del %_HB_LIB_INSTALL%\%HB_DLL_NAME%.lib
|
||||
if exist ..\..\lib\%_HB_CC_NAME%\%HB_DLL_NAME%.lib copy ..\..\lib\%_HB_CC_NAME%\%HB_DLL_NAME%.lib %_HB_LIB_INSTALL%
|
||||
goto POST_EXIT
|
||||
|
||||
:POST_EXIT
|
||||
|
||||
set CFLAGS=
|
||||
set HB_DLL_NAME=
|
||||
set HB_DLL_DIR=
|
||||
@@ -1,48 +0,0 @@
|
||||
/*
|
||||
* $Id$
|
||||
*/
|
||||
|
||||
|
||||
This folder contains compression related files including:
|
||||
* zlib library (http://www.zlib.net/) wrapper functions
|
||||
* zip file support based on minizip library (http://www.winimage.com/zLibDll/minizip.html)
|
||||
including:
|
||||
* minizip version 1.01e source files
|
||||
* wrapper functions for minizip
|
||||
* some additionl functions to provide a higher level API for zip files
|
||||
|
||||
The sources of zlib itself is not included. You'll find it in the system under linux.
|
||||
For windows, please, download dll file containig compiled zlib library and make import
|
||||
library for the compiler you are using. If you want a static library try to locate it on
|
||||
the net, ex., you can find it for several compiler on http://libharu.sourceforge.net/
|
||||
|
||||
|
||||
Some small changes (to fix compile time warning and errors) are applied to original
|
||||
source of minizip 1.01e:
|
||||
|
||||
* harbour/contrib/hbzlib/zip.c
|
||||
* added forward definitions of allocate_new_datablock(),
|
||||
free_datablock(), init_linkedlist(), add_data_in_datablock(),
|
||||
ziplocal_TmzDateToDosDate()
|
||||
* pacified warnings of unused args dosDate and crcForCrypting
|
||||
* fixed 2 warnings: assigned value is not used. See, TOFIX
|
||||
comment for one of the fixes
|
||||
* fixed BCC warning "function call with no prototype" by changing
|
||||
local int zipFlushWriteBuffer(zi)
|
||||
zip_internal* zi;
|
||||
{
|
||||
to
|
||||
local int zipFlushWriteBuffer(zip_internal* zi)
|
||||
{
|
||||
I expected this code be equivavlent! ??? :/
|
||||
|
||||
* harbour/contrib/hbzlib/unzip.c
|
||||
* added forward definitions of strcmpcasenosensitive_internal(),
|
||||
unzlocal_DosDateToTmuDate(), unzlocal_CheckCurrentFileCoherencyHeader()
|
||||
* fixed 8 warnings: assigned value is not used. See, TOFIX
|
||||
comment for one of the fixes
|
||||
|
||||
* harbour/contrib/hbzlib/ioapi.c
|
||||
* pacified 7 warnings: unused args opaque
|
||||
* fixed warning: assigned value is not used
|
||||
|
||||
@@ -1,14 +0,0 @@
|
||||
@echo off
|
||||
rem
|
||||
rem $Id$
|
||||
rem
|
||||
|
||||
if "%HB_BIN_INSTALL%" == "" set HB_BIN_INSTALL=..\..\..\bin
|
||||
if "%HB_LIB_INSTALL%" == "" set HB_LIB_INSTALL=..\..\..\lib
|
||||
if "%HB_INC_INSTALL%" == "" set HB_INC_INSTALL=..\..\..\include
|
||||
|
||||
set HB_ARCHITECTURE=w32
|
||||
set HB_COMPILER=bcc32
|
||||
set HB_USER_LIBS=hbzlib.lib zlib1.lib
|
||||
|
||||
call %HB_BIN_INSTALL%\bld.bat %1 %2 %3 %4 %5 %6 %7 %8 %9
|
||||
@@ -1,14 +0,0 @@
|
||||
@echo off
|
||||
rem
|
||||
rem $Id$
|
||||
rem
|
||||
|
||||
if "%HB_BIN_INSTALL%" == "" set HB_BIN_INSTALL=..\..\..\bin
|
||||
if "%HB_LIB_INSTALL%" == "" set HB_LIB_INSTALL=..\..\..\lib
|
||||
if "%HB_INC_INSTALL%" == "" set HB_INC_INSTALL=..\..\..\include
|
||||
|
||||
set HB_ARCHITECTURE=w32
|
||||
set HB_COMPILER=msvc
|
||||
set HB_USER_LIBS=hbzlib.lib zlib1.lib
|
||||
|
||||
call %HB_BIN_INSTALL%\bld.bat %1 %2 %3 %4 %5 %6 %7 %8 %9
|
||||
@@ -1,105 +0,0 @@
|
||||
/*
|
||||
* $Id$
|
||||
*/
|
||||
|
||||
/*
|
||||
* Harbour Project source code:
|
||||
* MyUnzip utility
|
||||
*
|
||||
* Copyright 2008 Mindaugas Kavaliauskas <dbtopas.at.dbtopas.lt>
|
||||
* www - http://www.harbour-project.org
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; either version 2, or (at your option)
|
||||
* any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this software; see the file COPYING. If not, write to
|
||||
* the Free Software Foundation, Inc., 59 Temple Place, Suite 330,
|
||||
* Boston, MA 02111-1307 USA (or visit the web site http://www.gnu.org/).
|
||||
*
|
||||
* As a special exception, the Harbour Project gives permission for
|
||||
* additional uses of the text contained in its release of Harbour.
|
||||
*
|
||||
* The exception is that, if you link the Harbour libraries with other
|
||||
* files to produce an executable, this does not by itself cause the
|
||||
* resulting executable to be covered by the GNU General Public License.
|
||||
* Your use of that executable is in no way restricted on account of
|
||||
* linking the Harbour library code into it.
|
||||
*
|
||||
* This exception does not however invalidate any other reasons why
|
||||
* the executable file might be covered by the GNU General Public License.
|
||||
*
|
||||
* This exception applies only to the code released by the Harbour
|
||||
* Project under the name Harbour. If you copy code from other
|
||||
* Harbour Project or Free Software Foundation releases into a copy of
|
||||
* Harbour, as the General Public License permits, the exception does
|
||||
* not apply to the code that you add in this way. To avoid misleading
|
||||
* anyone as to the status of such modified files, you must delete
|
||||
* this exception notice from them.
|
||||
*
|
||||
* If you write modifications of your own for Harbour, it is your choice
|
||||
* whether to permit this exception to apply to your modifications.
|
||||
* If you do not wish that, delete this exception notice.
|
||||
*
|
||||
*/
|
||||
|
||||
|
||||
|
||||
PROC MyUnzip( ... )
|
||||
LOCAL hUnzip, aWild, cFileName, cWild, cFile, dDate, cTime, nSize, nCompSize, nErr, cPassword, tmp
|
||||
|
||||
aWild := { ... }
|
||||
IF LEN( aWild ) < 1
|
||||
? "Usage: myunzip <ZipName> [ --pass <password> ] [ <FilePattern1> ... ]"
|
||||
RETURN
|
||||
ENDIF
|
||||
|
||||
cFileName := aWild[ 1 ]
|
||||
IF ! ( "." $ cFileName )
|
||||
cFileName += ".zip"
|
||||
ENDIF
|
||||
|
||||
ADEL( aWild, 1 )
|
||||
ASIZE( aWild, LEN( aWild ) - 1 )
|
||||
|
||||
FOR tmp := 1 TO LEN( aWild ) - 1
|
||||
IF LOWER( aWild[ tmp ] ) == "--pass"
|
||||
cPassword := aWild[ tmp + 1 ]
|
||||
aWild[ tmp ] := ""
|
||||
aWild[ tmp + 1 ] := ""
|
||||
ENDIF
|
||||
NEXT
|
||||
|
||||
AEVAL( aWild, {|cPattern, nPos| aWild[ nPos ] := STRTRAN( cPattern, "\", "/" ) } )
|
||||
|
||||
hUnzip := HB_UNZIPOPEN( cFileName )
|
||||
|
||||
IF ! EMPTY( hUnzip )
|
||||
? "Archive file:", cFileName
|
||||
? ""
|
||||
? "Filename Date Time Size Compressed Action"
|
||||
? "---------------------------------------------------------------------------------"
|
||||
nErr := HB_UNZIPFILEFIRST( hUnzip )
|
||||
DO WHILE nErr == 0
|
||||
HB_UnzipFileInfo( hUnzip, @cFile, @dDate, @cTime,,,, @nSize, @nCompSize )
|
||||
? PADR( cFile, 30 ), dDate, cTime, nSize, nCompSize
|
||||
|
||||
IF ASCAN( aWild, {|cPattern| HB_WILDMATCH( cPattern, cFile, .T. ) } ) > 0
|
||||
?? " Extracting"
|
||||
HB_UnzipExtractCurrentFile( hUnzip, NIL, cPassword )
|
||||
ELSE
|
||||
?? " Skipping"
|
||||
ENDIF
|
||||
|
||||
nErr := HB_UNZIPFILENEXT( hUnzip )
|
||||
ENDDO
|
||||
HB_UNZIPCLOSE( hUnzip )
|
||||
ENDIF
|
||||
RETURN
|
||||
@@ -1,97 +0,0 @@
|
||||
/*
|
||||
* $Id$
|
||||
*/
|
||||
|
||||
/*
|
||||
* Harbour Project source code:
|
||||
* MyZip utility
|
||||
*
|
||||
* Copyright 2008 Mindaugas Kavaliauskas <dbtopas.at.dbtopas.lt>
|
||||
* www - http://www.harbour-project.org
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; either version 2, or (at your option)
|
||||
* any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this software; see the file COPYING. If not, write to
|
||||
* the Free Software Foundation, Inc., 59 Temple Place, Suite 330,
|
||||
* Boston, MA 02111-1307 USA (or visit the web site http://www.gnu.org/).
|
||||
*
|
||||
* As a special exception, the Harbour Project gives permission for
|
||||
* additional uses of the text contained in its release of Harbour.
|
||||
*
|
||||
* The exception is that, if you link the Harbour libraries with other
|
||||
* files to produce an executable, this does not by itself cause the
|
||||
* resulting executable to be covered by the GNU General Public License.
|
||||
* Your use of that executable is in no way restricted on account of
|
||||
* linking the Harbour library code into it.
|
||||
*
|
||||
* This exception does not however invalidate any other reasons why
|
||||
* the executable file might be covered by the GNU General Public License.
|
||||
*
|
||||
* This exception applies only to the code released by the Harbour
|
||||
* Project under the name Harbour. If you copy code from other
|
||||
* Harbour Project or Free Software Foundation releases into a copy of
|
||||
* Harbour, as the General Public License permits, the exception does
|
||||
* not apply to the code that you add in this way. To avoid misleading
|
||||
* anyone as to the status of such modified files, you must delete
|
||||
* this exception notice from them.
|
||||
*
|
||||
* If you write modifications of your own for Harbour, it is your choice
|
||||
* whether to permit this exception to apply to your modifications.
|
||||
* If you do not wish that, delete this exception notice.
|
||||
*
|
||||
*/
|
||||
|
||||
|
||||
|
||||
PROC MyZip( ... )
|
||||
LOCAL hZip, aDir, aFile, aWild, cFileName, cPath, cWild, cPassword, tmp
|
||||
|
||||
aWild := { ... }
|
||||
IF LEN(aWild) < 2
|
||||
? "Usage: myzip <ZipName> [ --pass <password> ] <FilePattern1> [ <FilePattern2> ... ]"
|
||||
RETURN
|
||||
ENDIF
|
||||
|
||||
cFileName := aWild[ 1 ]
|
||||
IF ! ( "." $ cFileName )
|
||||
cFileName += ".zip"
|
||||
ENDIF
|
||||
|
||||
ADEL( aWild, 1 )
|
||||
ASIZE( aWild, LEN( aWild ) - 1 )
|
||||
|
||||
FOR tmp := 1 TO LEN( aWild ) - 1
|
||||
IF LOWER( aWild[ tmp ] ) == "--pass"
|
||||
cPassword := aWild[ tmp + 1 ]
|
||||
aWild[ tmp ] := ""
|
||||
aWild[ tmp + 1 ] := ""
|
||||
ENDIF
|
||||
NEXT
|
||||
|
||||
hZip := HB_ZIPOPEN( cFileName )
|
||||
IF ! EMPTY( hZip )
|
||||
? "Archive file:", cFileName
|
||||
FOR EACH cWild IN aWild
|
||||
IF !EMPTY( cWild )
|
||||
aDir := DIRECTORY( cWild )
|
||||
cPath = LEFT( cWild, RAT( HB_OSPATHSEPARATOR(), cWild ) )
|
||||
FOR EACH aFile IN aDir
|
||||
IF cPath + aFile[ 1 ] != cFileName
|
||||
? "Adding", cPath + aFile[ 1 ]
|
||||
HB_ZipStoreFile( hZip, cPath + aFile[ 1 ], cPath + aFile[ 1 ], cPassword )
|
||||
ENDIF
|
||||
NEXT
|
||||
ENDIF
|
||||
NEXT
|
||||
HB_ZIPCLOSE( hZip )
|
||||
ENDIF
|
||||
RETURN
|
||||
File diff suppressed because it is too large
Load Diff
@@ -1,354 +0,0 @@
|
||||
/* unzip.h -- IO for uncompress .zip files using zlib
|
||||
Version 1.01e, February 12th, 2005
|
||||
|
||||
Copyright (C) 1998-2005 Gilles Vollant
|
||||
|
||||
This unzip package allow extract file from .ZIP file, compatible with PKZip 2.04g
|
||||
WinZip, InfoZip tools and compatible.
|
||||
|
||||
Multi volume ZipFile (span) are not supported.
|
||||
Encryption compatible with pkzip 2.04g only supported
|
||||
Old compressions used by old PKZip 1.x are not supported
|
||||
|
||||
|
||||
I WAIT FEEDBACK at mail info@winimage.com
|
||||
Visit also http://www.winimage.com/zLibDll/unzip.htm for evolution
|
||||
|
||||
Condition of use and distribution are the same than zlib :
|
||||
|
||||
This software is provided 'as-is', without any express or implied
|
||||
warranty. In no event will the authors be held liable for any damages
|
||||
arising from the use of this software.
|
||||
|
||||
Permission is granted to anyone to use this software for any purpose,
|
||||
including commercial applications, and to alter it and redistribute it
|
||||
freely, subject to the following restrictions:
|
||||
|
||||
1. The origin of this software must not be misrepresented; you must not
|
||||
claim that you wrote the original software. If you use this software
|
||||
in a product, an acknowledgment in the product documentation would be
|
||||
appreciated but is not required.
|
||||
2. Altered source versions must be plainly marked as such, and must not be
|
||||
misrepresented as being the original software.
|
||||
3. This notice may not be removed or altered from any source distribution.
|
||||
|
||||
|
||||
*/
|
||||
|
||||
/* for more info about .ZIP format, see
|
||||
http://www.info-zip.org/pub/infozip/doc/appnote-981119-iz.zip
|
||||
http://www.info-zip.org/pub/infozip/doc/
|
||||
PkWare has also a specification at :
|
||||
ftp://ftp.pkware.com/probdesc.zip
|
||||
*/
|
||||
|
||||
#ifndef _unz_H
|
||||
#define _unz_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#ifndef _ZLIB_H
|
||||
#include "zlib.h"
|
||||
#endif
|
||||
|
||||
#ifndef _ZLIBIOAPI_H
|
||||
#include "ioapi.h"
|
||||
#endif
|
||||
|
||||
#if defined(STRICTUNZIP) || defined(STRICTZIPUNZIP)
|
||||
/* like the STRICT of WIN32, we define a pointer that cannot be converted
|
||||
from (void*) without cast */
|
||||
typedef struct TagunzFile__ { int unused; } unzFile__;
|
||||
typedef unzFile__ *unzFile;
|
||||
#else
|
||||
typedef voidp unzFile;
|
||||
#endif
|
||||
|
||||
|
||||
#define UNZ_OK (0)
|
||||
#define UNZ_END_OF_LIST_OF_FILE (-100)
|
||||
#define UNZ_ERRNO (Z_ERRNO)
|
||||
#define UNZ_EOF (0)
|
||||
#define UNZ_PARAMERROR (-102)
|
||||
#define UNZ_BADZIPFILE (-103)
|
||||
#define UNZ_INTERNALERROR (-104)
|
||||
#define UNZ_CRCERROR (-105)
|
||||
|
||||
/* tm_unz contain date/time info */
|
||||
typedef struct tm_unz_s
|
||||
{
|
||||
uInt tm_sec; /* seconds after the minute - [0,59] */
|
||||
uInt tm_min; /* minutes after the hour - [0,59] */
|
||||
uInt tm_hour; /* hours since midnight - [0,23] */
|
||||
uInt tm_mday; /* day of the month - [1,31] */
|
||||
uInt tm_mon; /* months since January - [0,11] */
|
||||
uInt tm_year; /* years - [1980..2044] */
|
||||
} tm_unz;
|
||||
|
||||
/* unz_global_info structure contain global data about the ZIPfile
|
||||
These data comes from the end of central dir */
|
||||
typedef struct unz_global_info_s
|
||||
{
|
||||
uLong number_entry; /* total number of entries in
|
||||
the central dir on this disk */
|
||||
uLong size_comment; /* size of the global comment of the zipfile */
|
||||
} unz_global_info;
|
||||
|
||||
|
||||
/* unz_file_info contain information about a file in the zipfile */
|
||||
typedef struct unz_file_info_s
|
||||
{
|
||||
uLong version; /* version made by 2 bytes */
|
||||
uLong version_needed; /* version needed to extract 2 bytes */
|
||||
uLong flag; /* general purpose bit flag 2 bytes */
|
||||
uLong compression_method; /* compression method 2 bytes */
|
||||
uLong dosDate; /* last mod file date in Dos fmt 4 bytes */
|
||||
uLong crc; /* crc-32 4 bytes */
|
||||
uLong compressed_size; /* compressed size 4 bytes */
|
||||
uLong uncompressed_size; /* uncompressed size 4 bytes */
|
||||
uLong size_filename; /* filename length 2 bytes */
|
||||
uLong size_file_extra; /* extra field length 2 bytes */
|
||||
uLong size_file_comment; /* file comment length 2 bytes */
|
||||
|
||||
uLong disk_num_start; /* disk number start 2 bytes */
|
||||
uLong internal_fa; /* internal file attributes 2 bytes */
|
||||
uLong external_fa; /* external file attributes 4 bytes */
|
||||
|
||||
tm_unz tmu_date;
|
||||
} unz_file_info;
|
||||
|
||||
extern int ZEXPORT unzStringFileNameCompare OF ((const char* fileName1,
|
||||
const char* fileName2,
|
||||
int iCaseSensitivity));
|
||||
/*
|
||||
Compare two filename (fileName1,fileName2).
|
||||
If iCaseSenisivity = 1, comparision is case sensitivity (like strcmp)
|
||||
If iCaseSenisivity = 2, comparision is not case sensitivity (like strcmpi
|
||||
or strcasecmp)
|
||||
If iCaseSenisivity = 0, case sensitivity is defaut of your operating system
|
||||
(like 1 on Unix, 2 on Windows)
|
||||
*/
|
||||
|
||||
|
||||
extern unzFile ZEXPORT unzOpen OF((const char *path));
|
||||
/*
|
||||
Open a Zip file. path contain the full pathname (by example,
|
||||
on a Windows XP computer "c:\\zlib\\zlib113.zip" or on an Unix computer
|
||||
"zlib/zlib113.zip".
|
||||
If the zipfile cannot be opened (file don't exist or in not valid), the
|
||||
return value is NULL.
|
||||
Else, the return value is a unzFile Handle, usable with other function
|
||||
of this unzip package.
|
||||
*/
|
||||
|
||||
extern unzFile ZEXPORT unzOpen2 OF((const char *path,
|
||||
zlib_filefunc_def* pzlib_filefunc_def));
|
||||
/*
|
||||
Open a Zip file, like unzOpen, but provide a set of file low level API
|
||||
for read/write the zip file (see ioapi.h)
|
||||
*/
|
||||
|
||||
extern int ZEXPORT unzClose OF((unzFile file));
|
||||
/*
|
||||
Close a ZipFile opened with unzipOpen.
|
||||
If there is files inside the .Zip opened with unzOpenCurrentFile (see later),
|
||||
these files MUST be closed with unzipCloseCurrentFile before call unzipClose.
|
||||
return UNZ_OK if there is no problem. */
|
||||
|
||||
extern int ZEXPORT unzGetGlobalInfo OF((unzFile file,
|
||||
unz_global_info *pglobal_info));
|
||||
/*
|
||||
Write info about the ZipFile in the *pglobal_info structure.
|
||||
No preparation of the structure is needed
|
||||
return UNZ_OK if there is no problem. */
|
||||
|
||||
|
||||
extern int ZEXPORT unzGetGlobalComment OF((unzFile file,
|
||||
char *szComment,
|
||||
uLong uSizeBuf));
|
||||
/*
|
||||
Get the global comment string of the ZipFile, in the szComment buffer.
|
||||
uSizeBuf is the size of the szComment buffer.
|
||||
return the number of byte copied or an error code <0
|
||||
*/
|
||||
|
||||
|
||||
/***************************************************************************/
|
||||
/* Unzip package allow you browse the directory of the zipfile */
|
||||
|
||||
extern int ZEXPORT unzGoToFirstFile OF((unzFile file));
|
||||
/*
|
||||
Set the current file of the zipfile to the first file.
|
||||
return UNZ_OK if there is no problem
|
||||
*/
|
||||
|
||||
extern int ZEXPORT unzGoToNextFile OF((unzFile file));
|
||||
/*
|
||||
Set the current file of the zipfile to the next file.
|
||||
return UNZ_OK if there is no problem
|
||||
return UNZ_END_OF_LIST_OF_FILE if the actual file was the latest.
|
||||
*/
|
||||
|
||||
extern int ZEXPORT unzLocateFile OF((unzFile file,
|
||||
const char *szFileName,
|
||||
int iCaseSensitivity));
|
||||
/*
|
||||
Try locate the file szFileName in the zipfile.
|
||||
For the iCaseSensitivity signification, see unzStringFileNameCompare
|
||||
|
||||
return value :
|
||||
UNZ_OK if the file is found. It becomes the current file.
|
||||
UNZ_END_OF_LIST_OF_FILE if the file is not found
|
||||
*/
|
||||
|
||||
|
||||
/* ****************************************** */
|
||||
/* Ryan supplied functions */
|
||||
/* unz_file_info contain information about a file in the zipfile */
|
||||
typedef struct unz_file_pos_s
|
||||
{
|
||||
uLong pos_in_zip_directory; /* offset in zip file directory */
|
||||
uLong num_of_file; /* # of file */
|
||||
} unz_file_pos;
|
||||
|
||||
extern int ZEXPORT unzGetFilePos(
|
||||
unzFile file,
|
||||
unz_file_pos* file_pos);
|
||||
|
||||
extern int ZEXPORT unzGoToFilePos(
|
||||
unzFile file,
|
||||
unz_file_pos* file_pos);
|
||||
|
||||
/* ****************************************** */
|
||||
|
||||
extern int ZEXPORT unzGetCurrentFileInfo OF((unzFile file,
|
||||
unz_file_info *pfile_info,
|
||||
char *szFileName,
|
||||
uLong fileNameBufferSize,
|
||||
void *extraField,
|
||||
uLong extraFieldBufferSize,
|
||||
char *szComment,
|
||||
uLong commentBufferSize));
|
||||
/*
|
||||
Get Info about the current file
|
||||
if pfile_info!=NULL, the *pfile_info structure will contain somes info about
|
||||
the current file
|
||||
if szFileName!=NULL, the filemane string will be copied in szFileName
|
||||
(fileNameBufferSize is the size of the buffer)
|
||||
if extraField!=NULL, the extra field information will be copied in extraField
|
||||
(extraFieldBufferSize is the size of the buffer).
|
||||
This is the Central-header version of the extra field
|
||||
if szComment!=NULL, the comment string of the file will be copied in szComment
|
||||
(commentBufferSize is the size of the buffer)
|
||||
*/
|
||||
|
||||
/***************************************************************************/
|
||||
/* for reading the content of the current zipfile, you can open it, read data
|
||||
from it, and close it (you can close it before reading all the file)
|
||||
*/
|
||||
|
||||
extern int ZEXPORT unzOpenCurrentFile OF((unzFile file));
|
||||
/*
|
||||
Open for reading data the current file in the zipfile.
|
||||
If there is no error, the return value is UNZ_OK.
|
||||
*/
|
||||
|
||||
extern int ZEXPORT unzOpenCurrentFilePassword OF((unzFile file,
|
||||
const char* password));
|
||||
/*
|
||||
Open for reading data the current file in the zipfile.
|
||||
password is a crypting password
|
||||
If there is no error, the return value is UNZ_OK.
|
||||
*/
|
||||
|
||||
extern int ZEXPORT unzOpenCurrentFile2 OF((unzFile file,
|
||||
int* method,
|
||||
int* level,
|
||||
int raw));
|
||||
/*
|
||||
Same than unzOpenCurrentFile, but open for read raw the file (not uncompress)
|
||||
if raw==1
|
||||
*method will receive method of compression, *level will receive level of
|
||||
compression
|
||||
note : you can set level parameter as NULL (if you did not want known level,
|
||||
but you CANNOT set method parameter as NULL
|
||||
*/
|
||||
|
||||
extern int ZEXPORT unzOpenCurrentFile3 OF((unzFile file,
|
||||
int* method,
|
||||
int* level,
|
||||
int raw,
|
||||
const char* password));
|
||||
/*
|
||||
Same than unzOpenCurrentFile, but open for read raw the file (not uncompress)
|
||||
if raw==1
|
||||
*method will receive method of compression, *level will receive level of
|
||||
compression
|
||||
note : you can set level parameter as NULL (if you did not want known level,
|
||||
but you CANNOT set method parameter as NULL
|
||||
*/
|
||||
|
||||
|
||||
extern int ZEXPORT unzCloseCurrentFile OF((unzFile file));
|
||||
/*
|
||||
Close the file in zip opened with unzOpenCurrentFile
|
||||
Return UNZ_CRCERROR if all the file was read but the CRC is not good
|
||||
*/
|
||||
|
||||
extern int ZEXPORT unzReadCurrentFile OF((unzFile file,
|
||||
voidp buf,
|
||||
unsigned len));
|
||||
/*
|
||||
Read bytes from the current file (opened by unzOpenCurrentFile)
|
||||
buf contain buffer where data must be copied
|
||||
len the size of buf.
|
||||
|
||||
return the number of byte copied if somes bytes are copied
|
||||
return 0 if the end of file was reached
|
||||
return <0 with error code if there is an error
|
||||
(UNZ_ERRNO for IO error, or zLib error for uncompress error)
|
||||
*/
|
||||
|
||||
extern z_off_t ZEXPORT unztell OF((unzFile file));
|
||||
/*
|
||||
Give the current position in uncompressed data
|
||||
*/
|
||||
|
||||
extern int ZEXPORT unzeof OF((unzFile file));
|
||||
/*
|
||||
return 1 if the end of file was reached, 0 elsewhere
|
||||
*/
|
||||
|
||||
extern int ZEXPORT unzGetLocalExtrafield OF((unzFile file,
|
||||
voidp buf,
|
||||
unsigned len));
|
||||
/*
|
||||
Read extra field from the current file (opened by unzOpenCurrentFile)
|
||||
This is the local-header version of the extra field (sometimes, there is
|
||||
more info in the local-header version than in the central-header)
|
||||
|
||||
if buf==NULL, it return the size of the local extra field
|
||||
|
||||
if buf!=NULL, len is the size of the buffer, the extra header is copied in
|
||||
buf.
|
||||
the return value is the number of bytes copied in buf, or (if <0)
|
||||
the error code
|
||||
*/
|
||||
|
||||
/***************************************************************************/
|
||||
|
||||
/* Get the current file offset */
|
||||
extern uLong ZEXPORT unzGetOffset (unzFile file);
|
||||
|
||||
/* Set the current file offset */
|
||||
extern int ZEXPORT unzSetOffset (unzFile file, uLong pos);
|
||||
|
||||
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif /* _unz_H */
|
||||
File diff suppressed because it is too large
Load Diff
@@ -1,235 +0,0 @@
|
||||
/* zip.h -- IO for compress .zip files using zlib
|
||||
Version 1.01e, February 12th, 2005
|
||||
|
||||
Copyright (C) 1998-2005 Gilles Vollant
|
||||
|
||||
This unzip package allow creates .ZIP file, compatible with PKZip 2.04g
|
||||
WinZip, InfoZip tools and compatible.
|
||||
Multi volume ZipFile (span) are not supported.
|
||||
Encryption compatible with pkzip 2.04g only supported
|
||||
Old compressions used by old PKZip 1.x are not supported
|
||||
|
||||
For uncompress .zip file, look at unzip.h
|
||||
|
||||
|
||||
I WAIT FEEDBACK at mail info@winimage.com
|
||||
Visit also http://www.winimage.com/zLibDll/unzip.html for evolution
|
||||
|
||||
Condition of use and distribution are the same than zlib :
|
||||
|
||||
This software is provided 'as-is', without any express or implied
|
||||
warranty. In no event will the authors be held liable for any damages
|
||||
arising from the use of this software.
|
||||
|
||||
Permission is granted to anyone to use this software for any purpose,
|
||||
including commercial applications, and to alter it and redistribute it
|
||||
freely, subject to the following restrictions:
|
||||
|
||||
1. The origin of this software must not be misrepresented; you must not
|
||||
claim that you wrote the original software. If you use this software
|
||||
in a product, an acknowledgment in the product documentation would be
|
||||
appreciated but is not required.
|
||||
2. Altered source versions must be plainly marked as such, and must not be
|
||||
misrepresented as being the original software.
|
||||
3. This notice may not be removed or altered from any source distribution.
|
||||
|
||||
|
||||
*/
|
||||
|
||||
/* for more info about .ZIP format, see
|
||||
http://www.info-zip.org/pub/infozip/doc/appnote-981119-iz.zip
|
||||
http://www.info-zip.org/pub/infozip/doc/
|
||||
PkWare has also a specification at :
|
||||
ftp://ftp.pkware.com/probdesc.zip
|
||||
*/
|
||||
|
||||
#ifndef _zip_H
|
||||
#define _zip_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#ifndef _ZLIB_H
|
||||
#include "zlib.h"
|
||||
#endif
|
||||
|
||||
#ifndef _ZLIBIOAPI_H
|
||||
#include "ioapi.h"
|
||||
#endif
|
||||
|
||||
#if defined(STRICTZIP) || defined(STRICTZIPUNZIP)
|
||||
/* like the STRICT of WIN32, we define a pointer that cannot be converted
|
||||
from (void*) without cast */
|
||||
typedef struct TagzipFile__ { int unused; } zipFile__;
|
||||
typedef zipFile__ *zipFile;
|
||||
#else
|
||||
typedef voidp zipFile;
|
||||
#endif
|
||||
|
||||
#define ZIP_OK (0)
|
||||
#define ZIP_EOF (0)
|
||||
#define ZIP_ERRNO (Z_ERRNO)
|
||||
#define ZIP_PARAMERROR (-102)
|
||||
#define ZIP_BADZIPFILE (-103)
|
||||
#define ZIP_INTERNALERROR (-104)
|
||||
|
||||
#ifndef DEF_MEM_LEVEL
|
||||
# if MAX_MEM_LEVEL >= 8
|
||||
# define DEF_MEM_LEVEL 8
|
||||
# else
|
||||
# define DEF_MEM_LEVEL MAX_MEM_LEVEL
|
||||
# endif
|
||||
#endif
|
||||
/* default memLevel */
|
||||
|
||||
/* tm_zip contain date/time info */
|
||||
typedef struct tm_zip_s
|
||||
{
|
||||
uInt tm_sec; /* seconds after the minute - [0,59] */
|
||||
uInt tm_min; /* minutes after the hour - [0,59] */
|
||||
uInt tm_hour; /* hours since midnight - [0,23] */
|
||||
uInt tm_mday; /* day of the month - [1,31] */
|
||||
uInt tm_mon; /* months since January - [0,11] */
|
||||
uInt tm_year; /* years - [1980..2044] */
|
||||
} tm_zip;
|
||||
|
||||
typedef struct
|
||||
{
|
||||
tm_zip tmz_date; /* date in understandable format */
|
||||
uLong dosDate; /* if dos_date == 0, tmu_date is used */
|
||||
/* uLong flag; */ /* general purpose bit flag 2 bytes */
|
||||
|
||||
uLong internal_fa; /* internal file attributes 2 bytes */
|
||||
uLong external_fa; /* external file attributes 4 bytes */
|
||||
} zip_fileinfo;
|
||||
|
||||
typedef const char* zipcharpc;
|
||||
|
||||
|
||||
#define APPEND_STATUS_CREATE (0)
|
||||
#define APPEND_STATUS_CREATEAFTER (1)
|
||||
#define APPEND_STATUS_ADDINZIP (2)
|
||||
|
||||
extern zipFile ZEXPORT zipOpen OF((const char *pathname, int append));
|
||||
/*
|
||||
Create a zipfile.
|
||||
pathname contain on Windows XP a filename like "c:\\zlib\\zlib113.zip" or on
|
||||
an Unix computer "zlib/zlib113.zip".
|
||||
if the file pathname exist and append==APPEND_STATUS_CREATEAFTER, the zip
|
||||
will be created at the end of the file.
|
||||
(useful if the file contain a self extractor code)
|
||||
if the file pathname exist and append==APPEND_STATUS_ADDINZIP, we will
|
||||
add files in existing zip (be sure you don't add file that doesn't exist)
|
||||
If the zipfile cannot be opened, the return value is NULL.
|
||||
Else, the return value is a zipFile Handle, usable with other function
|
||||
of this zip package.
|
||||
*/
|
||||
|
||||
/* Note : there is no delete function into a zipfile.
|
||||
If you want delete file into a zipfile, you must open a zipfile, and create another
|
||||
Of couse, you can use RAW reading and writing to copy the file you did not want delte
|
||||
*/
|
||||
|
||||
extern zipFile ZEXPORT zipOpen2 OF((const char *pathname,
|
||||
int append,
|
||||
zipcharpc* globalcomment,
|
||||
zlib_filefunc_def* pzlib_filefunc_def));
|
||||
|
||||
extern int ZEXPORT zipOpenNewFileInZip OF((zipFile file,
|
||||
const char* filename,
|
||||
const zip_fileinfo* zipfi,
|
||||
const void* extrafield_local,
|
||||
uInt size_extrafield_local,
|
||||
const void* extrafield_global,
|
||||
uInt size_extrafield_global,
|
||||
const char* comment,
|
||||
int method,
|
||||
int level));
|
||||
/*
|
||||
Open a file in the ZIP for writing.
|
||||
filename : the filename in zip (if NULL, '-' without quote will be used
|
||||
*zipfi contain supplemental information
|
||||
if extrafield_local!=NULL and size_extrafield_local>0, extrafield_local
|
||||
contains the extrafield data the the local header
|
||||
if extrafield_global!=NULL and size_extrafield_global>0, extrafield_global
|
||||
contains the extrafield data the the local header
|
||||
if comment != NULL, comment contain the comment string
|
||||
method contain the compression method (0 for store, Z_DEFLATED for deflate)
|
||||
level contain the level of compression (can be Z_DEFAULT_COMPRESSION)
|
||||
*/
|
||||
|
||||
|
||||
extern int ZEXPORT zipOpenNewFileInZip2 OF((zipFile file,
|
||||
const char* filename,
|
||||
const zip_fileinfo* zipfi,
|
||||
const void* extrafield_local,
|
||||
uInt size_extrafield_local,
|
||||
const void* extrafield_global,
|
||||
uInt size_extrafield_global,
|
||||
const char* comment,
|
||||
int method,
|
||||
int level,
|
||||
int raw));
|
||||
|
||||
/*
|
||||
Same than zipOpenNewFileInZip, except if raw=1, we write raw file
|
||||
*/
|
||||
|
||||
extern int ZEXPORT zipOpenNewFileInZip3 OF((zipFile file,
|
||||
const char* filename,
|
||||
const zip_fileinfo* zipfi,
|
||||
const void* extrafield_local,
|
||||
uInt size_extrafield_local,
|
||||
const void* extrafield_global,
|
||||
uInt size_extrafield_global,
|
||||
const char* comment,
|
||||
int method,
|
||||
int level,
|
||||
int raw,
|
||||
int windowBits,
|
||||
int memLevel,
|
||||
int strategy,
|
||||
const char* password,
|
||||
uLong crcForCtypting));
|
||||
|
||||
/*
|
||||
Same than zipOpenNewFileInZip2, except
|
||||
windowBits,memLevel,,strategy : see parameter strategy in deflateInit2
|
||||
password : crypting password (NULL for no crypting)
|
||||
crcForCtypting : crc of file to compress (needed for crypting)
|
||||
*/
|
||||
|
||||
|
||||
extern int ZEXPORT zipWriteInFileInZip OF((zipFile file,
|
||||
const void* buf,
|
||||
unsigned len));
|
||||
/*
|
||||
Write data in the zipfile
|
||||
*/
|
||||
|
||||
extern int ZEXPORT zipCloseFileInZip OF((zipFile file));
|
||||
/*
|
||||
Close the current file in the zipfile
|
||||
*/
|
||||
|
||||
extern int ZEXPORT zipCloseFileInZipRaw OF((zipFile file,
|
||||
uLong uncompressed_size,
|
||||
uLong crc32));
|
||||
/*
|
||||
Close the current file in the zipfile, for fiel opened with
|
||||
parameter raw=1 in zipOpenNewFileInZip2
|
||||
uncompressed_size and crc32 are value for the uncompressed size
|
||||
*/
|
||||
|
||||
extern int ZEXPORT zipClose OF((zipFile file,
|
||||
const char* global_comment));
|
||||
/*
|
||||
Close the zipfile
|
||||
*/
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif /* _zip_H */
|
||||
Reference in New Issue
Block a user