regression_multi_pass_error_handler.cpp 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. // Copyright (c) 2001-2010 Hartmut Kaiser
  2. // Copyright (c) 2011 Laurent Gomila
  3. //
  4. // Distributed under the Boost Software License, Version 1.0. (See accompanying
  5. // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
  6. #include <boost/config/warning_disable.hpp>
  7. #include <boost/detail/lightweight_test.hpp>
  8. #include <boost/spirit/include/qi.hpp>
  9. #include <boost/spirit/include/phoenix_operator.hpp>
  10. #include <boost/spirit/include/support_multi_pass.hpp>
  11. #include <sstream>
  12. #include <iostream>
  13. #include <iterator>
  14. #include <string>
  15. using namespace boost::spirit;
  16. using namespace boost;
  17. int main()
  18. {
  19. {
  20. std::string input("5x");
  21. std::istringstream iss(input);
  22. typedef std::istreambuf_iterator<char> base_iterator_type;
  23. typedef multi_pass<base_iterator_type> iterator_type;
  24. iterator_type first = make_default_multi_pass(base_iterator_type(iss));
  25. iterator_type last = make_default_multi_pass(base_iterator_type());
  26. std::ostringstream oss;
  27. qi::rule<iterator_type> r = qi::int_ > qi::int_;
  28. qi::on_error<qi::fail>(r, phoenix::ref(oss) << phoenix::val("error"));
  29. BOOST_TEST(!qi::parse(first, last, r));
  30. BOOST_TEST(oss.str() == "error");
  31. }
  32. {
  33. std::string input("5x");
  34. std::istringstream iss(input);
  35. typedef std::istreambuf_iterator<char> base_iterator_type;
  36. typedef multi_pass<base_iterator_type> iterator_type;
  37. iterator_type first = make_default_multi_pass(base_iterator_type(iss));
  38. iterator_type last = make_default_multi_pass(base_iterator_type());
  39. std::ostringstream oss;
  40. qi::rule<iterator_type> r1 = qi::int_ > qi::int_;
  41. qi::rule<iterator_type> r2 = qi::int_ > qi::char_;
  42. qi::on_error<qi::fail>(r1, phoenix::ref(oss) << phoenix::val("error in r1"));
  43. qi::on_error<qi::fail>(r2, phoenix::ref(oss) << phoenix::val("error in r2"));
  44. BOOST_TEST(qi::parse(first, last, r1 | r2));
  45. BOOST_TEST(oss.str() == "error in r1");
  46. }
  47. return boost::report_errors();
  48. }