Disk ARchive 2.7.16
Full featured and portable backup and archiving tool
cat_file.hpp
Go to the documentation of this file.
1/*********************************************************************/
2// dar - disk archive - a backup/restoration program
3// Copyright (C) 2002-2024 Denis Corbin
4//
5// This program is free software; you can redistribute it and/or
6// modify it under the terms of the GNU General Public License
7// as published by the Free Software Foundation; either version 2
8// of the License, or (at your option) any later version.
9//
10// This program is distributed in the hope that it will be useful,
11// but WITHOUT ANY WARRANTY; without even the implied warranty of
12// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13// GNU General Public License for more details.
14//
15// You should have received a copy of the GNU General Public License
16// along with this program; if not, write to the Free Software
17// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
18//
19// to contact the author, see the AUTHOR file
20/*********************************************************************/
21
25
26#ifndef CAT_FILE_HPP
27#define CAT_FILE_HPP
28
29#include "../my_config.h"
30
31extern "C"
32{
33} // end extern "C"
34
35#include "cat_inode.hpp"
36#include "memory_file.hpp"
38
39namespace libdar
40{
41
44
45
47
48 class cat_file : public cat_inode
49 {
50 public :
51
54 {
58 plain
59 };
60
61 static constexpr U_8 FILE_DATA_WITH_HOLE = 0x01;
62 static constexpr U_8 FILE_DATA_IS_DIRTY = 0x02;
63 static constexpr U_8 FILE_DATA_HAS_DELTA_SIG = 0x04;
64
65 cat_file(const infinint & xuid,
66 const infinint & xgid,
67 U_16 xperm,
68 const datetime & last_access,
69 const datetime & last_modif,
70 const datetime & last_change,
71 const std::string & src,
72 const path & che,
73 const infinint & taille,
74 const infinint & fs_device,
75 bool x_furtive_read_mode);
76 cat_file(const std::shared_ptr<user_interaction> & dialog,
78 const archive_version & reading_ver,
79 saved_status saved,
80 compression default_algo,
81 bool small);
82 cat_file(const cat_file & ref);
83 cat_file(cat_file && ref) = delete;
84 cat_file & operator = (const cat_file & ref) = delete;
85 cat_file & operator = (cat_file && ref) = delete;
86 ~cat_file() { detruit(); };
87
88 virtual bool has_changed_since(const cat_inode & ref,
89 const infinint & hourshift,
90 comparison_fields what_to_check) const override;
91 infinint get_size() const { return *size; };
92 void change_size(const infinint & s) const { *size = s; };
93 infinint get_storage_size() const { return *storage_size; };
94 void set_storage_size(const infinint & s) { *storage_size = s; };
95
97 bool can_get_data() const { return get_saved_status() == saved_status::saved || get_saved_status() == saved_status::delta || status == from_path; };
98
100
114 std::shared_ptr<memory_file> delta_sig_mem,
115 U_I signature_block_size,
116 std::shared_ptr<memory_file> delta_ref,
117 const crc **checksum = nullptr) const;
118 void clean_data(); // partially free memory (but get_data() becomes disabled)
119 void set_offset(const infinint & r);
120 const infinint & get_offset() const;
121 virtual unsigned char signature() const override { return 'f'; };
122 virtual std::string get_description() const override { return "file"; };
123
124 void set_crc(const crc &c);
125 bool get_crc(const crc * & c) const;
126 bool has_crc() const { return check != nullptr; };
127 bool get_crc_size(infinint & val) const;
128 void drop_crc() { if(check != nullptr) { delete check; check = nullptr; } };
129
130 // whether the plain file has to detect sparse file
131 void set_sparse_file_detection_read(bool val) { if(status == from_cat) throw SRC_BUG; if(val) file_data_status_read |= FILE_DATA_WITH_HOLE; else file_data_status_read &= ~FILE_DATA_WITH_HOLE; };
132
133 void set_sparse_file_detection_write(bool val) { if(val) file_data_status_write |= FILE_DATA_WITH_HOLE; else file_data_status_write &= ~FILE_DATA_WITH_HOLE; };
134
135 // whether the plain file is stored with a sparse_file datastructure in the archive
136 bool get_sparse_file_detection_read() const { return (file_data_status_read & FILE_DATA_WITH_HOLE) != 0; };
137 bool get_sparse_file_detection_write() const { return (file_data_status_write & FILE_DATA_WITH_HOLE) != 0; };
138
139 virtual cat_entree *clone() const override { return new (std::nothrow) cat_file(*this); };
140
141 compression get_compression_algo_read() const { return algo_read; };
142
143 compression get_compression_algo_write() const { return algo_write; };
144
145 // object migration methods (merging)
146 void change_compression_algo_write(compression x) { algo_write = x; };
147
148 // dirtiness
149
150 bool is_dirty() const { return dirty; };
151 void set_dirty(bool value) { dirty = value; };
152
153
155 bool has_delta_signature_structure() const { return delta_sig != nullptr; };
156
158
162 bool has_delta_signature_available() const { return delta_sig != nullptr && delta_sig->can_obtain_sig(); };
163
164
166 bool has_patch_base_crc() const;
167
169 bool get_patch_base_crc(const crc * & c) const;
170
172 void set_patch_base_crc(const crc & c);
173
174
175
178
180 bool get_patch_result_crc(const crc * & c) const;
181
183 void set_patch_result_crc(const crc & c);
184
187
189
194
196
201 void dump_delta_signature(std::shared_ptr<memory_file> & sig, U_I sign_block_size, generic_file & where, bool small) const;
202
204 void dump_delta_signature(generic_file & where, bool small) const;
205
206
208
211
213
218 void read_delta_signature(std::shared_ptr<memory_file> & delta_sig,
219 U_I & block_len) const;
220
223
225 bool has_same_delta_signature(const cat_file & ref) const;
226
229
232
234 virtual bool operator == (const cat_entree & ref) const override { return true; };
235
237 bool same_data_as(const cat_file & other, bool check_data, const infinint & hourshift);
238
240 const archive_version & get_archive_version() const { return read_ver; };
241
242 protected:
243 virtual void sub_compare(const cat_inode & other, bool isolated_mode) const override;
244 virtual void inherited_dump(const pile_descriptor & pdesc, bool small) const override;
245 virtual void post_constructor(const pile_descriptor & pdesc) override;
246
247 enum { empty, from_path, from_cat } status;
248
249 private:
250 std::string chemin;
255 bool dirty;
263 mutable bool delta_sig_read;
265
266 void sub_compare_internal(const cat_inode & other,
267 bool can_read_my_data,
268 bool can_read_other_data,
269 const infinint & hourshift) const;
270
271 void clean_patch_base_crc();
272
273 void detruit();
274
275 };
276
278
279} // end of namespace
280
281#endif
class used to manage binary delta signature in catalogue and archive
base object for all inode types, managed EA and FSA, dates, permissions, ownership,...
class archive_version manages the version of the archive format
the cat_delta_signature file class
bool can_obtain_sig() const
the cat_delta_signature structure can only hold CRC without delta_signature, this call gives the situ...
the root class from all other inherite for any entry in the catalogue
Definition: cat_entree.hpp:60
saved_status get_saved_status() const
obtain the saved status of the object
Definition: cat_entree.hpp:164
the plain file class
Definition: cat_file.hpp:49
infinint * size
size of the data (uncompressed)
Definition: cat_file.hpp:252
bool get_crc(const crc *&c) const
the argument is set the an allocated crc object the owned by the "cat_file" object,...
bool has_same_delta_signature(const cat_file &ref) const
return true if ref and "this" have both equal delta signatures
void set_patch_base_crc(const crc &c)
set the reference CRC of the file to base the patch on, for s_detla objects
bool get_patch_base_crc(const crc *&c) const
returns the CRC of the file to base the patch on, for s_delta objects
void dump_delta_signature(std::shared_ptr< memory_file > &sig, U_I sign_block_size, generic_file &where, bool small) const
write down to archive the given delta signature
const archive_version & get_archive_version() const
expose the archive format the object of the backup this object comes from
Definition: cat_file.hpp:240
static constexpr U_8 FILE_DATA_HAS_DELTA_SIG
delta signature is present
Definition: cat_file.hpp:63
void read_delta_signature(std::shared_ptr< memory_file > &delta_sig, U_I &block_len) const
fetch the delta signature from the archive
void drop_delta_signature_data() const
drop the delta signature from memory (will not more be posible to be read, using read_delta_signature...
virtual void post_constructor(const pile_descriptor &pdesc) override
let inherited classes build object's data after CRC has been read from file in small read mode
bool dirty
true when a file has been modified at the time it was saved
Definition: cat_file.hpp:255
bool get_patch_result_crc(const crc *&c) const
returns the CRC the file will have once restored or patched (for s_saved, s_delta,...
compression algo_write
which compression algorithm to use to write down (merging) the file's data
Definition: cat_file.hpp:257
bool same_data_as(const cat_file &other, bool check_data, const infinint &hourshift)
compare just data not inode information EA nor FSA
bool delta_sig_read
whether delta sig has been read/initialized from filesystem
Definition: cat_file.hpp:263
static constexpr U_8 FILE_DATA_IS_DIRTY
data modified while being saved
Definition: cat_file.hpp:62
get_data_mode
how to get data from archive
Definition: cat_file.hpp:54
@ keep_compressed
provide access to compressed data
Definition: cat_file.hpp:55
@ normal
provide access to full data (uncompressed, uses skip() to restore holes)
Definition: cat_file.hpp:57
@ keep_hole
provide access to uncompressed data but sparse_file datastructure
Definition: cat_file.hpp:56
@ plain
provide access to plain data, no skip to restore holes, provide instead zeroed bytes
Definition: cat_file.hpp:58
cat_delta_signature * delta_sig
delta signature and associated CRC
Definition: cat_file.hpp:262
crc * patch_base_check
when data contains a delta patch, moved from delta_sig since format 10.2
Definition: cat_file.hpp:261
void will_have_delta_signature_available()
prepare the object to receive a delta signature structure including delta signature
void clear_delta_signature_structure()
remove any information about delta signature
bool get_crc_size(infinint &val) const
returns true if crc is know and puts its width in argument
void clear_delta_signature_only()
remove information about delta signature also associated CRCs if status is not s_delta
bool has_delta_signature_structure() const
return whether the object has an associated delta signature structure
Definition: cat_file.hpp:155
char file_data_status_read
defines the datastructure to use when reading the data
Definition: cat_file.hpp:259
infinint * storage_size
how much data used in archive (after compression)
Definition: cat_file.hpp:253
bool has_patch_result_crc() const
returns whether the object has a CRC corresponding to data (for s_saved, s_delta, and when delta sign...
crc * check
crc computed on the data
Definition: cat_file.hpp:254
static constexpr U_8 FILE_DATA_WITH_HOLE
file's data contains hole datastructure
Definition: cat_file.hpp:61
virtual void inherited_dump(const pile_descriptor &pdesc, bool small) const override
true if object has been created by sequential reading of an archive
virtual bool operator==(const cat_entree &ref) const override
not used
Definition: cat_file.hpp:234
bool has_delta_signature_available() const
return whether the object has an associated delta signature structure including a delta signature dat...
Definition: cat_file.hpp:162
virtual cat_entree * clone() const override
a way to copy the exact type of an object even if pointed to by a parent class pointer
Definition: cat_file.hpp:139
bool furtive_read_mode
used only when status equals "from_path"
Definition: cat_file.hpp:258
char file_data_status_write
defines the datastructure to apply when writing down the data
Definition: cat_file.hpp:260
void will_have_delta_signature_structure()
prepare the object to receive a delta signature structure
archive_version read_ver
archive format used/to use
Definition: cat_file.hpp:264
void read_delta_signature_metadata() const
load metadata (and delta signature when in sequential mode) into memory
virtual std::string get_description() const override
inherited class designation
Definition: cat_file.hpp:122
void set_patch_result_crc(const crc &c)
set the CRC the file will have once restored or patched (for s_saved, s_delta, and when delta signatu...
bool can_get_data() const
check whether the object will be able to provide a object using get_data() method
Definition: cat_file.hpp:97
void dump_delta_signature(generic_file &where, bool small) const
variant of dump_delta_signature when just CRC have to be dumped
bool has_patch_base_crc() const
returns whether the object has a base patch CRC (s_delta status objects)
std::string chemin
path to the data (when read from filesystem)
Definition: cat_file.hpp:250
virtual unsigned char signature() const override
inherited class signature
Definition: cat_file.hpp:121
infinint * offset
start location of the data in 'loc'
Definition: cat_file.hpp:251
virtual generic_file * get_data(get_data_mode mode, std::shared_ptr< memory_file > delta_sig_mem, U_I signature_block_size, std::shared_ptr< memory_file > delta_ref, const crc **checksum=nullptr) const
returns a newly allocated object in read_only mode
compression algo_read
which compression algorithm to use to read the file's data
Definition: cat_file.hpp:256
the root class for all cat_inode
Definition: cat_inode.hpp:53
pure virtual class defining interface of a CRC object
Definition: crc.hpp:47
stores time information
Definition: datetime.hpp:59
this is the interface class from which all other data transfer classes inherit
the arbitrary large positive integer class
the class path is here to manipulate paths in the Unix notation: using'/'
Definition: path.hpp:51
comparison_fields
how to consider file change during comparison and incremental backup
Definition: archive_aux.hpp:53
compression
the different compression algorithm available
Definition: compression.hpp:46
saved_status
data saved status for an entry
Definition: cat_status.hpp:45
@ saved
inode is saved in the archive
@ delta
inode is saved but as delta binary from the content (delta signature) of what was found in the archiv...
Memory_file is a generic_file class that only uses virtual memory.
libdar namespace encapsulate all libdar symbols
Definition: archive.hpp:47