Disk ARchive  2.4.17
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Modules
defile.hpp
Go to the documentation of this file.
1 /*********************************************************************/
2 // dar - disk archive - a backup/restoration program
3 // Copyright (C) 2002-2052 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
18 //
19 // to contact the author : http://dar.linux.free.fr/email.html
20 /*********************************************************************/
21 
25 
26 #ifndef DEFILE_HPP
27 #define DEFILE_HPP
28 
29 #include "../my_config.h"
30 #include "catalogue.hpp"
31 #include "path.hpp"
32 
33 namespace libdar
34 {
35 
38 
40 
47  class defile
48  {
49  public :
50  defile(const path &racine) : chemin(racine) { init = true; };
51 
52  void enfile(const entree *e);
53  const path & get_path() const { return chemin; };
54  const std::string & get_string() const { return cache; };
55 
56 #ifdef LIBDAR_SPECIAL_ALLOC
57  USE_SPECIAL_ALLOC(defile);
58 #endif
59 
60  private :
61  path chemin; //< current path
62  bool init; //< true if reached the "root" (all pushed arguments have been poped)
63  std::string cache; //< cache of "chemin" converted into string
64  };
65 
67 
68 } // end of namespace
69 
70 #endif
the root class from all other inherite for any entry in the catalogue
Definition: catalogue.hpp:94
the defile class keep trace of the real path of files while the flow in the filter routines ...
Definition: defile.hpp:47
here is the definition of the path classthe path class handle path and provide several operation on t...
the cache class implements a very basic read/write caching mechanism
Definition: cache.hpp:50
libdar namespace encapsulate all libdar symbols
Definition: archive.hpp:43
here is defined the many classed which is build of the catalogue
the class path is here to manipulate paths in the Unix notation: using'/'
Definition: path.hpp:50