push_back.cpp 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. /*=============================================================================
  2. Copyright (c) 2001-2011 Joel de Guzman
  3. Distributed under the Boost Software License, Version 1.0. (See accompanying
  4. file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
  5. ==============================================================================*/
  6. #include <boost/detail/lightweight_test.hpp>
  7. #include <boost/fusion/container/vector/vector.hpp>
  8. #include <boost/fusion/adapted/mpl.hpp>
  9. #include <boost/fusion/sequence/io/out.hpp>
  10. #include <boost/fusion/sequence/comparison/equal_to.hpp>
  11. #include <boost/fusion/sequence/intrinsic/at.hpp>
  12. #include <boost/fusion/container/generation/make_vector.hpp>
  13. #include <boost/fusion/algorithm/transformation/push_back.hpp>
  14. #include <boost/fusion/algorithm/iteration/for_each.hpp>
  15. #include <boost/mpl/vector_c.hpp>
  16. #include <string>
  17. struct plus_one
  18. {
  19. template <typename T>
  20. void operator()(T& v) const
  21. {
  22. v += 1;
  23. }
  24. };
  25. int
  26. main()
  27. {
  28. using namespace boost::fusion;
  29. std::cout << tuple_open('[');
  30. std::cout << tuple_close(']');
  31. std::cout << tuple_delimiter(", ");
  32. /// Testing push_back
  33. {
  34. char const* s = "Ruby";
  35. typedef vector<int, char, double, char const*> vector_type;
  36. vector_type t1(1, 'x', 3.3, s);
  37. {
  38. std::cout << push_back(t1, 123456) << std::endl;
  39. BOOST_TEST((push_back(t1, 123456)
  40. == make_vector(1, 'x', 3.3, s, 123456)));
  41. }
  42. {
  43. std::cout << push_back(t1, "funny") << std::endl;
  44. BOOST_TEST((push_back(t1, "funny")
  45. == make_vector(1, 'x', 3.3, s, std::string("funny"))));
  46. }
  47. {
  48. std::cout << push_back(t1, t1) << std::endl;
  49. BOOST_TEST((push_back(t1, t1)
  50. == make_vector(1, 'x', 3.3, s, t1)));
  51. }
  52. }
  53. {
  54. typedef boost::mpl::vector_c<int, 1, 2, 3, 4, 5> mpl_vec;
  55. std::cout << boost::fusion::push_back(mpl_vec(), boost::mpl::int_<6>()) << std::endl;
  56. BOOST_TEST((boost::fusion::push_back(mpl_vec(), boost::mpl::int_<6>())
  57. == make_vector(1, 2, 3, 4, 5, 6)));
  58. }
  59. return boost::report_errors();
  60. }