/*============================================================================= Copyright (c) 2009 Hartmut Kaiser Copyright (c) 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(SPIRIT_X3_BOOL_SEP_29_2009_0709AM) #define SPIRIT_X3_BOOL_SEP_29_2009_0709AM #include #include #include namespace boost { namespace spirit { namespace x3 { template > struct bool_parser : parser> { typedef Encoding encoding; typedef T attribute_type; static bool const has_attribute = true; bool_parser() : policies() {} bool_parser(BoolPolicies const& policies) : policies(policies) {} template bool parse(Iterator& first, Iterator const& last , Context const& context, unused_type, T& attr) const { x3::skip_over(first, last, context); return policies.parse_true(first, last, attr, get_case_compare(context)) || policies.parse_false(first, last, attr, get_case_compare(context)); } template bool parse(Iterator& first, Iterator const& last , Context const& context, unused_type, Attribute& attr_param) const { // this case is called when Attribute is not T T attr_; if (parse(first, last, context, unused, attr_)) { traits::move_to(attr_, attr_param); return true; } return false; } BoolPolicies policies; }; template > struct literal_bool_parser : parser> { typedef Encoding encoding; typedef T attribute_type; static bool const has_attribute = true; template literal_bool_parser(Value const& n) : policies(), n_(n) {} template literal_bool_parser(Value const& n, BoolPolicies const& policies) : policies(policies), n_(n) {} template bool parse_main(Iterator& first, Iterator const& last , Context& context, T& attr) const { x3::skip_over(first, last, context); return (n_ && policies.parse_true(first, last, attr, get_case_compare(context))) || (!n_ && policies.parse_false(first, last, attr, get_case_compare(context))); } template bool parse(Iterator& first, Iterator const& last , Context& context, unused_type, T& attr) const { return parse_main(first, last, context, attr); } template bool parse(Iterator& first, Iterator const& last , Context const& context, unused_type, Attribute& attr_param) const { // this case is called when Attribute is not T T attr_; if (parse_main(first, last, context, attr_)) { traits::move_to(attr_, attr_param); return true; } return false; } BoolPolicies policies; T n_; }; namespace standard { typedef bool_parser bool_type; bool_type const bool_ = {}; typedef literal_bool_parser true_type; true_type const true_ = { true }; typedef literal_bool_parser false_type; false_type const false_ = { false }; } namespace standard_wide { typedef bool_parser bool_type; bool_type const bool_ = {}; typedef literal_bool_parser true_type; true_type const true_ = { true }; typedef literal_bool_parser false_type; false_type const false_ = { false }; } namespace ascii { typedef bool_parser bool_type; bool_type const bool_ = {}; typedef literal_bool_parser true_type; true_type const true_ = { true }; typedef literal_bool_parser false_type; false_type const false_ = { false }; } namespace iso8859_1 { typedef bool_parser bool_type; bool_type const bool_ = {}; typedef literal_bool_parser true_type; true_type const true_ = { true }; typedef literal_bool_parser false_type; false_type const false_ = { false }; } using standard::bool_; using standard::true_; using standard::false_; }}} #endif