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 // complex& operator/=(const complex& rhs);
125a83710eSEric Fiselier 
135a83710eSEric Fiselier #include <complex>
145a83710eSEric Fiselier #include <cassert>
155a83710eSEric Fiselier 
16*7fc6a556SMarshall Clow #include "test_macros.h"
17*7fc6a556SMarshall Clow 
185a83710eSEric Fiselier template <class T>
195a83710eSEric Fiselier void
test()205a83710eSEric Fiselier test()
215a83710eSEric Fiselier {
225a83710eSEric Fiselier     std::complex<T> c(-4, 7.5);
235a83710eSEric Fiselier     const std::complex<T> c2(1.5, 2.5);
245a83710eSEric Fiselier     assert(c.real() == -4);
255a83710eSEric Fiselier     assert(c.imag() == 7.5);
265a83710eSEric Fiselier     c /= c2;
275a83710eSEric Fiselier     assert(c.real() == 1.5);
285a83710eSEric Fiselier     assert(c.imag() == 2.5);
295a83710eSEric Fiselier     c /= c2;
305a83710eSEric Fiselier     assert(c.real() == 1);
315a83710eSEric Fiselier     assert(c.imag() == 0);
325a83710eSEric Fiselier 
335a83710eSEric Fiselier     std::complex<T> c3;
345a83710eSEric Fiselier 
355a83710eSEric Fiselier     c3 = c;
365a83710eSEric Fiselier     std::complex<int> ic (1,1);
375a83710eSEric Fiselier     c3 /= ic;
385a83710eSEric Fiselier     assert(c3.real() ==  0.5);
395a83710eSEric Fiselier     assert(c3.imag() == -0.5);
405a83710eSEric Fiselier 
415a83710eSEric Fiselier     c3 = c;
425a83710eSEric Fiselier     std::complex<float> fc (1,1);
435a83710eSEric Fiselier     c3 /= fc;
445a83710eSEric Fiselier     assert(c3.real() ==  0.5);
455a83710eSEric Fiselier     assert(c3.imag() == -0.5);
465a83710eSEric Fiselier 
475a83710eSEric Fiselier }
485a83710eSEric Fiselier 
main(int,char **)492df59c50SJF Bastien int main(int, char**)
505a83710eSEric Fiselier {
515a83710eSEric Fiselier     test<float>();
525a83710eSEric Fiselier     test<double>();
535a83710eSEric Fiselier     test<long double>();
542df59c50SJF Bastien 
552df59c50SJF Bastien   return 0;
565a83710eSEric Fiselier }
57