diff options
author | Stephan T. Lavavej <stl@exchange.microsoft.com> | 2017-05-05 23:01:38 +0000 |
---|---|---|
committer | Stephan T. Lavavej <stl@exchange.microsoft.com> | 2017-05-05 23:01:38 +0000 |
commit | 40608ce4c9ba2cfbbb9976d06785699515dff3f2 (patch) | |
tree | 76422f5fa7b8ecc95adb55b044cc8d69bfb93dbc | |
parent | 64293fca3946bee0a71975999c4216db1834b03d (diff) | |
download | bcm5719-llvm-40608ce4c9ba2cfbbb9976d06785699515dff3f2.tar.gz bcm5719-llvm-40608ce4c9ba2cfbbb9976d06785699515dff3f2.zip |
[libcxx] [test] Be compatible with LWG 2438 "std::iterator inheritance shouldn't be mandated".
In C++17, these iterators are allowed but not required
to inherit from the deprecated std::iterator base class.
Fixes D32727.
llvm-svn: 302318
3 files changed, 54 insertions, 0 deletions
diff --git a/libcxx/test/std/iterators/stream.iterators/istream.iterator/types.pass.cpp b/libcxx/test/std/iterators/stream.iterators/istream.iterator/types.pass.cpp index a680aa3f499..3046ced75a7 100644 --- a/libcxx/test/std/iterators/stream.iterators/istream.iterator/types.pass.cpp +++ b/libcxx/test/std/iterators/stream.iterators/istream.iterator/types.pass.cpp @@ -40,12 +40,22 @@ #include <type_traits> #include <string> +#include "test_macros.h" + int main() { typedef std::istream_iterator<double> I1; // double is trivially destructible +#if TEST_STD_VER <= 14 static_assert((std::is_convertible<I1, std::iterator<std::input_iterator_tag, double, std::ptrdiff_t, const double*, const double&> >::value), ""); +#else + static_assert((std::is_same<I1::iterator_category, std::input_iterator_tag>::value), ""); + static_assert((std::is_same<I1::value_type, double>::value), ""); + static_assert((std::is_same<I1::difference_type, std::ptrdiff_t>::value), ""); + static_assert((std::is_same<I1::pointer, const double*>::value), ""); + static_assert((std::is_same<I1::reference, const double&>::value), ""); +#endif static_assert((std::is_same<I1::char_type, char>::value), ""); static_assert((std::is_same<I1::traits_type, std::char_traits<char> >::value), ""); static_assert((std::is_same<I1::istream_type, std::istream>::value), ""); @@ -53,9 +63,17 @@ int main() static_assert( std::is_trivially_destructible<I1>::value, ""); typedef std::istream_iterator<unsigned, wchar_t> I2; // unsigned is trivially destructible +#if TEST_STD_VER <= 14 static_assert((std::is_convertible<I2, std::iterator<std::input_iterator_tag, unsigned, std::ptrdiff_t, const unsigned*, const unsigned&> >::value), ""); +#else + static_assert((std::is_same<I2::iterator_category, std::input_iterator_tag>::value), ""); + static_assert((std::is_same<I2::value_type, unsigned>::value), ""); + static_assert((std::is_same<I2::difference_type, std::ptrdiff_t>::value), ""); + static_assert((std::is_same<I2::pointer, const unsigned*>::value), ""); + static_assert((std::is_same<I2::reference, const unsigned&>::value), ""); +#endif static_assert((std::is_same<I2::char_type, wchar_t>::value), ""); static_assert((std::is_same<I2::traits_type, std::char_traits<wchar_t> >::value), ""); static_assert((std::is_same<I2::istream_type, std::wistream>::value), ""); diff --git a/libcxx/test/std/iterators/stream.iterators/ostream.iterator/types.pass.cpp b/libcxx/test/std/iterators/stream.iterators/ostream.iterator/types.pass.cpp index 460da642bc6..8d043e1e634 100644 --- a/libcxx/test/std/iterators/stream.iterators/ostream.iterator/types.pass.cpp +++ b/libcxx/test/std/iterators/stream.iterators/ostream.iterator/types.pass.cpp @@ -23,17 +23,35 @@ #include <iterator> #include <type_traits> +#include "test_macros.h" + int main() { typedef std::ostream_iterator<double> I1; +#if TEST_STD_VER <= 14 static_assert((std::is_convertible<I1, std::iterator<std::output_iterator_tag, void, void, void, void> >::value), ""); +#else + static_assert((std::is_same<I1::iterator_category, std::output_iterator_tag>::value), ""); + static_assert((std::is_same<I1::value_type, void>::value), ""); + static_assert((std::is_same<I1::difference_type, void>::value), ""); + static_assert((std::is_same<I1::pointer, void>::value), ""); + static_assert((std::is_same<I1::reference, void>::value), ""); +#endif static_assert((std::is_same<I1::char_type, char>::value), ""); static_assert((std::is_same<I1::traits_type, std::char_traits<char> >::value), ""); static_assert((std::is_same<I1::ostream_type, std::ostream>::value), ""); typedef std::ostream_iterator<unsigned, wchar_t> I2; +#if TEST_STD_VER <= 14 static_assert((std::is_convertible<I2, std::iterator<std::output_iterator_tag, void, void, void, void> >::value), ""); +#else + static_assert((std::is_same<I2::iterator_category, std::output_iterator_tag>::value), ""); + static_assert((std::is_same<I2::value_type, void>::value), ""); + static_assert((std::is_same<I2::difference_type, void>::value), ""); + static_assert((std::is_same<I2::pointer, void>::value), ""); + static_assert((std::is_same<I2::reference, void>::value), ""); +#endif static_assert((std::is_same<I2::char_type, wchar_t>::value), ""); static_assert((std::is_same<I2::traits_type, std::char_traits<wchar_t> >::value), ""); static_assert((std::is_same<I2::ostream_type, std::wostream>::value), ""); diff --git a/libcxx/test/std/iterators/stream.iterators/ostreambuf.iterator/types.pass.cpp b/libcxx/test/std/iterators/stream.iterators/ostreambuf.iterator/types.pass.cpp index a699b241983..cdf74846547 100644 --- a/libcxx/test/std/iterators/stream.iterators/ostreambuf.iterator/types.pass.cpp +++ b/libcxx/test/std/iterators/stream.iterators/ostreambuf.iterator/types.pass.cpp @@ -24,19 +24,37 @@ #include <string> #include <type_traits> +#include "test_macros.h" + int main() { typedef std::ostreambuf_iterator<char> I1; +#if TEST_STD_VER <= 14 static_assert((std::is_convertible<I1, std::iterator<std::output_iterator_tag, void, void, void, void> >::value), ""); +#else + static_assert((std::is_same<I1::iterator_category, std::output_iterator_tag>::value), ""); + static_assert((std::is_same<I1::value_type, void>::value), ""); + static_assert((std::is_same<I1::difference_type, void>::value), ""); + static_assert((std::is_same<I1::pointer, void>::value), ""); + static_assert((std::is_same<I1::reference, void>::value), ""); +#endif static_assert((std::is_same<I1::char_type, char>::value), ""); static_assert((std::is_same<I1::traits_type, std::char_traits<char> >::value), ""); static_assert((std::is_same<I1::streambuf_type, std::streambuf>::value), ""); static_assert((std::is_same<I1::ostream_type, std::ostream>::value), ""); typedef std::ostreambuf_iterator<wchar_t> I2; +#if TEST_STD_VER <= 14 static_assert((std::is_convertible<I2, std::iterator<std::output_iterator_tag, void, void, void, void> >::value), ""); +#else + static_assert((std::is_same<I2::iterator_category, std::output_iterator_tag>::value), ""); + static_assert((std::is_same<I2::value_type, void>::value), ""); + static_assert((std::is_same<I2::difference_type, void>::value), ""); + static_assert((std::is_same<I2::pointer, void>::value), ""); + static_assert((std::is_same<I2::reference, void>::value), ""); +#endif static_assert((std::is_same<I2::char_type, wchar_t>::value), ""); static_assert((std::is_same<I2::traits_type, std::char_traits<wchar_t> >::value), ""); static_assert((std::is_same<I2::streambuf_type, std::wstreambuf>::value), ""); |