mirror of
https://github.com/boostorg/iterator.git
synced 2025-05-11 05:23:52 +00:00
С++03 support was deprecated in 1.85 and now can be removed. This PR clears many of workarounds, which are no longer needed now. * Remove unused workaround macros (many of). * Remove BOOST_STATIC_ASSERT usages. * Minimize Boost::type_traits dependency (in favour of STL's type_traits). Closes https://github.com/boostorg/iterator/pull/82. Squashed commit of the following: commit 741a627b736ba81fe0054e5bf373141b04a8a597 Author: Georgy Guminov <gogagum@gmail.com> Date: Sat Jan 25 12:13:05 2025 +0300 Replace testers with standard metafunctions. commit bf4cce611454713f1c8e5f46a2c3e599c548656d Author: Georgy Guminov <gogagum@gmail.com> Date: Sat Jan 25 11:51:32 2025 +0300 Refactor is_lvalue_iterator.hpp. commit 8d080c6c58726269cf55aedd64aa239f7d098fc7 Author: Georgy Guminov <gogagum@gmail.com> Date: Sat Jan 25 10:27:32 2025 +0300 Remove more workarounds. commit 5a4ba24d361ac0676d2cce95fdff22824ecdc287 Author: Georgy Guminov <gogagum@gmail.com> Date: Sun Jan 19 16:38:30 2025 +0300 Fixes. commit fdfafce2b9a71b1d85cbc697983652788f1c4bb7 Author: Georgy Guminov <gogagum@gmail.com> Date: Sat Oct 26 15:06:43 2024 +0300 Remove BOOST_NO_STRICT_ITERATOR_INTEROPERABILITY Correct static_assert messages. Fix messages & replace is_standard_layout with is_copy_constructible. commit c69ac1408af2fe5a105b288644367bbb6e0bc30d Author: Georgy Guminov <gogagum@gmail.com> Date: Sat Oct 26 14:48:51 2024 +0300 Correct static_assert messages. commit b5df827151a6d752168a59fa8c20c9ffd3766c0b Author: Georqy Guminov <gogagum@gmail.com> Date: Sun Jun 23 16:12:29 2024 +0300 Fixes. Remove some Boost.MPL usages. Remove unused includes. commit 01fd35e9f87d43f4bb46ed525a0e8eec46cba44a Author: Georgiy Guminov <gogagum@gmail.com> Date: Wed Jun 12 17:14:21 2024 +0300 abstract conjunction. commit c02def8acf68e0829082761d26955320974e5078 Author: Georgiy Guminov <gogagum@gmail.com> Date: Wed Jun 12 16:35:43 2024 +0300 return addressof & conjunction. commit 3b3d1625752cbe8c9ec62662e594a1af1fd9a458 Author: Georgiy Guminov <gogagum@gmail.com> Date: Wed Jun 12 16:30:44 2024 +0300 Make macro more readable. commit 4ab19e045fc535dc80228062d11bb6584ccd17ff Author: Georgiy Guminov <gogagum@gmail.com> Date: Wed Jun 12 15:56:49 2024 +0300 Add static_assert messages. commit 82b5c44cd34435d63af5cdbc7fcc1b07b39394de Author: Georgiy Guminov <gogagum@gmail.com> Date: Wed Jun 12 14:12:10 2024 +0300 Return is iterator CXX17 test. commit 2d58d65462e837430a0990c2a414d5c397e9fa31 Author: Georgiy Guminov <gogagum@gmail.com> Date: Tue Jun 11 14:04:17 2024 +0300 Omitted. commit a0d04d9491de818df990188436e04afc3ddba3ad Author: Georgiy Guminov <gogagum@gmail.com> Date: Tue Jun 11 14:00:35 2024 +0300 Replace move with static_cast commit 4a49b8a1a2d44d2da728dd064fe810ca86d8d1fd Author: Georgiy Guminov <gogagum@gmail.com> Date: Mon Jun 10 21:38:53 2024 +0300 Return BOOST_NOEXCEPT commit 054c013bba75c42710537a819de91d6abfe25658 Author: Georgiy Guminov <gogagum@gmail.com> Date: Sun Jun 9 15:20:41 2024 +0300 CXX11
289 lines
7.2 KiB
C++
289 lines
7.2 KiB
C++
// Copyright David Abrahams and Jeremy Siek 2003.
|
|
// 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)
|
|
#ifndef BOOST_ITERATOR_TESTS_HPP
|
|
# define BOOST_ITERATOR_TESTS_HPP
|
|
|
|
// This is meant to be the beginnings of a comprehensive, generic
|
|
// test suite for STL concepts such as iterators and containers.
|
|
//
|
|
// Revision History:
|
|
// 28 Apr 2002 Fixed input iterator requirements.
|
|
// For a == b a++ == b++ is no longer required.
|
|
// See 24.1.1/3 for details.
|
|
// (Thomas Witt)
|
|
// 08 Feb 2001 Fixed bidirectional iterator test so that
|
|
// --i is no longer a precondition.
|
|
// (Jeremy Siek)
|
|
// 04 Feb 2001 Added lvalue test, corrected preconditions
|
|
// (David Abrahams)
|
|
|
|
# include <iterator>
|
|
# include <type_traits>
|
|
# include <boost/concept_archetype.hpp> // for detail::dummy_constructor
|
|
# include <boost/core/ignore_unused.hpp>
|
|
# include <boost/core/lightweight_test.hpp>
|
|
|
|
namespace boost {
|
|
|
|
// use this for the value type
|
|
struct dummyT {
|
|
dummyT() { }
|
|
dummyT(detail::dummy_constructor) { }
|
|
dummyT(int x) : m_x(x) { }
|
|
int foo() const { return m_x; }
|
|
bool operator==(const dummyT& d) const { return m_x == d.m_x; }
|
|
int m_x;
|
|
};
|
|
|
|
}
|
|
|
|
namespace boost {
|
|
namespace iterators {
|
|
|
|
// Tests whether type Iterator satisfies the requirements for a
|
|
// TrivialIterator.
|
|
// Preconditions: i != j, *i == val
|
|
template <class Iterator, class T>
|
|
void trivial_iterator_test(const Iterator i, const Iterator j, T val)
|
|
{
|
|
Iterator k;
|
|
BOOST_TEST(i == i);
|
|
BOOST_TEST(j == j);
|
|
BOOST_TEST(i != j);
|
|
#ifdef BOOST_NO_STD_ITERATOR_TRAITS
|
|
T v = *i;
|
|
#else
|
|
typename std::iterator_traits<Iterator>::value_type v = *i;
|
|
#endif
|
|
BOOST_TEST(v == val);
|
|
boost::ignore_unused(v);
|
|
#if 0
|
|
// hmm, this will give a warning for transform_iterator... perhaps
|
|
// this should be separated out into a stand-alone test since there
|
|
// are several situations where it can't be used, like for
|
|
// integer_range::iterator.
|
|
BOOST_TEST(v == i->foo());
|
|
#endif
|
|
k = i;
|
|
BOOST_TEST(k == k);
|
|
BOOST_TEST(k == i);
|
|
BOOST_TEST(k != j);
|
|
BOOST_TEST(*k == val);
|
|
boost::ignore_unused(k);
|
|
}
|
|
|
|
|
|
// Preconditions: i != j
|
|
template <class Iterator, class T>
|
|
void mutable_trivial_iterator_test(const Iterator i, const Iterator j, T val)
|
|
{
|
|
*i = val;
|
|
trivial_iterator_test(i, j, val);
|
|
}
|
|
|
|
|
|
// Preconditions: *i == v1, *++i == v2
|
|
template <class Iterator, class T>
|
|
void input_iterator_test(Iterator i, T v1, T v2)
|
|
{
|
|
Iterator i1(i);
|
|
|
|
BOOST_TEST(i == i1);
|
|
BOOST_TEST(!(i != i1));
|
|
|
|
// I can see no generic way to create an input iterator
|
|
// that is in the domain of== of i and != i.
|
|
// The following works for istream_iterator but is not
|
|
// guaranteed to work for arbitrary input iterators.
|
|
//
|
|
// Iterator i2;
|
|
//
|
|
// BOOST_TEST(i != i2);
|
|
// BOOST_TEST(!(i == i2));
|
|
|
|
BOOST_TEST(*i1 == v1);
|
|
BOOST_TEST(*i == v1);
|
|
|
|
// we cannot test for equivalence of (void)++i & (void)i++
|
|
// as i is only guaranteed to be single pass.
|
|
BOOST_TEST(*i++ == v1);
|
|
boost::ignore_unused(i1);
|
|
|
|
i1 = i;
|
|
|
|
BOOST_TEST(i == i1);
|
|
BOOST_TEST(!(i != i1));
|
|
|
|
BOOST_TEST(*i1 == v2);
|
|
BOOST_TEST(*i == v2);
|
|
boost::ignore_unused(i1);
|
|
|
|
// i is dereferencable, so it must be incrementable.
|
|
++i;
|
|
|
|
// how to test for operator-> ?
|
|
}
|
|
|
|
// how to test output iterator?
|
|
|
|
|
|
template <bool is_pointer> struct lvalue_test
|
|
{
|
|
template <class Iterator> static void check(Iterator)
|
|
{
|
|
# ifndef BOOST_NO_STD_ITERATOR_TRAITS
|
|
typedef typename std::iterator_traits<Iterator>::reference reference;
|
|
typedef typename std::iterator_traits<Iterator>::value_type value_type;
|
|
# else
|
|
typedef typename Iterator::reference reference;
|
|
typedef typename Iterator::value_type value_type;
|
|
# endif
|
|
static_assert(std::is_reference<reference>::value, "reference must be a reference type.");
|
|
static_assert(
|
|
std::is_same<reference, value_type&>::value || std::is_same<reference, const value_type&>::value,
|
|
"reference must either be a reference to value_type or constant reference to value_type."
|
|
);
|
|
}
|
|
};
|
|
|
|
# ifdef BOOST_NO_STD_ITERATOR_TRAITS
|
|
template <> struct lvalue_test<true> {
|
|
template <class T> static void check(T) {}
|
|
};
|
|
#endif
|
|
|
|
template <class Iterator, class T>
|
|
void forward_iterator_test(Iterator i, T v1, T v2)
|
|
{
|
|
input_iterator_test(i, v1, v2);
|
|
|
|
Iterator i1 = i, i2 = i;
|
|
|
|
BOOST_TEST(i == i1++);
|
|
BOOST_TEST(i != ++i2);
|
|
|
|
trivial_iterator_test(i, i1, v1);
|
|
trivial_iterator_test(i, i2, v1);
|
|
|
|
++i;
|
|
BOOST_TEST(i == i1);
|
|
BOOST_TEST(i == i2);
|
|
++i1;
|
|
++i2;
|
|
|
|
trivial_iterator_test(i, i1, v2);
|
|
trivial_iterator_test(i, i2, v2);
|
|
|
|
// borland doesn't allow non-type template parameters
|
|
# if !defined(BOOST_BORLANDC) || (BOOST_BORLANDC > 0x551)
|
|
lvalue_test<std::is_pointer<Iterator>::value>::check(i);
|
|
#endif
|
|
}
|
|
|
|
// Preconditions: *i == v1, *++i == v2
|
|
template <class Iterator, class T>
|
|
void bidirectional_iterator_test(Iterator i, T v1, T v2)
|
|
{
|
|
forward_iterator_test(i, v1, v2);
|
|
++i;
|
|
|
|
Iterator i1 = i, i2 = i;
|
|
|
|
BOOST_TEST(i == i1--);
|
|
BOOST_TEST(i != --i2);
|
|
|
|
trivial_iterator_test(i, i1, v2);
|
|
trivial_iterator_test(i, i2, v2);
|
|
|
|
--i;
|
|
BOOST_TEST(i == i1);
|
|
BOOST_TEST(i == i2);
|
|
++i1;
|
|
++i2;
|
|
|
|
trivial_iterator_test(i, i1, v1);
|
|
trivial_iterator_test(i, i2, v1);
|
|
}
|
|
|
|
// mutable_bidirectional_iterator_test
|
|
|
|
template <class U> struct undefined;
|
|
|
|
// Preconditions: [i,i+N) is a valid range
|
|
template <class Iterator, class TrueVals>
|
|
void random_access_iterator_test(Iterator i, int N, TrueVals vals)
|
|
{
|
|
bidirectional_iterator_test(i, vals[0], vals[1]);
|
|
const Iterator j = i;
|
|
int c;
|
|
|
|
typedef typename std::iterator_traits<Iterator>::value_type value_type;
|
|
struct local
|
|
{
|
|
static value_type to_value_type(value_type v) { return v; }
|
|
};
|
|
|
|
for (c = 0; c < N-1; ++c) {
|
|
BOOST_TEST(i == j + c);
|
|
BOOST_TEST(*i == vals[c]);
|
|
BOOST_TEST(*i == local::to_value_type(j[c]));
|
|
BOOST_TEST(*i == *(j + c));
|
|
BOOST_TEST(*i == *(c + j));
|
|
++i;
|
|
BOOST_TEST(i > j);
|
|
BOOST_TEST(i >= j);
|
|
BOOST_TEST(j <= i);
|
|
BOOST_TEST(j < i);
|
|
}
|
|
|
|
Iterator k = j + N - 1;
|
|
for (c = 0; c < N-1; ++c) {
|
|
BOOST_TEST(i == k - c);
|
|
BOOST_TEST(*i == vals[N - 1 - c]);
|
|
BOOST_TEST(*i == local::to_value_type(j[N - 1 - c]));
|
|
Iterator q = k - c;
|
|
boost::ignore_unused(q);
|
|
BOOST_TEST(*i == *q);
|
|
BOOST_TEST(i > j);
|
|
BOOST_TEST(i >= j);
|
|
BOOST_TEST(j <= i);
|
|
BOOST_TEST(j < i);
|
|
--i;
|
|
}
|
|
}
|
|
|
|
// Precondition: i != j
|
|
template <class Iterator, class ConstIterator>
|
|
void const_nonconst_iterator_test(Iterator i, ConstIterator j)
|
|
{
|
|
BOOST_TEST(i != j);
|
|
BOOST_TEST(j != i);
|
|
|
|
ConstIterator k(i);
|
|
BOOST_TEST(k == i);
|
|
BOOST_TEST(i == k);
|
|
|
|
k = i;
|
|
BOOST_TEST(k == i);
|
|
BOOST_TEST(i == k);
|
|
boost::ignore_unused(k);
|
|
}
|
|
|
|
} // namespace iterators
|
|
|
|
using iterators::undefined;
|
|
using iterators::trivial_iterator_test;
|
|
using iterators::mutable_trivial_iterator_test;
|
|
using iterators::input_iterator_test;
|
|
using iterators::lvalue_test;
|
|
using iterators::forward_iterator_test;
|
|
using iterators::bidirectional_iterator_test;
|
|
using iterators::random_access_iterator_test;
|
|
using iterators::const_nonconst_iterator_test;
|
|
|
|
} // namespace boost
|
|
|
|
#endif // BOOST_ITERATOR_TESTS_HPP
|