blob: f499156f64ee8a7eb70e91ce800dede0fda36723 [file] [log] [blame]
Yann Collet394bdd72017-08-29 09:24:11 -07001/*
Elliott Hughes44aba642023-09-12 20:18:59 +00002 * Copyright (c) Meta Platforms, Inc. and affiliates.
Yann Collet4ded9e52016-08-30 10:04:33 -07003 * All rights reserved.
4 *
Yann Collet394bdd72017-08-29 09:24:11 -07005 * This source code is licensed under both the BSD-style license (found in the
6 * LICENSE file in the root directory of this source tree) and the GPLv2 (found
7 * in the COPYING file in the root directory of this source tree).
Yann Collet3128e032017-09-08 00:09:23 -07008 * You may select, at your option, one of the above-listed licenses.
Yann Collet4ded9e52016-08-30 10:04:33 -07009 */
Yann Collet0809a882016-07-09 18:25:10 +020010
Yann Collet0809a882016-07-09 18:25:10 +020011#include <stdio.h> // printf
Nick Terrell1d0c1702019-04-05 18:11:17 -070012#include <stdlib.h> // free
Yann Collet0809a882016-07-09 18:25:10 +020013#include <zstd.h> // presumes zstd library is installed
Nick Terrell1d0c1702019-04-05 18:11:17 -070014#include "common.h" // Helper functions, CHECK(), and CHECK_ZSTD()
Yann Collet0809a882016-07-09 18:25:10 +020015
Yann Collet0809a882016-07-09 18:25:10 +020016static void decompress(const char* fname)
17{
18 size_t cSize;
Yi Jinbc4dc602018-12-17 16:54:55 -080019 void* const cBuff = mallocAndLoadFile_orDie(fname, &cSize);
Nick Terrell1d0c1702019-04-05 18:11:17 -070020 /* Read the content size from the frame header. For simplicity we require
21 * that it is always present. By default, zstd will write the content size
22 * in the header when it is known. If you can't guarantee that the frame
23 * content size is always written into the header, either use streaming
24 * decompression, or ZSTD_decompressBound().
25 */
26 unsigned long long const rSize = ZSTD_getFrameContentSize(cBuff, cSize);
27 CHECK(rSize != ZSTD_CONTENTSIZE_ERROR, "%s: not compressed by zstd!", fname);
28 CHECK(rSize != ZSTD_CONTENTSIZE_UNKNOWN, "%s: original size unknown!", fname);
Soojin Nam971c1612017-02-22 16:04:48 +090029
Yann Collet45960372017-02-15 12:00:03 -080030 void* const rBuff = malloc_orDie((size_t)rSize);
Yann Collet0809a882016-07-09 18:25:10 +020031
Nick Terrell1d0c1702019-04-05 18:11:17 -070032 /* Decompress.
33 * If you are doing many decompressions, you may want to reuse the context
34 * and use ZSTD_decompressDCtx(). If you want to set advanced parameters,
35 * use ZSTD_DCtx_setParameter().
36 */
Yann Collet0809a882016-07-09 18:25:10 +020037 size_t const dSize = ZSTD_decompress(rBuff, rSize, cBuff, cSize);
Nick Terrell1d0c1702019-04-05 18:11:17 -070038 CHECK_ZSTD(dSize);
39 /* When zstd knows the content size, it will error if it doesn't match. */
40 CHECK(dSize == rSize, "Impossible because zstd will check this condition!");
Yann Collet0809a882016-07-09 18:25:10 +020041
42 /* success */
43 printf("%25s : %6u -> %7u \n", fname, (unsigned)cSize, (unsigned)rSize);
44
45 free(rBuff);
46 free(cBuff);
47}
48
Yann Collet0809a882016-07-09 18:25:10 +020049int main(int argc, const char** argv)
50{
51 const char* const exeName = argv[0];
52
53 if (argc!=2) {
54 printf("wrong arguments\n");
55 printf("usage:\n");
56 printf("%s FILE\n", exeName);
57 return 1;
58 }
59
60 decompress(argv[1]);
61
Yann Collet677ed262016-07-10 14:23:30 +020062 printf("%s correctly decoded (in memory). \n", argv[1]);
63
64 return 0;
Yann Collet0809a882016-07-09 18:25:10 +020065}