- filesystem[meta header]
- std::filesystem[meta namespace]
- function[meta id-type]
- cpp17[meta cpp]
namespace std::filesystem {
std::uintmax_t remove_all(const path& p); // (1)
std::uintmax_t remove_all(const path& p, std::error_code& ec); // (2)
}
- path[link path.md]
- std::uintmax_t[link /reference/cstdint/uintmax_t.md]
再帰的にファイル・ディレクトリを削除する。
remove()
関数では、環境によって空でないディレクトリを削除できない場合があるため、空でないディレクトリを削除するために、本関数を使用する。
- パス
p
のコンテンツを、再帰的に削除する - POSIX環境では、それぞれのコンテンツの削除に、
remove()
関数を使用する
削除されたファイルの数が返る
- (1) : ファイルシステムがエラーを報告する場合がある。エラーが発生した場合は、
std::filesystem::filesystem_error
例外を送出する - (2) : ディレクトリを走査する際にメモリ確保に失敗した場合、例外を送出する可能性がある
#include <cassert>
#include <filesystem>
#include <fstream>
namespace fs = std::filesystem;
int main()
{
std::ofstream{"regular.txt"};
fs::create_directory("empty_dir");
fs::create_directory("non_empty_dir");
std::ofstream{"non_empty_dir/file_in_dir.txt"};
// 単一ファイルを削除
fs::remove_all("regular.txt");
// 空、および非空のディレクトリを削除
fs::remove_all("empty_dir");
fs::remove_all("non_empty_dir");
// 存在しないファイルを削除。
// エラーにはならず、0が返る
std::uintmax_t result = fs::remove_all("not_exist.file");
assert(result == 0);
assert(!fs::exists("regular.txt"));
assert(!fs::exists("empty_dir"));
assert(!fs::exists("non_empty_dir"));
}
- fs::remove_all[color ff0000]
- fs::create_directory[link create_directory.md]
- fs::exists[link exists.md]
- std::uintmax_t[link /reference/cstdint/uintmax_t.md]
- C++17
- Clang: 7.0 [mark verified]
- GCC: 8.1 [mark verified]
- Visual C++: