//===----------------------------------------------------------------------===// // // 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. // //===----------------------------------------------------------------------===// // <complex> // template<class T> // bool // operator!=(const T& lhs, const complex<T>& rhs); #include <complex> #include <cassert> template <class T> void test_constexpr() { #if _LIBCPP_STD_VER > 11 { constexpr T lhs(-2.5); constexpr std::complex<T> rhs(1.5, 2.5); static_assert (lhs != rhs, ""); } { constexpr T lhs(-2.5); constexpr std::complex<T> rhs(1.5, 0); static_assert (lhs != rhs, ""); } { constexpr T lhs(1.5); constexpr std::complex<T> rhs(1.5, 2.5); static_assert (lhs != rhs, ""); } { constexpr T lhs(1.5); constexpr std::complex<T> rhs(1.5, 0); static_assert (!(lhs != rhs), ""); } #endif } template <class T> void test() { { T lhs(-2.5); std::complex<T> rhs(1.5, 2.5); assert (lhs != rhs); } { T lhs(-2.5); std::complex<T> rhs(1.5, 0); assert (lhs != rhs); } { T lhs(1.5); std::complex<T> rhs(1.5, 2.5); assert (lhs != rhs); } { T lhs(1.5); std::complex<T> rhs(1.5, 0); assert (!(lhs != rhs)); } test_constexpr<T> (); } int main() { test<float>(); test<double>(); test<long double>(); // test_constexpr<int>(); }