15a83710eSEric Fiselier //===----------------------------------------------------------------------===//
25a83710eSEric Fiselier //
357b08b09SChandler Carruth // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
457b08b09SChandler Carruth // See https://llvm.org/LICENSE.txt for license information.
557b08b09SChandler Carruth // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
65a83710eSEric Fiselier //
75a83710eSEric Fiselier //===----------------------------------------------------------------------===//
85a83710eSEric Fiselier 
95a83710eSEric Fiselier // <complex>
105a83710eSEric Fiselier 
115a83710eSEric Fiselier // template<class T>
125a83710eSEric Fiselier //   bool
135a83710eSEric Fiselier //   operator==(const complex<T>& lhs, const complex<T>& rhs);
145a83710eSEric Fiselier 
155a83710eSEric Fiselier #include <complex>
165a83710eSEric Fiselier #include <cassert>
175a83710eSEric Fiselier 
180f901c7eSStephan T. Lavavej #include "test_macros.h"
190f901c7eSStephan T. Lavavej 
205a83710eSEric Fiselier template <class T>
215a83710eSEric Fiselier void
test_constexpr()225a83710eSEric Fiselier test_constexpr()
235a83710eSEric Fiselier {
240f901c7eSStephan T. Lavavej #if TEST_STD_VER > 11
255a83710eSEric Fiselier     {
265a83710eSEric Fiselier     constexpr std::complex<T> lhs(1.5,  2.5);
275a83710eSEric Fiselier     constexpr std::complex<T> rhs(1.5, -2.5);
285a83710eSEric Fiselier     static_assert( !(lhs == rhs), "");
295a83710eSEric Fiselier     }
305a83710eSEric Fiselier     {
315a83710eSEric Fiselier     constexpr std::complex<T> lhs(1.5, 2.5);
325a83710eSEric Fiselier     constexpr std::complex<T> rhs(1.5, 2.5);
335a83710eSEric Fiselier     static_assert(lhs == rhs, "");
345a83710eSEric Fiselier     }
355a83710eSEric Fiselier #endif
365a83710eSEric Fiselier }
375a83710eSEric Fiselier 
385a83710eSEric Fiselier template <class T>
395a83710eSEric Fiselier void
test()405a83710eSEric Fiselier test()
415a83710eSEric Fiselier {
425a83710eSEric Fiselier     {
435a83710eSEric Fiselier     std::complex<T> lhs(1.5,  2.5);
445a83710eSEric Fiselier     std::complex<T> rhs(1.5, -2.5);
455a83710eSEric Fiselier     assert( !(lhs == rhs));
465a83710eSEric Fiselier     }
475a83710eSEric Fiselier     {
485a83710eSEric Fiselier     std::complex<T> lhs(1.5, 2.5);
495a83710eSEric Fiselier     std::complex<T> rhs(1.5, 2.5);
505a83710eSEric Fiselier     assert(lhs == rhs);
515a83710eSEric Fiselier     }
525a83710eSEric Fiselier     test_constexpr<T> ();
535a83710eSEric Fiselier }
545a83710eSEric Fiselier 
main(int,char **)55*2df59c50SJF Bastien int main(int, char**)
565a83710eSEric Fiselier {
575a83710eSEric Fiselier     test<float>();
585a83710eSEric Fiselier     test<double>();
595a83710eSEric Fiselier     test<long double>();
605a83710eSEric Fiselier //    test_constexpr<int> ();
61*2df59c50SJF Bastien 
62*2df59c50SJF Bastien   return 0;
635a83710eSEric Fiselier }
64