Namespaces
Variants

std::filesystem::filesystem_error:: what

From cppreference.net
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

#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(): ""