libstdc++
bits/fs_ops.h
Go to the documentation of this file.
1 // Filesystem operational functions -*- C++ -*-
2 
3 // Copyright (C) 2014-2022 Free Software Foundation, Inc.
4 //
5 // This file is part of the GNU ISO C++ Library. This library is free
6 // software; you can redistribute it and/or modify it under the
7 // terms of the GNU General Public License as published by the
8 // Free Software Foundation; either version 3, or (at your __option)
9 // any later version.
10 
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 // GNU General Public License for more details.
15 
16 // Under Section 7 of GPL version 3, you are granted additional
17 // permissions described in the GCC Runtime Library Exception, version
18 // 3.1, as published by the Free Software Foundation.
19 
20 // You should have received a copy of the GNU General Public License and
21 // a copy of the GCC Runtime Library Exception along with this program;
22 // see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
23 // <http://www.gnu.org/licenses/>.
24 
25 /** @file include/bits/fs_ops.h
26  * This is an internal header file, included by other library headers.
27  * Do not attempt to use it directly. @headername{filesystem}
28  */
29 
30 #ifndef _GLIBCXX_FS_OPS_H
31 #define _GLIBCXX_FS_OPS_H 1
32 
33 #if __cplusplus >= 201703L
34 
35 #include <cstdint>
36 
37 namespace std _GLIBCXX_VISIBILITY(default)
38 {
39 _GLIBCXX_BEGIN_NAMESPACE_VERSION
40 
41 namespace filesystem
42 {
43  /** @addtogroup filesystem
44  * @{
45  */
46 
47  [[nodiscard]]
48  path absolute(const path& __p);
49 
50  [[nodiscard]]
51  path absolute(const path& __p, error_code& __ec);
52 
53  [[nodiscard]]
54  path canonical(const path& __p);
55 
56  [[nodiscard]]
57  path canonical(const path& __p, error_code& __ec);
58 
59  inline void
60  copy(const path& __from, const path& __to)
61  { copy(__from, __to, copy_options::none); }
62 
63  inline void
64  copy(const path& __from, const path& __to, error_code& __ec)
65  { copy(__from, __to, copy_options::none, __ec); }
66 
67  void copy(const path& __from, const path& __to, copy_options __options);
68  void copy(const path& __from, const path& __to, copy_options __options,
69  error_code& __ec);
70 
71  inline bool
72  copy_file(const path& __from, const path& __to)
73  { return copy_file(__from, __to, copy_options::none); }
74 
75  inline bool
76  copy_file(const path& __from, const path& __to, error_code& __ec)
77  { return copy_file(__from, __to, copy_options::none, __ec); }
78 
79  bool copy_file(const path& __from, const path& __to, copy_options __option);
80  bool copy_file(const path& __from, const path& __to, copy_options __option,
81  error_code& __ec);
82 
83  void copy_symlink(const path& __existing_symlink, const path& __new_symlink);
84  void copy_symlink(const path& __existing_symlink, const path& __new_symlink,
85  error_code& __ec) noexcept;
86 
87  bool create_directories(const path& __p);
88  bool create_directories(const path& __p, error_code& __ec);
89 
90  bool create_directory(const path& __p);
91  bool create_directory(const path& __p, error_code& __ec) noexcept;
92 
93  bool create_directory(const path& __p, const path& attributes);
94  bool create_directory(const path& __p, const path& attributes,
95  error_code& __ec) noexcept;
96 
97  void create_directory_symlink(const path& __to, const path& __new_symlink);
98  void create_directory_symlink(const path& __to, const path& __new_symlink,
99  error_code& __ec) noexcept;
100 
101  void create_hard_link(const path& __to, const path& __new_hard_link);
102  void create_hard_link(const path& __to, const path& __new_hard_link,
103  error_code& __ec) noexcept;
104 
105  void create_symlink(const path& __to, const path& __new_symlink);
106  void create_symlink(const path& __to, const path& __new_symlink,
107  error_code& __ec) noexcept;
108 
109  [[nodiscard]]
110  path current_path();
111 
112  [[nodiscard]]
113  path current_path(error_code& __ec);
114 
115  void current_path(const path& __p);
116  void current_path(const path& __p, error_code& __ec) noexcept;
117 
118  [[nodiscard]]
119  bool
120  equivalent(const path& __p1, const path& __p2);
121 
122  [[nodiscard]]
123  bool
124  equivalent(const path& __p1, const path& __p2, error_code& __ec) noexcept;
125 
126  [[nodiscard]]
127  inline bool
128  exists(file_status __s) noexcept
129  { return status_known(__s) && __s.type() != file_type::not_found; }
130 
131  [[nodiscard]]
132  inline bool
133  exists(const path& __p)
134  { return exists(status(__p)); }
135 
136  [[nodiscard]]
137  inline bool
138  exists(const path& __p, error_code& __ec) noexcept
139  {
140  auto __s = status(__p, __ec);
141  if (status_known(__s))
142  {
143  __ec.clear();
144  return __s.type() != file_type::not_found;
145  }
146  return false;
147  }
148 
149  [[nodiscard]]
150  uintmax_t file_size(const path& __p);
151 
152  [[nodiscard]]
153  uintmax_t file_size(const path& __p, error_code& __ec) noexcept;
154 
155  [[nodiscard]]
156  uintmax_t hard_link_count(const path& __p);
157 
158  [[nodiscard]]
159  uintmax_t hard_link_count(const path& __p, error_code& __ec) noexcept;
160 
161  [[nodiscard]]
162  inline bool
163  is_block_file(file_status __s) noexcept
164  { return __s.type() == file_type::block; }
165 
166  [[nodiscard]]
167  inline bool
168  is_block_file(const path& __p)
169  { return is_block_file(status(__p)); }
170 
171  [[nodiscard]]
172  inline bool
173  is_block_file(const path& __p, error_code& __ec) noexcept
174  { return is_block_file(status(__p, __ec)); }
175 
176  [[nodiscard]]
177  inline bool
178  is_character_file(file_status __s) noexcept
179  { return __s.type() == file_type::character; }
180 
181  [[nodiscard]]
182  inline bool
183  is_character_file(const path& __p)
184  { return is_character_file(status(__p)); }
185 
186  [[nodiscard]]
187  inline bool
188  is_character_file(const path& __p, error_code& __ec) noexcept
189  { return is_character_file(status(__p, __ec)); }
190 
191  [[nodiscard]]
192  inline bool
193  is_directory(file_status __s) noexcept
194  { return __s.type() == file_type::directory; }
195 
196  [[nodiscard]]
197  inline bool
198  is_directory(const path& __p)
199  { return is_directory(status(__p)); }
200 
201  [[nodiscard]]
202  inline bool
203  is_directory(const path& __p, error_code& __ec) noexcept
204  { return is_directory(status(__p, __ec)); }
205 
206  [[nodiscard]]
207  bool is_empty(const path& __p);
208 
209  [[nodiscard]]
210  bool is_empty(const path& __p, error_code& __ec);
211 
212  [[nodiscard]]
213  inline bool
214  is_fifo(file_status __s) noexcept
215  { return __s.type() == file_type::fifo; }
216 
217  [[nodiscard]]
218  inline bool
219  is_fifo(const path& __p)
220  { return is_fifo(status(__p)); }
221 
222  [[nodiscard]]
223  inline bool
224  is_fifo(const path& __p, error_code& __ec) noexcept
225  { return is_fifo(status(__p, __ec)); }
226 
227  [[nodiscard]]
228  inline bool
229  is_other(file_status __s) noexcept
230  {
231  return exists(__s) && !is_regular_file(__s) && !is_directory(__s)
232  && !is_symlink(__s);
233  }
234 
235  [[nodiscard]]
236  inline bool
237  is_other(const path& __p)
238  { return is_other(status(__p)); }
239 
240  [[nodiscard]]
241  inline bool
242  is_other(const path& __p, error_code& __ec) noexcept
243  { return is_other(status(__p, __ec)); }
244 
245  [[nodiscard]]
246  inline bool
247  is_regular_file(file_status __s) noexcept
248  { return __s.type() == file_type::regular; }
249 
250  [[nodiscard]]
251  inline bool
252  is_regular_file(const path& __p)
253  { return is_regular_file(status(__p)); }
254 
255  [[nodiscard]]
256  inline bool
257  is_regular_file(const path& __p, error_code& __ec) noexcept
258  { return is_regular_file(status(__p, __ec)); }
259 
260  [[nodiscard]]
261  inline bool
262  is_socket(file_status __s) noexcept
263  { return __s.type() == file_type::socket; }
264 
265  [[nodiscard]]
266  inline bool
267  is_socket(const path& __p)
268  { return is_socket(status(__p)); }
269 
270  [[nodiscard]]
271  inline bool
272  is_socket(const path& __p, error_code& __ec) noexcept
273  { return is_socket(status(__p, __ec)); }
274 
275  [[nodiscard]]
276  inline bool
277  is_symlink(file_status __s) noexcept
278  { return __s.type() == file_type::symlink; }
279 
280  [[nodiscard]]
281  inline bool
282  is_symlink(const path& __p)
283  { return is_symlink(symlink_status(__p)); }
284 
285  [[nodiscard]]
286  inline bool
287  is_symlink(const path& __p, error_code& __ec) noexcept
288  { return is_symlink(symlink_status(__p, __ec)); }
289 
290  [[nodiscard]]
291  file_time_type last_write_time(const path& __p);
292 
293  [[nodiscard]]
294  file_time_type last_write_time(const path& __p, error_code& __ec) noexcept;
295 
296  void last_write_time(const path& __p, file_time_type __new_time);
297  void last_write_time(const path& __p, file_time_type __new_time,
298  error_code& __ec) noexcept;
299 
300  void
301  permissions(const path& __p, perms __prms,
302  perm_options __opts = perm_options::replace);
303 
304  inline void
305  permissions(const path& __p, perms __prms, error_code& __ec) noexcept
306  { permissions(__p, __prms, perm_options::replace, __ec); }
307 
308  void
309  permissions(const path& __p, perms __prms, perm_options __opts,
310  error_code& __ec) noexcept;
311 
312  [[nodiscard]]
313  inline path proximate(const path& __p, error_code& __ec)
314  { return proximate(__p, current_path(), __ec); }
315 
316  [[nodiscard]]
317  path proximate(const path& __p, const path& __base = current_path());
318 
319  [[nodiscard]]
320  path proximate(const path& __p, const path& __base, error_code& __ec);
321 
322  [[nodiscard]]
323  path read_symlink(const path& __p);
324 
325  [[nodiscard]]
326  path read_symlink(const path& __p, error_code& __ec);
327 
328  [[nodiscard]]
329  inline path relative(const path& __p, error_code& __ec)
330  { return relative(__p, current_path(), __ec); }
331 
332  [[nodiscard]]
333  path relative(const path& __p, const path& __base = current_path());
334 
335  [[nodiscard]]
336  path relative(const path& __p, const path& __base, error_code& __ec);
337 
338  bool remove(const path& __p);
339  bool remove(const path& __p, error_code& __ec) noexcept;
340 
341  uintmax_t remove_all(const path& __p);
342  uintmax_t remove_all(const path& __p, error_code& __ec);
343 
344  void rename(const path& __from, const path& __to);
345  void rename(const path& __from, const path& __to, error_code& __ec) noexcept;
346 
347  void resize_file(const path& __p, uintmax_t __size);
348  void resize_file(const path& __p, uintmax_t __size, error_code& __ec) noexcept;
349 
350  [[nodiscard]]
351  space_info space(const path& __p);
352 
353  [[nodiscard]]
354  space_info space(const path& __p, error_code& __ec) noexcept;
355 
356  [[nodiscard]]
357  file_status status(const path& __p);
358 
359  [[nodiscard]]
360  file_status status(const path& __p, error_code& __ec) noexcept;
361 
362  [[nodiscard]]
363  inline bool status_known(file_status __s) noexcept
364  { return __s.type() != file_type::none; }
365 
366  [[nodiscard]]
367  file_status symlink_status(const path& __p);
368 
369  [[nodiscard]]
370  file_status symlink_status(const path& __p, error_code& __ec) noexcept;
371 
372  [[nodiscard]]
373  path temp_directory_path();
374 
375  [[nodiscard]]
376  path temp_directory_path(error_code& __ec);
377 
378  [[nodiscard]]
379  path weakly_canonical(const path& __p);
380 
381  [[nodiscard]]
382  path weakly_canonical(const path& __p, error_code& __ec);
383 
384  /// @} group filesystem
385 } // namespace filesystem
386 
387 _GLIBCXX_END_NAMESPACE_VERSION
388 } // namespace std
389 
390 #endif // C++17
391 
392 #endif // _GLIBCXX_FS_OPS_H
copy_options
Bitmask type controlling effects of filesystem::copy
Definition: bits/fs_fwd.h:84
perms
Bitmask type representing file access permissions.
Definition: bits/fs_fwd.h:140
perm_options
Bitmask type controlling changes to permissions.
Definition: bits/fs_fwd.h:209
__file_clock::time_point file_time_type
The type used for file timestamps.
Definition: bits/fs_fwd.h:314
ISO C++ entities toplevel namespace is std.
constexpr _Iterator __base(_Iterator __it)