Disk ARchive  2.6.8
Full featured and portable backup and archiving tool
archive_summary.hpp
Go to the documentation of this file.
1 /*********************************************************************/
2 // dar - disk archive - a backup/restoration program
3 // Copyright (C) 2002-2020 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 : http://dar.linux.free.fr/email.html
20 /*********************************************************************/
21 
25 
26 
27 #ifndef ARCHIVE_SUMMARY_HPP
28 #define ARCHIVE_SUMMARY_HPP
29 
30 #include "../my_config.h"
31 #include <string>
32 #include "infinint.hpp"
33 #include "entree_stats.hpp"
34 
35 namespace libdar
36 {
37 
40 
41 
43 
45  {
46  public:
47  archive_summary() { clear(); };
48  archive_summary(const archive_summary & ref) = default;
49  archive_summary(archive_summary && ref) noexcept = default;
50  archive_summary & operator = (const archive_summary & ref) = default;
51  archive_summary & operator = (archive_summary && ref) noexcept = default;
52  ~archive_summary() = default;
53 
54  // GETTINGS
55 
56  const infinint & get_slice_size() const { return slice_size; };
57  const infinint & get_first_slice_size() const { return first_slice_size; };
58  const infinint & get_last_slice_size() const { return last_slice_size; };
59  const infinint & get_slice_number() const { return slice_number; };
60  const infinint & get_archive_size() const { return archive_size; };
61  const infinint & get_catalog_size() const { return catalog_size; };
62  const infinint & get_storage_size() const { return storage_size; };
63  const infinint & get_data_size() const { return data_size; };
64  const entree_stats & get_contents() const { return contents; };
65  std::string get_edition() const { return edition; };
66  std::string get_compression_algo() const { return algo_zip; };
67  std::string get_user_comment() const { return user_comment; };
68  std::string get_cipher() const { return cipher; };
69  std::string get_asym() const { return asym; };
70  bool get_signed() const { return is_signed; };
71  bool get_tape_marks() const { return tape_marks; };
72 
73 
74  // SETTINGS
75 
76  void set_slice_size(const infinint & arg) { slice_size = arg; };
77  void set_first_slice_size(const infinint & arg) { first_slice_size = arg; };
78  void set_last_slice_size(const infinint & arg) { last_slice_size = arg; };
79  void set_slice_number(const infinint & arg) { slice_number = arg; };
80  void set_archive_size(const infinint & arg) { archive_size = arg; };
81  void set_catalog_size(const infinint & arg) { catalog_size = arg; };
82  void set_storage_size(const infinint & arg) { storage_size = arg; };
83  void set_data_size(const infinint & arg) { data_size = arg; };
84  void set_contents(const entree_stats & arg) { contents = arg; };
85  void set_edition(const std::string & arg) { edition = arg; };
86  void set_compression_algo(const std::string & arg) { algo_zip = arg; };
87  void set_user_comment(const std::string & arg) { user_comment = arg; };
88  void set_cipher(const std::string & arg) { cipher = arg; };
89  void set_asym(const std::string & arg) { asym = arg; };
90  void set_signed(bool arg) { is_signed = arg; };
91  void set_tape_marks(bool arg) { tape_marks = arg; };
92 
93  void clear();
94 
95  private:
105  std::string edition;
106  std::string algo_zip;
107  std::string user_comment;
108  std::string cipher;
109  std::string asym;
110  bool is_signed;
111  bool tape_marks;
112 
113  };
114 
115 } // end of namespace
116 
117 #endif
libdar::archive_summary::slice_size
infinint slice_size
slice of the first slice or zero if not applicable
Definition: archive_summary.hpp:96
libdar::archive_summary::asym
std::string asym
asymetrical encryption
Definition: archive_summary.hpp:109
libdar::archive_summary::archive_size
infinint archive_size
total size of the archive
Definition: archive_summary.hpp:100
infinint.hpp
switch module to limitint (32 ou 64 bits integers) or infinint
libdar::infinint
the arbitrary large positive integer class
Definition: real_infinint.hpp:61
libdar::archive_summary::storage_size
infinint storage_size
amount of byte used to store (compressed/encrypted) data
Definition: archive_summary.hpp:102
libdar::entree_stats
holds the statistics contents of a catalogue
Definition: entree_stats.hpp:48
libdar::archive_summary
the archive_summary class provides information about a given archive
Definition: archive_summary.hpp:44
libdar::archive_summary::tape_marks
bool tape_marks
whether the archive has tape marks (for sequential reading)
Definition: archive_summary.hpp:111
entree_stats.hpp
datastructure holding the nature of file present in a given archive
libdar::archive_summary::edition
std::string edition
archive format
Definition: archive_summary.hpp:105
libdar::archive_summary::is_signed
bool is_signed
whether the archive is signed
Definition: archive_summary.hpp:110
libdar::archive_summary::catalog_size
infinint catalog_size
catalogue size if known, zero if not
Definition: archive_summary.hpp:101
libdar::archive_summary::slice_number
infinint slice_number
number of slices composing the archive of zero if unknown
Definition: archive_summary.hpp:99
libdar::archive_summary::data_size
infinint data_size
amount of data saved (once uncompressed/unciphered)
Definition: archive_summary.hpp:103
libdar::archive_summary::contents
entree_stats contents
nature of saved files
Definition: archive_summary.hpp:104
libdar::archive_summary::user_comment
std::string user_comment
user comment
Definition: archive_summary.hpp:107
libdar::archive_summary::algo_zip
std::string algo_zip
compression algorithm
Definition: archive_summary.hpp:106
libdar::archive_summary::cipher
std::string cipher
encryption algorithm
Definition: archive_summary.hpp:108
libdar::archive_summary::first_slice_size
infinint first_slice_size
slice of the middle slices or zero if not applicable
Definition: archive_summary.hpp:97
libdar::archive_summary::last_slice_size
infinint last_slice_size
slice of the last slice or zero if not applicable
Definition: archive_summary.hpp:98
libdar
libdar namespace encapsulate all libdar symbols
Definition: archive.hpp:46