26 #ifndef COMMAND_LINE_HPP 27 #define COMMAND_LINE_HPP 29 #include "../my_config.h" 41 enum operation { noop, extract, create, diff, test, listing, isolate, merging, version_or_help, repairing };
45 enum dirty_behavior { dirtyb_ignore, dirtyb_warn, dirtyb_ok };
59 { ent_proto.clear(); ent_login.clear(); ent_pass.
clear();
60 ent_host.clear(); ent_port.clear(); network_retry = 3;
61 auth_from_file =
false; };
177 ref_filename =
nullptr;
179 compress_mask =
nullptr;
181 aux_filename =
nullptr;
183 backup_hook_mask =
nullptr;
189 if(fs_root !=
nullptr)
191 if(sauv_root !=
nullptr)
193 if(ref_root !=
nullptr)
195 if(selection !=
nullptr)
197 if(subtree !=
nullptr)
199 if(ref_filename !=
nullptr)
201 if(ea_mask !=
nullptr)
203 if(compress_mask !=
nullptr)
204 delete compress_mask;
205 if(aux_root !=
nullptr)
207 if(aux_filename !=
nullptr)
209 if(overwrite !=
nullptr)
211 if(backup_hook_mask !=
nullptr)
212 delete backup_hook_mask;
218 extern bool get_args(shared_ptr<user_interaction> & dialog,
220 const deque<string> & dar_dcf_path,
221 const deque<string> & dar_duc_path,
228 const struct option *get_long_opt();
231 const char *get_short_opt();
comparison_fields
how to consider file change during comparison and incremental backup
modified_data_detection modet
how to detect that a file has changed since the archive of reference was done
infinint first_file_size
sice of the first slice to create
hash_algo kdf_hash
hash algo used for key derivation function
infinint sparse_file_min_size
minimum size of a zeroed byte sequence to be considered as a hole and stored this way in the archive ...
all parameters retreived from command-line
bool lax
whether to activate the last chance recovery mode (use with caution!)
the generic class, parent of all masks
bool quiet
whether to display final summary for the operation
bool delta_sig
whether to calculate rsync signature of files
string input_pipe
if not an empty string, name of the pipe through which to read data from dar_slave ...
bool sizes_in_bytes
whether to display sizes in bytes of to the larges unit (Mo, Go, To,...)
bool info_details
whether to show processing messages
delta_sig_block_size delta_sig_len
block len to used for delta signature computation
infinint num_digits
minimum number of decimal for the slice number
string backup_hook_execute
which command to execute as backup hook
string slice_user
user to set when creating a slice
U_I network_retry
libcurl entrepot network retry time
bool cache_directory_tagging
whether to ignore directory contents where a the cache directory tagging files is found ...
U_32 crypto_size_ref
block size by which to uncypher data from the archive of reference
infinint delta_sig_min_size
size below which to never calculate delta signatures
infinint hourshift
consider equal two dates that have an integer hour of difference equal or less than hourshift ...
bool only_deleted
whether to only consider deleted files
mask * delta_mask
which file to calculate delta sig when not using the default mask
bool same_fs
whether to stick to a same filesystem
string * ref_filename
basename of the archive of reference (nullptr => no archive of reference)
bool alter_atime
whether to reset the atime of file read during backup to their original value (resetting atime does m...
path * fs_root
filesystem root
bool snapshot
whether to perform a snapshot backup
string slice_group
group to set when creating a slice
bool multi_threaded
allows libdar to use multiple threads (requires libthreadar)
defines how to calculate delta signature block size based of file size to delta sign ...
string filename
basename of the archive to operate on
entrepot relative parameters
string execute_ref
if not an empty string, the command to execute between slices of the archive of reference ...
U_32 aux_crypto_size
block size by which to cypher/uncypher data to/from the auxiliary archive of reference ...
string ignored_as_symlink
column separated list of absolute paths of links to follow rather to record as such ...
operation op
which operation to perform
fsa_scope scope
FSA scope to consider for the operation.
bool empty_dir
whether to store skipped directories as empty, whether to avoid restoring directory where no data is ...
ent_params remote
remote entrepot coordinates
bool keep_compressed
when merging, whether to not uncompress/re-compress data in the process
vector< string > signatories
list of email's key to use to sign the archive
bool display_finished
whether to display summary (space/compression ratio) for each completed directory ...
string ent_proto
entrepot protocol
archive_options_listing_shell::listformat list_mode
type of listing to follow
mask * backup_hook_mask
which file have to considered for backup hook
bool display_skipped
whether to display skipped files
infinint pause
whether to pause between slices
bool furtive_read_mode
whether to use the furtive read mode
string execute
if not an empty string, the command to execute between slices
bool filter_unsaved
whether to not list files that are not saved in the archive
string output_pipe
if not an empty string, name of the pipe through which to write orders to dar_slave ...
infinint aux_num_digits
minimum number of decimal for the slice number of the auxiliary archive of reference ...
mask * subtree
filter files for the operation based on path+filename
secu_string ent_pass
entrepot password
bool beep
whether to ring the terminal upon user interaction request
mask * ea_mask
which EA to work on
infinint fixed_date
the data for the snapshot backup
bool allow_over
whether to allow slice overwriting
path * sauv_root
where is the archive to operate on (create, read, etc.)
bool sequential_read
whether to follow escape sequential marks to achieve a sequential reading of the archive ...
secu_string aux_pass
crypto to use for the auxiliary archive
const crit_action * overwrite
the overwriting policy
string ent_host
entrepot hostname
bool not_deleted
whether to ignore deleted files
bool display_treated_only_dir
whether to show treated files's current working directory
void clear()
clear the string (set to an empty string)
bool display_masks
whether to display masks value
the global action for overwriting
U_I compression_level
compression level to use when generating an archive
bool warn_over
whether to warn before overwriting files or slices
bool nodump
whether to ignore files having the "nodump" flag set when performing a backup
bool no_compare_symlink_date
whether to report difference in dates of symlinks while diffing an archive with filesystem ...
U_32 crypto_size
block size by which to cypher data
string ea_name_for_exclusion
EA name to use for file exclusion, or empty string for the default EA name.
bool delta_diff
whether to save binary diff or whole file's data during a differential backup
mask * selection
filter files for the operation based on filename only
bool zeroing_neg_dates
whether to automatically zeroing negative dates while reading inode from filesystem ...
std::set< fsa_family > fsa_scope
set of fsa families
ent_params ref_remote
remote entrepot coordinates for archive of reference
compression algo
compression algorithm to use when generating an archive
bool decremental
whether to produce a decremental backup (when merging)
bool get_args(shared_ptr< user_interaction > &dialog, const char *home, const deque< string > &dar_dcf_path, const deque< string > &dar_duc_path, S_I argc, char *const argv[], line_param ¶m)
main routine to extract parameters from command-line and included files
ent_params aux_remote
remote entrepot coordinates for the auxiliary archive
string ent_port
entrepot port
bool auth_from_file
whether ~/.netrc and ~/.ssh files should be considered for credentials
modified_data_detection
how to detect data has changed when some fields
bool warn_remove_no_match
whether to warn file about to be removed during a restoration, when they to no match the expected typ...
dirty_behavior dirty
what to do when comes the time to restore a file that is flagged as dirty
compression
the different compression algorithm available
string user_comment
user comment to add to the archive
bool exclude_by_ea
whether inode have to be check against a given EA before backup
infinint iteration_count
iteration count used when creating/isolating/merging an encrypted archive (key derivation) ...
string * aux_filename
basename of the auxiliary archive if reference (nullptr => no auxiliary of reference) ...
the main file of the libdar API definitions
path * ref_root
where is the archive of reference
string slice_perm
permission to set when creating a slice
bool display_treated
whether to show treated files
infinint repeat_count
number of time to try saving a file if it changes at the time it is read for backup ...
infinint ref_num_digits
minimum number of decimal for the slice number of the archive of reference
hash_algo
hashing algorithm available
bool use_sequential_marks
whether to add escape sequential marks in the archive
the arbitrary large positive integer class
hash_algo hash
whether to produce a hash file, and which algoritm to use for that hash
bool security_check
whether to signal possible root-kit presence
bool flat
whether to ignore directory structure when restoring data
secu_string pass
if not an empty string, encrypt the archive with the given algo:pass string
secu_string pass_ref
if not an empty string, use the provided encryption scheme to read the archive of reference ...
bool blind_signatures
whether to ignore signature check failures
bool header_only
whether we just display the header of archives to be read
infinint file_size
size of the slices to create (except the first)
string ent_login
entrepot login
bool list_ea
whether to list Extended Attribute of files
comparison_fields what_to_check
what fields to take into account when comparing/restoring files,
path * aux_root
where is the auxiliary archive of reference [used for merging but also when creating an archive...
bool ignore_unknown_inode
whether to ignore unknown inode types
listformat
defines the way archive listing is done:
infinint min_compr_size
below which size to never try compressing files
libdar namespace encapsulate all libdar symbols
mask * compress_mask
which file to compress
bool empty
whether to do a dry-run execution
string aux_execute
command to be run between the slice of the auxiliary archive of reference
the class path is here to manipulate paths in the Unix notation: using'/'
infinint repeat_byte
archive total maximum amount of byte to waste re-saving changing files