diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-27 18:24:20 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-27 18:24:20 +0000 |
commit | 483eb2f56657e8e7f419ab1a4fab8dce9ade8609 (patch) | |
tree | e5d88d25d870d5dedacb6bbdbe2a966086a0a5cf /src/boost/libs/foreach/test/stl_byval.cpp | |
parent | Initial commit. (diff) | |
download | ceph-upstream.tar.xz ceph-upstream.zip |
Adding upstream version 14.2.21.upstream/14.2.21upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/boost/libs/foreach/test/stl_byval.cpp')
-rw-r--r-- | src/boost/libs/foreach/test/stl_byval.cpp | 61 |
1 files changed, 61 insertions, 0 deletions
diff --git a/src/boost/libs/foreach/test/stl_byval.cpp b/src/boost/libs/foreach/test/stl_byval.cpp new file mode 100644 index 00000000..699839e9 --- /dev/null +++ b/src/boost/libs/foreach/test/stl_byval.cpp @@ -0,0 +1,61 @@ +// stl_byval.cpp +/// +// (C) Copyright Eric Niebler 2004. +// Use, modification and distribution are subject to 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) + +/* + Revision history: + 25 August 2005 : Initial version. +*/ + +#include <list> +#include <boost/test/minimal.hpp> +#include <boost/foreach.hpp> + +/////////////////////////////////////////////////////////////////////////////// +// define the container types, used by utility.hpp to generate the helper functions +typedef std::list<int> foreach_container_type; +typedef std::list<int> const foreach_const_container_type; +typedef int foreach_value_type; +typedef int &foreach_reference_type; +typedef int const &foreach_const_reference_type; + +#include "./utility.hpp" + +/////////////////////////////////////////////////////////////////////////////// +// initialize a std::list<int> +std::list<int> make_list() +{ + std::list<int> l; + l.push_back(1); + l.push_back(2); + l.push_back(3); + l.push_back(4); + l.push_back(5); + return l; +} + +/////////////////////////////////////////////////////////////////////////////// +// define some containers +// +std::list<int> my_list = make_list(); +std::list<int> const &my_const_list = my_list; + +/////////////////////////////////////////////////////////////////////////////// +// test_main +// +int test_main( int, char*[] ) +{ + boost::mpl::false_ *p = BOOST_FOREACH_IS_LIGHTWEIGHT_PROXY(my_list); + (void)p; + + // non-const containers by value + BOOST_CHECK(sequence_equal_byval_n(my_list, "\1\2\3\4\5")); + + // const containers by value + BOOST_CHECK(sequence_equal_byval_c(my_const_list, "\1\2\3\4\5")); + + return 0; +} |