1*27162e4eSAndroid Build Coastguard Worker /* 2*27162e4eSAndroid Build Coastguard Worker LZ4io.h - LZ4 File/Stream Interface 3*27162e4eSAndroid Build Coastguard Worker Copyright (C) Yann Collet 2011-2023 4*27162e4eSAndroid Build Coastguard Worker GPL v2 License 5*27162e4eSAndroid Build Coastguard Worker 6*27162e4eSAndroid Build Coastguard Worker This program is free software; you can redistribute it and/or modify 7*27162e4eSAndroid Build Coastguard Worker it under the terms of the GNU General Public License as published by 8*27162e4eSAndroid Build Coastguard Worker the Free Software Foundation; either version 2 of the License, or 9*27162e4eSAndroid Build Coastguard Worker (at your option) any later version. 10*27162e4eSAndroid Build Coastguard Worker 11*27162e4eSAndroid Build Coastguard Worker This program is distributed in the hope that it will be useful, 12*27162e4eSAndroid Build Coastguard Worker but WITHOUT ANY WARRANTY; without even the implied warranty of 13*27162e4eSAndroid Build Coastguard Worker MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 14*27162e4eSAndroid Build Coastguard Worker GNU General Public License for more details. 15*27162e4eSAndroid Build Coastguard Worker 16*27162e4eSAndroid Build Coastguard Worker You should have received a copy of the GNU General Public License along 17*27162e4eSAndroid Build Coastguard Worker with this program; if not, write to the Free Software Foundation, Inc., 18*27162e4eSAndroid Build Coastguard Worker 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. 19*27162e4eSAndroid Build Coastguard Worker 20*27162e4eSAndroid Build Coastguard Worker You can contact the author at : 21*27162e4eSAndroid Build Coastguard Worker - LZ4 source repository : https://github.com/lz4/lz4 22*27162e4eSAndroid Build Coastguard Worker - LZ4 public forum : https://groups.google.com/forum/#!forum/lz4c 23*27162e4eSAndroid Build Coastguard Worker */ 24*27162e4eSAndroid Build Coastguard Worker /* 25*27162e4eSAndroid Build Coastguard Worker Note : this is stand-alone program. 26*27162e4eSAndroid Build Coastguard Worker It is not part of LZ4 compression library, it is a user code of the LZ4 library. 27*27162e4eSAndroid Build Coastguard Worker - The license of LZ4 library is BSD. 28*27162e4eSAndroid Build Coastguard Worker - The license of xxHash library is BSD. 29*27162e4eSAndroid Build Coastguard Worker - The license of this source file is GPLv2. 30*27162e4eSAndroid Build Coastguard Worker */ 31*27162e4eSAndroid Build Coastguard Worker 32*27162e4eSAndroid Build Coastguard Worker #ifndef LZ4IO_H_237902873 33*27162e4eSAndroid Build Coastguard Worker #define LZ4IO_H_237902873 34*27162e4eSAndroid Build Coastguard Worker 35*27162e4eSAndroid Build Coastguard Worker /*--- Dependency ---*/ 36*27162e4eSAndroid Build Coastguard Worker #include <stddef.h> /* size_t */ 37*27162e4eSAndroid Build Coastguard Worker 38*27162e4eSAndroid Build Coastguard Worker 39*27162e4eSAndroid Build Coastguard Worker /* ************************************************** */ 40*27162e4eSAndroid Build Coastguard Worker /* Special input/output values */ 41*27162e4eSAndroid Build Coastguard Worker /* ************************************************** */ 42*27162e4eSAndroid Build Coastguard Worker #define stdinmark "stdin" 43*27162e4eSAndroid Build Coastguard Worker #define stdoutmark "stdout" 44*27162e4eSAndroid Build Coastguard Worker #define NULL_OUTPUT "null" 45*27162e4eSAndroid Build Coastguard Worker #ifdef _WIN32 46*27162e4eSAndroid Build Coastguard Worker #define nulmark "nul" 47*27162e4eSAndroid Build Coastguard Worker #else 48*27162e4eSAndroid Build Coastguard Worker #define nulmark "/dev/null" 49*27162e4eSAndroid Build Coastguard Worker #endif 50*27162e4eSAndroid Build Coastguard Worker 51*27162e4eSAndroid Build Coastguard Worker /* ************************************************** */ 52*27162e4eSAndroid Build Coastguard Worker /* ****************** Type Definitions ************** */ 53*27162e4eSAndroid Build Coastguard Worker /* ************************************************** */ 54*27162e4eSAndroid Build Coastguard Worker 55*27162e4eSAndroid Build Coastguard Worker typedef struct LZ4IO_prefs_s LZ4IO_prefs_t; 56*27162e4eSAndroid Build Coastguard Worker 57*27162e4eSAndroid Build Coastguard Worker LZ4IO_prefs_t* LZ4IO_defaultPreferences(void); 58*27162e4eSAndroid Build Coastguard Worker void LZ4IO_freePreferences(LZ4IO_prefs_t* prefs); 59*27162e4eSAndroid Build Coastguard Worker 60*27162e4eSAndroid Build Coastguard Worker 61*27162e4eSAndroid Build Coastguard Worker /* *************************************************** */ 62*27162e4eSAndroid Build Coastguard Worker /* ****************** Processing ********************* */ 63*27162e4eSAndroid Build Coastguard Worker /* *************************************************** */ 64*27162e4eSAndroid Build Coastguard Worker 65*27162e4eSAndroid Build Coastguard Worker /* if output_filename == stdoutmark, writes to stdout */ 66*27162e4eSAndroid Build Coastguard Worker int LZ4IO_compressFilename(const char* input_filename, const char* output_filename, int compressionlevel, const LZ4IO_prefs_t* prefs); 67*27162e4eSAndroid Build Coastguard Worker int LZ4IO_decompressFilename(const char* input_filename, const char* output_filename, const LZ4IO_prefs_t* prefs); 68*27162e4eSAndroid Build Coastguard Worker 69*27162e4eSAndroid Build Coastguard Worker /* if suffix == stdoutmark, writes to stdout */ 70*27162e4eSAndroid Build Coastguard Worker int LZ4IO_compressMultipleFilenames(const char** inFileNamesTable, int ifntSize, const char* suffix, int compressionlevel, const LZ4IO_prefs_t* prefs); 71*27162e4eSAndroid Build Coastguard Worker int LZ4IO_decompressMultipleFilenames(const char** inFileNamesTable, int ifntSize, const char* suffix, const LZ4IO_prefs_t* prefs); 72*27162e4eSAndroid Build Coastguard Worker 73*27162e4eSAndroid Build Coastguard Worker 74*27162e4eSAndroid Build Coastguard Worker /* ************************************************** */ 75*27162e4eSAndroid Build Coastguard Worker /* ****************** Parameters ******************** */ 76*27162e4eSAndroid Build Coastguard Worker /* ************************************************** */ 77*27162e4eSAndroid Build Coastguard Worker 78*27162e4eSAndroid Build Coastguard Worker int LZ4IO_setNbWorkers(LZ4IO_prefs_t* const prefs, int nbWorkers); 79*27162e4eSAndroid Build Coastguard Worker int LZ4IO_defaultNbWorkers(void); 80*27162e4eSAndroid Build Coastguard Worker 81*27162e4eSAndroid Build Coastguard Worker int LZ4IO_setDictionaryFilename(LZ4IO_prefs_t* const prefs, const char* dictionaryFilename); 82*27162e4eSAndroid Build Coastguard Worker 83*27162e4eSAndroid Build Coastguard Worker /* Default setting : passThrough = 0; 84*27162e4eSAndroid Build Coastguard Worker return : passThrough mode (0/1) */ 85*27162e4eSAndroid Build Coastguard Worker int LZ4IO_setPassThrough(LZ4IO_prefs_t* const prefs, int yes); 86*27162e4eSAndroid Build Coastguard Worker 87*27162e4eSAndroid Build Coastguard Worker /* Default setting : overwrite = 1; 88*27162e4eSAndroid Build Coastguard Worker return : overwrite mode (0/1) */ 89*27162e4eSAndroid Build Coastguard Worker int LZ4IO_setOverwrite(LZ4IO_prefs_t* const prefs, int yes); 90*27162e4eSAndroid Build Coastguard Worker 91*27162e4eSAndroid Build Coastguard Worker /* Default setting : testMode = 0; 92*27162e4eSAndroid Build Coastguard Worker return : testMode (0/1) */ 93*27162e4eSAndroid Build Coastguard Worker int LZ4IO_setTestMode(LZ4IO_prefs_t* const prefs, int yes); 94*27162e4eSAndroid Build Coastguard Worker 95*27162e4eSAndroid Build Coastguard Worker /* blockSizeID : valid values : 4-5-6-7 96*27162e4eSAndroid Build Coastguard Worker return : 0 if error, blockSize if OK */ 97*27162e4eSAndroid Build Coastguard Worker size_t LZ4IO_setBlockSizeID(LZ4IO_prefs_t* const prefs, unsigned blockSizeID); 98*27162e4eSAndroid Build Coastguard Worker 99*27162e4eSAndroid Build Coastguard Worker /* blockSize : valid values : 32 -> 4MB 100*27162e4eSAndroid Build Coastguard Worker return : 0 if error, actual blocksize if OK */ 101*27162e4eSAndroid Build Coastguard Worker size_t LZ4IO_setBlockSize(LZ4IO_prefs_t* const prefs, size_t blockSize); 102*27162e4eSAndroid Build Coastguard Worker 103*27162e4eSAndroid Build Coastguard Worker /* Default setting : independent blocks */ 104*27162e4eSAndroid Build Coastguard Worker typedef enum { LZ4IO_blockLinked=0, LZ4IO_blockIndependent} LZ4IO_blockMode_t; 105*27162e4eSAndroid Build Coastguard Worker int LZ4IO_setBlockMode(LZ4IO_prefs_t* const prefs, LZ4IO_blockMode_t blockMode); 106*27162e4eSAndroid Build Coastguard Worker 107*27162e4eSAndroid Build Coastguard Worker /* Default setting : no block checksum */ 108*27162e4eSAndroid Build Coastguard Worker int LZ4IO_setBlockChecksumMode(LZ4IO_prefs_t* const prefs, int xxhash); 109*27162e4eSAndroid Build Coastguard Worker 110*27162e4eSAndroid Build Coastguard Worker /* Default setting : stream checksum enabled */ 111*27162e4eSAndroid Build Coastguard Worker int LZ4IO_setStreamChecksumMode(LZ4IO_prefs_t* const prefs, int xxhash); 112*27162e4eSAndroid Build Coastguard Worker 113*27162e4eSAndroid Build Coastguard Worker /* Default setting : 0 (no notification) */ 114*27162e4eSAndroid Build Coastguard Worker int LZ4IO_setNotificationLevel(int level); 115*27162e4eSAndroid Build Coastguard Worker 116*27162e4eSAndroid Build Coastguard Worker /* Default setting : 0 (disabled) */ 117*27162e4eSAndroid Build Coastguard Worker int LZ4IO_setSparseFile(LZ4IO_prefs_t* const prefs, int enable); 118*27162e4eSAndroid Build Coastguard Worker 119*27162e4eSAndroid Build Coastguard Worker /* Default setting : 0 == no content size present in frame header */ 120*27162e4eSAndroid Build Coastguard Worker int LZ4IO_setContentSize(LZ4IO_prefs_t* const prefs, int enable); 121*27162e4eSAndroid Build Coastguard Worker 122*27162e4eSAndroid Build Coastguard Worker /* Default setting : 0 == src file preserved */ 123*27162e4eSAndroid Build Coastguard Worker void LZ4IO_setRemoveSrcFile(LZ4IO_prefs_t* const prefs, unsigned flag); 124*27162e4eSAndroid Build Coastguard Worker 125*27162e4eSAndroid Build Coastguard Worker /* Default setting : 0 == favor compression ratio 126*27162e4eSAndroid Build Coastguard Worker * Note : 1 only works for high compression levels (10+) */ 127*27162e4eSAndroid Build Coastguard Worker void LZ4IO_favorDecSpeed(LZ4IO_prefs_t* const prefs, int favor); 128*27162e4eSAndroid Build Coastguard Worker 129*27162e4eSAndroid Build Coastguard Worker 130*27162e4eSAndroid Build Coastguard Worker /* implement --list 131*27162e4eSAndroid Build Coastguard Worker * @return 0 on success, 1 on error */ 132*27162e4eSAndroid Build Coastguard Worker int LZ4IO_displayCompressedFilesInfo(const char** inFileNames, size_t ifnIdx); 133*27162e4eSAndroid Build Coastguard Worker 134*27162e4eSAndroid Build Coastguard Worker 135*27162e4eSAndroid Build Coastguard Worker #endif /* LZ4IO_H_237902873 */ 136