table of contents
std::system_category(3) | C++ Standard Libary | std::system_category(3) |
NAME¶
std::system_category - std::system_category
Synopsis¶
Defined in header <system_error>
const std::error_category& system_category() noexcept; (since
C++11)
Obtains a reference to the static error category object for errors reported
by the
operating system. The object is required to override the virtual function
std::error_category::name() to return a pointer to the string
"system". It is also
required to override the virtual function
std::error_category::default_error_condition() to map the error codes that
match
POSIX errno values to std::generic_category.
Parameters¶
(none)
Return value¶
A reference to the static object of unspecified runtime type,
derived from
std::error_category.
Notes¶
On Windows, system_category() typically maps some Windows error
codes to POSIX ones.
On POSIX, system_category() tends to be equivalent to std::generic_category()
except
for the name.
Example¶
// Run this code
#include <iomanip>
#include <iostream>
#include <string>
#include <system_error>
int main()
{
for (int const code : {EDOM, 10001})
{
const std::error_condition econd =
std::system_category().default_error_condition(code);
std::cout << "Category: " << econd.category().name()
<< '\n'
<< "Value: " << econd.value() << '\n'
<< "Message: " << econd.message() <<
"\n\n";
}
}
Possible output:¶
Category: generic
Value: 33
Message: Numerical argument out of domain
Category: system
Value: 10001
Message: Unknown error 10001
See also¶
generic_category identifies the generic error category
(C++11) (function)
errc the std::error_condition enumeration listing all standard <cerrno>
(C++11) macro constants
(class)
2024.06.10 | http://cppreference.com |