// Copyright (c) 2014-2022 Dr. Colin Hirsch and Daniel Frey // Please see LICENSE for license or visit https://github.com/taocpp/PEGTL/ #ifndef TAO_PEGTL_NORMAL_HPP #define TAO_PEGTL_NORMAL_HPP #include #include #include #include "apply_mode.hpp" #include "config.hpp" #include "match.hpp" #include "parse_error.hpp" #include "rewind_mode.hpp" #include "internal/enable_control.hpp" #include "internal/has_match.hpp" #if defined( __cpp_exceptions ) #include "demangle.hpp" #else #include "internal/dependent_false.hpp" #include #endif namespace TAO_PEGTL_NAMESPACE { template< typename Rule > struct normal { static constexpr bool enable = internal::enable_control< Rule >; template< typename ParseInput, typename... States > static void start( const ParseInput& /*unused*/, States&&... /*unused*/ ) noexcept {} template< typename ParseInput, typename... States > static void success( const ParseInput& /*unused*/, States&&... /*unused*/ ) noexcept {} template< typename ParseInput, typename... States > static void failure( const ParseInput& /*unused*/, States&&... /*unused*/ ) noexcept {} template< typename ParseInput, typename... States > [[noreturn]] static void raise( const ParseInput& in, States&&... /*unused*/ ) { #if defined( __cpp_exceptions ) throw parse_error( "parse error matching " + std::string( demangle< Rule >() ), in ); #else static_assert( internal::dependent_false< Rule >, "exception support required for normal< Rule >::raise()" ); (void)in; std::terminate(); #endif } template< template< typename... > class Action, typename Iterator, typename ParseInput, typename... States > static auto apply( const Iterator& begin, const ParseInput& in, States&&... st ) noexcept( noexcept( Action< Rule >::apply( std::declval< const typename ParseInput::action_t& >(), st... ) ) ) -> decltype( Action< Rule >::apply( std::declval< const typename ParseInput::action_t& >(), st... ) ) { const typename ParseInput::action_t action_input( begin, in ); return Action< Rule >::apply( action_input, st... ); } template< template< typename... > class Action, typename ParseInput, typename... States > static auto apply0( const ParseInput& /*unused*/, States&&... st ) noexcept( noexcept( Action< Rule >::apply0( st... ) ) ) -> decltype( Action< Rule >::apply0( st... ) ) { return Action< Rule >::apply0( st... ); } template< apply_mode A, rewind_mode M, template< typename... > class Action, template< typename... > class Control, typename ParseInput, typename... States > [[nodiscard]] static bool match( ParseInput& in, States&&... st ) { if constexpr( internal::has_match< bool, Rule, A, M, Action, Control, ParseInput, States... > ) { return Action< Rule >::template match< Rule, A, M, Action, Control >( in, st... ); } else { return TAO_PEGTL_NAMESPACE::match< Rule, A, M, Action, Control >( in, st... ); } } }; } // namespace TAO_PEGTL_NAMESPACE #endif