fileio.h 7.1 KB

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