//===----------------------------------------------------------------------===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// // UNSUPPORTED: c++03, c++11, c++14 // XFAIL: target=powerpc{{.*}}le-unknown-linux-gnu // // // [simd.class] // reference operator[](size_t i); // value_type operator[](size_t i) const; #include "../test_utils.h" #include namespace ex = std::experimental::parallelism_v2; template struct CheckSimdReferenceSubscr { template void operator()() { ex::simd origin_simd([](T i) { return i; }); for (size_t i = 0; i < origin_simd.size(); ++i) { static_assert(noexcept(origin_simd[i])); static_assert(std::is_same_v::reference, decltype(origin_simd[i])>); assert(origin_simd[i] == static_cast(i)); } } }; template struct CheckSimdValueTypeSubscr { template void operator()() { const ex::simd origin_simd([](T i) { return i; }); for (size_t i = 0; i < origin_simd.size(); ++i) { static_assert(noexcept(origin_simd[i])); static_assert(std::is_same_v); assert(origin_simd[i] == static_cast(i)); } } }; int main(int, char**) { test_all_simd_abi(); test_all_simd_abi(); return 0; }