// // 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_URI_REFERENCE_RULE_HPP #define BOOST_URL_RFC_URI_REFERENCE_RULE_HPP #include #include #include namespace boost { namespace urls { /** Rule for URI-reference @par Value Type @code using value_type = url_view; @endcode; @par Example Rules are used with the function @ref grammar::parse. @code system::result< url_view > rv = grammar::parse( "ws://echo.example.com/?name=boost#demo", uri_reference_rule ); @endcode @par BNF @code URI-reference = URI / relative-ref URI = scheme ":" hier-part [ "?" query ] [ "#" fragment ] relative-ref = relative-part [ "?" query ] [ "#" fragment ] @endcode @par Specification @li 3. Syntax Components (rfc3986) @see @ref grammar::parse, @ref parse_uri_reference, @ref url_view. */ #ifdef BOOST_URL_DOCS constexpr __implementation_defined__ uri_reference_rule{}; #else struct uri_reference_rule_t { using value_type = url_view; BOOST_URL_DECL auto parse( char const*& it, char const* end ) const noexcept -> system::result; }; constexpr uri_reference_rule_t uri_reference_rule{}; #endif } // urls } // boost #endif