From 8a0794b722bd42d12c58295c69b659e79c73a903 Mon Sep 17 00:00:00 2001 From: Marshall Clow Date: Tue, 24 Jul 2018 03:01:02 +0000 Subject: Implement . Reviewed as https://reviews.llvm.org/D49338 llvm-svn: 337804 --- .../containers/views/span.cons/stdarray.pass.cpp | 111 +++++++++++++++++++++ 1 file changed, 111 insertions(+) create mode 100644 libcxx/test/std/containers/views/span.cons/stdarray.pass.cpp (limited to 'libcxx/test/std/containers/views/span.cons/stdarray.pass.cpp') diff --git a/libcxx/test/std/containers/views/span.cons/stdarray.pass.cpp b/libcxx/test/std/containers/views/span.cons/stdarray.pass.cpp new file mode 100644 index 00000000000..204935db058 --- /dev/null +++ b/libcxx/test/std/containers/views/span.cons/stdarray.pass.cpp @@ -0,0 +1,111 @@ +// -*- C++ -*- +//===------------------------------ span ---------------------------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is dual licensed under the MIT and the University of Illinois Open +// Source Licenses. See LICENSE.TXT for details. +// +//===---------------------------------------------------------------------===// +// UNSUPPORTED: c++98, c++03, c++11, c++14, c++17 + +// + +// template +// constexpr span(array& arr) noexcept; +// template +// constexpr span(const array& arr) noexcept; +// +// Remarks: These constructors shall not participate in overload resolution unless: +// — extent == dynamic_extent || N == extent is true, and +// — remove_pointer_t(*)[] is convertible to ElementType(*)[]. +// + + +#include +#include +#include + +#include "test_macros.h" + + +void checkCV() +{ + std::array arr = {1,2,3}; +// STL says these are not cromulent +// std::array carr = {4,5,6}; +// std::array varr = {7,8,9}; +// std::array cvarr = {1,3,5}; + +// Types the same (dynamic sized) + { + std::span< int> s1{ arr}; // a span< int> pointing at int. + } + +// Types the same (static sized) + { + std::span< int,3> s1{ arr}; // a span< int> pointing at int. + } + + +// types different (dynamic sized) + { + std::span s1{ arr}; // a span pointing at int. + std::span< volatile int> s2{ arr}; // a span< volatile int> pointing at int. + std::span< volatile int> s3{ arr}; // a span< volatile int> pointing at const int. + std::span s4{ arr}; // a span pointing at int. + } + +// types different (static sized) + { + std::span s1{ arr}; // a span pointing at int. + std::span< volatile int,3> s2{ arr}; // a span< volatile int> pointing at int. + std::span< volatile int,3> s3{ arr}; // a span< volatile int> pointing at const int. + std::span s4{ arr}; // a span pointing at int. + } +} + + +template +constexpr bool testConstexprSpan() +{ + constexpr std::array val = { T(), T() }; + ASSERT_NOEXCEPT(std::span {val}); + ASSERT_NOEXCEPT(std::span{val}); + std::span s1{val}; + std::span s2{val}; + return + s1.data() == &val[0] && s1.size() == 2 + && s2.data() == &val[0] && s2.size() == 2; +} + + +template +void testRuntimeSpan() +{ + std::array val; + ASSERT_NOEXCEPT(std::span {val}); + ASSERT_NOEXCEPT(std::span{val}); + std::span s1{val}; + std::span s2{val}; + assert(s1.data() == &val[0] && s1.size() == 2); + assert(s2.data() == &val[0] && s2.size() == 2); +} + +struct A{}; + +int main () +{ + static_assert(testConstexprSpan(), ""); + static_assert(testConstexprSpan(), ""); + static_assert(testConstexprSpan(), ""); + static_assert(testConstexprSpan(), ""); + + testRuntimeSpan(); + testRuntimeSpan(); + testRuntimeSpan(); + testRuntimeSpan(); + testRuntimeSpan(); + + checkCV(); +} -- cgit v1.2.3