eedb/share/include/tao/json/external/pegtl/internal/istring.hh
2017-02-26 09:32:45 +01:00

90 lines
2.3 KiB
C++

// 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 <type_traits>
#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