xref: /netbsd-src/external/gpl3/gcc/dist/libstdc++-v3/include/bits/fs_ops.h (revision 0a3071956a3a9fdebdbf7f338cf2d439b45fc728)
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 
_GLIBCXX_VISIBILITY(default)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
393