// Copyright (c) 2014-2016 Dr. Colin Hirsch and Daniel Frey // Please see LICENSE for license or visit https://github.com/ColinH/PEGTL/ #ifndef TAO_CPP_PEGTL_INTERNAL_ISTRING_HH #define TAO_CPP_PEGTL_INTERNAL_ISTRING_HH #include #include "result_on_found.hh" #include "skip_control.hh" #include "bump_util.hh" #include "trivial.hh" #include "../analysis/counted.hh" namespace tao_json_pegtl { namespace internal { template< char C > using is_alpha = std::integral_constant< bool, ( ( 'a' <= C ) && ( C <= 'z' ) ) || ( ( 'A' <= C ) && ( C <= 'Z' ) ) >; template< char C, bool A = is_alpha< C >::value > struct ichar_equal; template< char C > struct ichar_equal< C, true > { static bool match( const char c ) { return ( C | 0x20 ) == ( c | 0x20 ); } }; template< char C > struct ichar_equal< C, false > { static bool match( const char c ) { return c == C; } }; template< char ... Cs > struct istring_equal; template<> struct istring_equal<> { static bool match( const char * ) { return true; } }; template< char C, char ... Cs > struct istring_equal< C, Cs ... > { static bool match( const char * r ) { return ichar_equal< C >::match( * r ) && istring_equal< Cs ... >::match( r + 1 ); } }; template< char ... Cs > struct istring; template< char ... Cs > struct skip_control< istring< Cs ... > > : std::true_type {}; template<> struct istring<> : trivial< true > {}; template< char ... Cs > struct istring { using analyze_t = analysis::counted< analysis::rule_type::ANY, sizeof ... ( Cs ) >; template< typename Input > static bool match( Input & in ) { if ( in.size( sizeof ... ( Cs ) ) >= sizeof ... ( Cs ) ) { if ( istring_equal< Cs ... >::match( in.begin() ) ) { bump< result_on_found::SUCCESS, Input, char, Cs ... >( in, sizeof ... ( Cs ) ); return true; } } return false; } }; } // namespace internal } // namespace tao_json_pegtl #endif