summaryrefslogtreecommitdiffhomepage
path: root/zlib/gzclose.c
diff options
context:
space:
mode:
authorYasha Jannoo <alledodo@gmail.com>2019-09-14 12:15:04 +0100
committerYasha Jannoo <alledodo@gmail.com>2019-09-14 12:51:21 +0100
commitf2e1338eba568ac7caa0051d57f1f6a10ae81801 (patch)
tree4a6589fb83fe95308b75a76505d97a972f2bd7be /zlib/gzclose.c
parente31b0c1803d976e29b258c7307e32fd0d63821e5 (diff)
downloadstarshatter-f2e1338eba568ac7caa0051d57f1f6a10ae81801.zip
starshatter-f2e1338eba568ac7caa0051d57f1f6a10ae81801.tar.gz
starshatter-f2e1338eba568ac7caa0051d57f1f6a10ae81801.tar.bz2
Update zlib 3rd party code to v1.2.11
zlib source code, version 1.2.11. https://www.zlib.net/. Include all the gynmastics involved in: - making sure we compile zlibstat and set the output files locations and filename to those expected by the starshatter setup. - turning off the ASM includes as they are invalid for the new versions of zlib (and crash when running). - matching the calling conventions of the Starshatter code by ommiting ZLIB_WINAPI from the zlib preprocessor defines. - fix debug build compile error in zlibstatic: https://stackoverflow.com/questions/31867018/unresolved-external-symbol-except-handler4-common-in-visual-studio-2015 This fixes some string warnings.
Diffstat (limited to 'zlib/gzclose.c')
-rw-r--r--zlib/gzclose.c25
1 files changed, 25 insertions, 0 deletions
diff --git a/zlib/gzclose.c b/zlib/gzclose.c
new file mode 100644
index 0000000..caeb99a
--- /dev/null
+++ b/zlib/gzclose.c
@@ -0,0 +1,25 @@
+/* gzclose.c -- zlib gzclose() function
+ * Copyright (C) 2004, 2010 Mark Adler
+ * For conditions of distribution and use, see copyright notice in zlib.h
+ */
+
+#include "gzguts.h"
+
+/* gzclose() is in a separate file so that it is linked in only if it is used.
+ That way the other gzclose functions can be used instead to avoid linking in
+ unneeded compression or decompression routines. */
+int ZEXPORT gzclose(file)
+ gzFile file;
+{
+#ifndef NO_GZCOMPRESS
+ gz_statep state;
+
+ if (file == NULL)
+ return Z_STREAM_ERROR;
+ state = (gz_statep)file;
+
+ return state->mode == GZ_READ ? gzclose_r(file) : gzclose_w(file);
+#else
+ return gzclose_r(file);
+#endif
+}