ZipStream.st
author ca
Mon, 03 Aug 2009 15:38:33 +0200
changeset 2196 9eecfefd08aa
parent 2193 db70507b21ba
child 2335 609923563c1d
permissions -rw-r--r--
suppressHeaderAndChecksum is configurable
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1308
d7bea6d0b3b6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
     1
"
d7bea6d0b3b6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
     2
 COPYRIGHT (c) 2002 by eXept Software AG
1439
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
     3
	      All Rights Reserved
1308
d7bea6d0b3b6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
     4
d7bea6d0b3b6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
     5
 This software is furnished under a license and may be used
d7bea6d0b3b6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
     6
 only in accordance with the terms of that license and with the
d7bea6d0b3b6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
d7bea6d0b3b6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
     8
 be provided or otherwise made available to, or used by, any
d7bea6d0b3b6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
     9
 other person.  No title to or ownership of the software is
d7bea6d0b3b6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
    10
 hereby transferred.
d7bea6d0b3b6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
    11
"
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
    12
"{ Package: 'stx:libbasic2' }"
1044
c73aee830691 initial checkin
ca
parents:
diff changeset
    13
1059
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
    14
CompressionStream subclass:#ZipStream
1193
7688148ec90c Code formatting & clean up
Stefan Vogel <sv@exept.de>
parents: 1061
diff changeset
    15
	instanceVariableNames:''
7688148ec90c Code formatting & clean up
Stefan Vogel <sv@exept.de>
parents: 1061
diff changeset
    16
	classVariableNames:'Z_DEFLATED HEAD_OS_CODE HEAD_RESERVED HEAD_EXTRA_FIELD
7688148ec90c Code formatting & clean up
Stefan Vogel <sv@exept.de>
parents: 1061
diff changeset
    17
		HEAD_ORIG_NAME HEAD_COMMENT HEAD_CRC GZ_MAGIC_ID'
7688148ec90c Code formatting & clean up
Stefan Vogel <sv@exept.de>
parents: 1061
diff changeset
    18
	poolDictionaries:''
7688148ec90c Code formatting & clean up
Stefan Vogel <sv@exept.de>
parents: 1061
diff changeset
    19
	category:'System-Compress'
1044
c73aee830691 initial checkin
ca
parents:
diff changeset
    20
!
c73aee830691 initial checkin
ca
parents:
diff changeset
    21
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
    22
!ZipStream primitiveDefinitions!
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
    23
%{
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
    24
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
    25
/*
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
    26
 * includes, defines, structure definitions
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
    27
 * and typedefs come here.
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
    28
 */
1836
e9e1ba3735c6 Correct include path for zlib
Stefan Vogel <sv@exept.de>
parents: 1828
diff changeset
    29
#include "zlib.h"
e9e1ba3735c6 Correct include path for zlib
Stefan Vogel <sv@exept.de>
parents: 1828
diff changeset
    30
#include "zutil.h"
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
    31
1051
4f18d73427bb *** empty log message ***
ca
parents: 1050
diff changeset
    32
typedef enum {
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
    33
	  e_opmode_unspecified          /* processing done */
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
    34
	, e_opmode_deflate              /* running deflate */
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
    35
	, e_opmode_inflate              /* running inflate */
1051
4f18d73427bb *** empty log message ***
ca
parents: 1050
diff changeset
    36
} e_opmode;
4f18d73427bb *** empty log message ***
ca
parents: 1050
diff changeset
    37
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
    38
typedef struct {
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
    39
	z_stream        stream;         /* pointer to the external in -stream */
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
    40
	Bytef *         in_ref;         /* size    of the external in -stream */
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
    41
	Bytef *         out_ref;        /* pointer to the external out-stream */
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
    42
	uLong           out_total;      /* size    of the external out-stream */
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
    43
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
    44
	e_opmode        op_mode;        /* current operational mode */
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
    45
	uLong           crc_32;         /* keeps the current crc */
1061
be824dc5e0e7 *** empty log message ***
ca
parents: 1060
diff changeset
    46
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
    47
	Bytef           tail_buff[ 8 ]; /* store the tail in the read modus */
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
    48
	uLong           tail_size;      /* to check the crc and data length */
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
    49
} zstream_s;
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
    50
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
    51
%}
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
    52
! !
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
    53
1197
c86e858c2893 Documentation. Does not work yet.
Stefan Vogel <sv@exept.de>
parents: 1195
diff changeset
    54
!ZipStream class methodsFor:'documentation'!
c86e858c2893 Documentation. Does not work yet.
Stefan Vogel <sv@exept.de>
parents: 1195
diff changeset
    55
1308
d7bea6d0b3b6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
    56
copyright
d7bea6d0b3b6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
    57
"
d7bea6d0b3b6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
    58
 COPYRIGHT (c) 2002 by eXept Software AG
1439
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
    59
	      All Rights Reserved
1308
d7bea6d0b3b6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
    60
d7bea6d0b3b6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
    61
 This software is furnished under a license and may be used
d7bea6d0b3b6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
    62
 only in accordance with the terms of that license and with the
d7bea6d0b3b6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
    63
 inclusion of the above copyright notice.   This software may not
d7bea6d0b3b6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
    64
 be provided or otherwise made available to, or used by, any
d7bea6d0b3b6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
    65
 other person.  No title to or ownership of the software is
d7bea6d0b3b6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
    66
 hereby transferred.
d7bea6d0b3b6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
    67
"
d7bea6d0b3b6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
    68
!
d7bea6d0b3b6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
    69
1197
c86e858c2893 Documentation. Does not work yet.
Stefan Vogel <sv@exept.de>
parents: 1195
diff changeset
    70
documentation
c86e858c2893 Documentation. Does not work yet.
Stefan Vogel <sv@exept.de>
parents: 1195
diff changeset
    71
"
c86e858c2893 Documentation. Does not work yet.
Stefan Vogel <sv@exept.de>
parents: 1195
diff changeset
    72
    Zip compression and decompression (used in gzip and zip)
c86e858c2893 Documentation. Does not work yet.
Stefan Vogel <sv@exept.de>
parents: 1195
diff changeset
    73
c86e858c2893 Documentation. Does not work yet.
Stefan Vogel <sv@exept.de>
parents: 1195
diff changeset
    74
    [author:]
1439
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
    75
	Claus Atzkern
1197
c86e858c2893 Documentation. Does not work yet.
Stefan Vogel <sv@exept.de>
parents: 1195
diff changeset
    76
c86e858c2893 Documentation. Does not work yet.
Stefan Vogel <sv@exept.de>
parents: 1195
diff changeset
    77
    [instance variables:]
c86e858c2893 Documentation. Does not work yet.
Stefan Vogel <sv@exept.de>
parents: 1195
diff changeset
    78
c86e858c2893 Documentation. Does not work yet.
Stefan Vogel <sv@exept.de>
parents: 1195
diff changeset
    79
    [class variables:]
c86e858c2893 Documentation. Does not work yet.
Stefan Vogel <sv@exept.de>
parents: 1195
diff changeset
    80
c86e858c2893 Documentation. Does not work yet.
Stefan Vogel <sv@exept.de>
parents: 1195
diff changeset
    81
    [see also:]
c86e858c2893 Documentation. Does not work yet.
Stefan Vogel <sv@exept.de>
parents: 1195
diff changeset
    82
c86e858c2893 Documentation. Does not work yet.
Stefan Vogel <sv@exept.de>
parents: 1195
diff changeset
    83
"
c86e858c2893 Documentation. Does not work yet.
Stefan Vogel <sv@exept.de>
parents: 1195
diff changeset
    84
!
c86e858c2893 Documentation. Does not work yet.
Stefan Vogel <sv@exept.de>
parents: 1195
diff changeset
    85
c86e858c2893 Documentation. Does not work yet.
Stefan Vogel <sv@exept.de>
parents: 1195
diff changeset
    86
examples
c86e858c2893 Documentation. Does not work yet.
Stefan Vogel <sv@exept.de>
parents: 1195
diff changeset
    87
"
2190
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
    88
								[exBegin]
1847
5364b697ad8f better example
sr
parents: 1836
diff changeset
    89
    |compressedDataStream zipStream compressedData uncompressedData|
5364b697ad8f better example
sr
parents: 1836
diff changeset
    90
5364b697ad8f better example
sr
parents: 1836
diff changeset
    91
    compressedDataStream := #[] writeStream.
5364b697ad8f better example
sr
parents: 1836
diff changeset
    92
    zipStream := ZipStream writeOpenOn:compressedDataStream.
5364b697ad8f better example
sr
parents: 1836
diff changeset
    93
    zipStream nextPutAll:'hallo Welt'.
5364b697ad8f better example
sr
parents: 1836
diff changeset
    94
    zipStream close.
5364b697ad8f better example
sr
parents: 1836
diff changeset
    95
5364b697ad8f better example
sr
parents: 1836
diff changeset
    96
    compressedData := compressedDataStream contents.
5364b697ad8f better example
sr
parents: 1836
diff changeset
    97
5364b697ad8f better example
sr
parents: 1836
diff changeset
    98
    zipStream := ZipStream readOpenOn:(compressedData readStream).
1197
c86e858c2893 Documentation. Does not work yet.
Stefan Vogel <sv@exept.de>
parents: 1195
diff changeset
    99
1847
5364b697ad8f better example
sr
parents: 1836
diff changeset
   100
    zipStream notNil ifTrue:[
2190
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   101
	|stream c|
1847
5364b697ad8f better example
sr
parents: 1836
diff changeset
   102
2190
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   103
	stream := '' writeStream.
1847
5364b697ad8f better example
sr
parents: 1836
diff changeset
   104
2190
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   105
	[ (c := zipStream next) notNil ] whileTrue:[
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   106
	    stream nextPut:c
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   107
	].
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   108
	stream close.
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   109
	uncompressedData := stream contents.
1847
5364b697ad8f better example
sr
parents: 1836
diff changeset
   110
    ].
5364b697ad8f better example
sr
parents: 1836
diff changeset
   111
    ^ uncompressedData
2190
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   112
								[exEnd]
1847
5364b697ad8f better example
sr
parents: 1836
diff changeset
   113
5364b697ad8f better example
sr
parents: 1836
diff changeset
   114
1197
c86e858c2893 Documentation. Does not work yet.
Stefan Vogel <sv@exept.de>
parents: 1195
diff changeset
   115
"
c86e858c2893 Documentation. Does not work yet.
Stefan Vogel <sv@exept.de>
parents: 1195
diff changeset
   116
! !
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   117
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   118
!ZipStream class methodsFor:'initialization'!
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   119
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   120
initialize
1061
be824dc5e0e7 *** empty log message ***
ca
parents: 1060
diff changeset
   121
    "setup class attributes derived from the library
be824dc5e0e7 *** empty log message ***
ca
parents: 1060
diff changeset
   122
    "
1059
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   123
    |z_deflated os_code|
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   124
%{
1059
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   125
    z_deflated = __MKSMALLINT( Z_DEFLATED );
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   126
    os_code    = __MKSMALLINT( OS_CODE );
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   127
%}.
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   128
1059
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   129
    Z_DEFLATED            := z_deflated.
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   130
1059
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   131
    HEAD_OS_CODE          := os_code.
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   132
    HEAD_RESERVED         := 16rE0.     " bits 5..7:  reserved "
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   133
    HEAD_EXTRA_FIELD      := 16r04.     " bit 2 set:  extra field present "
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   134
    HEAD_ORIG_NAME        := 16r08.     " bit 3 set:  original file name present "
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   135
    HEAD_COMMENT          := 16r10.     " bit 4 set:  file comment present "
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   136
    HEAD_CRC              := 16r02.     " bit 1 set:  header CRC present "
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   137
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   138
    GZ_MAGIC_ID           := #[ 16r1f 16r8b ]
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   139
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   140
! !
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   141
2006
0ad76801137e add instance creation methods to allow to open the ZipStream as
ab
parents: 1847
diff changeset
   142
!ZipStream class methodsFor:'instance creation'!
0ad76801137e add instance creation methods to allow to open the ZipStream as
ab
parents: 1847
diff changeset
   143
0ad76801137e add instance creation methods to allow to open the ZipStream as
ab
parents: 1847
diff changeset
   144
readOpenAsZipStreamOn:aStream
2190
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   145
    "open to read data compressed from stream,
2006
0ad76801137e add instance creation methods to allow to open the ZipStream as
ab
parents: 1847
diff changeset
   146
     the default readOpenOn: will open ZipStream as gzip stream"
2196
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   147
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   148
    ^ self
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   149
        readOpenAsZipStreamOn:aStream
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   150
        suppressHeaderAndChecksum:(self defaultSuppressHeaderAndChecksum)    
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   151
!
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   152
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   153
readOpenAsZipStreamOn:aStream suppressHeaderAndChecksum:aBoolean
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   154
    "open to read data compressed from stream,
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   155
     the default readOpenOn: will open ZipStream as gzip stream"
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   156
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   157
    ^ self basicNew
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   158
        streamOpenWithMode:#readonly
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   159
        on:aStream
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   160
        suppressHeaderAndChecksum:aBoolean
2006
0ad76801137e add instance creation methods to allow to open the ZipStream as
ab
parents: 1847
diff changeset
   161
!
0ad76801137e add instance creation methods to allow to open the ZipStream as
ab
parents: 1847
diff changeset
   162
0ad76801137e add instance creation methods to allow to open the ZipStream as
ab
parents: 1847
diff changeset
   163
writeOpenAsZipStreamOn:aStream
2190
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   164
    "open to write data compressed to stream,
2006
0ad76801137e add instance creation methods to allow to open the ZipStream as
ab
parents: 1847
diff changeset
   165
     the default writeOpenOn: will open ZipStream as gzip stream"
2196
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   166
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   167
    ^ self
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   168
        writeOpenAsZipStreamOn:aStream
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   169
        suppressHeaderAndChecksum:(self defaultSuppressHeaderAndChecksum)    
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   170
!
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   171
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   172
writeOpenAsZipStreamOn:aStream suppressHeaderAndChecksum:aBoolean
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   173
    "open to write data compressed to stream,
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   174
     the default writeOpenOn: will open ZipStream as gzip stream"
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   175
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   176
    ^ self basicNew
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   177
        streamOpenWithMode:#writeonly
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   178
        on:aStream
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   179
        suppressHeaderAndChecksum:aBoolean
2006
0ad76801137e add instance creation methods to allow to open the ZipStream as
ab
parents: 1847
diff changeset
   180
! !
0ad76801137e add instance creation methods to allow to open the ZipStream as
ab
parents: 1847
diff changeset
   181
1439
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   182
!ZipStream class methodsFor:'ZipInterface compatibility - compress/uncompress'!
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   183
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   184
compress: aUncompressedByteArray into: aCompressedByteArray
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   185
    ^ self flatBytesIn: aUncompressedByteArray
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   186
		  from: 1
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   187
		    to: (aUncompressedByteArray size)
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   188
		  into: aCompressedByteArray
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   189
	    doCompress: true.
1439
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   190
!
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   191
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   192
flatBytesIn:bytesIn from:start to:stop into:bytesOut doCompress:doCompress
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   193
    "compress or uncompress the bytesIn buffer into the bytesOut buffer; returns
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   194
     the un/compressed size; on error an exception is raised
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   195
    "
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   196
    |errorNr size|
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   197
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   198
     size := stop - start + 1.
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   199
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   200
     (    (start between:1 and:stop)
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   201
      and:[size > 0
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   202
      and:[bytesIn  size >= stop
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   203
      and:[bytesOut size >  0]]]
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   204
     ) ifFalse:[
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   205
	^ self error:'invalid argument size'
1439
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   206
    ].
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   207
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   208
%{
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   209
    char *  __bytesIn  = 0;
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   210
    uLong   __countIn  = 0;
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   211
    char *  __bytesOut = 0;
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   212
    uLong   __countOut = 0;
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   213
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   214
    if( (__isSmallInteger(start)) && (__isSmallInteger(stop)) && (__isSmallInteger(size)) )
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   215
    {
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   216
	__countIn = __intVal( size );
1439
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   217
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   218
	if (__isBytes(bytesIn)) {
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   219
	    __bytesIn = __ByteArrayInstPtr(bytesIn)->ba_element;
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   220
	} else {
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   221
	    if (__isString(bytesIn)) {
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   222
		__bytesIn = __stringVal( bytesIn );
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   223
	    }
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   224
	}
1439
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   225
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   226
	if (__isBytes(bytesOut)) {
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   227
	    __bytesOut = __ByteArrayInstPtr(bytesOut)->ba_element;
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   228
	    __countOut = __byteArraySize( bytesOut );
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   229
	} else {
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   230
	    if (__isString(bytesOut)) {
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   231
		__bytesOut = __stringVal( bytesOut );
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   232
		__countOut = __stringSize( bytesOut );
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   233
	    }
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   234
	}
1439
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   235
    }
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   236
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   237
    if( __bytesOut && __bytesIn )
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   238
    {
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   239
	int __result = Z_OK;
1439
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   240
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   241
	__bytesIn += (__intVal( start)) - 1;
1439
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   242
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   243
	if( doCompress == true )
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   244
	    __result   = compress  ( (Byte *) __bytesOut, & __countOut, (Byte *) __bytesIn, __countIn );
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   245
	else
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   246
	    __result   = uncompress( (Byte *) __bytesOut, & __countOut, (Byte *) __bytesIn, __countIn );
1439
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   247
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   248
	if( __result == Z_OK )
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   249
	    { RETURN(__MKSMALLINT(__countOut)); }
1439
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   250
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   251
	errorNr = __MKSMALLINT( __result );
1439
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   252
    }
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   253
%}.
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   254
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   255
    errorNr isNil ifTrue:[ ^ self error:'invalid arguments' ].
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   256
    errorNr ==  1 ifTrue:[ ^ self error:'stream at end' ].
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   257
    errorNr == -3 ifTrue:[ ^ self error:'input data are corrupted' ].
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   258
    errorNr == -4 ifTrue:[ ^ self error:'not enough memory' ].
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   259
    errorNr == -5 ifTrue:[ ^ self error:'not enough memory in the output stream' ].
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   260
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   261
    self error:('compressing error: ', errorNr printString).
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   262
!
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   263
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   264
uncompress: aCompressedByteArray into: aUncompressedByteArray
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   265
    ^ self flatBytesIn: aCompressedByteArray
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   266
		  from: 1
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   267
		    to: (aCompressedByteArray size)
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   268
		  into: aUncompressedByteArray
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   269
	    doCompress: false.
1439
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   270
! !
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   271
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   272
!ZipStream class methodsFor:'ZipInterface compatibility - crc'!
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   273
2178
f6f0d919aed2 Fix windows compilation bug in 1.31
Stefan Vogel <sv@exept.de>
parents: 2177
diff changeset
   274
crc32Add:aCharacterOrByte crc:crc
f6f0d919aed2 Fix windows compilation bug in 1.31
Stefan Vogel <sv@exept.de>
parents: 2177
diff changeset
   275
    "Update a running crc waCharacterOrByte
f6f0d919aed2 Fix windows compilation bug in 1.31
Stefan Vogel <sv@exept.de>
parents: 2177
diff changeset
   276
     and return the updated crc "
f6f0d919aed2 Fix windows compilation bug in 1.31
Stefan Vogel <sv@exept.de>
parents: 2177
diff changeset
   277
%{
f6f0d919aed2 Fix windows compilation bug in 1.31
Stefan Vogel <sv@exept.de>
parents: 2177
diff changeset
   278
    if( (__isInteger(crc)))     {
2190
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   279
	char __byte;
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   280
	uLong  __crc;
2178
f6f0d919aed2 Fix windows compilation bug in 1.31
Stefan Vogel <sv@exept.de>
parents: 2177
diff changeset
   281
2190
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   282
	if (__isCharacter(aCharacterOrByte)) {
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   283
	    __byte = __smallIntegerVal(__characterVal(aCharacterOrByte));
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   284
	} else if (__isSmallInteger(aCharacterOrByte)) {
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   285
	    __byte = __intVal(aCharacterOrByte);
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   286
	} else{
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   287
	    goto err;
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   288
	}
2178
f6f0d919aed2 Fix windows compilation bug in 1.31
Stefan Vogel <sv@exept.de>
parents: 2177
diff changeset
   289
2190
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   290
	__crc  = __unsignedLongIntVal( crc );
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   291
	__crc = crc32(__crc, (Byte *) &__byte, 1 );
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   292
	RETURN( __MKUINT(__crc) );
2178
f6f0d919aed2 Fix windows compilation bug in 1.31
Stefan Vogel <sv@exept.de>
parents: 2177
diff changeset
   293
    }
f6f0d919aed2 Fix windows compilation bug in 1.31
Stefan Vogel <sv@exept.de>
parents: 2177
diff changeset
   294
err:;
f6f0d919aed2 Fix windows compilation bug in 1.31
Stefan Vogel <sv@exept.de>
parents: 2177
diff changeset
   295
%}.
f6f0d919aed2 Fix windows compilation bug in 1.31
Stefan Vogel <sv@exept.de>
parents: 2177
diff changeset
   296
f6f0d919aed2 Fix windows compilation bug in 1.31
Stefan Vogel <sv@exept.de>
parents: 2177
diff changeset
   297
    ^ self error:'invalid argument'
f6f0d919aed2 Fix windows compilation bug in 1.31
Stefan Vogel <sv@exept.de>
parents: 2177
diff changeset
   298
!
f6f0d919aed2 Fix windows compilation bug in 1.31
Stefan Vogel <sv@exept.de>
parents: 2177
diff changeset
   299
1439
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   300
crc32BytesIn:bytesIn
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   301
    "compute crc with the bytes buf[1.. bytesIn size]
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   302
     and return the crc
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   303
    "
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   304
    ^ self crc32BytesIn:bytesIn from:1
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   305
!
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   306
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   307
crc32BytesIn:bytesIn crc:aCrc
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   308
    "Update a running crc with the bytes buf[1.. bytesIn size]
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   309
     and return the updated
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   310
    "
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   311
    ^ self crc32BytesIn:bytesIn from:1 crc:aCrc
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   312
!
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   313
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   314
crc32BytesIn:bytesIn from:start
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   315
    "compute crc with the bytes buf[start.. bytesIn size]
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   316
     and return the crc
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   317
    "
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   318
    ^ self crc32BytesIn:bytesIn from:start to:(bytesIn size)
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   319
!
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   320
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   321
crc32BytesIn:bytesIn from:start crc:aCrc
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   322
    "Update a running crc with the bytes buf[start.. bytesIn size]
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   323
     and return the updated
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   324
    "
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   325
    ^ self crc32BytesIn:bytesIn from:start to:(bytesIn size) crc:aCrc
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   326
!
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   327
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   328
crc32BytesIn:bytesIn from:start to:stop
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   329
    "compute crc with the bytes buf[start.. stop]
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   330
     and return the crc
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   331
    "
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   332
    ^ self crc32BytesIn:bytesIn from:start to:stop crc:0
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   333
!
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   334
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   335
crc32BytesIn:bytesIn from:start to:stop crc:crc
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   336
    "Update a running crc with the bytes buf[start.. stop]
2178
f6f0d919aed2 Fix windows compilation bug in 1.31
Stefan Vogel <sv@exept.de>
parents: 2177
diff changeset
   337
     and return the updated crc"
1439
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   338
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   339
%{
2178
f6f0d919aed2 Fix windows compilation bug in 1.31
Stefan Vogel <sv@exept.de>
parents: 2177
diff changeset
   340
    if (__isInteger(crc) && __isSmallInteger(start) && __isSmallInteger(stop)) {
2190
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   341
	char * __bytes  = 0;
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   342
	unsigned int __size;
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   343
	uLong  __crc  = __unsignedLongIntVal( crc );
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   344
	uInt   __start = __intVal( start );
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   345
	uInt   __stop = __intVal( stop );
1439
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   346
2190
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   347
	if (__isBytes(bytesIn)) {
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   348
	    __bytes = __byteArrayVal(bytesIn);
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   349
	    __size = __byteArraySize(bytesIn);
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   350
	} else if (__isString(bytesIn)) {
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   351
	    __bytes = __stringVal(bytesIn);
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   352
	    __size = __stringSize(bytesIn);
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   353
	} else {
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   354
	    goto err;
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   355
	}
2178
f6f0d919aed2 Fix windows compilation bug in 1.31
Stefan Vogel <sv@exept.de>
parents: 2177
diff changeset
   356
1439
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   357
2190
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   358
	if (__start < 1 || __start > __size) goto err;
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   359
	if (__stop < 1 || __stop > __size) goto err;
2178
f6f0d919aed2 Fix windows compilation bug in 1.31
Stefan Vogel <sv@exept.de>
parents: 2177
diff changeset
   360
2190
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   361
	__size = __stop - __start + 1;
1439
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   362
2190
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   363
	__bytes += __start - 1;
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   364
	__crc = crc32(__crc, (Byte *) __bytes, __size );
1439
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   365
2190
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   366
	RETURN( __MKUINT(__crc) );
1439
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   367
    }
2178
f6f0d919aed2 Fix windows compilation bug in 1.31
Stefan Vogel <sv@exept.de>
parents: 2177
diff changeset
   368
err:;
1439
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   369
%}.
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   370
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   371
    ^ self error:'invalid argument size'
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   372
! !
134b4620d6d0 add ZipInterface compatibility used by SEL MDT Application
ab
parents: 1308
diff changeset
   373
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   374
!ZipStream methodsFor:'low level'!
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   375
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   376
zclose
1052
055841c03c8a *** empty log message ***
ca
parents: 1051
diff changeset
   377
    "low level close of the zip stream
055841c03c8a *** empty log message ***
ca
parents: 1051
diff changeset
   378
    "
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   379
%{
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   380
    OBJ _zstreamObj = __INST( zstream );
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   381
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   382
    if( _zstreamObj != nil )
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   383
    {
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   384
	zstream_s * _zstream = (zstream_s *) __externalBytesAddress( _zstreamObj );
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   385
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   386
	__INST(zstream) = nil;
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   387
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   388
	if( _zstream->stream.state != NULL )
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   389
	{
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   390
	    if( _zstream->op_mode == e_opmode_inflate )
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   391
		inflateEnd( & _zstream->stream );
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   392
	    else
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   393
		deflateEnd( & _zstream->stream );
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   394
	}
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   395
	free( _zstream );
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   396
    }
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   397
%}.
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   398
!
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   399
1057
9df4a60df0ef *** empty log message ***
ca
parents: 1056
diff changeset
   400
zdeflate
1570
b6dd9a871cc2 Fix typo
Stefan Vogel <sv@exept.de>
parents: 1565
diff changeset
   401
    "low level - deflate"
b6dd9a871cc2 Fix typo
Stefan Vogel <sv@exept.de>
parents: 1565
diff changeset
   402
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   403
    |errorNo|
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   404
    errorNo := nil.
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   405
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   406
%{
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   407
    OBJ _zstreamObj = __INST( zstream );
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   408
1056
44871623590b *** empty log message ***
ca
parents: 1054
diff changeset
   409
    if( _zstreamObj != nil )
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   410
    {
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   411
	int         _errorNo, _action;
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   412
	uLong       _bfsize;
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   413
	zstream_s * _zstream = (zstream_s *) __externalBytesAddress( _zstreamObj );
1047
1cd99e473c08 *** empty log message ***
ca
parents: 1046
diff changeset
   414
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   415
	if( _zstream->op_mode != e_opmode_deflate )
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   416
	    RETURN( false );
1051
4f18d73427bb *** empty log message ***
ca
parents: 1050
diff changeset
   417
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   418
	_bfsize = _zstream->out_total;
1051
4f18d73427bb *** empty log message ***
ca
parents: 1050
diff changeset
   419
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   420
	if( _zstream->stream.state == NULL )
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   421
	{
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   422
	    /* processing finished; write crc_32 and the total size
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   423
	    */
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   424
	    uLong   v, i;
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   425
	    Bytef * p = _zstream->out_ref;
1051
4f18d73427bb *** empty log message ***
ca
parents: 1050
diff changeset
   426
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   427
	    v = _zstream->crc_32;
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   428
	    for( i = 0; i < 4; ++i ) { p[i] = v & 0xff; v >>= 8; }
1051
4f18d73427bb *** empty log message ***
ca
parents: 1050
diff changeset
   429
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   430
	    v = _zstream->stream.total_in;
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   431
	    for( i = 4; i < 8; ++i ) { p[i] = v & 0xff; v >>= 8; }
1051
4f18d73427bb *** empty log message ***
ca
parents: 1050
diff changeset
   432
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   433
	    _zstream->op_mode          = e_opmode_unspecified;
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   434
	    _zstream->stream.avail_in  = 0;
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   435
	    _zstream->stream.next_in   = Z_NULL;
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   436
	    _zstream->stream.avail_out = _bfsize - 8;
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   437
	    RETURN( true );
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   438
	}
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   439
	_zstream->stream.avail_out = _bfsize;
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   440
	_zstream->stream.next_out  = _zstream->out_ref;
1056
44871623590b *** empty log message ***
ca
parents: 1054
diff changeset
   441
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   442
	_action  = (__INST(hitEOF) == true) ? Z_FINISH : Z_NO_FLUSH;
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   443
	_errorNo = deflate( & _zstream->stream, _action );
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   444
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   445
	if( _errorNo == Z_STREAM_END )
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   446
	{
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   447
	    _zstream->stream.avail_in = 0;
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   448
	    _zstream->stream.next_in  = Z_NULL;
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   449
	    _errorNo = deflateEnd( & _zstream->stream );
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   450
	}
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   451
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   452
	if( _errorNo == Z_OK )
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   453
	{
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   454
	    if( _zstream->stream.avail_out == 0 )
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   455
	      RETURN( true );
1050
b7e7d51e0a9f *** empty log message ***
ca
parents: 1049
diff changeset
   456
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   457
	    RETURN( false );
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   458
	}
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   459
	errorNo = __MKSMALLINT( _errorNo );
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   460
    }
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   461
%}.
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   462
    errorNo ifNil:[
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   463
	zstream ifNil:[self errorNotOpen].
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   464
	self invalidArgument.
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   465
    ].
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   466
    self zerror:errorNo.
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   467
!
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   468
1059
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   469
zdeflateInit
1570
b6dd9a871cc2 Fix typo
Stefan Vogel <sv@exept.de>
parents: 1565
diff changeset
   470
    "low level - deflateInit"
b6dd9a871cc2 Fix typo
Stefan Vogel <sv@exept.de>
parents: 1565
diff changeset
   471
2193
db70507b21ba suppress header & checksum configurable
ca
parents: 2190
diff changeset
   472
    |errorNo level windowBits|
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   473
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   474
    errorNo := nil.
1059
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   475
    level   := BlockSize.
2193
db70507b21ba suppress header & checksum configurable
ca
parents: 2190
diff changeset
   476
    windowBits := self zget_windowBits.
db70507b21ba suppress header & checksum configurable
ca
parents: 2190
diff changeset
   477
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   478
%{
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   479
    OBJ _zstreamObj = __INST( zstream );
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   480
1059
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   481
    if( (_zstreamObj != nil) && __isSmallInteger(level) )
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   482
    {
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   483
	int         _errorNo;
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   484
	zstream_s * _zstream = (zstream_s *) __externalBytesAddress( _zstreamObj );
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   485
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   486
	_zstream->op_mode = e_opmode_deflate;
1051
4f18d73427bb *** empty log message ***
ca
parents: 1050
diff changeset
   487
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   488
	_errorNo = deflateInit2( & _zstream->stream
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   489
			       , __intVal( level )
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   490
			       , Z_DEFLATED
2193
db70507b21ba suppress header & checksum configurable
ca
parents: 2190
diff changeset
   491
			       , __intVal( windowBits )
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   492
			       , DEF_MEM_LEVEL
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   493
			       , Z_DEFAULT_STRATEGY
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   494
			       );
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   495
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   496
	if( _errorNo == Z_OK )
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   497
	    RETURN( self );
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   498
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   499
	errorNo = __MKSMALLINT( _errorNo );
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   500
    }
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   501
%}.
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   502
    errorNo ifNil:[
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   503
	zstream ifNil:[ self errorNotOpen ].
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   504
	self invalidArgument .
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   505
    ].
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   506
    self zerror:errorNo.
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   507
!
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   508
1059
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   509
zget_avail_out
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   510
    "low level - get the number of available out bytes
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   511
    "
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   512
%{
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   513
    OBJ _zstreamObj = __INST( zstream );
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   514
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   515
    if( _zstreamObj != nil )
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   516
    {
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   517
	uInt        _count;
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   518
	zstream_s * _zstream = (zstream_s *) __externalBytesAddress( _zstreamObj );
1059
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   519
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   520
	_count = _zstream->out_total - _zstream->stream.avail_out;
1059
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   521
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   522
	RETURN( __MKSMALLINT (_count) );
1059
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   523
    }
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   524
%}.
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   525
    self errorNotOpen.
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   526
!
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   527
2193
db70507b21ba suppress header & checksum configurable
ca
parents: 2190
diff changeset
   528
zget_windowBits
db70507b21ba suppress header & checksum configurable
ca
parents: 2190
diff changeset
   529
    "answer the bits used for inflateInit2 or deflateInit2...
db70507b21ba suppress header & checksum configurable
ca
parents: 2190
diff changeset
   530
    a negative WindowBits value suppresses the zlib header and the checksum..."
db70507b21ba suppress header & checksum configurable
ca
parents: 2190
diff changeset
   531
db70507b21ba suppress header & checksum configurable
ca
parents: 2190
diff changeset
   532
    |windowBits|
db70507b21ba suppress header & checksum configurable
ca
parents: 2190
diff changeset
   533
%{
db70507b21ba suppress header & checksum configurable
ca
parents: 2190
diff changeset
   534
    windowBits = __MKSMALLINT( MAX_WBITS );
db70507b21ba suppress header & checksum configurable
ca
parents: 2190
diff changeset
   535
%}.
db70507b21ba suppress header & checksum configurable
ca
parents: 2190
diff changeset
   536
db70507b21ba suppress header & checksum configurable
ca
parents: 2190
diff changeset
   537
    self isHeaderAndChecksumSuppressed ifTrue:[
db70507b21ba suppress header & checksum configurable
ca
parents: 2190
diff changeset
   538
	"/ undocumented feature.....
db70507b21ba suppress header & checksum configurable
ca
parents: 2190
diff changeset
   539
	^ windowBits negated
db70507b21ba suppress header & checksum configurable
ca
parents: 2190
diff changeset
   540
    ].
db70507b21ba suppress header & checksum configurable
ca
parents: 2190
diff changeset
   541
    ^ windowBits
db70507b21ba suppress header & checksum configurable
ca
parents: 2190
diff changeset
   542
!
db70507b21ba suppress header & checksum configurable
ca
parents: 2190
diff changeset
   543
1050
b7e7d51e0a9f *** empty log message ***
ca
parents: 1049
diff changeset
   544
zinflate
1052
055841c03c8a *** empty log message ***
ca
parents: 1051
diff changeset
   545
    "low level - inflate
055841c03c8a *** empty log message ***
ca
parents: 1051
diff changeset
   546
    "
1061
be824dc5e0e7 *** empty log message ***
ca
parents: 1060
diff changeset
   547
    |errorNo tailError|
1050
b7e7d51e0a9f *** empty log message ***
ca
parents: 1049
diff changeset
   548
1061
be824dc5e0e7 *** empty log message ***
ca
parents: 1060
diff changeset
   549
    tailError := nil.
be824dc5e0e7 *** empty log message ***
ca
parents: 1060
diff changeset
   550
    errorNo   := nil.
1050
b7e7d51e0a9f *** empty log message ***
ca
parents: 1049
diff changeset
   551
%{
b7e7d51e0a9f *** empty log message ***
ca
parents: 1049
diff changeset
   552
    OBJ _zstreamObj = __INST( zstream );
b7e7d51e0a9f *** empty log message ***
ca
parents: 1049
diff changeset
   553
b7e7d51e0a9f *** empty log message ***
ca
parents: 1049
diff changeset
   554
    if( _zstreamObj != nil )
b7e7d51e0a9f *** empty log message ***
ca
parents: 1049
diff changeset
   555
    {
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   556
	int         _errorNo, _count;
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   557
	zstream_s * _zstream;
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   558
	int         _avail_in;
1050
b7e7d51e0a9f *** empty log message ***
ca
parents: 1049
diff changeset
   559
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   560
	_zstream = (zstream_s *) __externalBytesAddress( _zstreamObj );
1050
b7e7d51e0a9f *** empty log message ***
ca
parents: 1049
diff changeset
   561
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   562
	if( _zstream->op_mode != e_opmode_inflate )
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   563
	    RETURN( nil );
1051
4f18d73427bb *** empty log message ***
ca
parents: 1050
diff changeset
   564
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   565
	_avail_in = _zstream->stream.avail_in;
1061
be824dc5e0e7 *** empty log message ***
ca
parents: 1060
diff changeset
   566
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   567
	if( _zstream->stream.state == NULL )
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   568
	{
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   569
	    /* processing finished : check crc and data length */
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   570
	    Bytef * _next_in;
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   571
	    Bytef * _buff;
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   572
	    uLong   _tnum;
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   573
	    int     _i;
1061
be824dc5e0e7 *** empty log message ***
ca
parents: 1060
diff changeset
   574
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   575
	    _next_in   = _zstream->stream.next_in;
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   576
	    _buff = _zstream->tail_buff;
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   577
	    _tnum = _zstream->tail_size;
1061
be824dc5e0e7 *** empty log message ***
ca
parents: 1060
diff changeset
   578
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   579
	    while( (_avail_in > 0) && (_tnum < 8) )
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   580
	    {
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   581
	       _buff[_tnum] = * _next_in;
1061
be824dc5e0e7 *** empty log message ***
ca
parents: 1060
diff changeset
   582
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   583
		++_next_in;
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   584
		++_tnum;
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   585
		--_avail_in;
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   586
	    }
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   587
	    _zstream->tail_size = _tnum;
1061
be824dc5e0e7 *** empty log message ***
ca
parents: 1060
diff changeset
   588
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   589
	    if( _tnum < 8 )                     /* test whether tail is read */
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   590
		RETURN( __MKSMALLINT (0) );     /* need more data */
1061
be824dc5e0e7 *** empty log message ***
ca
parents: 1060
diff changeset
   591
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   592
	    /* compute and check crc */
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   593
	    for( _tnum = 0, _i = 4; --_i >= 0; _tnum = (_tnum << 8) + _buff[_i] );
1061
be824dc5e0e7 *** empty log message ***
ca
parents: 1060
diff changeset
   594
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   595
	    if( _tnum != _zstream->crc_32 )
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   596
		{ tailError = __MKSMALLINT( 1 ); goto badTail; }
1061
be824dc5e0e7 *** empty log message ***
ca
parents: 1060
diff changeset
   597
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   598
	    /* compute and check data length */
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   599
	    for( _tnum = 0, _i = 8; --_i >= 4; _tnum = (_tnum << 8) + _buff[_i] );
1061
be824dc5e0e7 *** empty log message ***
ca
parents: 1060
diff changeset
   600
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   601
	    if( _zstream->stream.total_out != _tnum )
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   602
		{ tailError = __MKSMALLINT( 2 ); goto badTail; }
1051
4f18d73427bb *** empty log message ***
ca
parents: 1050
diff changeset
   603
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   604
	    _zstream->op_mode = e_opmode_unspecified;
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   605
	    RETURN( nil );
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   606
	}
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   607
	if( _avail_in == 0 )
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   608
	    RETURN( __MKSMALLINT (0) );
1050
b7e7d51e0a9f *** empty log message ***
ca
parents: 1049
diff changeset
   609
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   610
	_zstream->stream.avail_out = _zstream->out_total;
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   611
	_zstream->stream.next_out  = _zstream->out_ref;
1050
b7e7d51e0a9f *** empty log message ***
ca
parents: 1049
diff changeset
   612
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   613
	_errorNo = inflate( & _zstream->stream, Z_NO_FLUSH );
1050
b7e7d51e0a9f *** empty log message ***
ca
parents: 1049
diff changeset
   614
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   615
	if( _errorNo == Z_STREAM_END )
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   616
	    _errorNo = inflateEnd( & _zstream->stream );
1050
b7e7d51e0a9f *** empty log message ***
ca
parents: 1049
diff changeset
   617
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   618
	if( _errorNo == Z_OK )
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   619
	{
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   620
	    _count = _zstream->out_total - _zstream->stream.avail_out;
1051
4f18d73427bb *** empty log message ***
ca
parents: 1050
diff changeset
   621
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   622
	    if( _count > 0 )
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   623
		_zstream->crc_32 = crc32( _zstream->crc_32, _zstream->out_ref, _count );
1051
4f18d73427bb *** empty log message ***
ca
parents: 1050
diff changeset
   624
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   625
	    RETURN( __MKSMALLINT (_count) );
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   626
	}
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   627
	errorNo = __MKSMALLINT( _errorNo );
1050
b7e7d51e0a9f *** empty log message ***
ca
parents: 1049
diff changeset
   628
    }
1061
be824dc5e0e7 *** empty log message ***
ca
parents: 1060
diff changeset
   629
badTail:;
1050
b7e7d51e0a9f *** empty log message ***
ca
parents: 1049
diff changeset
   630
%}.
1061
be824dc5e0e7 *** empty log message ***
ca
parents: 1060
diff changeset
   631
    errorNo ifNil:[
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   632
	tailError ifNotNil:[
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   633
	    tailError == 1 ifTrue:[
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   634
		self zerror:'invalid compressed data--crc error'
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   635
	    ].
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   636
	    self zerror:'invalid compressed data--length error'
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   637
	].
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   638
	self errorNotOpen
1061
be824dc5e0e7 *** empty log message ***
ca
parents: 1060
diff changeset
   639
    ].
1050
b7e7d51e0a9f *** empty log message ***
ca
parents: 1049
diff changeset
   640
    self zerror:errorNo.
b7e7d51e0a9f *** empty log message ***
ca
parents: 1049
diff changeset
   641
!
b7e7d51e0a9f *** empty log message ***
ca
parents: 1049
diff changeset
   642
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   643
zinflateInit
1052
055841c03c8a *** empty log message ***
ca
parents: 1051
diff changeset
   644
    "low level - inflateInit
055841c03c8a *** empty log message ***
ca
parents: 1051
diff changeset
   645
    "
2193
db70507b21ba suppress header & checksum configurable
ca
parents: 2190
diff changeset
   646
    |errorNo windowBits|
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   647
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   648
    errorNo := nil.
2193
db70507b21ba suppress header & checksum configurable
ca
parents: 2190
diff changeset
   649
    windowBits := self zget_windowBits.
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   650
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   651
%{
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   652
    OBJ _zstreamObj = __INST( zstream );
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   653
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   654
    if( _zstreamObj != nil )
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   655
    {
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   656
	int         _errorNo;
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   657
	zstream_s * _zstream = (zstream_s *) __externalBytesAddress( _zstreamObj );
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   658
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   659
	_zstream->op_mode = e_opmode_inflate;
2193
db70507b21ba suppress header & checksum configurable
ca
parents: 2190
diff changeset
   660
	_errorNo = inflateInit2 ( & _zstream->stream
db70507b21ba suppress header & checksum configurable
ca
parents: 2190
diff changeset
   661
				, __intVal( windowBits )
db70507b21ba suppress header & checksum configurable
ca
parents: 2190
diff changeset
   662
				);
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   663
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   664
	if( _errorNo == Z_OK )
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   665
	    RETURN( self );
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   666
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   667
	_zstream->stream.avail_in = 0;
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   668
	errorNo = __MKSMALLINT( _errorNo );
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   669
    }
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   670
%}.
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   671
    errorNo ifNil:[ self errorNotOpen ].
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   672
    self zerror:errorNo.
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   673
!
1047
1cd99e473c08 *** empty log message ***
ca
parents: 1046
diff changeset
   674
1059
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   675
zopen
1052
055841c03c8a *** empty log message ***
ca
parents: 1051
diff changeset
   676
    "low level - opens the zip stream
055841c03c8a *** empty log message ***
ca
parents: 1051
diff changeset
   677
    "
1051
4f18d73427bb *** empty log message ***
ca
parents: 1050
diff changeset
   678
    |outTotal|
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   679
1059
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   680
    outTotal := outputBytes size.
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   681
%{
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   682
    zstream_s * _zstream = (zstream_s *) malloc( sizeof(zstream_s) );
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   683
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   684
    if( _zstream )
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   685
    {
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   686
	OBJ     _zobj   = __MKEXTERNALADDRESS( _zstream );
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   687
	OBJ     _outObj = __INST( outputBytes );
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   688
	OBJ     _inpObj = __INST( inputBytes  );
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   689
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   690
	zmemzero( _zstream, sizeof(zstream_s) );
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   691
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   692
	_zstream->in_ref           = (Bytef *) __externalBytesAddress( _inpObj );
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   693
	_zstream->stream.next_in   = Z_NULL;
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   694
	_zstream->stream.avail_in  = 0;
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   695
	_zstream->stream.total_in  = 0;
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   696
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   697
	_zstream->out_total        = __intVal( outTotal );
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   698
	_zstream->out_ref          = (Bytef *) __externalBytesAddress( _outObj );
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   699
	_zstream->stream.next_out  = _zstream->out_ref;
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   700
	_zstream->stream.avail_out = _zstream->out_total;
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   701
	_zstream->stream.total_out = 0;
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   702
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   703
	_zstream->stream.zalloc    = (alloc_func)0;
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   704
	_zstream->stream.zfree     = (free_func) 0;
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   705
	_zstream->stream.opaque    = (voidpf)    0;
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   706
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   707
	_zstream->crc_32           = crc32( 0L, Z_NULL, 0 );
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   708
	_zstream->op_mode          = e_opmode_unspecified;
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   709
	_zstream->tail_size        = 0;
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   710
1195
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   711
	__INST (zstream) = _zobj;
9d887847d1b6 Add BZipStream and ZipStream
Stefan Vogel <sv@exept.de>
parents: 1193
diff changeset
   712
	__STORE(self, _zobj);
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   713
    }
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   714
%}.
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   715
!
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   716
1059
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   717
zset_avail_in:count
1570
b6dd9a871cc2 Fix typo
Stefan Vogel <sv@exept.de>
parents: 1565
diff changeset
   718
    "set the 'avail_in' and compute the crc"
1059
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   719
%{
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   720
    OBJ _zstreamObj = __INST( zstream );
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   721
1059
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   722
    if( (_zstreamObj != nil) && __isSmallInteger(count) )
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   723
    {
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   724
	int         _count;
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   725
	zstream_s * _zstream = (zstream_s *) __externalBytesAddress( _zstreamObj );
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   726
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   727
	if( (_count = __intVal( count )) > 0 )
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   728
	{
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   729
	    Bytef * _in_ref = _zstream->in_ref;
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   730
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   731
	    _zstream->stream.avail_in = _count;
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   732
	    _zstream->stream.next_in  = _in_ref;
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   733
1828
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   734
	    if( _zstream->op_mode == e_opmode_deflate )
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   735
		_zstream->crc_32 = crc32( _zstream->crc_32, _in_ref, _count );
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   736
	} else {
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   737
	    _zstream->stream.avail_in = 0;
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   738
	    _zstream->stream.next_in  = Z_NULL;
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   739
	}
47cd819e24af *** empty log message ***
ca
parents: 1619
diff changeset
   740
	RETURN( self );
1059
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   741
    }
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   742
%}.
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   743
    zstream ifNil:[ self errorNotOpen ].
1570
b6dd9a871cc2 Fix typo
Stefan Vogel <sv@exept.de>
parents: 1565
diff changeset
   744
    self invalidArgument.
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   745
! !
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   746
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   747
!ZipStream methodsFor:'startup & release'!
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   748
2196
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   749
openWithMode:aMode on:aStream suppressHeaderAndChecksum:aBoolean
2006
0ad76801137e add instance creation methods to allow to open the ZipStream as
ab
parents: 1847
diff changeset
   750
    "open stream and write or check gzip header"
2019
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   751
2196
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   752
    super
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   753
        openWithMode:aMode
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   754
        on:aStream
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   755
        suppressHeaderAndChecksum:aBoolean.
2019
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   756
1193
7688148ec90c Code formatting & clean up
Stefan Vogel <sv@exept.de>
parents: 1061
diff changeset
   757
    self isReadable ifTrue:[
2196
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   758
        "Check for the gzip magic id"
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   759
        self readHeader
2019
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   760
    ] ifFalse:[
2196
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   761
        "write the gzip magic id"
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   762
        self writeHeader
2019
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   763
    ].
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   764
!
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   765
2019
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   766
readHeader
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   767
    "Check for the gzip magic id"
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   768
    |flags|
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   769
2019
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   770
    GZ_MAGIC_ID do:[:b|
2190
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   771
	onStream nextByte ~~ b ifTrue:[ self zerror:'version error' ]
2019
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   772
    ].
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   773
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   774
    onStream nextByte ~~ Z_DEFLATED ifTrue:[
2190
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   775
	self zerror:'invalid method (not deflated)'
2019
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   776
    ].
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   777
2019
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   778
    flags := onStream nextByte.
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   779
    (flags bitAnd:HEAD_RESERVED) ~~ 0 ifTrue:[
2190
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   780
	self zerror:'wrong data format'
2019
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   781
    ].
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   782
2019
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   783
    "discard time, xflags and OS code"
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   784
    onStream skip:6.
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   785
2019
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   786
    (flags bitAnd:HEAD_EXTRA_FIELD) ~~ 0 ifTrue:[|len|
2190
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   787
	"skip the extra field"
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   788
	len := onStream nextByte + (onStream nextByte bitShift:8).
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   789
	len timesRepeat:[ onStream nextByte ].
2019
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   790
    ].
1050
b7e7d51e0a9f *** empty log message ***
ca
parents: 1049
diff changeset
   791
2019
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   792
    (flags bitAnd:HEAD_ORIG_NAME) ~~ 0 ifTrue:[|b|
2190
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   793
	"skip the original file name"
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   794
	[ (b := onStream nextByte) ~~ 0 ] whileTrue.
2019
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   795
    ].
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   796
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   797
    (flags bitAnd:HEAD_CRC) ~~ 0 ifTrue:[
2190
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   798
	"skip the header crc"
6c3f9241753a fixed stream processing
Claus Gittinger <cg@exept.de>
parents: 2178
diff changeset
   799
	onStream skip:2.
2019
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   800
    ].
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   801
!
1050
b7e7d51e0a9f *** empty log message ***
ca
parents: 1049
diff changeset
   802
2019
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   803
writeHeader
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   804
    "write the gzip magic id"
1059
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   805
2019
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   806
    GZ_MAGIC_ID do:[:b| onStream nextPutByte:b ].
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   807
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   808
    "write the method"
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   809
    onStream nextPutByte:Z_DEFLATED.
1050
b7e7d51e0a9f *** empty log message ***
ca
parents: 1049
diff changeset
   810
2019
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   811
    "write the flags"
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   812
    onStream nextPutByte:0.
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   813
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   814
    "write time"
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   815
    4 timesRepeat:[ onStream nextPutByte:0 ].
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   816
2019
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   817
    "write xflags"
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   818
    onStream nextPutByte:0.
1059
b47e4eff5543 *** empty log message ***
ca
parents: 1058
diff changeset
   819
2019
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   820
    "write OS code"
4a33a6715a51 refactored
Claus Gittinger <cg@exept.de>
parents: 2006
diff changeset
   821
    onStream nextPutByte:HEAD_OS_CODE.
1045
6f093ef80063 *** empty log message ***
ca
parents: 1044
diff changeset
   822
! !
1044
c73aee830691 initial checkin
ca
parents:
diff changeset
   823
c73aee830691 initial checkin
ca
parents:
diff changeset
   824
!ZipStream class methodsFor:'documentation'!
c73aee830691 initial checkin
ca
parents:
diff changeset
   825
c73aee830691 initial checkin
ca
parents:
diff changeset
   826
version
2196
9eecfefd08aa suppressHeaderAndChecksum is configurable
ca
parents: 2193
diff changeset
   827
    ^ '$Header: /cvs/stx/stx/libbasic2/ZipStream.st,v 1.36 2009-08-03 13:38:33 ca Exp $'
1044
c73aee830691 initial checkin
ca
parents:
diff changeset
   828
! !
1193
7688148ec90c Code formatting & clean up
Stefan Vogel <sv@exept.de>
parents: 1061
diff changeset
   829
1047
1cd99e473c08 *** empty log message ***
ca
parents: 1046
diff changeset
   830
ZipStream initialize!