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
;
|
(depuis C++17) | |
Retourne une chaîne d'octets explicative. Cette chaîne explicative contient la chaîne explicative passée lors de la construction. Les implémentations sont encouragées à inclure les noms de chemin de path1() et path2() au format natif ainsi que la chaîne std::system_error::what() dans la chaîne retournée.
Paramètres
(aucun)
Valeur de retour
Une chaîne d'octets explicative de style C qui contient la chaîne explicative passée lors de la construction.
Exemple
Exécuter ce code
#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); } }
Sortie possible :
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(): ""