Disk ARchive  2.7.15
Full featured and portable backup and archiving tool
cat_directory.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_DIRECTORY_HPP
27 #define CAT_DIRECTORY_HPP
28 
29 #include "../my_config.h"
30 
31 extern "C"
32 {
33 } // end extern "C"
34 
35 #include "cat_inode.hpp"
36 
37 #ifdef LIBDAR_FAST_DIR
38 #include <map>
39 #endif
40 #include <list>
41 
42 namespace libdar
43 {
44  class cat_eod;
45 
48 
50 
51  class cat_directory : public cat_inode
52  {
53  public :
54  cat_directory(const infinint & xuid,
55  const infinint & xgid,
56  U_16 xperm,
57  const datetime & last_access,
58  const datetime & last_modif,
59  const datetime & last_change,
60  const std::string & xname,
61  const infinint & device);
62  cat_directory(const std::shared_ptr<user_interaction> & dialog,
63  const smart_pointer<pile_descriptor> & pdesc,
64  const archive_version & reading_ver,
66  entree_stats & stats,
67  std::map <infinint, cat_etoile *> & corres,
68  compression default_algo,
69  bool lax,
70  bool only_detruit, // objects of other class than detruit and cat_directory are not built in memory
71  bool small);
72  cat_directory(const cat_directory &ref); // only the inode part is build, no children is duplicated (empty dir)
73  cat_directory(cat_directory && ref) noexcept;
74  cat_directory & operator = (const cat_directory & ref); // set the inode part *only* no subdirectories/subfiles are copies or removed.
75  cat_directory & operator = (cat_directory && ref);
76  ~cat_directory() noexcept(false); // detruit aussi tous les fils et se supprime de son 'parent'
77 
79  virtual bool operator == (const cat_entree & ref) const override;
80 
81  void add_children(cat_nomme *r); // when r is a cat_directory, 'parent' is set to 'this'
82  bool has_children() const { return !ordered_fils.empty(); };
83  void reset_read_children() const;
84  void end_read() const;
85  bool read_children(const cat_nomme * &r) const; // read the direct children of the cat_directory, returns false if no more is available
86  // remove all entry not yet read by read_children
87  void tail_to_read_children();
88 
89 
91 
96  void remove(const std::string & name);
97 
98  cat_directory * get_parent() const { return parent; };
99  bool search_children(const std::string &name, const cat_nomme *&ref) const;
100 
101  // using is_more_recent_than() from cat_inode class
102  // using method has_changed_since() from cat_inode class
103  virtual unsigned char signature() const override { return 'd'; };
104 
105  virtual std::string get_description() const override { return "folder"; };
106 
107 
109  bool get_recursive_has_changed() const { return recursive_has_changed; };
110 
113 
115  infinint get_dir_size() const { return ordered_fils.size(); };
116 
119 
122 
125 
126  // for each mirage found (hard link implementation) in the cat_directory tree, add its etiquette to the returned
127  // list with the number of reference that has been found in the tree. (map[etiquette] = number of occurence)
128  // from outside of class cat_directory, the given argument is expected to be an empty map.
129  void get_etiquettes_found_in_tree(std::map<infinint, infinint> & already_found) const;
130 
132  bool is_empty() const { return ordered_fils.empty(); };
133 
136 
139 
142 
143  virtual cat_entree *clone() const override { return new (std::nothrow) cat_directory(*this); };
144 
145  const infinint & get_size() const { recursive_update_sizes(); return x_size; };
146  const infinint & get_storage_size() const { recursive_update_sizes(); return x_storage_size; };
147 
148  void recursively_set_to_unsaved_data_and_FSA();
149 
151  virtual void change_location(const smart_pointer<pile_descriptor> & pdesc) override;
152 
153  protected:
154  virtual void inherited_dump(const pile_descriptor & pdesc, bool small) const override;
155 
156  private:
157  static const cat_eod fin;
158 
159  mutable infinint x_size;
160  mutable infinint x_storage_size;
161  mutable bool updated_sizes;
162  cat_directory *parent;
163 #ifdef LIBDAR_FAST_DIR
164  std::map<std::string, cat_nomme *> fils; // used for fast lookup
165 #endif
166  std::deque<cat_nomme *> ordered_fils;
167  mutable std::deque<cat_nomme *>::const_iterator it;
168  mutable bool recursive_has_changed;
169 
170  void init() noexcept;
171  void clear();
172  void recursive_update_sizes() const;
173  void recursive_flag_size_to_update() const;
174  void erase_ordered_fils(std::deque<cat_nomme *>::const_iterator debut,
175  std::deque<cat_nomme *>::const_iterator fin);
176  };
177 
179 
180 } // end of namespace
181 
182 #endif
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_directory inode class
void set_all_mirage_s_inode_wrote_field_to(bool val) const
recursively set all mirage inode_wrote flag
infinint get_tree_ea_num() const
get the number of entry having some EA set in the cat_directory tree (recursive call)
void recursive_has_changed_update() const
ask recursive update for the recursive_has_changed field
void set_all_mirage_s_inode_dumped_field_to(bool val) const
set the value of inode_dumped for all mirage (recusively)
void remove_all_mirages_and_reduce_dirs()
recursively remove all mirage entries
infinint get_dir_size() const
get the number of "cat_nomme" entry directly containted in this cat_directory (no recursive call)
virtual std::string get_description() const override
inherited class designation
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 unsigned char signature() const override
inherited class signature
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
infinint get_tree_mirage_num() const
get the number of entry that are hard linked inode (aka mirage in dar implementation) (recursive call...
void remove(const std::string &name)
remove the given entry from the catalogue
virtual void change_location(const smart_pointer< pile_descriptor > &pdesc) override
overwrite virtual method of cat_entree to propagate the action to all entries of the directory tree
bool get_recursive_has_changed() const
detemine whether some data has changed since archive of reference in this cat_directory or subdirecto...
infinint get_tree_size() const
get then number of "cat_nomme" entry contained in this cat_directory and subdirectories (recursive ca...
std::deque< cat_nomme * >::const_iterator it
next entry to be returned by read_children
bool is_empty() const
whether this cat_directory is empty or not
virtual bool operator==(const cat_entree &ref) const override
attention this compares only the directories themselves, not the list of their children
the root class from all other inherite for any entry in the catalogue
Definition: cat_entree.hpp:60
the End of Directory entry class
Definition: cat_eod.hpp:46
the root class for all cat_inode
Definition: cat_inode.hpp:53
the base class for all entry that have a name
Definition: cat_nomme.hpp:45
stores time information
Definition: datetime.hpp:59
the arbitrary large positive integer class
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
libdar namespace encapsulate all libdar symbols
Definition: archive.hpp:47
holds the statistics contents of a catalogue