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/mpl/test/deque.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 '')
-rw-r--r-- | src/boost/libs/mpl/test/deque.cpp | 92 |
1 files changed, 92 insertions, 0 deletions
diff --git a/src/boost/libs/mpl/test/deque.cpp b/src/boost/libs/mpl/test/deque.cpp new file mode 100644 index 00000000..4ac747cd --- /dev/null +++ b/src/boost/libs/mpl/test/deque.cpp @@ -0,0 +1,92 @@ + +// Copyright Aleksey Gurtovoy 2000-2004 +// +// 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) +// +// See http://www.boost.org/libs/mpl for documentation. + +// $Id$ +// $Date$ +// $Revision$ + +#include <boost/mpl/deque.hpp> +#include <boost/mpl/push_back.hpp> +#include <boost/mpl/pop_back.hpp> +#include <boost/mpl/push_front.hpp> +#include <boost/mpl/pop_front.hpp> +#include <boost/mpl/back.hpp> +#include <boost/mpl/front.hpp> +#include <boost/mpl/size.hpp> +#include <boost/mpl/empty.hpp> + +#include <boost/mpl/aux_/test.hpp> + + +MPL_TEST_CASE() +{ + typedef deque<> d0; + typedef deque<char> d1; + typedef deque<char,long> d2; + typedef deque<char,char,char,char,char,char,char,char,int> d9; + + MPL_ASSERT_RELATION( size<d0>::value, ==, 0 ); + MPL_ASSERT_RELATION( size<d1>::value, ==, 1 ); + MPL_ASSERT_RELATION( size<d2>::value, ==, 2 ); + MPL_ASSERT_RELATION( size<d9>::value, ==, 9 ); + + MPL_ASSERT(( empty<d0> )); + MPL_ASSERT_NOT(( empty<d1> )); + MPL_ASSERT_NOT(( empty<d2> )); + MPL_ASSERT_NOT(( empty<d9> )); + + MPL_ASSERT(( is_same< front<d1>::type,char > )); + MPL_ASSERT(( is_same< back<d1>::type,char > )); + MPL_ASSERT(( is_same< front<d2>::type,char > )); + MPL_ASSERT(( is_same< back<d2>::type,long > )); + MPL_ASSERT(( is_same< front<d9>::type,char > )); + MPL_ASSERT(( is_same< back<d9>::type,int > )); +} + + +MPL_TEST_CASE() +{ + typedef deque<char,long> d2; + + typedef begin<d2>::type i1; + typedef next<i1>::type i2; + typedef next<i2>::type i3; + + MPL_ASSERT(( is_same<deref<i1>::type,char> )); + MPL_ASSERT(( is_same<deref<i2>::type,long> )); + MPL_ASSERT(( is_same< i3, end<d2>::type > )); +} + +MPL_TEST_CASE() +{ + typedef deque<> d0; + + typedef push_back<d0,int>::type d1; + MPL_ASSERT(( is_same< back<d1>::type,int > )); + + typedef push_front<d1,char>::type d2; + MPL_ASSERT(( is_same< back<d2>::type,int > )); + MPL_ASSERT(( is_same< front<d2>::type,char > )); + + typedef push_back<d2,long>::type d3; + MPL_ASSERT(( is_same< back<d3>::type,long > )); +} + +MPL_TEST_CASE() +{ + typedef deque<> d0; + typedef deque<char> d1; + typedef deque<char,long> d2; + typedef deque<char,char,char,char,char,char,char,char,int> d9; + + MPL_ASSERT_RELATION( size<d0>::value, ==, 0 ); + MPL_ASSERT_RELATION( size<d1>::value, ==, 1 ); + MPL_ASSERT_RELATION( size<d2>::value, ==, 2 ); + MPL_ASSERT_RELATION( size<d9>::value, ==, 9 ); +} |