2008-01-16 01:20 UTC+0200 Mindaugas Kavaliauskas (dbtopas/at/dbtopas.lt)
+ harbout/contrib/hbzlib
+ added support for zlib library and zip files (based on
minizip)
+ harbour/contrib/hbzlib/zconf.h
+ harbour/contrib/hbzlib/zlib.h
+ zlib include files
+ harbour/contrib/hbzlib/zip.h
+ harbour/contrib/hbzlib/unzip.h
+ minizip include files
+ harbour/contrib/hbzlib/ioapi.c
+ harbour/contrib/hbzlib/zip.c
+ harbour/contrib/hbzlib/unzip.c
+ minizip source files. Some fixes are applied to avoid compile
time warning and errors, see readme.txt for list
; I've compiled with BCC only, please, check other compilers
+ harbour/contrib/hbzlib/hbzlib.c
+ zlib wrapper functions. Przemyslaw Czerpak is author of this code.
The file was posted to developers mailing list on 2007-05-17.
I think licence statments in the begining of file gives permission
to include it into SVN.
* HB_UNCOMPRESSLEN() function added. Source copied from Przemyslaw's
email on 2008-01-10.
+ harbour/contrib/hbzlib/hbmzip.c
+ wrapper functions for minizip library
Function names uses convention:
- HB_ZIP*() - manages compression of .zip file:
HB_ZIPOPEN(), HB_ZIPCLOSE()
- HB_ZIPFILE*() - manages compression of files inside .zip:
HB_ZIPFILECREATE(), HB_ZIPFILEWRITE(), HB_ZIPFILECLOSE()
- HB_UNZIP*() - manages decompression of .zip fileL
HB_UNZIPOPEN(), HB_UNZIPCLOSE()
- HB_UNZIPFILE*() - manages decompression of files inside .zip
HB_UNZIPFILEOPEN(), HB_UNZIPFILEREAD(), HB_UNZIPFILECLOSE(),
HB_UNZIPFILEFIRST(), HB_UNZIPFILENEXT(), HB_UNZIPFILEPOS(),
HB_UNZIPFILEGOTO(), HB_UNZIPFILEINFO()
Parameters of functions are documented inside source files.
+ implemented some higher level functions. These function are not
wrapper of minizip:
HB_ZIPSTOREFILE(), HB_UNZIPEXTRACTCURRENTFILE()
; minizip gives low level access on zip files. This could be a
problem if you not going to put your fingers on internals, but
just want to compress/decompress files. Because managing of
file attributes is a little complicated. These higher level
functions do the job.
; please test code under linux. Source is written using docs only,
without test or deeper knowledge.
+ harbour/contrib/hbzlib/hbzlib.ch
+ defines for zlib and minizip libraries
; I've used HB_ZLIB_* and HB_ZIP_* prefixes, because some original
names of minizip library are too general, ex., APPEND_STATUS_CREATE
If you want to use original define names we change this.
+ harbour/contrib/hbzlib/readme.txt
* some comments on the source of libraries and ChangeLog for minizip
files
+ harbour/contrib/hbzlib/tests/myzip.prg
+ harbour/contrib/hbzlib/tests/myunzip.prg
+ tiny compression/decompression utilities written in Harbour
+ harbour/contrib/hbzlib/Makefile
+ harbour/contrib/hbzlib/make_b32.bat
+ harbour/contrib/hbzlib/make_vc.bat
+ makefiles written using another contrib's makefiles as template
; I'm not makefiles guru, please test it. I've also used command line
parameters: -DNOCRYPT -DNOUNCRYPT, to compile minizip. I don't know
howto include these to our makefiles
This commit is contained in:
@@ -8,6 +8,72 @@
|
||||
2002-12-01 13:30 UTC+0100 Foo Bar <foo.bar@foobar.org>
|
||||
*/
|
||||
|
||||
2008-01-16 01:20 UTC+0200 Mindaugas Kavaliauskas (dbtopas/at/dbtopas.lt)
|
||||
+ harbout/contrib/hbzlib
|
||||
+ added support for zlib library and zip files (based on
|
||||
minizip)
|
||||
+ harbour/contrib/hbzlib/zconf.h
|
||||
+ harbour/contrib/hbzlib/zlib.h
|
||||
+ zlib include files
|
||||
+ harbour/contrib/hbzlib/zip.h
|
||||
+ harbour/contrib/hbzlib/unzip.h
|
||||
+ minizip include files
|
||||
+ harbour/contrib/hbzlib/ioapi.c
|
||||
+ harbour/contrib/hbzlib/zip.c
|
||||
+ harbour/contrib/hbzlib/unzip.c
|
||||
+ minizip source files. Some fixes are applied to avoid compile
|
||||
time warning and errors, see readme.txt for list
|
||||
; I've compiled with BCC only, please, check other compilers
|
||||
+ harbour/contrib/hbzlib/hbzlib.c
|
||||
+ zlib wrapper functions. Przemyslaw Czerpak is author of this code.
|
||||
The file was posted to developers mailing list on 2007-05-17.
|
||||
I think licence statments in the begining of file gives permission
|
||||
to include it into SVN.
|
||||
* HB_UNCOMPRESSLEN() function added. Source copied from Przemyslaw's
|
||||
email on 2008-01-10.
|
||||
+ harbour/contrib/hbzlib/hbmzip.c
|
||||
+ wrapper functions for minizip library
|
||||
Function names uses convention:
|
||||
- HB_ZIP*() - manages compression of .zip file:
|
||||
HB_ZIPOPEN(), HB_ZIPCLOSE()
|
||||
- HB_ZIPFILE*() - manages compression of files inside .zip:
|
||||
HB_ZIPFILECREATE(), HB_ZIPFILEWRITE(), HB_ZIPFILECLOSE()
|
||||
- HB_UNZIP*() - manages decompression of .zip fileL
|
||||
HB_UNZIPOPEN(), HB_UNZIPCLOSE()
|
||||
- HB_UNZIPFILE*() - manages decompression of files inside .zip
|
||||
HB_UNZIPFILEOPEN(), HB_UNZIPFILEREAD(), HB_UNZIPFILECLOSE(),
|
||||
HB_UNZIPFILEFIRST(), HB_UNZIPFILENEXT(), HB_UNZIPFILEPOS(),
|
||||
HB_UNZIPFILEGOTO(), HB_UNZIPFILEINFO()
|
||||
Parameters of functions are documented inside source files.
|
||||
+ implemented some higher level functions. These function are not
|
||||
wrapper of minizip:
|
||||
HB_ZIPSTOREFILE(), HB_UNZIPEXTRACTCURRENTFILE()
|
||||
; minizip gives low level access on zip files. This could be a
|
||||
problem if you not going to put your fingers on internals, but
|
||||
just want to compress/decompress files. Because managing of
|
||||
file attributes is a little complicated. These higher level
|
||||
functions do the job.
|
||||
; please test code under linux. Source is written using docs only,
|
||||
without test or deeper knowledge.
|
||||
+ harbour/contrib/hbzlib/hbzlib.ch
|
||||
+ defines for zlib and minizip libraries
|
||||
; I've used HB_ZLIB_* and HB_ZIP_* prefixes, because some original
|
||||
names of minizip library are too general, ex., APPEND_STATUS_CREATE
|
||||
If you want to use original define names we change this.
|
||||
+ harbour/contrib/hbzlib/readme.txt
|
||||
* some comments on the source of libraries and ChangeLog for minizip
|
||||
files
|
||||
+ harbour/contrib/hbzlib/tests/myzip.prg
|
||||
+ harbour/contrib/hbzlib/tests/myunzip.prg
|
||||
+ tiny compression/decompression utilities written in Harbour
|
||||
+ harbour/contrib/hbzlib/Makefile
|
||||
+ harbour/contrib/hbzlib/make_b32.bat
|
||||
+ harbour/contrib/hbzlib/make_vc.bat
|
||||
+ makefiles written using another contrib's makefiles as template
|
||||
; I'm not makefiles guru, please test it. I've also used command line
|
||||
parameters: -DNOCRYPT -DNOUNCRYPT, to compile minizip. I don't know
|
||||
howto include these to our makefiles
|
||||
|
||||
2008-01-15 19:30 UTC+0100 Tomaz Zupan (tomaz.zupan/at/orpo.si)
|
||||
* harbour.spec
|
||||
* Recognize more Mandriva releases
|
||||
|
||||
19
harbour/contrib/hbzlib/Makefile
Normal file
19
harbour/contrib/hbzlib/Makefile
Normal file
@@ -0,0 +1,19 @@
|
||||
#
|
||||
# $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
|
||||
764
harbour/contrib/hbzlib/hbmzip.c
Normal file
764
harbour/contrib/hbzlib/hbmzip.c
Normal file
@@ -0,0 +1,764 @@
|
||||
/*
|
||||
* $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>
|
||||
#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 = 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 = 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 = 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 ] ) --> 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( zipOpenNewFileInZip( hZip, szZipName, &zfi,
|
||||
NULL, 0, NULL, 0, NULL, iMethod, iLevel ) );
|
||||
}
|
||||
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 = 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( unzOpenCurrentFile( hUnzip ) );
|
||||
}
|
||||
|
||||
|
||||
/* 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 * 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 = GetFileAttributes( szFileName );
|
||||
|
||||
if( (LONG) ulExtAttr != -1 )
|
||||
{
|
||||
ulExtAttr = GetFileAttributes( 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( stricmp( pString, ".exe" ) == 0 || stricmp( pString, ".com" ) == 0 ||
|
||||
stricmp( pString, ".bat" ) == 0 )
|
||||
{
|
||||
ulExtAttr |= 0x00490000; /* --x--x--x */
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
fError = TRUE;
|
||||
}
|
||||
#elif defined( HB_OS_UNIX )
|
||||
{
|
||||
struct stat statbuf;
|
||||
struct tm st;
|
||||
|
||||
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;
|
||||
|
||||
localtime_r( &statbuf.st_mtime, &st );
|
||||
|
||||
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 = zipOpenNewFileInZip( hZip, szZipName, &zfi, NULL, 0, NULL, 0, NULL,
|
||||
Z_DEFLATED, Z_DEFAULT_COMPRESSION );
|
||||
if( iResult == 0 )
|
||||
zipCloseFileInZip( hZip );
|
||||
}
|
||||
else
|
||||
{
|
||||
hFile = hb_fsOpen( szFileName, 0 );
|
||||
|
||||
if( hFile != FS_ERROR )
|
||||
{
|
||||
#if defined( HB_OS_WIN_32 )
|
||||
{
|
||||
FILETIME ftutc, ft;
|
||||
SYSTEMTIME st;
|
||||
|
||||
if( GetFileTime( LongToHandle( 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 = zipOpenNewFileInZip( hZip, szZipName, &zfi, NULL, 0, NULL, 0, NULL,
|
||||
Z_DEFLATED, Z_DEFAULT_COMPRESSION );
|
||||
if( iResult == 0 )
|
||||
{
|
||||
pString = (char*) hb_xgrab( 1024 * 16 );
|
||||
while ( ( ulLen = hb_fsReadLarge( hFile, 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 ] ) --> 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 ) ) );
|
||||
}
|
||||
else
|
||||
hb_errRT_BASE_SubstR( EG_ARG, 3012, NULL, &hb_errFuncName, HB_ERR_ARGS_BASEPARAMS );
|
||||
}
|
||||
|
||||
|
||||
static int hb_unzipExtractCurrentFile( unzFile hUnzip, char* szFileName )
|
||||
{
|
||||
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 = unzOpenCurrentFile( hUnzip );
|
||||
|
||||
if( iResult != 0 )
|
||||
return iResult;
|
||||
|
||||
if( szFileName )
|
||||
{
|
||||
hb_strncpy( szName, szFileName, sizeof( szName ) );
|
||||
}
|
||||
|
||||
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( szName );
|
||||
szName[ ulPos ] = cSep;
|
||||
}
|
||||
ulPos++;
|
||||
}
|
||||
|
||||
if( ufi.external_fa & 0x40000000 ) /* DIRECTORY */
|
||||
{
|
||||
hb_fsMkDir( szName );
|
||||
iResult = 0;
|
||||
}
|
||||
else
|
||||
{
|
||||
hFile = hb_fsCreate( szName, 0 );
|
||||
|
||||
if( hFile != FS_ERROR )
|
||||
{
|
||||
pString = (char*) hb_xgrab( 1024 * 16 );
|
||||
|
||||
while ( ( iResult = unzReadCurrentFile( hUnzip, pString, 16 * 1024 ) ) > 0 )
|
||||
{
|
||||
hb_fsWriteLarge( hFile, 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( LongToHandle( hFile ), &ftutc, &ftutc, &ftutc );
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
hb_fsClose( hFile );
|
||||
}
|
||||
else
|
||||
{
|
||||
iResult = -200 - hb_fsError();
|
||||
}
|
||||
}
|
||||
unzCloseCurrentFile( hUnzip );
|
||||
|
||||
|
||||
#if defined( HB_OS_WIN_32 )
|
||||
{
|
||||
SetFileAttributes( szName, ufi.external_fa & 0xFF );
|
||||
}
|
||||
#elif defined( HB_OS_UNIX )
|
||||
{
|
||||
struct utimebuf utim;
|
||||
struct tm st;
|
||||
time_t tim;
|
||||
|
||||
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.tmz_date.tm_mon + 1;
|
||||
st.tm_year = ufi.tmu_date.tm_year;
|
||||
|
||||
utim.actime = mktime( &st );
|
||||
utim.modtime = utim.actime;
|
||||
|
||||
utime( szFile, &utm );
|
||||
}
|
||||
#else
|
||||
{
|
||||
int TODO; /* To force warning */
|
||||
}
|
||||
#endif
|
||||
|
||||
return iResult;
|
||||
}
|
||||
|
||||
|
||||
/* HB_UnzipExtractCurrentFile( hZip [, cFileName ] ) --> nError */
|
||||
HB_FUNC( HB_UNZIPEXTRACTCURRENTFILE )
|
||||
{
|
||||
unzFile hUnzip = hb_unzipfileParam( 1 );
|
||||
|
||||
if( hUnzip )
|
||||
hb_retni( hb_unzipExtractCurrentFile( hUnzip, hb_parc( 2 ) ) );
|
||||
}
|
||||
|
||||
520
harbour/contrib/hbzlib/hbzlib.c
Normal file
520
harbour/contrib/hbzlib/hbzlib.c
Normal file
@@ -0,0 +1,520 @@
|
||||
/*
|
||||
* $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"
|
||||
|
||||
/*
|
||||
* HB_ZLIBVERSION( [<nType>] ) -> <cZlibVersion>
|
||||
*/
|
||||
HB_FUNC( HB_ZLIBVERSION )
|
||||
{
|
||||
if( hb_parni( 1 ) == 1 )
|
||||
hb_retc( ZLIB_VERSION );
|
||||
else
|
||||
hb_retc( zlibVersion() );
|
||||
}
|
||||
|
||||
/*
|
||||
* HB_COMPARESBOUND( <cData> | <nDataLen> ) -> <nMaxCompressLen>
|
||||
*/
|
||||
HB_FUNC( HB_COMPRESSBOUND )
|
||||
{
|
||||
if( ISCHAR( 1 ) )
|
||||
hb_retnint( compressBound( hb_parclen( 1 ) ) );
|
||||
else if( ISNUM( 1 ) )
|
||||
hb_retnint( compressBound( hb_parnint( 1 ) ) );
|
||||
else
|
||||
hb_errRT_BASE_SubstR( EG_ARG, 3012, NULL, &hb_errFuncName, HB_ERR_ARGS_BASEPARAMS );
|
||||
}
|
||||
|
||||
/*
|
||||
* HB_COMPARESS( <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 ) ? hb_parnint( 2 ) : compressBound( ulLen );
|
||||
pDest = ( char * ) hb_xgrab( ulDstLen + 1 );
|
||||
}
|
||||
|
||||
if( ISNUM( 4 ) )
|
||||
iResult = compress2( ( Bytef * ) pDest, &ulDstLen, szData, ulLen, hb_parni( 4 ) );
|
||||
else
|
||||
iResult = compress( ( Bytef * ) pDest, &ulDstLen, szData, ulLen );
|
||||
hb_storni( iResult, 3 );
|
||||
|
||||
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
|
||||
{
|
||||
hb_retc( NULL );
|
||||
hb_storni( Z_OK, 3 );
|
||||
}
|
||||
}
|
||||
else
|
||||
hb_errRT_BASE_SubstR( EG_ARG, 3012, NULL, &hb_errFuncName, HB_ERR_ARGS_BASEPARAMS );
|
||||
}
|
||||
|
||||
/*
|
||||
* HB_UNCOMPARESS( <cCompressedData>, <nDstBufLen>|<@cBuffer>, [<@nResult>] )
|
||||
* => <cCompressedData> or NIL on Error
|
||||
*/
|
||||
HB_FUNC( HB_UNCOMPRESS )
|
||||
{
|
||||
PHB_ITEM pBuffer = ISBYREF( 4 ) ? hb_param( 4, HB_IT_STRING ) : NULL;
|
||||
char * szData = hb_parc( 1 );
|
||||
|
||||
if( szData && ( pBuffer || ISNUM( 2 ) ) )
|
||||
{
|
||||
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 = hb_parnint( 2 );
|
||||
pDest = ( char * ) hb_xgrab( ulDstLen + 1 );
|
||||
}
|
||||
|
||||
iResult = uncompress( ( Bytef * ) pDest, &ulDstLen, szData, ulLen );
|
||||
hb_storni( iResult, 3 );
|
||||
|
||||
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
|
||||
{
|
||||
hb_retc( NULL );
|
||||
hb_storni( Z_OK, 3 );
|
||||
}
|
||||
}
|
||||
else
|
||||
hb_errRT_BASE_SubstR( EG_ARG, 3012, NULL, &hb_errFuncName, HB_ERR_ARGS_BASEPARAMS );
|
||||
}
|
||||
|
||||
|
||||
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;
|
||||
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_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 );
|
||||
}
|
||||
|
||||
|
||||
/* 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 = 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 = 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_xgrab( iLen + 1 );
|
||||
|
||||
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, 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 );
|
||||
}
|
||||
70
harbour/contrib/hbzlib/hbzlib.ch
Normal file
70
harbour/contrib/hbzlib/hbzlib.ch
Normal file
@@ -0,0 +1,70 @@
|
||||
/*
|
||||
* $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
|
||||
|
||||
198
harbour/contrib/hbzlib/ioapi.c
Normal file
198
harbour/contrib/hbzlib/ioapi.c
Normal file
@@ -0,0 +1,198 @@
|
||||
/* 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 (opaque, filename, mode)
|
||||
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 (opaque, stream, buf, size)
|
||||
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 (opaque, stream, buf, size)
|
||||
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 (opaque, stream)
|
||||
voidpf opaque;
|
||||
voidpf stream;
|
||||
{
|
||||
long ret;
|
||||
|
||||
(void) opaque;
|
||||
|
||||
ret = ftell((FILE *)stream);
|
||||
return ret;
|
||||
}
|
||||
|
||||
long ZCALLBACK fseek_file_func (opaque, stream, offset, origin)
|
||||
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 (opaque, stream)
|
||||
voidpf opaque;
|
||||
voidpf stream;
|
||||
{
|
||||
int ret;
|
||||
|
||||
(void) opaque;
|
||||
|
||||
ret = fclose((FILE *)stream);
|
||||
return ret;
|
||||
}
|
||||
|
||||
int ZCALLBACK ferror_file_func (opaque, stream)
|
||||
voidpf opaque;
|
||||
voidpf stream;
|
||||
{
|
||||
int ret;
|
||||
|
||||
(void) opaque;
|
||||
|
||||
ret = ferror((FILE *)stream);
|
||||
return ret;
|
||||
}
|
||||
|
||||
void fill_fopen_filefunc (pzlib_filefunc_def)
|
||||
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;
|
||||
}
|
||||
75
harbour/contrib/hbzlib/ioapi.h
Normal file
75
harbour/contrib/hbzlib/ioapi.h
Normal file
@@ -0,0 +1,75 @@
|
||||
/* 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
|
||||
|
||||
6
harbour/contrib/hbzlib/make_b32.bat
Normal file
6
harbour/contrib/hbzlib/make_b32.bat
Normal file
@@ -0,0 +1,6 @@
|
||||
@echo off
|
||||
rem
|
||||
rem $Id$
|
||||
rem
|
||||
|
||||
call ..\mtpl_b32.bat %1 %2 %3 %4 %5 %6 %7 %8 %9
|
||||
6
harbour/contrib/hbzlib/make_vc.bat
Normal file
6
harbour/contrib/hbzlib/make_vc.bat
Normal file
@@ -0,0 +1,6 @@
|
||||
@echo off
|
||||
rem
|
||||
rem $Id$
|
||||
rem
|
||||
|
||||
call ..\mtpl_vc.bat %1 %2 %3 %4 %5 %6 %7 %8 %9
|
||||
50
harbour/contrib/hbzlib/readme.txt
Normal file
50
harbour/contrib/hbzlib/readme.txt
Normal file
@@ -0,0 +1,50 @@
|
||||
/*
|
||||
* $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/zconf.h
|
||||
* changed #if 1 to #if 0 to not include unistd.h
|
||||
|
||||
* 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
|
||||
|
||||
96
harbour/contrib/hbzlib/tests/myunzip.prg
Normal file
96
harbour/contrib/hbzlib/tests/myunzip.prg
Normal file
@@ -0,0 +1,96 @@
|
||||
/*
|
||||
* $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
|
||||
|
||||
aWild := { ... }
|
||||
IF LEN( aWild ) < 1
|
||||
? "Usage: myunzip <ZipName> [ <FilePattern1> ... ]"
|
||||
RETURN
|
||||
ENDIF
|
||||
|
||||
cFileName := aWild[ 1 ]
|
||||
IF ! ( "." $ cFileName )
|
||||
cFileName += ".zip"
|
||||
ENDIF
|
||||
|
||||
ADEL( aWild, 1 )
|
||||
ASIZE( aWild, LEN( aWild ) - 1 )
|
||||
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 )
|
||||
ELSE
|
||||
?? " Skipping"
|
||||
ENDIF
|
||||
|
||||
nErr := HB_UNZIPFILENEXT( hUnzip )
|
||||
ENDDO
|
||||
HB_UNZIPCLOSE( hUnzip )
|
||||
ENDIF
|
||||
RETURN 0
|
||||
87
harbour/contrib/hbzlib/tests/myzip.prg
Normal file
87
harbour/contrib/hbzlib/tests/myzip.prg
Normal file
@@ -0,0 +1,87 @@
|
||||
/*
|
||||
* $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
|
||||
|
||||
aWild := { ... }
|
||||
IF LEN(aWild) < 2
|
||||
? "Usage: myzip <ZipName> <FilePattern1> [ <FilePattern2> ... ]"
|
||||
RETURN
|
||||
ENDIF
|
||||
|
||||
cFileName := aWild[ 1 ]
|
||||
IF ! ( "." $ cFileName )
|
||||
cFileName += ".zip"
|
||||
ENDIF
|
||||
|
||||
ADEL( aWild, 1 )
|
||||
ASIZE( aWild, LEN( aWild ) - 1 )
|
||||
|
||||
hZip := HB_ZIPOPEN( cFileName )
|
||||
IF ! EMPTY( hZip )
|
||||
? "Archive file:", cFileName
|
||||
FOR EACH cWild IN aWild
|
||||
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 ] )
|
||||
ENDIF
|
||||
NEXT
|
||||
NEXT
|
||||
HB_ZIPCLOSE( hZip )
|
||||
ENDIF
|
||||
RETURN 0
|
||||
1599
harbour/contrib/hbzlib/unzip.c
Normal file
1599
harbour/contrib/hbzlib/unzip.c
Normal file
File diff suppressed because it is too large
Load Diff
354
harbour/contrib/hbzlib/unzip.h
Normal file
354
harbour/contrib/hbzlib/unzip.h
Normal file
@@ -0,0 +1,354 @@
|
||||
/* 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 */
|
||||
332
harbour/contrib/hbzlib/zconf.h
Normal file
332
harbour/contrib/hbzlib/zconf.h
Normal file
@@ -0,0 +1,332 @@
|
||||
/* zconf.h -- configuration of the zlib compression library
|
||||
* Copyright (C) 1995-2005 Jean-loup Gailly.
|
||||
* For conditions of distribution and use, see copyright notice in zlib.h
|
||||
*/
|
||||
|
||||
/* @(#) $Id$ */
|
||||
|
||||
#ifndef ZCONF_H
|
||||
#define ZCONF_H
|
||||
|
||||
/*
|
||||
* If you *really* need a unique prefix for all types and library functions,
|
||||
* compile with -DZ_PREFIX. The "standard" zlib should be compiled without it.
|
||||
*/
|
||||
#ifdef Z_PREFIX
|
||||
# define deflateInit_ z_deflateInit_
|
||||
# define deflate z_deflate
|
||||
# define deflateEnd z_deflateEnd
|
||||
# define inflateInit_ z_inflateInit_
|
||||
# define inflate z_inflate
|
||||
# define inflateEnd z_inflateEnd
|
||||
# define deflateInit2_ z_deflateInit2_
|
||||
# define deflateSetDictionary z_deflateSetDictionary
|
||||
# define deflateCopy z_deflateCopy
|
||||
# define deflateReset z_deflateReset
|
||||
# define deflateParams z_deflateParams
|
||||
# define deflateBound z_deflateBound
|
||||
# define deflatePrime z_deflatePrime
|
||||
# define inflateInit2_ z_inflateInit2_
|
||||
# define inflateSetDictionary z_inflateSetDictionary
|
||||
# define inflateSync z_inflateSync
|
||||
# define inflateSyncPoint z_inflateSyncPoint
|
||||
# define inflateCopy z_inflateCopy
|
||||
# define inflateReset z_inflateReset
|
||||
# define inflateBack z_inflateBack
|
||||
# define inflateBackEnd z_inflateBackEnd
|
||||
# define compress z_compress
|
||||
# define compress2 z_compress2
|
||||
# define compressBound z_compressBound
|
||||
# define uncompress z_uncompress
|
||||
# define adler32 z_adler32
|
||||
# define crc32 z_crc32
|
||||
# define get_crc_table z_get_crc_table
|
||||
# define zError z_zError
|
||||
|
||||
# define alloc_func z_alloc_func
|
||||
# define free_func z_free_func
|
||||
# define in_func z_in_func
|
||||
# define out_func z_out_func
|
||||
# define Byte z_Byte
|
||||
# define uInt z_uInt
|
||||
# define uLong z_uLong
|
||||
# define Bytef z_Bytef
|
||||
# define charf z_charf
|
||||
# define intf z_intf
|
||||
# define uIntf z_uIntf
|
||||
# define uLongf z_uLongf
|
||||
# define voidpf z_voidpf
|
||||
# define voidp z_voidp
|
||||
#endif
|
||||
|
||||
#if defined(__MSDOS__) && !defined(MSDOS)
|
||||
# define MSDOS
|
||||
#endif
|
||||
#if (defined(OS_2) || defined(__OS2__)) && !defined(OS2)
|
||||
# define OS2
|
||||
#endif
|
||||
#if defined(_WINDOWS) && !defined(WINDOWS)
|
||||
# define WINDOWS
|
||||
#endif
|
||||
#if defined(_WIN32) || defined(_WIN32_WCE) || defined(__WIN32__)
|
||||
# ifndef WIN32
|
||||
# define WIN32
|
||||
# endif
|
||||
#endif
|
||||
#if (defined(MSDOS) || defined(OS2) || defined(WINDOWS)) && !defined(WIN32)
|
||||
# if !defined(__GNUC__) && !defined(__FLAT__) && !defined(__386__)
|
||||
# ifndef SYS16BIT
|
||||
# define SYS16BIT
|
||||
# endif
|
||||
# endif
|
||||
#endif
|
||||
|
||||
/*
|
||||
* Compile with -DMAXSEG_64K if the alloc function cannot allocate more
|
||||
* than 64k bytes at a time (needed on systems with 16-bit int).
|
||||
*/
|
||||
#ifdef SYS16BIT
|
||||
# define MAXSEG_64K
|
||||
#endif
|
||||
#ifdef MSDOS
|
||||
# define UNALIGNED_OK
|
||||
#endif
|
||||
|
||||
#ifdef __STDC_VERSION__
|
||||
# ifndef STDC
|
||||
# define STDC
|
||||
# endif
|
||||
# if __STDC_VERSION__ >= 199901L
|
||||
# ifndef STDC99
|
||||
# define STDC99
|
||||
# endif
|
||||
# endif
|
||||
#endif
|
||||
#if !defined(STDC) && (defined(__STDC__) || defined(__cplusplus))
|
||||
# define STDC
|
||||
#endif
|
||||
#if !defined(STDC) && (defined(__GNUC__) || defined(__BORLANDC__))
|
||||
# define STDC
|
||||
#endif
|
||||
#if !defined(STDC) && (defined(MSDOS) || defined(WINDOWS) || defined(WIN32))
|
||||
# define STDC
|
||||
#endif
|
||||
#if !defined(STDC) && (defined(OS2) || defined(__HOS_AIX__))
|
||||
# define STDC
|
||||
#endif
|
||||
|
||||
#if defined(__OS400__) && !defined(STDC) /* iSeries (formerly AS/400). */
|
||||
# define STDC
|
||||
#endif
|
||||
|
||||
#ifndef STDC
|
||||
# ifndef const /* cannot use !defined(STDC) && !defined(const) on Mac */
|
||||
# define const /* note: need a more gentle solution here */
|
||||
# endif
|
||||
#endif
|
||||
|
||||
/* Some Mac compilers merge all .h files incorrectly: */
|
||||
#if defined(__MWERKS__)||defined(applec)||defined(THINK_C)||defined(__SC__)
|
||||
# define NO_DUMMY_DECL
|
||||
#endif
|
||||
|
||||
/* Maximum value for memLevel in deflateInit2 */
|
||||
#ifndef MAX_MEM_LEVEL
|
||||
# ifdef MAXSEG_64K
|
||||
# define MAX_MEM_LEVEL 8
|
||||
# else
|
||||
# define MAX_MEM_LEVEL 9
|
||||
# endif
|
||||
#endif
|
||||
|
||||
/* Maximum value for windowBits in deflateInit2 and inflateInit2.
|
||||
* WARNING: reducing MAX_WBITS makes minigzip unable to extract .gz files
|
||||
* created by gzip. (Files created by minigzip can still be extracted by
|
||||
* gzip.)
|
||||
*/
|
||||
#ifndef MAX_WBITS
|
||||
# define MAX_WBITS 15 /* 32K LZ77 window */
|
||||
#endif
|
||||
|
||||
/* The memory requirements for deflate are (in bytes):
|
||||
(1 << (windowBits+2)) + (1 << (memLevel+9))
|
||||
that is: 128K for windowBits=15 + 128K for memLevel = 8 (default values)
|
||||
plus a few kilobytes for small objects. For example, if you want to reduce
|
||||
the default memory requirements from 256K to 128K, compile with
|
||||
make CFLAGS="-O -DMAX_WBITS=14 -DMAX_MEM_LEVEL=7"
|
||||
Of course this will generally degrade compression (there's no free lunch).
|
||||
|
||||
The memory requirements for inflate are (in bytes) 1 << windowBits
|
||||
that is, 32K for windowBits=15 (default value) plus a few kilobytes
|
||||
for small objects.
|
||||
*/
|
||||
|
||||
/* Type declarations */
|
||||
|
||||
#ifndef OF /* function prototypes */
|
||||
# ifdef STDC
|
||||
# define OF(args) args
|
||||
# else
|
||||
# define OF(args) ()
|
||||
# endif
|
||||
#endif
|
||||
|
||||
/* The following definitions for FAR are needed only for MSDOS mixed
|
||||
* model programming (small or medium model with some far allocations).
|
||||
* This was tested only with MSC; for other MSDOS compilers you may have
|
||||
* to define NO_MEMCPY in zutil.h. If you don't need the mixed model,
|
||||
* just define FAR to be empty.
|
||||
*/
|
||||
#ifdef SYS16BIT
|
||||
# if defined(M_I86SM) || defined(M_I86MM)
|
||||
/* MSC small or medium model */
|
||||
# define SMALL_MEDIUM
|
||||
# ifdef _MSC_VER
|
||||
# define FAR _far
|
||||
# else
|
||||
# define FAR far
|
||||
# endif
|
||||
# endif
|
||||
# if (defined(__SMALL__) || defined(__MEDIUM__))
|
||||
/* Turbo C small or medium model */
|
||||
# define SMALL_MEDIUM
|
||||
# ifdef __BORLANDC__
|
||||
# define FAR _far
|
||||
# else
|
||||
# define FAR far
|
||||
# endif
|
||||
# endif
|
||||
#endif
|
||||
|
||||
#if defined(WINDOWS) || defined(WIN32)
|
||||
/* If building or using zlib as a DLL, define ZLIB_DLL.
|
||||
* This is not mandatory, but it offers a little performance increase.
|
||||
*/
|
||||
# ifdef ZLIB_DLL
|
||||
# if defined(WIN32) && (!defined(__BORLANDC__) || (__BORLANDC__ >= 0x500))
|
||||
# ifdef ZLIB_INTERNAL
|
||||
# define ZEXTERN extern __declspec(dllexport)
|
||||
# else
|
||||
# define ZEXTERN extern __declspec(dllimport)
|
||||
# endif
|
||||
# endif
|
||||
# endif /* ZLIB_DLL */
|
||||
/* If building or using zlib with the WINAPI/WINAPIV calling convention,
|
||||
* define ZLIB_WINAPI.
|
||||
* Caution: the standard ZLIB1.DLL is NOT compiled using ZLIB_WINAPI.
|
||||
*/
|
||||
# ifdef ZLIB_WINAPI
|
||||
# ifdef FAR
|
||||
# undef FAR
|
||||
# endif
|
||||
# include <windows.h>
|
||||
/* No need for _export, use ZLIB.DEF instead. */
|
||||
/* For complete Windows compatibility, use WINAPI, not __stdcall. */
|
||||
# define ZEXPORT WINAPI
|
||||
# ifdef WIN32
|
||||
# define ZEXPORTVA WINAPIV
|
||||
# else
|
||||
# define ZEXPORTVA FAR CDECL
|
||||
# endif
|
||||
# endif
|
||||
#endif
|
||||
|
||||
#if defined (__BEOS__)
|
||||
# ifdef ZLIB_DLL
|
||||
# ifdef ZLIB_INTERNAL
|
||||
# define ZEXPORT __declspec(dllexport)
|
||||
# define ZEXPORTVA __declspec(dllexport)
|
||||
# else
|
||||
# define ZEXPORT __declspec(dllimport)
|
||||
# define ZEXPORTVA __declspec(dllimport)
|
||||
# endif
|
||||
# endif
|
||||
#endif
|
||||
|
||||
#ifndef ZEXTERN
|
||||
# define ZEXTERN extern
|
||||
#endif
|
||||
#ifndef ZEXPORT
|
||||
# define ZEXPORT
|
||||
#endif
|
||||
#ifndef ZEXPORTVA
|
||||
# define ZEXPORTVA
|
||||
#endif
|
||||
|
||||
#ifndef FAR
|
||||
# define FAR
|
||||
#endif
|
||||
|
||||
#if !defined(__MACTYPES__)
|
||||
typedef unsigned char Byte; /* 8 bits */
|
||||
#endif
|
||||
typedef unsigned int uInt; /* 16 bits or more */
|
||||
typedef unsigned long uLong; /* 32 bits or more */
|
||||
|
||||
#ifdef SMALL_MEDIUM
|
||||
/* Borland C/C++ and some old MSC versions ignore FAR inside typedef */
|
||||
# define Bytef Byte FAR
|
||||
#else
|
||||
typedef Byte FAR Bytef;
|
||||
#endif
|
||||
typedef char FAR charf;
|
||||
typedef int FAR intf;
|
||||
typedef uInt FAR uIntf;
|
||||
typedef uLong FAR uLongf;
|
||||
|
||||
#ifdef STDC
|
||||
typedef void const *voidpc;
|
||||
typedef void FAR *voidpf;
|
||||
typedef void *voidp;
|
||||
#else
|
||||
typedef Byte const *voidpc;
|
||||
typedef Byte FAR *voidpf;
|
||||
typedef Byte *voidp;
|
||||
#endif
|
||||
|
||||
#if 0 /* HAVE_UNISTD_H -- this line is updated by ./configure */
|
||||
# include <sys/types.h> /* for off_t */
|
||||
# include <unistd.h> /* for SEEK_* and off_t */
|
||||
# ifdef VMS
|
||||
# include <unixio.h> /* for off_t */
|
||||
# endif
|
||||
# define z_off_t off_t
|
||||
#endif
|
||||
#ifndef SEEK_SET
|
||||
# define SEEK_SET 0 /* Seek from beginning of file. */
|
||||
# define SEEK_CUR 1 /* Seek from current position. */
|
||||
# define SEEK_END 2 /* Set file pointer to EOF plus "offset" */
|
||||
#endif
|
||||
#ifndef z_off_t
|
||||
# define z_off_t long
|
||||
#endif
|
||||
|
||||
#if defined(__OS400__)
|
||||
# define NO_vsnprintf
|
||||
#endif
|
||||
|
||||
#if defined(__MVS__)
|
||||
# define NO_vsnprintf
|
||||
# ifdef FAR
|
||||
# undef FAR
|
||||
# endif
|
||||
#endif
|
||||
|
||||
/* MVS linker does not support external names larger than 8 bytes */
|
||||
#if defined(__MVS__)
|
||||
# pragma map(deflateInit_,"DEIN")
|
||||
# pragma map(deflateInit2_,"DEIN2")
|
||||
# pragma map(deflateEnd,"DEEND")
|
||||
# pragma map(deflateBound,"DEBND")
|
||||
# pragma map(inflateInit_,"ININ")
|
||||
# pragma map(inflateInit2_,"ININ2")
|
||||
# pragma map(inflateEnd,"INEND")
|
||||
# pragma map(inflateSync,"INSY")
|
||||
# pragma map(inflateSetDictionary,"INSEDI")
|
||||
# pragma map(compressBound,"CMBND")
|
||||
# pragma map(inflate_table,"INTABL")
|
||||
# pragma map(inflate_fast,"INFA")
|
||||
# pragma map(inflate_copyright,"INCOPY")
|
||||
#endif
|
||||
|
||||
#endif /* ZCONF_H */
|
||||
1231
harbour/contrib/hbzlib/zip.c
Normal file
1231
harbour/contrib/hbzlib/zip.c
Normal file
File diff suppressed because it is too large
Load Diff
235
harbour/contrib/hbzlib/zip.h
Normal file
235
harbour/contrib/hbzlib/zip.h
Normal file
@@ -0,0 +1,235 @@
|
||||
/* 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 */
|
||||
1357
harbour/contrib/hbzlib/zlib.h
Normal file
1357
harbour/contrib/hbzlib/zlib.h
Normal file
File diff suppressed because it is too large
Load Diff
Reference in New Issue
Block a user