regression_binary_action.cpp 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. /*=============================================================================
  2. Copyright (c) 2001-2011 Hartmut Kaiser
  3. Copyright (c) 2011 Matthias Born
  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. ==============================================================================*/
  7. #include <boost/config/warning_disable.hpp>
  8. #include <boost/detail/lightweight_test.hpp>
  9. #include <boost/spirit/include/qi_operator.hpp>
  10. #include <boost/spirit/include/qi_char.hpp>
  11. #include <boost/spirit/include/qi_attr.hpp>
  12. #include <boost/spirit/include/qi_binary.hpp>
  13. #include <boost/spirit/include/qi_omit.hpp>
  14. #include <boost/spirit/include/qi_nonterminal.hpp>
  15. #include <boost/spirit/include/qi_action.hpp>
  16. #include <boost/spirit/include/phoenix_core.hpp>
  17. #include <boost/spirit/include/phoenix_operator.hpp>
  18. #include <boost/fusion/include/adapt_struct.hpp>
  19. #include <boost/predef/other/endian.h>
  20. #include "test.hpp"
  21. int main()
  22. {
  23. // This test assumes a little endian architecture
  24. #if BOOST_ENDIAN_LITTLE_BYTE
  25. using spirit_test::test_attr;
  26. using boost::spirit::qi::rule;
  27. using boost::spirit::qi::locals;
  28. using boost::spirit::qi::little_word;
  29. using boost::spirit::qi::omit;
  30. using boost::spirit::qi::_1;
  31. using boost::spirit::qi::_a;
  32. using boost::spirit::qi::attr;
  33. rule<char const*, short int(), locals<short int> > pass;
  34. pass = little_word;
  35. rule<char const*, short int(), locals<short int> > pass_ugly;
  36. pass_ugly %= omit[little_word[_a=_1]] >> attr(_a);
  37. rule<char const*, short int(), locals<short int> > fail;
  38. fail %= little_word[_a=_1];
  39. short int us = 0;
  40. BOOST_TEST(test_attr("\x01\x02", pass, us) && us == 0x0201);
  41. us = 0;
  42. BOOST_TEST(test_attr("\x01\x02", pass_ugly, us) && us == 0x0201);
  43. us = 0;
  44. BOOST_TEST(test_attr("\x01\x02", fail, us) && us == 0x0201);
  45. #endif
  46. return boost::report_errors();
  47. }