// Copyright 2015 Peter Dimov. // // Distributed under the Boost Software License, Version 1.0. // // See accompanying file LICENSE_1_0.txt or copy at // http://www.boost.org/LICENSE_1_0.txt #include #include #include #include #include #include int main() { { std::tuple tp{ 1, 2, 3 }; { int s = 0; boost::tuple_for_each( tp, [&]( int x ){ s = s * 10 + x; } ); BOOST_TEST_EQ( s, 123 ); } { int s = 0; boost::tuple_for_each( std::move(tp), [&]( int x ){ s = s * 10 + x; } ); BOOST_TEST_EQ( s, 123 ); } } { std::tuple, std::unique_ptr, std::unique_ptr> tp{ std::unique_ptr(new int(1)), std::unique_ptr(new int(2)), std::unique_ptr(new int(3)) }; int s = 0; boost::tuple_for_each( std::move(tp), [&]( std::unique_ptr p ){ s = s * 10 + *p; } ); BOOST_TEST_EQ( s, 123 ); } { std::pair tp{ 1, 2 }; { int s = 0; boost::tuple_for_each( tp, [&]( int x ){ s = s * 10 + x; } ); BOOST_TEST_EQ( s, 12 ); } { int s = 0; boost::tuple_for_each( std::move(tp), [&]( int x ){ s = s * 10 + x; } ); BOOST_TEST_EQ( s, 12 ); } } { std::array tp{{ 1, 2, 3 }}; { int s = 0; boost::tuple_for_each( tp, [&]( int x ){ s = s * 10 + x; } ); BOOST_TEST_EQ( s, 123 ); } { int s = 0; boost::tuple_for_each( std::move(tp), [&]( int x ){ s = s * 10 + x; } ); BOOST_TEST_EQ( s, 123 ); } } return boost::report_errors(); }