xref: /aosp_15_r20/external/lz4/programs/lz4io.h (revision 27162e4e17433d5aa7cb38e7b6a433a09405fc7f)
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