/*============================================================================= Copyright (c) 2001-2014 Joel de Guzman 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) ==============================================================================*/ #if !defined(BOOST_SPIRIT_X3_CHAR_APRIL_16_2006_1051AM) #define BOOST_SPIRIT_X3_CHAR_APRIL_16_2006_1051AM #include #include #include #include #include namespace boost { namespace spirit { namespace x3 { namespace standard { typedef any_char char_type; auto const char_ = char_type{}; inline literal_char lit(char ch) { return { ch }; } inline literal_char lit(wchar_t ch) { return { ch }; } } using standard::char_type; using standard::char_; using standard::lit; #ifndef BOOST_SPIRIT_NO_STANDARD_WIDE namespace standard_wide { typedef any_char char_type; auto const char_ = char_type{}; inline literal_char lit(wchar_t ch) { return { ch }; } } #endif namespace ascii { typedef any_char char_type; auto const char_ = char_type{}; inline literal_char lit(char ch) { return { ch }; } inline literal_char lit(wchar_t ch) { return { ch }; } } namespace iso8859_1 { typedef any_char char_type; auto const char_ = char_type{}; inline literal_char lit(char ch) { return { ch }; } inline literal_char lit(wchar_t ch) { return { ch }; } } namespace extension { template <> struct as_parser { typedef literal_char< char_encoding::standard, unused_type> type; typedef type value_type; static type call(char ch) { return { ch }; } }; #ifndef BOOST_SPIRIT_NO_STANDARD_WIDE template <> struct as_parser { typedef literal_char< char_encoding::standard_wide, unused_type> type; typedef type value_type; static type call(wchar_t ch) { return { ch }; } }; #endif template <> struct as_parser { typedef literal_char< char_encoding::standard, unused_type> type; typedef type value_type; static type call(char const ch[]) { return { ch[0] }; } }; #ifndef BOOST_SPIRIT_NO_STANDARD_WIDE template <> struct as_parser { typedef literal_char< char_encoding::standard_wide, unused_type> type; typedef type value_type; static type call(wchar_t const ch[] ) { return { ch[0] }; } }; #endif } }}} #endif