From 743b33f57eb3fdd9f3dee1a056db4d323cf30b77 Mon Sep 17 00:00:00 2001 From: Yann Collet Date: Fri, 2 Dec 2016 15:18:57 -0800 Subject: [PATCH] fix zstdcat --- NEWS | 4 ++- programs/fileio.c | 10 +++--- programs/fileio.h | 2 +- programs/zstd.1 | 2 +- programs/zstdcli.c | 79 +++++++++++++++++++++++++--------------------- tests/playTests.sh | 6 ++-- 6 files changed, 57 insertions(+), 46 deletions(-) diff --git a/NEWS b/NEWS index eaae710c..0b3dd92a 100644 --- a/NEWS +++ b/NEWS @@ -1,7 +1,9 @@ v1.1.2 Improved : faster decompression speed at ultra compression settings and in 32-bits mode -cli : new : preserve file attributes, by Przemyslaw Skibinski +cli : new : gzstd, experimental version able to decode .gz files, by Przemyslaw Skibinski +cli : new : preserve file attributes cli : fixed : status displays total amount decoded, even for file consisting of multiple frames (like pzstd) +cli : fixed : zstdcat API : changed : zbuff prototypes now generate deprecation warnings Changed : reduced stack memory use diff --git a/programs/fileio.c b/programs/fileio.c index 446799af..dff4eae0 100644 --- a/programs/fileio.c +++ b/programs/fileio.c @@ -700,7 +700,7 @@ static unsigned long long FIO_decompressGzFrame(dRess_t ress, FILE* srcFile, con @return : 0 : OK 1 : operation not started */ -static int FIO_decompressSrcFile(dRess_t ress, const char* srcFileName) +static int FIO_decompressSrcFile(dRess_t ress, const char* dstFileName, const char* srcFileName) { FILE* srcFile; unsigned readSomething = 0; @@ -737,7 +737,7 @@ static int FIO_decompressSrcFile(dRess_t ress, const char* srcFileName) #endif } else { if (!ZSTD_isFrame(ress.srcBuffer, toRead)) { - if ((g_overwrite) && !strcmp (srcFileName, stdinmark)) { /* pass-through mode */ + if ((g_overwrite) && !strcmp (dstFileName, stdoutmark)) { /* pass-through mode */ unsigned const result = FIO_passThrough(ress.dstFile, srcFile, ress.srcBuffer, ress.srcBufferSize); if (fclose(srcFile)) EXM_THROW(32, "zstd: %s close error", srcFileName); /* error should never happen */ return result; @@ -777,7 +777,7 @@ static int FIO_decompressDstFile(dRess_t ress, if (ress.dstFile==0) return 1; if (strcmp (srcFileName, stdinmark) && UTIL_getFileStat(srcFileName, &statbuf)) stat_result = 1; - result = FIO_decompressSrcFile(ress, srcFileName); + result = FIO_decompressSrcFile(ress, dstFileName, srcFileName); if (fclose(ress.dstFile)) EXM_THROW(38, "Write error : cannot properly close %s", dstFileName); @@ -814,12 +814,12 @@ int FIO_decompressMultipleFilenames(const char** srcNamesTable, unsigned nbFiles if (suffix==NULL) EXM_THROW(70, "zstd: decompression: unknown dst"); /* should never happen */ - if (!strcmp(suffix, stdoutmark) || !strcmp(suffix, nulmark)) { + if (!strcmp(suffix, stdoutmark) || !strcmp(suffix, nulmark)) { /* special cases : -c or -t */ unsigned u; ress.dstFile = FIO_openDstFile(suffix); if (ress.dstFile == 0) EXM_THROW(71, "cannot open %s", suffix); for (u=0; u tmp1 +$ZSTD -dcf tmp1 $ECHO "\n**** frame concatenation **** "