xref: /netbsd-src/external/bsd/zstd/dist/programs/fileio.h (revision 3117ece4fc4a4ca4489ba793710b60b0d26bab6c)
1*3117ece4Schristos /*
2*3117ece4Schristos  * Copyright (c) Meta Platforms, Inc. and affiliates.
3*3117ece4Schristos  * All rights reserved.
4*3117ece4Schristos  *
5*3117ece4Schristos  * This source code is licensed under both the BSD-style license (found in the
6*3117ece4Schristos  * LICENSE file in the root directory of this source tree) and the GPLv2 (found
7*3117ece4Schristos  * in the COPYING file in the root directory of this source tree).
8*3117ece4Schristos  * You may select, at your option, one of the above-listed licenses.
9*3117ece4Schristos  */
10*3117ece4Schristos 
11*3117ece4Schristos 
12*3117ece4Schristos #ifndef FILEIO_H_23981798732
13*3117ece4Schristos #define FILEIO_H_23981798732
14*3117ece4Schristos 
15*3117ece4Schristos #include "fileio_types.h"
16*3117ece4Schristos #include "util.h"                  /* FileNamesTable */
17*3117ece4Schristos #define ZSTD_STATIC_LINKING_ONLY   /* ZSTD_compressionParameters */
18*3117ece4Schristos #include "../lib/zstd.h"           /* ZSTD_* */
19*3117ece4Schristos 
20*3117ece4Schristos #if defined (__cplusplus)
21*3117ece4Schristos extern "C" {
22*3117ece4Schristos #endif
23*3117ece4Schristos 
24*3117ece4Schristos 
25*3117ece4Schristos /* *************************************
26*3117ece4Schristos *  Special i/o constants
27*3117ece4Schristos **************************************/
28*3117ece4Schristos #define stdinmark  "/*stdin*\\"
29*3117ece4Schristos #define stdoutmark "/*stdout*\\"
30*3117ece4Schristos #ifdef _WIN32
31*3117ece4Schristos #  define nulmark "NUL"
32*3117ece4Schristos #else
33*3117ece4Schristos #  define nulmark "/dev/null"
34*3117ece4Schristos #endif
35*3117ece4Schristos 
36*3117ece4Schristos /**
37*3117ece4Schristos  * We test whether the extension we found starts with 't', and if so, we append
38*3117ece4Schristos  * ".tar" to the end of the output name.
39*3117ece4Schristos  */
40*3117ece4Schristos #define LZMA_EXTENSION  ".lzma"
41*3117ece4Schristos #define XZ_EXTENSION    ".xz"
42*3117ece4Schristos #define TXZ_EXTENSION   ".txz"
43*3117ece4Schristos 
44*3117ece4Schristos #define GZ_EXTENSION    ".gz"
45*3117ece4Schristos #define TGZ_EXTENSION   ".tgz"
46*3117ece4Schristos 
47*3117ece4Schristos #define ZSTD_EXTENSION  ".zst"
48*3117ece4Schristos #define TZSTD_EXTENSION ".tzst"
49*3117ece4Schristos #define ZSTD_ALT_EXTENSION  ".zstd" /* allow decompression of .zstd files */
50*3117ece4Schristos 
51*3117ece4Schristos #define LZ4_EXTENSION   ".lz4"
52*3117ece4Schristos #define TLZ4_EXTENSION  ".tlz4"
53*3117ece4Schristos 
54*3117ece4Schristos 
55*3117ece4Schristos /*-*************************************
56*3117ece4Schristos *  Types
57*3117ece4Schristos ***************************************/
58*3117ece4Schristos FIO_prefs_t* FIO_createPreferences(void);
59*3117ece4Schristos void FIO_freePreferences(FIO_prefs_t* const prefs);
60*3117ece4Schristos 
61*3117ece4Schristos /* Mutable struct containing relevant context and state regarding (de)compression with respect to file I/O */
62*3117ece4Schristos typedef struct FIO_ctx_s FIO_ctx_t;
63*3117ece4Schristos 
64*3117ece4Schristos FIO_ctx_t* FIO_createContext(void);
65*3117ece4Schristos void FIO_freeContext(FIO_ctx_t* const fCtx);
66*3117ece4Schristos 
67*3117ece4Schristos 
68*3117ece4Schristos /*-*************************************
69*3117ece4Schristos *  Parameters
70*3117ece4Schristos ***************************************/
71*3117ece4Schristos /* FIO_prefs_t functions */
72*3117ece4Schristos void FIO_setCompressionType(FIO_prefs_t* const prefs, FIO_compressionType_t compressionType);
73*3117ece4Schristos void FIO_overwriteMode(FIO_prefs_t* const prefs);
74*3117ece4Schristos void FIO_setAdaptiveMode(FIO_prefs_t* const prefs, int adapt);
75*3117ece4Schristos void FIO_setAdaptMin(FIO_prefs_t* const prefs, int minCLevel);
76*3117ece4Schristos void FIO_setAdaptMax(FIO_prefs_t* const prefs, int maxCLevel);
77*3117ece4Schristos void FIO_setUseRowMatchFinder(FIO_prefs_t* const prefs, int useRowMatchFinder);
78*3117ece4Schristos void FIO_setBlockSize(FIO_prefs_t* const prefs, int blockSize);
79*3117ece4Schristos void FIO_setChecksumFlag(FIO_prefs_t* const prefs, int checksumFlag);
80*3117ece4Schristos void FIO_setDictIDFlag(FIO_prefs_t* const prefs, int dictIDFlag);
81*3117ece4Schristos void FIO_setLdmBucketSizeLog(FIO_prefs_t* const prefs, int ldmBucketSizeLog);
82*3117ece4Schristos void FIO_setLdmFlag(FIO_prefs_t* const prefs, unsigned ldmFlag);
83*3117ece4Schristos void FIO_setLdmHashRateLog(FIO_prefs_t* const prefs, int ldmHashRateLog);
84*3117ece4Schristos void FIO_setLdmHashLog(FIO_prefs_t* const prefs, int ldmHashLog);
85*3117ece4Schristos void FIO_setLdmMinMatch(FIO_prefs_t* const prefs, int ldmMinMatch);
86*3117ece4Schristos void FIO_setMemLimit(FIO_prefs_t* const prefs, unsigned memLimit);
87*3117ece4Schristos void FIO_setNbWorkers(FIO_prefs_t* const prefs, int nbWorkers);
88*3117ece4Schristos void FIO_setOverlapLog(FIO_prefs_t* const prefs, int overlapLog);
89*3117ece4Schristos void FIO_setRemoveSrcFile(FIO_prefs_t* const prefs, int flag);
90*3117ece4Schristos void FIO_setSparseWrite(FIO_prefs_t* const prefs, int sparse);  /**< 0: no sparse; 1: disable on stdout; 2: always enabled */
91*3117ece4Schristos void FIO_setRsyncable(FIO_prefs_t* const prefs, int rsyncable);
92*3117ece4Schristos void FIO_setStreamSrcSize(FIO_prefs_t* const prefs, size_t streamSrcSize);
93*3117ece4Schristos void FIO_setTargetCBlockSize(FIO_prefs_t* const prefs, size_t targetCBlockSize);
94*3117ece4Schristos void FIO_setSrcSizeHint(FIO_prefs_t* const prefs, size_t srcSizeHint);
95*3117ece4Schristos void FIO_setTestMode(FIO_prefs_t* const prefs, int testMode);
96*3117ece4Schristos void FIO_setLiteralCompressionMode(
97*3117ece4Schristos         FIO_prefs_t* const prefs,
98*3117ece4Schristos         ZSTD_paramSwitch_e mode);
99*3117ece4Schristos 
100*3117ece4Schristos void FIO_setProgressSetting(FIO_progressSetting_e progressSetting);
101*3117ece4Schristos void FIO_setNotificationLevel(int level);
102*3117ece4Schristos void FIO_setExcludeCompressedFile(FIO_prefs_t* const prefs, int excludeCompressedFiles);
103*3117ece4Schristos void FIO_setAllowBlockDevices(FIO_prefs_t* const prefs, int allowBlockDevices);
104*3117ece4Schristos void FIO_setPatchFromMode(FIO_prefs_t* const prefs, int value);
105*3117ece4Schristos void FIO_setContentSize(FIO_prefs_t* const prefs, int value);
106*3117ece4Schristos void FIO_displayCompressionParameters(const FIO_prefs_t* prefs);
107*3117ece4Schristos void FIO_setAsyncIOFlag(FIO_prefs_t* const prefs, int value);
108*3117ece4Schristos void FIO_setPassThroughFlag(FIO_prefs_t* const prefs, int value);
109*3117ece4Schristos void FIO_setMMapDict(FIO_prefs_t* const prefs, ZSTD_paramSwitch_e value);
110*3117ece4Schristos 
111*3117ece4Schristos /* FIO_ctx_t functions */
112*3117ece4Schristos void FIO_setNbFilesTotal(FIO_ctx_t* const fCtx, int value);
113*3117ece4Schristos void FIO_setHasStdoutOutput(FIO_ctx_t* const fCtx, int value);
114*3117ece4Schristos void FIO_determineHasStdinInput(FIO_ctx_t* const fCtx, const FileNamesTable* const filenames);
115*3117ece4Schristos 
116*3117ece4Schristos /*-*************************************
117*3117ece4Schristos *  Single File functions
118*3117ece4Schristos ***************************************/
119*3117ece4Schristos /** FIO_compressFilename() :
120*3117ece4Schristos  * @return : 0 == ok;  1 == pb with src file. */
121*3117ece4Schristos int FIO_compressFilename (FIO_ctx_t* const fCtx, FIO_prefs_t* const prefs,
122*3117ece4Schristos                           const char* outfilename, const char* infilename,
123*3117ece4Schristos                           const char* dictFileName, int compressionLevel,
124*3117ece4Schristos                           ZSTD_compressionParameters comprParams);
125*3117ece4Schristos 
126*3117ece4Schristos /** FIO_decompressFilename() :
127*3117ece4Schristos  * @return : 0 == ok;  1 == pb with src file. */
128*3117ece4Schristos int FIO_decompressFilename (FIO_ctx_t* const fCtx, FIO_prefs_t* const prefs,
129*3117ece4Schristos                             const char* outfilename, const char* infilename, const char* dictFileName);
130*3117ece4Schristos 
131*3117ece4Schristos int FIO_listMultipleFiles(unsigned numFiles, const char** filenameTable, int displayLevel);
132*3117ece4Schristos 
133*3117ece4Schristos 
134*3117ece4Schristos /*-*************************************
135*3117ece4Schristos *  Multiple File functions
136*3117ece4Schristos ***************************************/
137*3117ece4Schristos /** FIO_compressMultipleFilenames() :
138*3117ece4Schristos  * @return : nb of missing files */
139*3117ece4Schristos int FIO_compressMultipleFilenames(FIO_ctx_t* const fCtx,
140*3117ece4Schristos                                   FIO_prefs_t* const prefs,
141*3117ece4Schristos                                   const char** inFileNamesTable,
142*3117ece4Schristos                                   const char* outMirroredDirName,
143*3117ece4Schristos                                   const char* outDirName,
144*3117ece4Schristos                                   const char* outFileName, const char* suffix,
145*3117ece4Schristos                                   const char* dictFileName, int compressionLevel,
146*3117ece4Schristos                                   ZSTD_compressionParameters comprParams);
147*3117ece4Schristos 
148*3117ece4Schristos /** FIO_decompressMultipleFilenames() :
149*3117ece4Schristos  * @return : nb of missing or skipped files */
150*3117ece4Schristos int FIO_decompressMultipleFilenames(FIO_ctx_t* const fCtx,
151*3117ece4Schristos                                     FIO_prefs_t* const prefs,
152*3117ece4Schristos                                     const char** srcNamesTable,
153*3117ece4Schristos                                     const char* outMirroredDirName,
154*3117ece4Schristos                                     const char* outDirName,
155*3117ece4Schristos                                     const char* outFileName,
156*3117ece4Schristos                                     const char* dictFileName);
157*3117ece4Schristos 
158*3117ece4Schristos /* FIO_checkFilenameCollisions() :
159*3117ece4Schristos  * Checks for and warns if there are any files that would have the same output path
160*3117ece4Schristos  */
161*3117ece4Schristos int FIO_checkFilenameCollisions(const char** filenameTable, unsigned nbFiles);
162*3117ece4Schristos 
163*3117ece4Schristos 
164*3117ece4Schristos 
165*3117ece4Schristos /*-*************************************
166*3117ece4Schristos *  Advanced stuff (should actually be hosted elsewhere)
167*3117ece4Schristos ***************************************/
168*3117ece4Schristos 
169*3117ece4Schristos /* custom crash signal handler */
170*3117ece4Schristos void FIO_addAbortHandler(void);
171*3117ece4Schristos 
172*3117ece4Schristos char const* FIO_zlibVersion(void);
173*3117ece4Schristos char const* FIO_lz4Version(void);
174*3117ece4Schristos char const* FIO_lzmaVersion(void);
175*3117ece4Schristos 
176*3117ece4Schristos 
177*3117ece4Schristos #if defined (__cplusplus)
178*3117ece4Schristos }
179*3117ece4Schristos #endif
180*3117ece4Schristos 
181*3117ece4Schristos #endif  /* FILEIO_H_23981798732 */
182