cxx/test/numerics/complex.number/complex.member.ops/divide_equal_scalar.pass.cpp

45 lines
920 B
C++
Raw Normal View History

//===----------------------------------------------------------------------===//
//
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>The LLVM Compiler Infrastructure
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//
// <complex>
// complex& operator/=(const T& rhs);
#include <complex>
#include <cassert>
template <class T>
void
test()
{
std::complex<T> c(1);
assert(c.real() == 1);
assert(c.imag() == 0);
c /= 0.5;
assert(c.real() == 2);
assert(c.imag() == 0);
c /= 0.5;
assert(c.real() == 4);
assert(c.imag() == 0);
c /= -0.5;
assert(c.real() == -8);
assert(c.imag() == 0);
c.imag(2);
c /= 0.5;
assert(c.real() == -16);
assert(c.imag() == 4);
}
int main()
{
test<float>();
test<double>();
test<long double>();
}