Geant4 Cross Reference

Cross-Referencing   Geant4
Geant4/externals/zlib/src/gzwrite.c

Version: [ ReleaseNotes ] [ 1.0 ] [ 1.1 ] [ 2.0 ] [ 3.0 ] [ 3.1 ] [ 3.2 ] [ 4.0 ] [ 4.0.p1 ] [ 4.0.p2 ] [ 4.1 ] [ 4.1.p1 ] [ 5.0 ] [ 5.0.p1 ] [ 5.1 ] [ 5.1.p1 ] [ 5.2 ] [ 5.2.p1 ] [ 5.2.p2 ] [ 6.0 ] [ 6.0.p1 ] [ 6.1 ] [ 6.2 ] [ 6.2.p1 ] [ 6.2.p2 ] [ 7.0 ] [ 7.0.p1 ] [ 7.1 ] [ 7.1.p1 ] [ 8.0 ] [ 8.0.p1 ] [ 8.1 ] [ 8.1.p1 ] [ 8.1.p2 ] [ 8.2 ] [ 8.2.p1 ] [ 8.3 ] [ 8.3.p1 ] [ 8.3.p2 ] [ 9.0 ] [ 9.0.p1 ] [ 9.0.p2 ] [ 9.1 ] [ 9.1.p1 ] [ 9.1.p2 ] [ 9.1.p3 ] [ 9.2 ] [ 9.2.p1 ] [ 9.2.p2 ] [ 9.2.p3 ] [ 9.2.p4 ] [ 9.3 ] [ 9.3.p1 ] [ 9.3.p2 ] [ 9.4 ] [ 9.4.p1 ] [ 9.4.p2 ] [ 9.4.p3 ] [ 9.4.p4 ] [ 9.5 ] [ 9.5.p1 ] [ 9.5.p2 ] [ 9.6 ] [ 9.6.p1 ] [ 9.6.p2 ] [ 9.6.p3 ] [ 9.6.p4 ] [ 10.0 ] [ 10.0.p1 ] [ 10.0.p2 ] [ 10.0.p3 ] [ 10.0.p4 ] [ 10.1 ] [ 10.1.p1 ] [ 10.1.p2 ] [ 10.1.p3 ] [ 10.2 ] [ 10.2.p1 ] [ 10.2.p2 ] [ 10.2.p3 ] [ 10.3 ] [ 10.3.p1 ] [ 10.3.p2 ] [ 10.3.p3 ] [ 10.4 ] [ 10.4.p1 ] [ 10.4.p2 ] [ 10.4.p3 ] [ 10.5 ] [ 10.5.p1 ] [ 10.6 ] [ 10.6.p1 ] [ 10.6.p2 ] [ 10.6.p3 ] [ 10.7 ] [ 10.7.p1 ] [ 10.7.p2 ] [ 10.7.p3 ] [ 10.7.p4 ] [ 11.0 ] [ 11.0.p1 ] [ 11.0.p2 ] [ 11.0.p3, ] [ 11.0.p4 ] [ 11.1 ] [ 11.1.1 ] [ 11.1.2 ] [ 11.1.3 ] [ 11.2 ] [ 11.2.1 ] [ 11.2.2 ] [ 11.3.0 ]

Diff markup

Differences between /externals/zlib/src/gzwrite.c (Version 11.3.0) and /externals/zlib/src/gzwrite.c (Version 10.1.p2)


  1 /* gzwrite.c -- zlib functions for writing gzi      1 
  2  * Copyright (C) 2004-2019 Mark Adler             
  3  * For conditions of distribution and use, see    
  4  */                                               
  5                                                   
  6 #include "gzguts.h"                               
  7                                                   
  8 /* Local functions */                             
  9 local int gz_init OF((gz_statep));                
 10 local int gz_comp OF((gz_statep, int));           
 11 local int gz_zero OF((gz_statep, z_off64_t));     
 12 local z_size_t gz_write OF((gz_statep, voidpc,    
 13                                                   
 14 /* Initialize state for writing a gzip file.      
 15    state->size to non-zero.  Return -1 on a me    
 16    success. */                                    
 17 local int gz_init(state)                          
 18     gz_statep state;                              
 19 {                                                 
 20     int ret;                                      
 21     z_streamp strm = &(state->strm);              
 22                                                   
 23     /* allocate input buffer (double size for     
 24     state->in = (unsigned char *)malloc(state-    
 25     if (state->in == NULL) {                      
 26         gz_error(state, Z_MEM_ERROR, "out of m    
 27         return -1;                                
 28     }                                             
 29                                                   
 30     /* only need output buffer and deflate sta    
 31     if (!state->direct) {                         
 32         /* allocate output buffer */              
 33         state->out = (unsigned char *)malloc(s    
 34         if (state->out == NULL) {                 
 35             free(state->in);                      
 36             gz_error(state, Z_MEM_ERROR, "out     
 37             return -1;                            
 38         }                                         
 39                                                   
 40         /* allocate deflate memory, set up for    
 41         strm->zalloc = Z_NULL;                    
 42         strm->zfree = Z_NULL;                     
 43         strm->opaque = Z_NULL;                    
 44         ret = deflateInit2(strm, state->level,    
 45                            MAX_WBITS + 16, DEF    
 46         if (ret != Z_OK) {                        
 47             free(state->out);                     
 48             free(state->in);                      
 49             gz_error(state, Z_MEM_ERROR, "out     
 50             return -1;                            
 51         }                                         
 52         strm->next_in = NULL;                     
 53     }                                             
 54                                                   
 55     /* mark state as initialized */               
 56     state->size = state->want;                    
 57                                                   
 58     /* initialize write buffer if compressing     
 59     if (!state->direct) {                         
 60         strm->avail_out = state->size;            
 61         strm->next_out = state->out;              
 62         state->x.next = strm->next_out;           
 63     }                                             
 64     return 0;                                     
 65 }                                                 
 66                                                   
 67 /* Compress whatever is at avail_in and next_i    
 68    Return -1 if there is an error writing to t    
 69    fails to allocate memory, otherwise 0.  flu    
 70    deflate() flush value.  If flush is Z_FINIS    
 71    reset to start a new gzip stream.  If gz->d    
 72    to the output file without compressing, and    
 73 local int gz_comp(state, flush)                   
 74     gz_statep state;                              
 75     int flush;                                    
 76 {                                                 
 77     int ret, writ;                                
 78     unsigned have, put, max = ((unsigned)-1 >>    
 79     z_streamp strm = &(state->strm);              
 80                                                   
 81     /* allocate memory if this is the first ti    
 82     if (state->size == 0 && gz_init(state) ==     
 83         return -1;                                
 84                                                   
 85     /* write directly if requested */             
 86     if (state->direct) {                          
 87         while (strm->avail_in) {                  
 88             put = strm->avail_in > max ? max :    
 89             writ = write(state->fd, strm->next    
 90             if (writ < 0) {                       
 91                 gz_error(state, Z_ERRNO, zstre    
 92                 return -1;                        
 93             }                                     
 94             strm->avail_in -= (unsigned)writ;     
 95             strm->next_in += writ;                
 96         }                                         
 97         return 0;                                 
 98     }                                             
 99                                                   
100     /* check for a pending reset */               
101     if (state->reset) {                           
102         /* don't start a new gzip member unles    
103         if (strm->avail_in == 0)                  
104             return 0;                             
105         deflateReset(strm);                       
106         state->reset = 0;                         
107     }                                             
108                                                   
109     /* run deflate() on provided input until i    
110     ret = Z_OK;                                   
111     do {                                          
112         /* write out current buffer contents i    
113            doing Z_FINISH then don't write unt    
114         if (strm->avail_out == 0 || (flush !=     
115             (flush != Z_FINISH || ret == Z_STR    
116             while (strm->next_out > state->x.n    
117                 put = strm->next_out - state->    
118                       (unsigned)(strm->next_ou    
119                 writ = write(state->fd, state-    
120                 if (writ < 0) {                   
121                     gz_error(state, Z_ERRNO, z    
122                     return -1;                    
123                 }                                 
124                 state->x.next += writ;            
125             }                                     
126             if (strm->avail_out == 0) {           
127                 strm->avail_out = state->size;    
128                 strm->next_out = state->out;      
129                 state->x.next = state->out;       
130             }                                     
131         }                                         
132                                                   
133         /* compress */                            
134         have = strm->avail_out;                   
135         ret = deflate(strm, flush);               
136         if (ret == Z_STREAM_ERROR) {              
137             gz_error(state, Z_STREAM_ERROR,       
138                       "internal error: deflate    
139             return -1;                            
140         }                                         
141         have -= strm->avail_out;                  
142     } while (have);                               
143                                                   
144     /* if that completed a deflate stream, all    
145     if (flush == Z_FINISH)                        
146         state->reset = 1;                         
147                                                   
148     /* all done, no errors */                     
149     return 0;                                     
150 }                                                 
151                                                   
152 /* Compress len zeros to output.  Return -1 on    
153    allocation failure by gz_comp(), or 0 on su    
154 local int gz_zero(state, len)                     
155     gz_statep state;                              
156     z_off64_t len;                                
157 {                                                 
158     int first;                                    
159     unsigned n;                                   
160     z_streamp strm = &(state->strm);              
161                                                   
162     /* consume whatever's left in the input bu    
163     if (strm->avail_in && gz_comp(state, Z_NO_    
164         return -1;                                
165                                                   
166     /* compress len zeros (len guaranteed > 0)    
167     first = 1;                                    
168     while (len) {                                 
169         n = GT_OFF(state->size) || (z_off64_t)    
170             (unsigned)len : state->size;          
171         if (first) {                              
172             memset(state->in, 0, n);              
173             first = 0;                            
174         }                                         
175         strm->avail_in = n;                       
176         strm->next_in = state->in;                
177         state->x.pos += n;                        
178         if (gz_comp(state, Z_NO_FLUSH) == -1)     
179             return -1;                            
180         len -= n;                                 
181     }                                             
182     return 0;                                     
183 }                                                 
184                                                   
185 /* Write len bytes from buf to file.  Return t    
186    the returned value is less than len, then t    
187 local z_size_t gz_write(state, buf, len)          
188     gz_statep state;                              
189     voidpc buf;                                   
190     z_size_t len;                                 
191 {                                                 
192     z_size_t put = len;                           
193                                                   
194     /* if len is zero, avoid unnecessary opera    
195     if (len == 0)                                 
196         return 0;                                 
197                                                   
198     /* allocate memory if this is the first ti    
199     if (state->size == 0 && gz_init(state) ==     
200         return 0;                                 
201                                                   
202     /* check for seek request */                  
203     if (state->seek) {                            
204         state->seek = 0;                          
205         if (gz_zero(state, state->skip) == -1)    
206             return 0;                             
207     }                                             
208                                                   
209     /* for small len, copy to input buffer, ot    
210     if (len < state->size) {                      
211         /* copy to input buffer, compress when    
212         do {                                      
213             unsigned have, copy;                  
214                                                   
215             if (state->strm.avail_in == 0)        
216                 state->strm.next_in = state->i    
217             have = (unsigned)((state->strm.nex    
218                               state->in);         
219             copy = state->size - have;            
220             if (copy > len)                       
221                 copy = (unsigned)len;             
222             memcpy(state->in + have, buf, copy    
223             state->strm.avail_in += copy;         
224             state->x.pos += copy;                 
225             buf = (const char *)buf + copy;       
226             len -= copy;                          
227             if (len && gz_comp(state, Z_NO_FLU    
228                 return 0;                         
229         } while (len);                            
230     }                                             
231     else {                                        
232         /* consume whatever's left in the inpu    
233         if (state->strm.avail_in && gz_comp(st    
234             return 0;                             
235                                                   
236         /* directly compress user buffer to fi    
237         state->strm.next_in = (z_const Bytef *    
238         do {                                      
239             unsigned n = (unsigned)-1;            
240             if (n > len)                          
241                 n = (unsigned)len;                
242             state->strm.avail_in = n;             
243             state->x.pos += n;                    
244             if (gz_comp(state, Z_NO_FLUSH) ==     
245                 return 0;                         
246             len -= n;                             
247         } while (len);                            
248     }                                             
249                                                   
250     /* input was all buffered or compressed */    
251     return put;                                   
252 }                                                 
253                                                   
254 /* -- see zlib.h -- */                            
255 int ZEXPORT gzwrite(file, buf, len)               
256     gzFile file;                                  
257     voidpc buf;                                   
258     unsigned len;                                 
259 {                                                 
260     gz_statep state;                              
261                                                   
262     /* get internal structure */                  
263     if (file == NULL)                             
264         return 0;                                 
265     state = (gz_statep)file;                      
266                                                   
267     /* check that we're writing and that there    
268     if (state->mode != GZ_WRITE || state->err     
269         return 0;                                 
270                                                   
271     /* since an int is returned, make sure len    
272        with an error (this avoids a flaw in th    
273     if ((int)len < 0) {                           
274         gz_error(state, Z_DATA_ERROR, "request    
275         return 0;                                 
276     }                                             
277                                                   
278     /* write len bytes from buf (the return va    
279     return (int)gz_write(state, buf, len);        
280 }                                                 
281                                                   
282 /* -- see zlib.h -- */                            
283 z_size_t ZEXPORT gzfwrite(buf, size, nitems, f    
284     voidpc buf;                                   
285     z_size_t size;                                
286     z_size_t nitems;                              
287     gzFile file;                                  
288 {                                                 
289     z_size_t len;                                 
290     gz_statep state;                              
291                                                   
292     /* get internal structure */                  
293     if (file == NULL)                             
294         return 0;                                 
295     state = (gz_statep)file;                      
296                                                   
297     /* check that we're writing and that there    
298     if (state->mode != GZ_WRITE || state->err     
299         return 0;                                 
300                                                   
301     /* compute bytes to read -- error on overf    
302     len = nitems * size;                          
303     if (size && len / size != nitems) {           
304         gz_error(state, Z_STREAM_ERROR, "reque    
305         return 0;                                 
306     }                                             
307                                                   
308     /* write len bytes to buf, return the numb    
309     return len ? gz_write(state, buf, len) / s    
310 }                                                 
311                                                   
312 /* -- see zlib.h -- */                            
313 int ZEXPORT gzputc(file, c)                       
314     gzFile file;                                  
315     int c;                                        
316 {                                                 
317     unsigned have;                                
318     unsigned char buf[1];                         
319     gz_statep state;                              
320     z_streamp strm;                               
321                                                   
322     /* get internal structure */                  
323     if (file == NULL)                             
324         return -1;                                
325     state = (gz_statep)file;                      
326     strm = &(state->strm);                        
327                                                   
328     /* check that we're writing and that there    
329     if (state->mode != GZ_WRITE || state->err     
330         return -1;                                
331                                                   
332     /* check for seek request */                  
333     if (state->seek) {                            
334         state->seek = 0;                          
335         if (gz_zero(state, state->skip) == -1)    
336             return -1;                            
337     }                                             
338                                                   
339     /* try writing to input buffer for speed (    
340        initialized) */                            
341     if (state->size) {                            
342         if (strm->avail_in == 0)                  
343             strm->next_in = state->in;            
344         have = (unsigned)((strm->next_in + str    
345         if (have < state->size) {                 
346             state->in[have] = (unsigned char)c    
347             strm->avail_in++;                     
348             state->x.pos++;                       
349             return c & 0xff;                      
350         }                                         
351     }                                             
352                                                   
353     /* no room in buffer or not initialized, u    
354     buf[0] = (unsigned char)c;                    
355     if (gz_write(state, buf, 1) != 1)             
356         return -1;                                
357     return c & 0xff;                              
358 }                                                 
359                                                   
360 /* -- see zlib.h -- */                            
361 int ZEXPORT gzputs(file, s)                       
362     gzFile file;                                  
363     const char *s;                                
364 {                                                 
365     z_size_t len, put;                            
366     gz_statep state;                              
367                                                   
368     /* get internal structure */                  
369     if (file == NULL)                             
370         return -1;                                
371     state = (gz_statep)file;                      
372                                                   
373     /* check that we're writing and that there    
374     if (state->mode != GZ_WRITE || state->err     
375         return -1;                                
376                                                   
377     /* write string */                            
378     len = strlen(s);                              
379     if ((int)len < 0 || (unsigned)len != len)     
380         gz_error(state, Z_STREAM_ERROR, "strin    
381         return -1;                                
382     }                                             
383     put = gz_write(state, s, len);                
384     return put < len ? -1 : (int)len;             
385 }                                                 
386                                                   
387 #if defined(STDC) || defined(Z_HAVE_STDARG_H)     
388 #include <stdarg.h>                               
389                                                   
390 /* -- see zlib.h -- */                            
391 int ZEXPORTVA gzvprintf(gzFile file, const cha    
392 {                                                 
393     int len;                                      
394     unsigned left;                                
395     char *next;                                   
396     gz_statep state;                              
397     z_streamp strm;                               
398                                                   
399     /* get internal structure */                  
400     if (file == NULL)                             
401         return Z_STREAM_ERROR;                    
402     state = (gz_statep)file;                      
403     strm = &(state->strm);                        
404                                                   
405     /* check that we're writing and that there    
406     if (state->mode != GZ_WRITE || state->err     
407         return Z_STREAM_ERROR;                    
408                                                   
409     /* make sure we have some buffer space */     
410     if (state->size == 0 && gz_init(state) ==     
411         return state->err;                        
412                                                   
413     /* check for seek request */                  
414     if (state->seek) {                            
415         state->seek = 0;                          
416         if (gz_zero(state, state->skip) == -1)    
417             return state->err;                    
418     }                                             
419                                                   
420     /* do the printf() into the input buffer,     
421        buffer is double-sized just for this fu    
422        be state->size bytes available after th    
423     if (strm->avail_in == 0)                      
424         strm->next_in = state->in;                
425     next = (char *)(state->in + (strm->next_in    
426     next[state->size - 1] = 0;                    
427 #ifdef NO_vsnprintf                               
428 #  ifdef HAS_vsprintf_void                        
429     (void)vsprintf(next, format, va);             
430     for (len = 0; len < state->size; len++)       
431         if (next[len] == 0) break;                
432 #  else                                           
433     len = vsprintf(next, format, va);             
434 #  endif                                          
435 #else                                             
436 #  ifdef HAS_vsnprintf_void                       
437     (void)vsnprintf(next, state->size, format,    
438     len = strlen(next);                           
439 #  else                                           
440     len = vsnprintf(next, state->size, format,    
441 #  endif                                          
442 #endif                                            
443                                                   
444     /* check that printf() results fit in buff    
445     if (len == 0 || (unsigned)len >= state->si    
446         return 0;                                 
447                                                   
448     /* update buffer and position, compress fi    
449     strm->avail_in += (unsigned)len;              
450     state->x.pos += len;                          
451     if (strm->avail_in >= state->size) {          
452         left = strm->avail_in - state->size;      
453         strm->avail_in = state->size;             
454         if (gz_comp(state, Z_NO_FLUSH) == -1)     
455             return state->err;                    
456         memmove(state->in, state->in + state->    
457         strm->next_in = state->in;                
458         strm->avail_in = left;                    
459     }                                             
460     return len;                                   
461 }                                                 
462                                                   
463 int ZEXPORTVA gzprintf(gzFile file, const char    
464 {                                                 
465     va_list va;                                   
466     int ret;                                      
467                                                   
468     va_start(va, format);                         
469     ret = gzvprintf(file, format, va);            
470     va_end(va);                                   
471     return ret;                                   
472 }                                                 
473                                                   
474 #else /* !STDC && !Z_HAVE_STDARG_H */             
475                                                   
476 /* -- see zlib.h -- */                            
477 int ZEXPORTVA gzprintf(file, format, a1, a2, a    
478                        a11, a12, a13, a14, a15    
479     gzFile file;                                  
480     const char *format;                           
481     int a1, a2, a3, a4, a5, a6, a7, a8, a9, a1    
482         a11, a12, a13, a14, a15, a16, a17, a18    
483 {                                                 
484     unsigned len, left;                           
485     char *next;                                   
486     gz_statep state;                              
487     z_streamp strm;                               
488                                                   
489     /* get internal structure */                  
490     if (file == NULL)                             
491         return Z_STREAM_ERROR;                    
492     state = (gz_statep)file;                      
493     strm = &(state->strm);                        
494                                                   
495     /* check that can really pass pointer in i    
496     if (sizeof(int) != sizeof(void *))            
497         return Z_STREAM_ERROR;                    
498                                                   
499     /* check that we're writing and that there    
500     if (state->mode != GZ_WRITE || state->err     
501         return Z_STREAM_ERROR;                    
502                                                   
503     /* make sure we have some buffer space */     
504     if (state->size == 0 && gz_init(state) ==     
505         return state->error;                      
506                                                   
507     /* check for seek request */                  
508     if (state->seek) {                            
509         state->seek = 0;                          
510         if (gz_zero(state, state->skip) == -1)    
511             return state->error;                  
512     }                                             
513                                                   
514     /* do the printf() into the input buffer,     
515        buffer is double-sized just for this fu    
516        be state->size bytes available after th    
517     if (strm->avail_in == 0)                      
518         strm->next_in = state->in;                
519     next = (char *)(strm->next_in + strm->avai    
520     next[state->size - 1] = 0;                    
521 #ifdef NO_snprintf                                
522 #  ifdef HAS_sprintf_void                         
523     sprintf(next, format, a1, a2, a3, a4, a5,     
524             a13, a14, a15, a16, a17, a18, a19,    
525     for (len = 0; len < size; len++)              
526         if (next[len] == 0)                       
527             break;                                
528 #  else                                           
529     len = sprintf(next, format, a1, a2, a3, a4    
530                   a12, a13, a14, a15, a16, a17    
531 #  endif                                          
532 #else                                             
533 #  ifdef HAS_snprintf_void                        
534     snprintf(next, state->size, format, a1, a2    
535              a10, a11, a12, a13, a14, a15, a16    
536     len = strlen(next);                           
537 #  else                                           
538     len = snprintf(next, state->size, format,     
539                    a9, a10, a11, a12, a13, a14    
540 #  endif                                          
541 #endif                                            
542                                                   
543     /* check that printf() results fit in buff    
544     if (len == 0 || len >= state->size || next    
545         return 0;                                 
546                                                   
547     /* update buffer and position, compress fi    
548     strm->avail_in += len;                        
549     state->x.pos += len;                          
550     if (strm->avail_in >= state->size) {          
551         left = strm->avail_in - state->size;      
552         strm->avail_in = state->size;             
553         if (gz_comp(state, Z_NO_FLUSH) == -1)     
554             return state->err;                    
555         memmove(state->in, state->in + state->    
556         strm->next_in = state->in;                
557         strm->avail_in = left;                    
558     }                                             
559     return (int)len;                              
560 }                                                 
561                                                   
562 #endif                                            
563                                                   
564 /* -- see zlib.h -- */                            
565 int ZEXPORT gzflush(file, flush)                  
566     gzFile file;                                  
567     int flush;                                    
568 {                                                 
569     gz_statep state;                              
570                                                   
571     /* get internal structure */                  
572     if (file == NULL)                             
573         return Z_STREAM_ERROR;                    
574     state = (gz_statep)file;                      
575                                                   
576     /* check that we're writing and that there    
577     if (state->mode != GZ_WRITE || state->err     
578         return Z_STREAM_ERROR;                    
579                                                   
580     /* check flush parameter */                   
581     if (flush < 0 || flush > Z_FINISH)            
582         return Z_STREAM_ERROR;                    
583                                                   
584     /* check for seek request */                  
585     if (state->seek) {                            
586         state->seek = 0;                          
587         if (gz_zero(state, state->skip) == -1)    
588             return state->err;                    
589     }                                             
590                                                   
591     /* compress remaining data with requested     
592     (void)gz_comp(state, flush);                  
593     return state->err;                            
594 }                                                 
595                                                   
596 /* -- see zlib.h -- */                            
597 int ZEXPORT gzsetparams(file, level, strategy)    
598     gzFile file;                                  
599     int level;                                    
600     int strategy;                                 
601 {                                                 
602     gz_statep state;                              
603     z_streamp strm;                               
604                                                   
605     /* get internal structure */                  
606     if (file == NULL)                             
607         return Z_STREAM_ERROR;                    
608     state = (gz_statep)file;                      
609     strm = &(state->strm);                        
610                                                   
611     /* check that we're writing and that there    
612     if (state->mode != GZ_WRITE || state->err     
613         return Z_STREAM_ERROR;                    
614                                                   
615     /* if no change is requested, then do noth    
616     if (level == state->level && strategy == s    
617         return Z_OK;                              
618                                                   
619     /* check for seek request */                  
620     if (state->seek) {                            
621         state->seek = 0;                          
622         if (gz_zero(state, state->skip) == -1)    
623             return state->err;                    
624     }                                             
625                                                   
626     /* change compression parameters for subse    
627     if (state->size) {                            
628         /* flush previous input with previous     
629         if (strm->avail_in && gz_comp(state, Z    
630             return state->err;                    
631         deflateParams(strm, level, strategy);     
632     }                                             
633     state->level = level;                         
634     state->strategy = strategy;                   
635     return Z_OK;                                  
636 }                                                 
637                                                   
638 /* -- see zlib.h -- */                            
639 int ZEXPORT gzclose_w(file)                       
640     gzFile file;                                  
641 {                                                 
642     int ret = Z_OK;                               
643     gz_statep state;                              
644                                                   
645     /* get internal structure */                  
646     if (file == NULL)                             
647         return Z_STREAM_ERROR;                    
648     state = (gz_statep)file;                      
649                                                   
650     /* check that we're writing */                
651     if (state->mode != GZ_WRITE)                  
652         return Z_STREAM_ERROR;                    
653                                                   
654     /* check for seek request */                  
655     if (state->seek) {                            
656         state->seek = 0;                          
657         if (gz_zero(state, state->skip) == -1)    
658             ret = state->err;                     
659     }                                             
660                                                   
661     /* flush, free memory, and close file */      
662     if (gz_comp(state, Z_FINISH) == -1)           
663         ret = state->err;                         
664     if (state->size) {                            
665         if (!state->direct) {                     
666             (void)deflateEnd(&(state->strm));     
667             free(state->out);                     
668         }                                         
669         free(state->in);                          
670     }                                             
671     gz_error(state, Z_OK, NULL);                  
672     free(state->path);                            
673     if (close(state->fd) == -1)                   
674         ret = Z_ERRNO;                            
675     free(state);                                  
676     return ret;                                   
677 }                                                 
678