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