// // 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/url // #ifndef BOOST_URL_RFC_AUTHORITY_RULE_HPP #define BOOST_URL_RFC_AUTHORITY_RULE_HPP #include #include #include namespace boost { namespace urls { namespace implementation_defined { struct authority_rule_t { using value_type = authority_view; BOOST_URL_DECL auto parse( char const*& it, char const* end ) const noexcept -> system::result; }; } // implementation_defined /** Rule for authority @par Value Type @code using value_type = authority_view; @endcode @par Example Rules are used with the function @ref grammar::parse. @code system::result< authority_view > rv = grammar::parse( "user:pass@example.com:8080", authority_rule ); @endcode @par BNF @code authority = [ userinfo "@" ] host [ ":" port ] @endcode @par Specification @li 3.2. Authority (rfc3986) @see @ref authority_view, @ref grammar::parse, @ref parse_authority. */ constexpr implementation_defined::authority_rule_t authority_rule{}; } // urls } // boost #endif