std::filesystem::filesystem_error:: what
From cppreference.net
<
cpp
|
filesystem
|
filesystem error
C++
filesystem_error
| Member functions | ||||
|
filesystem_error::what
|
||||
| Inherited from std::system_error | ||||
|
const
char
*
what
(
)
const
noexcept
override
;
|
(seit C++17) | |
Gibt einen erklärenden Byte-String zurück. Dieser erklärende String enthält den bei der Konstruktion übergebenen erklärenden String. Implementierungen werden ermutigt, die Pfadnamen von path1() und path2() im nativen Format sowie den std::system_error::what() String ebenfalls in den zurückgegebenen String aufzunehmen.
Parameter
(keine)
Rückgabewert
Ein C-stye erklärender Byte-String, der den zur Konstruktionszeit übergebenen erklärenden String enthält.
Beispiel
Diesen Code ausführen
#include <cstdio> #include <filesystem> #include <iostream> #include <string_view> namespace fs = std::filesystem; void explain(std::string_view note, fs::filesystem_error const& ex) { std::cout << note << " exception:\n" << "what(): " << ex.what() << '\n' << "path1(): " << ex.path1() << ", path2(): " << ex.path2() << "\n\n"; } int main() { try { std::filesystem::rename("/dev", "/null"); } catch(fs::filesystem_error const& ex) { explain("fs::rename()", ex); } for (auto const path : {"/bool", "/bin/cat", "/bin/mouse"}) try { std::filesystem::create_directory(path); } catch(fs::filesystem_error const& ex) { explain("fs::create_directory()", ex); } }
Mögliche Ausgabe:
fs::rename() exception: what(): filesystem error: cannot rename: Permission denied [/dev] [/null] path1(): "/dev", path2(): "/null" fs::create_directory() exception: what(): filesystem error: cannot create directory: Permission denied [/bool] path1(): "/bool", path2(): "" fs::create_directory() exception: what(): filesystem error: cannot create directory: File exists [/bin/cat] path1(): "/bin/cat", path2(): "" fs::create_directory() exception: what(): filesystem error: cannot create directory: Read-only file system [/bin/mouse] path1(): "/bin/mouse", path2(): ""