xref: /freebsd/sys/contrib/zstd/programs/fileio.h (revision 5ff13fbc199bdf5f0572845351c68ee5ca828e71)
10c16b537SWarner Losh /*
2*5ff13fbcSAllan Jude  * Copyright (c) Yann Collet, Facebook, Inc.
30c16b537SWarner Losh  * All rights reserved.
40c16b537SWarner Losh  *
50c16b537SWarner Losh  * This source code is licensed under both the BSD-style license (found in the
60c16b537SWarner Losh  * LICENSE file in the root directory of this source tree) and the GPLv2 (found
70c16b537SWarner Losh  * in the COPYING file in the root directory of this source tree).
80c16b537SWarner Losh  * You may select, at your option, one of the above-listed licenses.
90c16b537SWarner Losh  */
100c16b537SWarner Losh 
110c16b537SWarner Losh 
120c16b537SWarner Losh #ifndef FILEIO_H_23981798732
130c16b537SWarner Losh #define FILEIO_H_23981798732
140c16b537SWarner Losh 
150c16b537SWarner Losh #define ZSTD_STATIC_LINKING_ONLY   /* ZSTD_compressionParameters */
1637f1f268SConrad Meyer #include "../lib/zstd.h"           /* ZSTD_* */
170c16b537SWarner Losh 
180c16b537SWarner Losh #if defined (__cplusplus)
190c16b537SWarner Losh extern "C" {
200c16b537SWarner Losh #endif
210c16b537SWarner Losh 
220c16b537SWarner Losh 
230c16b537SWarner Losh /* *************************************
240c16b537SWarner Losh *  Special i/o constants
250c16b537SWarner Losh **************************************/
260c16b537SWarner Losh #define stdinmark  "/*stdin*\\"
270c16b537SWarner Losh #define stdoutmark "/*stdout*\\"
280c16b537SWarner Losh #ifdef _WIN32
299cbefe25SConrad Meyer #  define nulmark "NUL"
300c16b537SWarner Losh #else
310c16b537SWarner Losh #  define nulmark "/dev/null"
320c16b537SWarner Losh #endif
339cbefe25SConrad Meyer 
349cbefe25SConrad Meyer /**
359cbefe25SConrad Meyer  * We test whether the extension we found starts with 't', and if so, we append
369cbefe25SConrad Meyer  * ".tar" to the end of the output name.
379cbefe25SConrad Meyer  */
380c16b537SWarner Losh #define LZMA_EXTENSION  ".lzma"
390c16b537SWarner Losh #define XZ_EXTENSION    ".xz"
409cbefe25SConrad Meyer #define TXZ_EXTENSION   ".txz"
419cbefe25SConrad Meyer 
420c16b537SWarner Losh #define GZ_EXTENSION    ".gz"
439cbefe25SConrad Meyer #define TGZ_EXTENSION   ".tgz"
449cbefe25SConrad Meyer 
450c16b537SWarner Losh #define ZSTD_EXTENSION  ".zst"
469cbefe25SConrad Meyer #define TZSTD_EXTENSION ".tzst"
47f7cd7fe5SConrad Meyer #define ZSTD_ALT_EXTENSION  ".zstd" /* allow decompression of .zstd files */
489cbefe25SConrad Meyer 
490c16b537SWarner Losh #define LZ4_EXTENSION   ".lz4"
509cbefe25SConrad Meyer #define TLZ4_EXTENSION  ".tlz4"
510c16b537SWarner Losh 
520c16b537SWarner Losh 
530c16b537SWarner Losh /*-*************************************
540c16b537SWarner Losh *  Types
550c16b537SWarner Losh ***************************************/
560c16b537SWarner Losh typedef enum { FIO_zstdCompression, FIO_gzipCompression, FIO_xzCompression, FIO_lzmaCompression, FIO_lz4Compression } FIO_compressionType_t;
570c16b537SWarner Losh 
582b9c00cbSConrad Meyer typedef struct FIO_prefs_s FIO_prefs_t;
592b9c00cbSConrad Meyer 
602b9c00cbSConrad Meyer FIO_prefs_t* FIO_createPreferences(void);
612b9c00cbSConrad Meyer void FIO_freePreferences(FIO_prefs_t* const prefs);
622b9c00cbSConrad Meyer 
63f7cd7fe5SConrad Meyer /* Mutable struct containing relevant context and state regarding (de)compression with respect to file I/O */
64f7cd7fe5SConrad Meyer typedef struct FIO_ctx_s FIO_ctx_t;
65f7cd7fe5SConrad Meyer 
66f7cd7fe5SConrad Meyer FIO_ctx_t* FIO_createContext(void);
67f7cd7fe5SConrad Meyer void FIO_freeContext(FIO_ctx_t* const fCtx);
68f7cd7fe5SConrad Meyer 
692b9c00cbSConrad Meyer typedef struct FIO_display_prefs_s FIO_display_prefs_t;
700c16b537SWarner Losh 
71*5ff13fbcSAllan Jude typedef enum { FIO_ps_auto, FIO_ps_never, FIO_ps_always } FIO_progressSetting_e;
72*5ff13fbcSAllan Jude 
730c16b537SWarner Losh /*-*************************************
740c16b537SWarner Losh *  Parameters
750c16b537SWarner Losh ***************************************/
76f7cd7fe5SConrad Meyer /* FIO_prefs_t functions */
772b9c00cbSConrad Meyer void FIO_setCompressionType(FIO_prefs_t* const prefs, FIO_compressionType_t compressionType);
782b9c00cbSConrad Meyer void FIO_overwriteMode(FIO_prefs_t* const prefs);
792b9c00cbSConrad Meyer void FIO_setAdaptiveMode(FIO_prefs_t* const prefs, unsigned adapt);
802b9c00cbSConrad Meyer void FIO_setAdaptMin(FIO_prefs_t* const prefs, int minCLevel);
812b9c00cbSConrad Meyer void FIO_setAdaptMax(FIO_prefs_t* const prefs, int maxCLevel);
82*5ff13fbcSAllan Jude void FIO_setUseRowMatchFinder(FIO_prefs_t* const prefs, int useRowMatchFinder);
832b9c00cbSConrad Meyer void FIO_setBlockSize(FIO_prefs_t* const prefs, int blockSize);
842b9c00cbSConrad Meyer void FIO_setChecksumFlag(FIO_prefs_t* const prefs, int checksumFlag);
852b9c00cbSConrad Meyer void FIO_setDictIDFlag(FIO_prefs_t* const prefs, int dictIDFlag);
862b9c00cbSConrad Meyer void FIO_setLdmBucketSizeLog(FIO_prefs_t* const prefs, int ldmBucketSizeLog);
872b9c00cbSConrad Meyer void FIO_setLdmFlag(FIO_prefs_t* const prefs, unsigned ldmFlag);
882b9c00cbSConrad Meyer void FIO_setLdmHashRateLog(FIO_prefs_t* const prefs, int ldmHashRateLog);
892b9c00cbSConrad Meyer void FIO_setLdmHashLog(FIO_prefs_t* const prefs, int ldmHashLog);
902b9c00cbSConrad Meyer void FIO_setLdmMinMatch(FIO_prefs_t* const prefs, int ldmMinMatch);
912b9c00cbSConrad Meyer void FIO_setMemLimit(FIO_prefs_t* const prefs, unsigned memLimit);
922b9c00cbSConrad Meyer void FIO_setNbWorkers(FIO_prefs_t* const prefs, int nbWorkers);
932b9c00cbSConrad Meyer void FIO_setOverlapLog(FIO_prefs_t* const prefs, int overlapLog);
942b9c00cbSConrad Meyer void FIO_setRemoveSrcFile(FIO_prefs_t* const prefs, unsigned flag);
952b9c00cbSConrad Meyer void FIO_setSparseWrite(FIO_prefs_t* const prefs, unsigned sparse);  /**< 0: no sparse; 1: disable on stdout; 2: always enabled */
962b9c00cbSConrad Meyer void FIO_setRsyncable(FIO_prefs_t* const prefs, int rsyncable);
979cbefe25SConrad Meyer void FIO_setStreamSrcSize(FIO_prefs_t* const prefs, size_t streamSrcSize);
984d3f1eafSConrad Meyer void FIO_setTargetCBlockSize(FIO_prefs_t* const prefs, size_t targetCBlockSize);
999cbefe25SConrad Meyer void FIO_setSrcSizeHint(FIO_prefs_t* const prefs, size_t srcSizeHint);
1009cbefe25SConrad Meyer void FIO_setTestMode(FIO_prefs_t* const prefs, int testMode);
1012b9c00cbSConrad Meyer void FIO_setLiteralCompressionMode(
1022b9c00cbSConrad Meyer         FIO_prefs_t* const prefs,
103*5ff13fbcSAllan Jude         ZSTD_paramSwitch_e mode);
1040c16b537SWarner Losh 
105*5ff13fbcSAllan Jude void FIO_setProgressSetting(FIO_progressSetting_e progressSetting);
1062b9c00cbSConrad Meyer void FIO_setNotificationLevel(int level);
1079cbefe25SConrad Meyer void FIO_setExcludeCompressedFile(FIO_prefs_t* const prefs, int excludeCompressedFiles);
108*5ff13fbcSAllan Jude void FIO_setAllowBlockDevices(FIO_prefs_t* const prefs, int allowBlockDevices);
10937f1f268SConrad Meyer void FIO_setPatchFromMode(FIO_prefs_t* const prefs, int value);
11037f1f268SConrad Meyer void FIO_setContentSize(FIO_prefs_t* const prefs, int value);
111*5ff13fbcSAllan Jude void FIO_displayCompressionParameters(const FIO_prefs_t* prefs);
1120c16b537SWarner Losh 
113f7cd7fe5SConrad Meyer /* FIO_ctx_t functions */
114f7cd7fe5SConrad Meyer void FIO_setNbFilesTotal(FIO_ctx_t* const fCtx, int value);
115f7cd7fe5SConrad Meyer void FIO_setHasStdoutOutput(FIO_ctx_t* const fCtx, int value);
116f7cd7fe5SConrad Meyer void FIO_determineHasStdinInput(FIO_ctx_t* const fCtx, const FileNamesTable* const filenames);
117f7cd7fe5SConrad Meyer 
1180c16b537SWarner Losh /*-*************************************
1190c16b537SWarner Losh *  Single File functions
1200c16b537SWarner Losh ***************************************/
1210c16b537SWarner Losh /** FIO_compressFilename() :
1229cbefe25SConrad Meyer  * @return : 0 == ok;  1 == pb with src file. */
123f7cd7fe5SConrad Meyer int FIO_compressFilename (FIO_ctx_t* const fCtx, FIO_prefs_t* const prefs,
1249cbefe25SConrad Meyer                           const char* outfilename, const char* infilename,
1259cbefe25SConrad Meyer                           const char* dictFileName, int compressionLevel,
1269cbefe25SConrad Meyer                           ZSTD_compressionParameters comprParams);
1270c16b537SWarner Losh 
1280c16b537SWarner Losh /** FIO_decompressFilename() :
1299cbefe25SConrad Meyer  * @return : 0 == ok;  1 == pb with src file. */
130f7cd7fe5SConrad Meyer int FIO_decompressFilename (FIO_ctx_t* const fCtx, FIO_prefs_t* const prefs,
1312b9c00cbSConrad Meyer                             const char* outfilename, const char* infilename, const char* dictFileName);
1320c16b537SWarner Losh 
1330c16b537SWarner Losh int FIO_listMultipleFiles(unsigned numFiles, const char** filenameTable, int displayLevel);
1340c16b537SWarner Losh 
1350f743729SConrad Meyer 
1360c16b537SWarner Losh /*-*************************************
1370c16b537SWarner Losh *  Multiple File functions
1380c16b537SWarner Losh ***************************************/
1390c16b537SWarner Losh /** FIO_compressMultipleFilenames() :
1409cbefe25SConrad Meyer  * @return : nb of missing files */
141f7cd7fe5SConrad Meyer int FIO_compressMultipleFilenames(FIO_ctx_t* const fCtx,
142f7cd7fe5SConrad Meyer                                   FIO_prefs_t* const prefs,
143f7cd7fe5SConrad Meyer                                   const char** inFileNamesTable,
144f7cd7fe5SConrad Meyer                                   const char* outMirroredDirName,
1459cbefe25SConrad Meyer                                   const char* outDirName,
146052d3c12SConrad Meyer                                   const char* outFileName, const char* suffix,
1470c16b537SWarner Losh                                   const char* dictFileName, int compressionLevel,
1480f743729SConrad Meyer                                   ZSTD_compressionParameters comprParams);
1490c16b537SWarner Losh 
1500c16b537SWarner Losh /** FIO_decompressMultipleFilenames() :
1519cbefe25SConrad Meyer  * @return : nb of missing or skipped files */
152f7cd7fe5SConrad Meyer int FIO_decompressMultipleFilenames(FIO_ctx_t* const fCtx,
153f7cd7fe5SConrad Meyer                                     FIO_prefs_t* const prefs,
154f7cd7fe5SConrad Meyer                                     const char** srcNamesTable,
155f7cd7fe5SConrad Meyer                                     const char* outMirroredDirName,
1569cbefe25SConrad Meyer                                     const char* outDirName,
157052d3c12SConrad Meyer                                     const char* outFileName,
1580c16b537SWarner Losh                                     const char* dictFileName);
1590c16b537SWarner Losh 
1609cbefe25SConrad Meyer /* FIO_checkFilenameCollisions() :
1619cbefe25SConrad Meyer  * Checks for and warns if there are any files that would have the same output path
1629cbefe25SConrad Meyer  */
1639cbefe25SConrad Meyer int FIO_checkFilenameCollisions(const char** filenameTable, unsigned nbFiles);
1649cbefe25SConrad Meyer 
1659cbefe25SConrad Meyer 
1660c16b537SWarner Losh 
1670f743729SConrad Meyer /*-*************************************
1680f743729SConrad Meyer *  Advanced stuff (should actually be hosted elsewhere)
1690f743729SConrad Meyer ***************************************/
1700f743729SConrad Meyer 
1710f743729SConrad Meyer /* custom crash signal handler */
1720f743729SConrad Meyer void FIO_addAbortHandler(void);
1730f743729SConrad Meyer 
1740f743729SConrad Meyer 
1750f743729SConrad Meyer 
1760c16b537SWarner Losh #if defined (__cplusplus)
1770c16b537SWarner Losh }
1780c16b537SWarner Losh #endif
1790c16b537SWarner Losh 
1800c16b537SWarner Losh #endif  /* FILEIO_H_23981798732 */
181