foldl_start_with_parser.cpp 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  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/foldl_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/return_.hpp>
  11. #include <boost/metaparse/v1/impl/back_inserter.hpp>
  12. #include "common.hpp"
  13. #include <boost/mpl/apply_wrap.hpp>
  14. #include <boost/mpl/char.hpp>
  15. #include <boost/mpl/assert.hpp>
  16. #include "test_case.hpp"
  17. namespace
  18. {
  19. struct keep_state
  20. {
  21. typedef keep_state type;
  22. template <class S, class C>
  23. struct apply : S {};
  24. };
  25. }
  26. BOOST_METAPARSE_TEST_CASE(foldl_start_with_parser)
  27. {
  28. using boost::metaparse::foldl_start_with_parser;
  29. using boost::metaparse::start;
  30. using boost::metaparse::is_error;
  31. using boost::metaparse::lit_c;
  32. using boost::metaparse::get_result;
  33. using boost::mpl::equal_to;
  34. using boost::mpl::apply_wrap2;
  35. using boost::mpl::char_;
  36. typedef foldl_start_with_parser<lit_c<'a'>, lit_c<'b'>, keep_state> p;
  37. // test_b
  38. BOOST_MPL_ASSERT((
  39. equal_to<get_result<apply_wrap2<p, str_b, start> >::type, char_<'b'> >
  40. ));
  41. // test_ba
  42. BOOST_MPL_ASSERT((
  43. equal_to<get_result<apply_wrap2<p, str_ba, start> >::type, char_<'b'> >
  44. ));
  45. // test_baaaa
  46. BOOST_MPL_ASSERT((
  47. equal_to<get_result<apply_wrap2<p, str_baaaa, start> >::type, char_<'b'> >
  48. ));
  49. // test_c
  50. BOOST_MPL_ASSERT((is_error<apply_wrap2<p, str_c, start> >));
  51. // test_ca
  52. BOOST_MPL_ASSERT((is_error<apply_wrap2<p, str_ca, start> >));
  53. }
  54. // Test foldl_start_with_parser as a normal fold
  55. using boost::metaparse::foldl_start_with_parser;
  56. using boost::metaparse::return_;
  57. using boost::metaparse::v1::impl::back_inserter;
  58. using boost::mpl::vector;
  59. namespace
  60. {
  61. template <class P>
  62. struct repeated :
  63. foldl_start_with_parser<P, return_<vector<> >, back_inserter>
  64. {};
  65. }
  66. #define TEST_NAME foldl_start_with_parser_as_foldl
  67. #include "repeated_test.hpp"