-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathcommandline.h
201 lines (160 loc) · 7.89 KB
/
commandline.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
// This file is part of par2cmdline (a PAR 2.0 compatible file verification and
// repair tool). See http://parchive.sourceforge.net for details of PAR 2.0.
//
// Copyright (c) 2003 Peter Brian Clements
//
// par2cmdline is free software; you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation; either version 2 of the License, or
// (at your option) any later version.
//
// par2cmdline is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
//
// Modifications for concurrent processing, Unicode support, and hierarchial
// directory support are Copyright (c) 2007-2008 Vincent Tan.
// Search for "#if WANT_CONCURRENT" for concurrent code.
// Concurrent processing utilises Intel Thread Building Blocks 2.0,
// Copyright (c) 2007 Intel Corp.
#ifndef __COMMANDLINE_H__
#define __COMMANDLINE_H__
// The CommandLine object is responsible for understanding the format
// of the command line parameters are parsing the command line to
// extract details as to what the user wants to do.
class CommandLine
{
static CommandLine* sInstance;
public:
static CommandLine* get(void);
static string FileOrPathForCout(const string& path);
CommandLine(void);
~CommandLine(void);
// Parse the supplied command line arguments.
bool Parse(int argc, TCHAR *argv[]);
// Display details of the correct format for command line parameters.
static void usage(void);
// What operation will we be carrying out
typedef enum
{
opNone = 0,
opCreate, // Create new PAR2 recovery volumes
opVerify, // Verify but don't repair damaged data files
opRepair // Verify and if possible repair damaged data files
} Operation;
typedef enum
{
verUnknown = 0,
verPar1, // Processing PAR 1.0 files
verPar2 // Processing PAR 2.0 files
} Version;
typedef enum
{
scUnknown = 0,
scVariable, // Each PAR2 file will have 2x as many blocks as previous
scLimited, // Limit PAR2 file size
scUniform // All PAR2 files the same size
} Scheme;
typedef enum
{
nlUnknown = 0,
nlSilent, // Absolutely no output (other than errors)
nlQuiet, // Bare minimum of output
nlNormal, // Normal level of output
nlNoisy, // Lots of output
nlDebug // Extra debugging information
} NoiseLevel;
// Any extra files listed on the command line
class ExtraFile
{
public:
ExtraFile(void);
ExtraFile(const ExtraFile&);
ExtraFile& operator=(const ExtraFile&);
ExtraFile(const string &name, u64 size);
const string &FileName(void) const {return filename;}
u64 FileSize(void) const {return filesize;}
protected:
string filename;
u64 filesize;
};
public:
// Accessor functions for the command line parameters
CommandLine::Operation GetOperation(void) const {return operation;}
CommandLine::Version GetVersion(void) const {return version;}
u64 GetBlockSize(void) const {return blocksize;}
u32 GetBlockCount(void) const {return blockcount;}
float GetRedundancy(void) const {return redundancy;}
u32 GetFirstRecoveryBlock(void) const {return firstblock;}
u32 GetRecoveryFileCount(void) const {return recoveryfilecount;}
u32 GetRecoveryBlockCount(void) const {return recoveryblockcount;}
CommandLine::Scheme GetRecoveryFileScheme(void) const {return recoveryfilescheme;}
size_t GetMemoryLimit(void) const {return memorylimit;}
u64 GetLargestSourceSize(void) const {return largestsourcesize;}
u64 GetTotalSourceSize(void) const {return totalsourcesize;}
CommandLine::NoiseLevel GetNoiseLevel(void) const {return noiselevel;}
u32 GetOpeningMessageLimit(void) const{return opening_message_limit;}
// 2007/10/21 for hierarchial support:
const string& GetBaseDirectory(void) const {return base_directory;}
#if WANT_CONCURRENT
concurrency_processing_t GetConcurrentProcessingLevel(void) const { return concurrent_processing_level; }
#endif
bool GetCreateDummyParFiles(void) const { return create_dummy_par_files; }
string GetParFilename(void) const {return parfilename;}
const list<CommandLine::ExtraFile>& GetExtraFiles(void) const {return extrafiles;}
protected:
Operation operation; // The operation to be carried out.
Version version; // What version files will be processed.
NoiseLevel noiselevel; // How much display output should there be.
u32 opening_message_limit; // How many "Opening:" messages to display on creation; default is 200; 0 for no limit
u32 blockcount; // How many blocks the source files should
// be virtually split into.
u64 blocksize; // What virtual block size to use.
u32 firstblock; // What the exponent value for the first
// recovery block will be.
Scheme recoveryfilescheme; // How the the size of the recovery files should
// be calculated.
u32 recoveryfilecount; // How many recovery files should be created.
u32 recoveryblockcount; // How many recovery blocks should be created.
bool recoveryblockcountset; // Set if the recoveryblockcount as been specified
float redundancy; // What percentage of recovery data should
// be created.
bool redundancyset; // Set if the redundancy has been specified
string parfilename; // The name of the PAR2 file to create, or
// the name of the first PAR2 file to read
// when verifying or repairing.
list<ExtraFile> extrafiles; // The list of other files specified on the
// command line. When creating, this will be
// the source files, and when verifying or
// repairing, this will be additional PAR2
// files or data files to be examined.
u64 totalsourcesize; // Total size of the source files.
u64 largestsourcesize; // Size of the largest source file.
size_t memorylimit; // How much memory is permitted to be used
// for the output buffer when creating
// or repairing.
// 2007/10/21 - added this to support hierarchial repair (eg, to protect a
// hierarchy of folders of jpg files)
// if non-empty then this is the base directory for paths stored in par2
// files to support hierarchial repair
string base_directory;
#if WANT_CONCURRENT
#if 1
// see definition of concurrency_processing_t for details
concurrency_processing_t concurrent_processing_level; // 2014/10/07
#elif 0
// although it is possible to specify how many threads that TBB should
// use, that functionality is not implemented (and the TBB documentation
// recommends not using it in production code), so this is merely a bool:
unsigned concurrent_processing_level; // whether to process serially or concurrently
#endif
#endif
bool create_dummy_par_files; // so that final par2 size can be determined
};
typedef list<CommandLine::ExtraFile>::const_iterator ExtraFileIterator;
#endif // __COMMANDLINE_H__