25namespace http_field_parsers
39namespace try_extract_field_details
51template<
typename Parsed_Field_Type >
60template<
typename,
typename = restinio::utils::metaprogramming::
void_t<> >
69 expected_t< T, restinio::easy_parser::parse_error_t >,
70 decltype(T::try_parse(std::declval<string_view_t>()))
75 > :
public std::true_type
81template<
typename Parsed_Field_Type >
89 "Parsed_Field_Type should have static try_parse method that "
90 "accepts string_view_t and returns "
91 "expected_t<Parsed_Field_Type, parse_error_t>" );
148template<
typename Parsed_Field_Type,
typename Extra_Data >
161 using namespace try_extract_field_details;
206template<
typename Parsed_Field_Type,
typename Extra_Data >
219 using namespace try_extract_field_details;
222 req.header().opt_value_of( field_id ),
Information about parsing error.
#define RESTINIO_NODISCARD
An very small, simple and somewhat limited implementation of recursive-descent parser.
RESTINIO_NODISCARD auto try_parse_field(const generic_request_t< Extra_Data > &req, string_view_t field_name, string_view_t default_value=string_view_t{})
A helper function for extraction and parsing a value of HTTP-field.
run_on_this_thread_settings_t< Traits > on_this_thread()
A special marker for the case when http_server must be run on the context of the current thread.
nonstd::string_view string_view_t
std::enable_if< std::is_same< Parameter_Container, query_string_params_t >::value||std::is_same< Parameter_Container, router::route_params_t >::value, optional_t< Value_Type > >::type opt_value(const Parameter_Container ¶ms, string_view_t key)
Gets the value of a parameter specified by key wrapped in optional_t<Value_Type> if parameter exists ...
http_field_t
C++ enum that repeats nodejs c-style enum.
A special type to be returned in the case if HTTP-field isn't found in a request.