//===----------------------------------------------------------------------===// // // 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 // //===----------------------------------------------------------------------===// // // template class valarray; // valarray operator!() const; #include #include #include #include "test_macros.h" int main(int, char**) { { typedef int T; T a[] = {1, 2, 3, 4, 5}; const unsigned N = sizeof(a)/sizeof(a[0]); std::valarray v(a, N); std::valarray v2 = !v; assert(v2.size() == v.size()); for (std::size_t i = 0; i < v2.size(); ++i) assert(v2[i] == !v[i]); } { typedef double T; T a[] = {1, 2.5, 3, 4.25, 5}; const unsigned N = sizeof(a)/sizeof(a[0]); std::valarray v(a, N); std::valarray v2 = !(v + v); assert(v2.size() == v.size()); for (std::size_t i = 0; i < v2.size(); ++i) assert(v2[i] == !(v[i] + v[i])); } { // Make sure we don't have dangling reference problems with unary expressions bool array[] = {true, false, true}; std::valarray a(array, 3); std::valarray b(array, 3); auto c = !a && b; assert(c.size() == 3); assert(c[0] == false && c[1] == false && c[2] == false); } return 0; }