Disk ARchive 2.7.18
Full featured and portable backup and archiving tool
Loading...
Searching...
No Matches
path.hpp
Go to the documentation of this file.
1/*********************************************************************/
2// dar - disk archive - a backup/restoration program
3// Copyright (C) 2002-2025 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
27
28#ifndef PATH_HPP
29#define PATH_HPP
30
31#include "../my_config.h"
32#include <list>
33#include <string>
34#include "integers.hpp"
35#include "erreurs.hpp"
36
37namespace libdar
38{
41
43
50 class path
51 {
52 public :
54
62 path(const std::string & s, bool x_undisclosed = false);
63
65 path(const path & ref);
66
68 path(path && ref) noexcept = default;
69
71 path & operator = (const path & ref);
72
74 path & operator = (path && ref) noexcept = default;
75
77 ~path() = default;
78
80 bool operator == (const path & ref) const;
81 bool operator != (const path & ref) const { return !(*this == ref); };
82
84
86 std::string basename() const;
87
89
91 void reset_read() const { reading = dirs.begin(); };
92
94
98 bool read_subdir(std::string & r) const;
99
101 bool is_relative() const { return relative; };
102
104 bool is_absolute() const { return !relative; };
105
107 bool is_undisclosed() const { return undisclosed; };
108
110
116 bool pop(std::string & arg);
117
119
125 bool pop_front(std::string & arg);
126
128
132 path operator + (const path & arg) const { path tmp = *this; tmp += arg; return tmp; };
133
135 path append(const std::string & sub) const { path tmp = *this; if(sub.find_first_of("/") != std::string::npos) throw SRC_BUG; tmp += sub; return tmp; };
136
138
141 path & operator += (const path & arg);
142
144 path & operator += (const std::string & sub);
145
147
150 bool is_subdir_of(const path & p, bool case_sensit) const;
151
153
155 std::string display() const;
156
158
161 std::string display_without_root() const;
162
164
166 U_I degre() const { return dirs.size() + (relative ? 0 : 1); };
167
170
171 private :
172 mutable std::list<std::string>::const_iterator reading;
173 std::list<std::string> dirs;
174 bool relative;
175 bool undisclosed;
176
177 void reduce();
178 void init(const std::string & chem, bool x_undisclosed);
179 };
180
182 extern const std::string PSEUDO_ROOT;
183
185 extern const path FAKE_ROOT;
186
188
189} // end of namespace
190
191#endif
the class path is here to manipulate paths in the Unix notation: using'/'
Definition path.hpp:51
void explode_undisclosed() const
if the current object is an undisclosed path, tries to convert it back to normal path
bool read_subdir(std::string &r) const
sequentially read the elements that compose the path
bool pop(std::string &arg)
remove and gives in argument the basename of the path
bool is_subdir_of(const path &p, bool case_sensit) const
test whether the current object is a subdir of the method's argument
~path()=default
destructor
path(path &&ref) noexcept=default
move constructor
void reset_read() const
reset the read_subdir operation
Definition path.hpp:91
bool operator==(const path &ref) const
comparison operator
U_I degre() const
returns the number of member in the path
Definition path.hpp:166
bool is_absolute() const
whether the path is absolute or relative
Definition path.hpp:104
path(const std::string &s, bool x_undisclosed=false)
constructor from a string
bool pop_front(std::string &arg)
remove and gives in argument the outer most member of the path
std::string display() const
convert back a path to a string
path & operator=(const path &ref)
assignment operator
std::string display_without_root() const
display the path as a string but without the first member of the path
path & operator+=(const path &arg)
add a path to the current path. The added path must be a relative path
path operator+(const path &arg) const
add a path to the current path. The added path must be a relative path
Definition path.hpp:132
path append(const std::string &sub) const
add a single sub-directory to the path
Definition path.hpp:135
bool is_undisclosed() const
whether the path has an undisclosed part at the beginning
Definition path.hpp:107
path(const path &ref)
copy constructor
bool is_relative() const
whether the path is relative or absolute (= start with a /)
Definition path.hpp:101
std::string basename() const
get the basename of a path
contains all the excetion class thrown by libdar
const std::string PSEUDO_ROOT
root name to use when archive operation does not use filesystem (archive testing for example)
const path FAKE_ROOT
root path object based on PSEUDO_ROOT
are defined here basic integer types that tend to be portable
include macro defined by the configure script and some specific additional ones
libdar namespace encapsulate all libdar symbols
Definition archive.hpp:47