diff options
author | madmaxoft <github@xoft.cz> | 2014-09-03 19:36:53 +0200 |
---|---|---|
committer | madmaxoft <github@xoft.cz> | 2014-09-03 19:36:53 +0200 |
commit | 44c1d9c2480fe6ea37dbed6199b51acf035de0c2 (patch) | |
tree | 23c4e5eb1578cc9d68ff3f184f857fa8cb1af9a3 /src/StringCompression.cpp | |
parent | Fixed style and alpha-sorting. (diff) | |
download | cuberite-44c1d9c2480fe6ea37dbed6199b51acf035de0c2.tar cuberite-44c1d9c2480fe6ea37dbed6199b51acf035de0c2.tar.gz cuberite-44c1d9c2480fe6ea37dbed6199b51acf035de0c2.tar.bz2 cuberite-44c1d9c2480fe6ea37dbed6199b51acf035de0c2.tar.lz cuberite-44c1d9c2480fe6ea37dbed6199b51acf035de0c2.tar.xz cuberite-44c1d9c2480fe6ea37dbed6199b51acf035de0c2.tar.zst cuberite-44c1d9c2480fe6ea37dbed6199b51acf035de0c2.zip |
Diffstat (limited to '')
-rw-r--r-- | src/StringCompression.cpp | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/src/StringCompression.cpp b/src/StringCompression.cpp index 71d64e71e..af9f1687f 100644 --- a/src/StringCompression.cpp +++ b/src/StringCompression.cpp @@ -180,3 +180,65 @@ extern int UncompressStringGZIP(const char * a_Data, size_t a_Length, AString & + +extern int InflateString(const char * a_Data, size_t a_Length, AString & a_Uncompressed) +{ + a_Uncompressed.reserve(a_Length); + + char Buffer[64 KiB]; + z_stream strm; + memset(&strm, 0, sizeof(strm)); + strm.next_in = (Bytef *)a_Data; + strm.avail_in = (uInt)a_Length; + strm.next_out = (Bytef *)Buffer; + strm.avail_out = sizeof(Buffer); + + int res = inflateInit(&strm); // Force GZIP decoding + if (res != Z_OK) + { + LOG("%s: inflation initialization failed: %d (\"%s\").", __FUNCTION__, res, strm.msg); + return res; + } + + for (;;) + { + res = inflate(&strm, Z_NO_FLUSH); + switch (res) + { + case Z_OK: + { + // Some data has been uncompressed. Consume the buffer and continue uncompressing + a_Uncompressed.append(Buffer, sizeof(Buffer) - strm.avail_out); + strm.next_out = (Bytef *)Buffer; + strm.avail_out = sizeof(Buffer); + if (strm.avail_in == 0) + { + // All data has been uncompressed + inflateEnd(&strm); + return Z_OK; + } + break; + } + + case Z_STREAM_END: + { + // Finished uncompressing. Consume the rest of the buffer and return + a_Uncompressed.append(Buffer, sizeof(Buffer) - strm.avail_out); + inflateEnd(&strm); + return Z_OK; + } + + default: + { + // An error has occurred, log it and return the error value + LOG("%s: inflation failed: %d (\"%s\").", __FUNCTION__, res, strm.msg); + inflateEnd(&strm); + return res; + } + } // switch (res) + } // while (true) +} + + + + |