// <system_error> -*- C++ -*- // Copyright (C) 2007-2017 Free Software Foundation, Inc. // // This file is part of the GNU ISO C++ Library. This library is free // software; you can redistribute it and/or modify it under the // terms of the GNU General Public License as published by the // Free Software Foundation; either version 3, or (at your option) // any later version. // This library is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // Under Section 7 of GPL version 3, you are granted additional // permissions described in the GCC Runtime Library Exception, version // 3.1, as published by the Free Software Foundation. // You should have received a copy of the GNU General Public License and // a copy of the GCC Runtime Library Exception along with this program; // see the files COPYING3 and COPYING.RUNTIME respectively. If not, see // <http://www.gnu.org/licenses/>. /** @file include/system_error * This is a Standard C++ Library header. */ #ifndef _GLIBCXX_SYSTEM_ERROR #define _GLIBCXX_SYSTEM_ERROR 1 #pragma GCC system_header #if __cplusplus < 201103L # include <bits/c++0x_warning.h> #else #include <bits/c++config.h> #include <bits/error_constants.h> #include <iosfwd> #include <stdexcept> namespace std _GLIBCXX_VISIBILITY(default) { _GLIBCXX_BEGIN_NAMESPACE_VERSION class error_code; class error_condition; class system_error; /// is_error_code_enum template<typename _Tp> struct is_error_code_enum : public false_type { }; /// is_error_condition_enum template<typename _Tp> struct is_error_condition_enum : public false_type { }; template<> struct is_error_condition_enum<errc> : public true_type { }; #if __cplusplus > 201402L template <typename _Tp> inline constexpr bool is_error_code_enum_v = is_error_code_enum<_Tp>::value; template <typename _Tp> inline constexpr bool is_error_condition_enum_v = is_error_condition_enum<_Tp>::value; #endif // C++17 inline namespace _V2 { /// error_category class error_category { public: constexpr error_category() noexcept = default; virtual ~error_category(); error_category(const error_category&) = delete; error_category& operator=(const error_category&) = delete; virtual const char* name() const noexcept = 0; // We need two different virtual functions here, one returning a // COW string and one returning an SSO string. Their positions in the // vtable must be consistent for dynamic dispatch to work, but which one // the name "message()" finds depends on which ABI the caller is using. #if _GLIBCXX_USE_CXX11_ABI private: _GLIBCXX_DEFAULT_ABI_TAG virtual __cow_string _M_message(int) const; public: _GLIBCXX_DEFAULT_ABI_TAG virtual string message(int) const = 0; #else virtual string message(int) const = 0; private: virtual __sso_string _M_message(int) const; #endif public: virtual error_condition default_error_condition(int __i) const noexcept; virtual bool equivalent(int __i, const error_condition& __cond) const noexcept; virtual bool equivalent(const error_code& __code, int __i) const noexcept; bool operator<(const error_category& __other) const noexcept { return less<const error_category*>()(this, &__other); } bool operator==(const error_category& __other) const noexcept { return this == &__other; } bool operator!=(const error_category& __other) const noexcept { return this != &__other; } }; // DR 890. _GLIBCXX_CONST const error_category& system_category() noexcept; _GLIBCXX_CONST const error_category& generic_category() noexcept; } // end inline namespace error_code make_error_code(errc) noexcept; template<typename _Tp> struct hash; /// error_code // Implementation-specific error identification struct error_code { error_code() noexcept : _M_value(0), _M_cat(&system_category()) { } error_code(int __v, const error_category& __cat) noexcept : _M_value(__v), _M_cat(&__cat) { } template<typename _ErrorCodeEnum, typename = typename enable_if<is_error_code_enum<_ErrorCodeEnum>::value>::type> error_code(_ErrorCodeEnum __e) noexcept { *this = make_error_code(__e); } void assign(int __v, const error_category& __cat) noexcept { _M_value = __v; _M_cat = &__cat; } void clear() noexcept { assign(0, system_category()); } // DR 804. template<typename _ErrorCodeEnum> typename enable_if<is_error_code_enum<_ErrorCodeEnum>::value, error_code&>::type operator=(_ErrorCodeEnum __e) noexcept { return *this = make_error_code(__e); } int value() const noexcept { return _M_value; } const error_category& category() const noexcept { return *_M_cat; } error_condition default_error_condition() const noexcept; _GLIBCXX_DEFAULT_ABI_TAG string message() const { return category().message(value()); } explicit operator bool() const noexcept { return _M_value != 0; } // DR 804. private: friend class hash<error_code>; int _M_value; const error_category* _M_cat; }; // 19.4.2.6 non-member functions inline error_code make_error_code(errc __e) noexcept { return error_code(static_cast<int>(__e), generic_category()); } inline bool operator<(const error_code& __lhs, const error_code& __rhs) noexcept { return (__lhs.category() < __rhs.category() || (__lhs.category() == __rhs.category() && __lhs.value() < __rhs.value())); } template<typename _CharT, typename _Traits> basic_ostream<_CharT, _Traits>& operator<<(basic_ostream<_CharT, _Traits>& __os, const error_code& __e) { return (__os << __e.category().name() << ':' << __e.value()); } error_condition make_error_condition(errc) noexcept; /// error_condition // Portable error identification struct error_condition { error_condition() noexcept : _M_value(0), _M_cat(&generic_category()) { } error_condition(int __v, const error_category& __cat) noexcept : _M_value(__v), _M_cat(&__cat) { } template<typename _ErrorConditionEnum, typename = typename enable_if<is_error_condition_enum<_ErrorConditionEnum>::value>::type> error_condition(_ErrorConditionEnum __e) noexcept { *this = make_error_condition(__e); } void assign(int __v, const error_category& __cat) noexcept { _M_value = __v; _M_cat = &__cat; } // DR 804. template<typename _ErrorConditionEnum> typename enable_if<is_error_condition_enum <_ErrorConditionEnum>::value, error_condition&>::type operator=(_ErrorConditionEnum __e) noexcept { return *this = make_error_condition(__e); } void clear() noexcept { assign(0, generic_category()); } // 19.4.3.4 observers int value() const noexcept { return _M_value; } const error_category& category() const noexcept { return *_M_cat; } _GLIBCXX_DEFAULT_ABI_TAG string message() const { return category().message(value()); } explicit operator bool() const noexcept { return _M_value != 0; } // DR 804. private: int _M_value; const error_category* _M_cat; }; // 19.4.3.6 non-member functions inline error_condition make_error_condition(errc __e) noexcept { return error_condition(static_cast<int>(__e), generic_category()); } inline bool operator<(const error_condition& __lhs, const error_condition& __rhs) noexcept { return (__lhs.category() < __rhs.category() || (__lhs.category() == __rhs.category() && __lhs.value() < __rhs.value())); } // 19.4.4 Comparison operators inline bool operator==(const error_code& __lhs, const error_code& __rhs) noexcept { return (__lhs.category() == __rhs.category() && __lhs.value() == __rhs.value()); } inline bool operator==(const error_code& __lhs, const error_condition& __rhs) noexcept { return (__lhs.category().equivalent(__lhs.value(), __rhs) || __rhs.category().equivalent(__lhs, __rhs.value())); } inline bool operator==(const error_condition& __lhs, const error_code& __rhs) noexcept { return (__rhs.category().equivalent(__rhs.value(), __lhs) || __lhs.category().equivalent(__rhs, __lhs.value())); } inline bool operator==(const error_condition& __lhs, const error_condition& __rhs) noexcept { return (__lhs.category() == __rhs.category() && __lhs.value() == __rhs.value()); } inline bool operator!=(const error_code& __lhs, const error_code& __rhs) noexcept { return !(__lhs == __rhs); } inline bool operator!=(const error_code& __lhs, const error_condition& __rhs) noexcept { return !(__lhs == __rhs); } inline bool operator!=(const error_condition& __lhs, const error_code& __rhs) noexcept { return !(__lhs == __rhs); } inline bool operator!=(const error_condition& __lhs, const error_condition& __rhs) noexcept { return !(__lhs == __rhs); } /** * @brief Thrown to indicate error code of underlying system. * * @ingroup exceptions */ class system_error : public std::runtime_error { private: error_code _M_code; public: system_error(error_code __ec = error_code()) : runtime_error(__ec.message()), _M_code(__ec) { } system_error(error_code __ec, const string& __what) : runtime_error(__what + ": " + __ec.message()), _M_code(__ec) { } system_error(error_code __ec, const char* __what) : runtime_error(__what + (": " + __ec.message())), _M_code(__ec) { } system_error(int __v, const error_category& __ecat, const char* __what) : system_error(error_code(__v, __ecat), __what) { } system_error(int __v, const error_category& __ecat) : runtime_error(error_code(__v, __ecat).message()), _M_code(__v, __ecat) { } system_error(int __v, const error_category& __ecat, const string& __what) : runtime_error(__what + ": " + error_code(__v, __ecat).message()), _M_code(__v, __ecat) { } virtual ~system_error() noexcept; const error_code& code() const noexcept { return _M_code; } }; _GLIBCXX_END_NAMESPACE_VERSION } // namespace #include <bits/functional_hash.h> namespace std _GLIBCXX_VISIBILITY(default) { _GLIBCXX_BEGIN_NAMESPACE_VERSION #ifndef _GLIBCXX_COMPATIBILITY_CXX0X // DR 1182. /// std::hash specialization for error_code. template<> struct hash<error_code> : public __hash_base<size_t, error_code> { size_t operator()(const error_code& __e) const noexcept { const size_t __tmp = std::_Hash_impl::hash(__e._M_value); return std::_Hash_impl::__hash_combine(__e._M_cat, __tmp); } }; #endif // _GLIBCXX_COMPATIBILITY_CXX0X #if __cplusplus > 201402L // DR 2686. /// std::hash specialization for error_condition. template<> struct hash<error_condition> : public __hash_base<size_t, error_condition> { size_t operator()(const error_condition& __e) const noexcept { const size_t __tmp = std::_Hash_impl::hash(__e.value()); return std::_Hash_impl::__hash_combine(__e.category(), __tmp); } }; #endif _GLIBCXX_END_NAMESPACE_VERSION } // namespace #endif // C++11 #endif // _GLIBCXX_SYSTEM_ERROR
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
backward | Folder | 0755 |
|
|
bits | Folder | 0755 |
|
|
debug | Folder | 0755 |
|
|
decimal | Folder | 0755 |
|
|
experimental | Folder | 0755 |
|
|
ext | Folder | 0755 |
|
|
parallel | Folder | 0755 |
|
|
profile | Folder | 0755 |
|
|
tr1 | Folder | 0755 |
|
|
tr2 | Folder | 0755 |
|
|
algorithm | File | 2.46 KB | 0644 |
|
any | File | 18.48 KB | 0644 |
|
array | File | 11.12 KB | 0644 |
|
atomic | File | 40.01 KB | 0644 |
|
bitset | File | 44.81 KB | 0644 |
|
cassert | File | 1.61 KB | 0644 |
|
ccomplex | File | 1.3 KB | 0644 |
|
cctype | File | 2.35 KB | 0644 |
|
cerrno | File | 1.73 KB | 0644 |
|
cfenv | File | 2 KB | 0644 |
|
cfloat | File | 1.84 KB | 0644 |
|
chrono | File | 29.38 KB | 0644 |
|
cinttypes | File | 2.11 KB | 0644 |
|
ciso646 | File | 1.43 KB | 0644 |
|
climits | File | 1.87 KB | 0644 |
|
clocale | File | 1.86 KB | 0644 |
|
cmath | File | 47.35 KB | 0644 |
|
codecvt | File | 5.22 KB | 0644 |
|
complex | File | 52.93 KB | 0644 |
|
complex.h | File | 1.43 KB | 0644 |
|
condition_variable | File | 8.74 KB | 0644 |
|
csetjmp | File | 1.9 KB | 0644 |
|
csignal | File | 1.81 KB | 0644 |
|
cstdalign | File | 1.37 KB | 0644 |
|
cstdarg | File | 1.82 KB | 0644 |
|
cstdbool | File | 1.37 KB | 0644 |
|
cstddef | File | 6.29 KB | 0644 |
|
cstdint | File | 2.12 KB | 0644 |
|
cstdio | File | 4.33 KB | 0644 |
|
cstdlib | File | 6.18 KB | 0644 |
|
cstring | File | 3.05 KB | 0644 |
|
ctgmath | File | 1.33 KB | 0644 |
|
ctime | File | 2.08 KB | 0644 |
|
cuchar | File | 2.16 KB | 0644 |
|
cwchar | File | 6.36 KB | 0644 |
|
cwctype | File | 2.73 KB | 0644 |
|
cxxabi.h | File | 21.46 KB | 0644 |
|
deque | File | 2.6 KB | 0644 |
|
exception | File | 4.67 KB | 0644 |
|
fenv.h | File | 1.97 KB | 0644 |
|
forward_list | File | 1.54 KB | 0644 |
|
fstream | File | 33.05 KB | 0644 |
|
functional | File | 38.64 KB | 0644 |
|
future | File | 49.49 KB | 0644 |
|
initializer_list | File | 2.9 KB | 0644 |
|
iomanip | File | 15.75 KB | 0644 |
|
ios | File | 1.56 KB | 0644 |
|
iosfwd | File | 6.76 KB | 0644 |
|
iostream | File | 2.63 KB | 0644 |
|
istream | File | 32.07 KB | 0644 |
|
iterator | File | 2.58 KB | 0644 |
|
limits | File | 67.56 KB | 0644 |
|
list | File | 2.53 KB | 0644 |
|
locale | File | 1.45 KB | 0644 |
|
map | File | 2.5 KB | 0644 |
|
math.h | File | 4.28 KB | 0644 |
|
memory | File | 4.6 KB | 0644 |
|
mutex | File | 17.88 KB | 0644 |
|
new | File | 7.33 KB | 0644 |
|
numeric | File | 5.11 KB | 0644 |
|
optional | File | 30.39 KB | 0644 |
|
ostream | File | 21.46 KB | 0644 |
|
queue | File | 2.41 KB | 0644 |
|
random | File | 1.65 KB | 0644 |
|
ratio | File | 19.42 KB | 0644 |
|
regex | File | 1.85 KB | 0644 |
|
scoped_allocator | File | 15.84 KB | 0644 |
|
set | File | 2.5 KB | 0644 |
|
shared_mutex | File | 18.95 KB | 0644 |
|
sstream | File | 26.21 KB | 0644 |
|
stack | File | 2.33 KB | 0644 |
|
stdexcept | File | 7.79 KB | 0644 |
|
stdlib.h | File | 2.2 KB | 0644 |
|
streambuf | File | 28.87 KB | 0644 |
|
string | File | 1.89 KB | 0644 |
|
string_view | File | 20.8 KB | 0644 |
|
system_error | File | 11.25 KB | 0644 |
|
tgmath.h | File | 1.33 KB | 0644 |
|
thread | File | 10.03 KB | 0644 |
|
tuple | File | 58.22 KB | 0644 |
|
type_traits | File | 90.28 KB | 0644 |
|
typeindex | File | 3.02 KB | 0644 |
|
typeinfo | File | 7.51 KB | 0644 |
|
unordered_map | File | 1.81 KB | 0644 |
|
unordered_set | File | 1.81 KB | 0644 |
|
utility | File | 12.16 KB | 0644 |
|
valarray | File | 39.33 KB | 0644 |
|
variant | File | 42.09 KB | 0644 |
|
vector | File | 2.68 KB | 0644 |
|