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