| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283 |
- //
- // Copyright (c) 2021 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_GRAMMAR_DIGIT_CHARS_HPP
- #define BOOST_URL_GRAMMAR_DIGIT_CHARS_HPP
- #include <boost/url/detail/config.hpp>
- #include <boost/url/grammar/detail/charset.hpp>
- namespace boost {
- namespace urls {
- namespace grammar {
- namespace implementation_defined {
- struct digit_chars_t
- {
- constexpr
- bool
- operator()(char c) const noexcept
- {
- return c >= '0' && c <= '9';
- }
- #ifdef BOOST_URL_USE_SSE2
- char const*
- find_if(
- char const* first,
- char const* last) const noexcept
- {
- return detail::find_if_pred(
- *this, first, last);
- }
- char const*
- find_if_not(
- char const* first,
- char const* last) const noexcept
- {
- return detail::find_if_not_pred(
- *this, first, last);
- }
- #endif
- };
- }
- /** The set of decimal digits
- @par Example
- Character sets are used with rules and the
- functions @ref find_if and @ref find_if_not.
- @code
- system::result< core::string_view > rv = parse( "2022", token_rule( digit_chars ) );
- @endcode
- @par BNF
- @code
- DIGIT = %x30-39
- ; 0-9
- @endcode
- @par Specification
- @li <a href="https://datatracker.ietf.org/doc/html/rfc5234#appendix-B.1"
- >B.1. Core Rules (rfc5234)</a>
- @see
- @ref find_if,
- @ref find_if_not,
- @ref parse,
- @ref token_rule.
- */
- constexpr implementation_defined::digit_chars_t digit_chars{};
- } // grammar
- } // urls
- } // boost
- #endif
|