error.ipp 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. //
  2. // Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
  3. //
  4. // Distributed under the Boost Software License, Version 1.0. (See accompanying
  5. // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
  6. //
  7. // Official repository: https://github.com/boostorg/beast
  8. //
  9. #ifndef BOOST_BEAST_HTTP_IMPL_ERROR_IPP
  10. #define BOOST_BEAST_HTTP_IMPL_ERROR_IPP
  11. #include <type_traits>
  12. namespace boost {
  13. namespace system {
  14. template<>
  15. struct is_error_code_enum<beast::http::error>
  16. {
  17. static bool const value = true;
  18. };
  19. } // system
  20. namespace beast {
  21. namespace http {
  22. namespace detail {
  23. class http_error_category : public error_category
  24. {
  25. public:
  26. const char*
  27. name() const noexcept override
  28. {
  29. return "beast.http";
  30. }
  31. std::string
  32. message(int ev) const override
  33. {
  34. switch(static_cast<error>(ev))
  35. {
  36. case error::end_of_stream: return "end of stream";
  37. case error::partial_message: return "partial message";
  38. case error::need_more: return "need more";
  39. case error::unexpected_body: return "unexpected body";
  40. case error::need_buffer: return "need buffer";
  41. case error::end_of_chunk: return "end of chunk";
  42. case error::buffer_overflow: return "buffer overflow";
  43. case error::header_limit: return "header limit exceeded";
  44. case error::body_limit: return "body limit exceeded";
  45. case error::bad_alloc: return "bad alloc";
  46. case error::bad_line_ending: return "bad line ending";
  47. case error::bad_method: return "bad method";
  48. case error::bad_target: return "bad target";
  49. case error::bad_version: return "bad version";
  50. case error::bad_status: return "bad status";
  51. case error::bad_reason: return "bad reason";
  52. case error::bad_field: return "bad field";
  53. case error::bad_value: return "bad value";
  54. case error::bad_content_length: return "bad Content-Length";
  55. case error::bad_transfer_encoding: return "bad Transfer-Encoding";
  56. case error::bad_chunk: return "bad chunk";
  57. case error::bad_chunk_extension: return "bad chunk extension";
  58. case error::bad_obs_fold: return "bad obs-fold";
  59. default:
  60. return "beast.http error";
  61. }
  62. }
  63. error_condition
  64. default_error_condition(
  65. int ev) const noexcept override
  66. {
  67. return error_condition{ev, *this};
  68. }
  69. bool
  70. equivalent(int ev,
  71. error_condition const& condition
  72. ) const noexcept override
  73. {
  74. return condition.value() == ev &&
  75. &condition.category() == this;
  76. }
  77. bool
  78. equivalent(error_code const& error,
  79. int ev) const noexcept override
  80. {
  81. return error.value() == ev &&
  82. &error.category() == this;
  83. }
  84. };
  85. inline
  86. error_category const&
  87. get_http_error_category()
  88. {
  89. static http_error_category const cat{};
  90. return cat;
  91. }
  92. } // detail
  93. inline
  94. error_code
  95. make_error_code(error ev)
  96. {
  97. return error_code{
  98. static_cast<std::underlying_type<error>::type>(ev),
  99. detail::get_http_error_category()};
  100. }
  101. } // http
  102. } // beast
  103. } // boost
  104. #endif