foldr_start_with_parser.cpp 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. // Copyright Abel Sinkovics (abel@sinkovics.hu) 2012.
  2. // Distributed under the Boost Software License, Version 1.0.
  3. // (See accompanying file LICENSE_1_0.txt or copy at
  4. // http://www.boost.org/LICENSE_1_0.txt)
  5. #include <boost/metaparse/foldr_start_with_parser.hpp>
  6. #include <boost/metaparse/start.hpp>
  7. #include <boost/metaparse/string.hpp>
  8. #include <boost/metaparse/is_error.hpp>
  9. #include <boost/metaparse/get_result.hpp>
  10. #include <boost/metaparse/fail.hpp>
  11. #include "common.hpp"
  12. #include <boost/mpl/apply_wrap.hpp>
  13. #include <boost/mpl/char.hpp>
  14. #include <boost/mpl/assert.hpp>
  15. #include "test_case.hpp"
  16. namespace
  17. {
  18. struct keep_state
  19. {
  20. typedef keep_state type;
  21. template <class S, class C>
  22. struct apply : S {};
  23. };
  24. }
  25. BOOST_METAPARSE_TEST_CASE(foldr_start_with_parser)
  26. {
  27. using boost::metaparse::foldr_start_with_parser;
  28. using boost::metaparse::start;
  29. using boost::metaparse::is_error;
  30. using boost::metaparse::lit_c;
  31. using boost::metaparse::get_result;
  32. using boost::mpl::equal_to;
  33. using boost::mpl::apply_wrap2;
  34. using boost::mpl::char_;
  35. typedef foldr_start_with_parser<lit_c<'a'>, lit_c<'b'>, keep_state> p;
  36. // test_b
  37. BOOST_MPL_ASSERT((
  38. equal_to<get_result<apply_wrap2<p, str_b, start> >::type, char_<'b'> >
  39. ));
  40. // test_ab
  41. BOOST_MPL_ASSERT((
  42. equal_to<get_result<apply_wrap2<p, str_ab, start> >::type, char_<'b'> >
  43. ));
  44. // test_aaaab
  45. BOOST_MPL_ASSERT((
  46. equal_to<get_result<apply_wrap2<p, str_aaaab, start> >::type, char_<'b'> >
  47. ));
  48. // test_c
  49. BOOST_MPL_ASSERT((is_error<apply_wrap2<p, str_c, start> >));
  50. // test_ac
  51. BOOST_MPL_ASSERT((is_error<apply_wrap2<p, str_ac, start> >));
  52. }