Disk ARchive  2.6.8
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-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 #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) noexcept;
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 
112  void recursive_has_changed_update() const;
113 
115  infinint get_dir_size() const { return ordered_fils.size(); };
116 
118  infinint get_tree_size() const;
119 
121  infinint get_tree_ea_num() const;
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 
138  void set_all_mirage_s_inode_wrote_field_to(bool val) const;
139 
141  void set_all_mirage_s_inode_dumped_field_to(bool val) const;
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
libdar::cat_directory::recursive_has_changed_update
void recursive_has_changed_update() const
ask recursive update for the recursive_has_changed field
libdar::cat_directory::get_description
virtual std::string get_description() const override
inherited class designation
Definition: cat_directory.hpp:105
libdar::cat_directory::change_location
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
libdar::compression
compression
the different compression algorithm available
Definition: compression.hpp:45
libdar::cat_directory::inherited_dump
virtual void inherited_dump(const pile_descriptor &pdesc, bool small) const override
true if object has been created by sequential reading of an archive
libdar::cat_directory::remove_all_mirages_and_reduce_dirs
void remove_all_mirages_and_reduce_dirs()
recursively remove all mirage entries
libdar::cat_directory::get_tree_size
infinint get_tree_size() const
get then number of "cat_nomme" entry contained in this cat_directory and subdirectories (recursive ca...
libdar::saved_status
saved_status
data saved status for an entry
Definition: cat_status.hpp:44
libdar::infinint
the arbitrary large positive integer class
Definition: real_infinint.hpp:61
libdar::cat_directory::signature
virtual unsigned char signature() const override
inherited class signature
Definition: cat_directory.hpp:103
libdar::cat_nomme
the base class for all entry that have a name
Definition: cat_nomme.hpp:44
cat_inode.hpp
base object for all inode types, managed EA and FSA, dates, permissions, ownership,...
libdar::cat_directory::get_dir_size
infinint get_dir_size() const
get the number of "cat_nomme" entry directly containted in this cat_directory (no recursive call)
Definition: cat_directory.hpp:115
libdar::cat_entree
the root class from all other inherite for any entry in the catalogue
Definition: cat_entree.hpp:59
libdar::entree_stats
holds the statistics contents of a catalogue
Definition: entree_stats.hpp:48
libdar::cat_inode
the root class for all cat_inode
Definition: cat_inode.hpp:52
libdar::archive_version
class archive_version manages the version of the archive format
Definition: archive_version.hpp:46
libdar::cat_directory::clone
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_directory.hpp:143
libdar::saved_status::saved
inode is saved in the archive
libdar::cat_directory::operator==
virtual bool operator==(const cat_entree &ref) const override
attention this compares only the directories themselves, not the list of their children
libdar::datetime
stores time information
Definition: datetime.hpp:58
libdar::cat_directory::get_tree_ea_num
infinint get_tree_ea_num() const
get the number of entry having some EA set in the cat_directory tree (recursive call)
libdar::cat_directory::get_tree_mirage_num
infinint get_tree_mirage_num() const
get the number of entry that are hard linked inode (aka mirage in dar implementation) (recursive call...
libdar::cat_directory
the cat_directory inode class
Definition: cat_directory.hpp:51
libdar::cat_directory::set_all_mirage_s_inode_dumped_field_to
void set_all_mirage_s_inode_dumped_field_to(bool val) const
set the value of inode_dumped for all mirage (recusively)
libdar::cat_directory::set_all_mirage_s_inode_wrote_field_to
void set_all_mirage_s_inode_wrote_field_to(bool val) const
recursively set all mirage inode_wrote flag
libdar::cat_directory::is_empty
bool is_empty() const
whether this cat_directory is empty or not
Definition: cat_directory.hpp:132
libdar::cat_directory::remove
void remove(const std::string &name)
remove the given entry from the catalogue
libdar::cat_directory::it
std::deque< cat_nomme * >::const_iterator it
next entry to be returned by read_children
Definition: cat_directory.hpp:167
libdar::smart_pointer< pile_descriptor >
libdar::cat_directory::get_recursive_has_changed
bool get_recursive_has_changed() const
detemine whether some data has changed since archive of reference in this cat_directory or subdirecto...
Definition: cat_directory.hpp:109
libdar
libdar namespace encapsulate all libdar symbols
Definition: archive.hpp:46