liuxiaolong
2021-07-20 58d904a328c0d849769b483e901a0be9426b8209
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
//
// Copyright (c) 2016-2019 Vinnie Falco (vinnie dot falco at gmail dot com)
//
// Distributed under the Boost Software License, Version 1.0. (See accompanying
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
//
// Official repository: https://github.com/boostorg/beast
//
 
#ifndef BOOST_BEAST_ERROR_HPP
#define BOOST_BEAST_ERROR_HPP
 
#include <boost/beast/core/detail/config.hpp>
#include <boost/system/error_code.hpp>
#include <boost/system/system_error.hpp>
 
namespace boost {
namespace beast {
 
/// The type of error code used by the library
using error_code = boost::system::error_code;
 
/// The type of system error thrown by the library
using system_error = boost::system::system_error;
 
/// The type of error category used by the library
using error_category = boost::system::error_category;
 
/// A function to return the generic error category used by the library
#if BOOST_BEAST_DOXYGEN
error_category const&
generic_category();
#else
using boost::system::generic_category;
#endif
 
/// A function to return the system error category used by the library
#if BOOST_BEAST_DOXYGEN
error_category const&
system_category();
#else
using boost::system::system_category;
#endif
 
/// The type of error condition used by the library
using error_condition = boost::system::error_condition;
 
/// The set of constants used for cross-platform error codes
#if BOOST_BEAST_DOXYGEN
enum errc{};
#else
namespace errc = boost::system::errc;
#endif
 
//------------------------------------------------------------------------------
 
/// Error codes returned from library operations
enum class error
{
    /** The socket was closed due to a timeout
 
        This error indicates that a socket was closed due to a
        a timeout detected during an operation.
 
        Error codes with this value will compare equal to @ref condition::timeout.
    */
    timeout = 1
};
 
/// Error conditions corresponding to sets of library error codes.
enum class condition
{
    /** The operation timed out
 
        This error indicates that an operation took took too long.
    */
    timeout = 1
};
 
} // beast
} // boost
 
#include <boost/beast/core/impl/error.hpp>
#ifdef BOOST_BEAST_HEADER_ONLY
#include <boost/beast/core/impl/error.ipp>
#endif
 
#endif