Implement constexpr (n3302) and fix operator *= and /=
git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@187529 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
0777473911
commit
a61e6f8705
@ -23,12 +23,12 @@ class complex
|
||||
public:
|
||||
typedef T value_type;
|
||||
|
||||
complex(const T& re = T(), const T& im = T());
|
||||
complex(const complex&);
|
||||
template<class X> complex(const complex<X>&);
|
||||
complex(const T& re = T(), const T& im = T()); // constexpr in C++14
|
||||
complex(const complex&); // constexpr in C++14
|
||||
template<class X> complex(const complex<X>&); // constexpr in C++14
|
||||
|
||||
T real() const;
|
||||
T imag() const;
|
||||
T real() const; // constexpr in C++14
|
||||
T imag() const; // constexpr in C++14
|
||||
|
||||
void real(T);
|
||||
void imag(T);
|
||||
@ -149,12 +149,12 @@ template<class T> complex<T> operator/(const complex<T>&, const T&);
|
||||
template<class T> complex<T> operator/(const T&, const complex<T>&);
|
||||
template<class T> complex<T> operator+(const complex<T>&);
|
||||
template<class T> complex<T> operator-(const complex<T>&);
|
||||
template<class T> bool operator==(const complex<T>&, const complex<T>&);
|
||||
template<class T> bool operator==(const complex<T>&, const T&);
|
||||
template<class T> bool operator==(const T&, const complex<T>&);
|
||||
template<class T> bool operator!=(const complex<T>&, const complex<T>&);
|
||||
template<class T> bool operator!=(const complex<T>&, const T&);
|
||||
template<class T> bool operator!=(const T&, const complex<T>&);
|
||||
template<class T> bool operator==(const complex<T>&, const complex<T>&); // constexpr in C++14
|
||||
template<class T> bool operator==(const complex<T>&, const T&); // constexpr in C++14
|
||||
template<class T> bool operator==(const T&, const complex<T>&); // constexpr in C++14
|
||||
template<class T> bool operator!=(const complex<T>&, const complex<T>&); // constexpr in C++14
|
||||
template<class T> bool operator!=(const complex<T>&, const T&); // constexpr in C++14
|
||||
template<class T> bool operator!=(const T&, const complex<T>&); // constexpr in C++14
|
||||
|
||||
template<class T, class charT, class traits>
|
||||
basic_istream<charT, traits>&
|
||||
@ -165,17 +165,17 @@ template<class T, class charT, class traits>
|
||||
|
||||
// 26.3.7 values:
|
||||
|
||||
template<class T> T real(const complex<T>&);
|
||||
long double real(long double);
|
||||
double real(double);
|
||||
template<Integral T> double real(T);
|
||||
float real(float);
|
||||
template<class T> T real(const complex<T>&); // constexpr in C++14
|
||||
long double real(long double); // constexpr in C++14
|
||||
double real(double); // constexpr in C++14
|
||||
template<Integral T> double real(T); // constexpr in C++14
|
||||
float real(float); // constexpr in C++14
|
||||
|
||||
template<class T> T imag(const complex<T>&);
|
||||
long double imag(long double);
|
||||
double imag(double);
|
||||
template<Integral T> double imag(T);
|
||||
float imag(float);
|
||||
template<class T> T imag(const complex<T>&); // constexpr in C++14
|
||||
long double imag(long double); // constexpr in C++14
|
||||
double imag(double); // constexpr in C++14
|
||||
template<Integral T> double imag(T); // constexpr in C++14
|
||||
float imag(float); // constexpr in C++14
|
||||
|
||||
template<class T> T abs(const complex<T>&);
|
||||
|
||||
@ -269,15 +269,15 @@ private:
|
||||
value_type __re_;
|
||||
value_type __im_;
|
||||
public:
|
||||
_LIBCPP_INLINE_VISIBILITY
|
||||
_LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
|
||||
complex(const value_type& __re = value_type(), const value_type& __im = value_type())
|
||||
: __re_(__re), __im_(__im) {}
|
||||
template<class _Xp> _LIBCPP_INLINE_VISIBILITY
|
||||
template<class _Xp> _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
|
||||
complex(const complex<_Xp>& __c)
|
||||
: __re_(__c.real()), __im_(__c.imag()) {}
|
||||
|
||||
_LIBCPP_INLINE_VISIBILITY value_type real() const {return __re_;}
|
||||
_LIBCPP_INLINE_VISIBILITY value_type imag() const {return __im_;}
|
||||
_LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 value_type real() const {return __re_;}
|
||||
_LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 value_type imag() const {return __im_;}
|
||||
|
||||
_LIBCPP_INLINE_VISIBILITY void real(value_type __re) {__re_ = __re;}
|
||||
_LIBCPP_INLINE_VISIBILITY void imag(value_type __im) {__im_ = __im;}
|
||||
@ -309,12 +309,12 @@ public:
|
||||
}
|
||||
template<class _Xp> _LIBCPP_INLINE_VISIBILITY complex& operator*=(const complex<_Xp>& __c)
|
||||
{
|
||||
*this = *this * __c;
|
||||
*this = *this * complex(__c.real(), __c.imag());
|
||||
return *this;
|
||||
}
|
||||
template<class _Xp> _LIBCPP_INLINE_VISIBILITY complex& operator/=(const complex<_Xp>& __c)
|
||||
{
|
||||
*this = *this / __c;
|
||||
*this = *this / complex(__c.real(), __c.imag());
|
||||
return *this;
|
||||
}
|
||||
};
|
||||
@ -368,12 +368,12 @@ public:
|
||||
}
|
||||
template<class _Xp> _LIBCPP_INLINE_VISIBILITY complex& operator*=(const complex<_Xp>& __c)
|
||||
{
|
||||
*this = *this * __c;
|
||||
*this = *this * complex(__c.real(), __c.imag());
|
||||
return *this;
|
||||
}
|
||||
template<class _Xp> _LIBCPP_INLINE_VISIBILITY complex& operator/=(const complex<_Xp>& __c)
|
||||
{
|
||||
*this = *this / __c;
|
||||
*this = *this / complex(__c.real(), __c.imag());
|
||||
return *this;
|
||||
}
|
||||
};
|
||||
@ -424,12 +424,12 @@ public:
|
||||
}
|
||||
template<class _Xp> _LIBCPP_INLINE_VISIBILITY complex& operator*=(const complex<_Xp>& __c)
|
||||
{
|
||||
*this = *this * __c;
|
||||
*this = *this * complex(__c.real(), __c.imag());
|
||||
return *this;
|
||||
}
|
||||
template<class _Xp> _LIBCPP_INLINE_VISIBILITY complex& operator/=(const complex<_Xp>& __c)
|
||||
{
|
||||
*this = *this / __c;
|
||||
*this = *this / complex(__c.real(), __c.imag());
|
||||
return *this;
|
||||
}
|
||||
};
|
||||
@ -480,12 +480,12 @@ public:
|
||||
}
|
||||
template<class _Xp> _LIBCPP_INLINE_VISIBILITY complex& operator*=(const complex<_Xp>& __c)
|
||||
{
|
||||
*this = *this * __c;
|
||||
*this = *this * complex(__c.real(), __c.imag());
|
||||
return *this;
|
||||
}
|
||||
template<class _Xp> _LIBCPP_INLINE_VISIBILITY complex& operator/=(const complex<_Xp>& __c)
|
||||
{
|
||||
*this = *this / __c;
|
||||
*this = *this / complex(__c.real(), __c.imag());
|
||||
return *this;
|
||||
}
|
||||
};
|
||||
@ -740,7 +740,7 @@ operator-(const complex<_Tp>& __x)
|
||||
}
|
||||
|
||||
template<class _Tp>
|
||||
inline _LIBCPP_INLINE_VISIBILITY
|
||||
inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
|
||||
bool
|
||||
operator==(const complex<_Tp>& __x, const complex<_Tp>& __y)
|
||||
{
|
||||
@ -748,7 +748,7 @@ operator==(const complex<_Tp>& __x, const complex<_Tp>& __y)
|
||||
}
|
||||
|
||||
template<class _Tp>
|
||||
inline _LIBCPP_INLINE_VISIBILITY
|
||||
inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
|
||||
bool
|
||||
operator==(const complex<_Tp>& __x, const _Tp& __y)
|
||||
{
|
||||
@ -756,7 +756,7 @@ operator==(const complex<_Tp>& __x, const _Tp& __y)
|
||||
}
|
||||
|
||||
template<class _Tp>
|
||||
inline _LIBCPP_INLINE_VISIBILITY
|
||||
inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
|
||||
bool
|
||||
operator==(const _Tp& __x, const complex<_Tp>& __y)
|
||||
{
|
||||
@ -764,7 +764,7 @@ operator==(const _Tp& __x, const complex<_Tp>& __y)
|
||||
}
|
||||
|
||||
template<class _Tp>
|
||||
inline _LIBCPP_INLINE_VISIBILITY
|
||||
inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
|
||||
bool
|
||||
operator!=(const complex<_Tp>& __x, const complex<_Tp>& __y)
|
||||
{
|
||||
@ -772,7 +772,7 @@ operator!=(const complex<_Tp>& __x, const complex<_Tp>& __y)
|
||||
}
|
||||
|
||||
template<class _Tp>
|
||||
inline _LIBCPP_INLINE_VISIBILITY
|
||||
inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
|
||||
bool
|
||||
operator!=(const complex<_Tp>& __x, const _Tp& __y)
|
||||
{
|
||||
@ -780,7 +780,7 @@ operator!=(const complex<_Tp>& __x, const _Tp& __y)
|
||||
}
|
||||
|
||||
template<class _Tp>
|
||||
inline _LIBCPP_INLINE_VISIBILITY
|
||||
inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
|
||||
bool
|
||||
operator!=(const _Tp& __x, const complex<_Tp>& __y)
|
||||
{
|
||||
@ -792,21 +792,21 @@ operator!=(const _Tp& __x, const complex<_Tp>& __y)
|
||||
// real
|
||||
|
||||
template<class _Tp>
|
||||
inline _LIBCPP_INLINE_VISIBILITY
|
||||
inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
|
||||
_Tp
|
||||
real(const complex<_Tp>& __c)
|
||||
{
|
||||
return __c.real();
|
||||
}
|
||||
|
||||
inline _LIBCPP_INLINE_VISIBILITY
|
||||
inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
|
||||
long double
|
||||
real(long double __re)
|
||||
{
|
||||
return __re;
|
||||
}
|
||||
|
||||
inline _LIBCPP_INLINE_VISIBILITY
|
||||
inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
|
||||
double
|
||||
real(double __re)
|
||||
{
|
||||
@ -814,7 +814,7 @@ real(double __re)
|
||||
}
|
||||
|
||||
template<class _Tp>
|
||||
inline _LIBCPP_INLINE_VISIBILITY
|
||||
inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
|
||||
typename enable_if
|
||||
<
|
||||
is_integral<_Tp>::value,
|
||||
@ -825,7 +825,7 @@ real(_Tp __re)
|
||||
return __re;
|
||||
}
|
||||
|
||||
inline _LIBCPP_INLINE_VISIBILITY
|
||||
inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
|
||||
float
|
||||
real(float __re)
|
||||
{
|
||||
@ -835,21 +835,21 @@ real(float __re)
|
||||
// imag
|
||||
|
||||
template<class _Tp>
|
||||
inline _LIBCPP_INLINE_VISIBILITY
|
||||
inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
|
||||
_Tp
|
||||
imag(const complex<_Tp>& __c)
|
||||
{
|
||||
return __c.imag();
|
||||
}
|
||||
|
||||
inline _LIBCPP_INLINE_VISIBILITY
|
||||
inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
|
||||
long double
|
||||
imag(long double __re)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
inline _LIBCPP_INLINE_VISIBILITY
|
||||
inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
|
||||
double
|
||||
imag(double __re)
|
||||
{
|
||||
@ -857,7 +857,7 @@ imag(double __re)
|
||||
}
|
||||
|
||||
template<class _Tp>
|
||||
inline _LIBCPP_INLINE_VISIBILITY
|
||||
inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
|
||||
typename enable_if
|
||||
<
|
||||
is_integral<_Tp>::value,
|
||||
@ -868,7 +868,7 @@ imag(_Tp __re)
|
||||
return 0;
|
||||
}
|
||||
|
||||
inline _LIBCPP_INLINE_VISIBILITY
|
||||
inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
|
||||
float
|
||||
imag(float __re)
|
||||
{
|
||||
|
@ -19,29 +19,41 @@
|
||||
|
||||
#include "../cases.h"
|
||||
|
||||
template <class T>
|
||||
template <class T, int x>
|
||||
void
|
||||
test(T x, typename std::enable_if<std::is_integral<T>::value>::type* = 0)
|
||||
test(typename std::enable_if<std::is_integral<T>::value>::type* = 0)
|
||||
{
|
||||
static_assert((std::is_same<decltype(std::imag(x)), double>::value), "");
|
||||
static_assert((std::is_same<decltype(std::imag(T(x))), double>::value), "");
|
||||
assert(std::imag(x) == 0);
|
||||
#if _LIBCPP_STD_VER > 11
|
||||
constexpr T val {x};
|
||||
static_assert(std::imag(val) == 0, "");
|
||||
constexpr std::complex<T> t{val, val};
|
||||
static_assert(t.imag() == x, "" );
|
||||
#endif
|
||||
}
|
||||
|
||||
template <class T>
|
||||
template <class T, int x>
|
||||
void
|
||||
test(T x, typename std::enable_if<!std::is_integral<T>::value>::type* = 0)
|
||||
test(typename std::enable_if<!std::is_integral<T>::value>::type* = 0)
|
||||
{
|
||||
static_assert((std::is_same<decltype(std::imag(x)), T>::value), "");
|
||||
static_assert((std::is_same<decltype(std::imag(T(x))), T>::value), "");
|
||||
assert(std::imag(x) == 0);
|
||||
#if _LIBCPP_STD_VER > 11
|
||||
constexpr T val {x};
|
||||
static_assert(std::imag(val) == 0, "");
|
||||
constexpr std::complex<T> t{val, val};
|
||||
static_assert(t.imag() == x, "" );
|
||||
#endif
|
||||
}
|
||||
|
||||
template <class T>
|
||||
void
|
||||
test()
|
||||
{
|
||||
test<T>(0);
|
||||
test<T>(1);
|
||||
test<T>(10);
|
||||
test<T, 0>();
|
||||
test<T, 1>();
|
||||
test<T, 10>();
|
||||
}
|
||||
|
||||
int main()
|
||||
|
@ -19,29 +19,41 @@
|
||||
|
||||
#include "../cases.h"
|
||||
|
||||
template <class T>
|
||||
template <class T, int x>
|
||||
void
|
||||
test(T x, typename std::enable_if<std::is_integral<T>::value>::type* = 0)
|
||||
test(typename std::enable_if<std::is_integral<T>::value>::type* = 0)
|
||||
{
|
||||
static_assert((std::is_same<decltype(std::real(x)), double>::value), "");
|
||||
static_assert((std::is_same<decltype(std::real(T(x))), double>::value), "");
|
||||
assert(std::real(x) == x);
|
||||
#if _LIBCPP_STD_VER > 11
|
||||
constexpr T val {x};
|
||||
static_assert(std::real(val) == val, "");
|
||||
constexpr std::complex<T> t{val, val};
|
||||
static_assert(t.real() == x, "" );
|
||||
#endif
|
||||
}
|
||||
|
||||
template <class T>
|
||||
template <class T, int x>
|
||||
void
|
||||
test(T x, typename std::enable_if<!std::is_integral<T>::value>::type* = 0)
|
||||
test(typename std::enable_if<!std::is_integral<T>::value>::type* = 0)
|
||||
{
|
||||
static_assert((std::is_same<decltype(std::real(x)), T>::value), "");
|
||||
static_assert((std::is_same<decltype(std::real(T(x))), T>::value), "");
|
||||
assert(std::real(x) == x);
|
||||
#if _LIBCPP_STD_VER > 11
|
||||
constexpr T val {x};
|
||||
static_assert(std::real(val) == val, "");
|
||||
constexpr std::complex<T> t{val, val};
|
||||
static_assert(t.real() == x, "" );
|
||||
#endif
|
||||
}
|
||||
|
||||
template <class T>
|
||||
void
|
||||
test()
|
||||
{
|
||||
test<T>(0);
|
||||
test<T>(1);
|
||||
test<T>(10);
|
||||
test<T, 0>();
|
||||
test<T, 1>();
|
||||
test<T, 10>();
|
||||
}
|
||||
|
||||
int main()
|
||||
|
@ -28,6 +28,21 @@ test()
|
||||
c /= c2;
|
||||
assert(c.real() == 1);
|
||||
assert(c.imag() == 0);
|
||||
|
||||
std::complex<T> c3;
|
||||
|
||||
c3 = c;
|
||||
std::complex<int> ic (1,1);
|
||||
c3 /= ic;
|
||||
assert(c3.real() == 0.5);
|
||||
assert(c3.imag() == -0.5);
|
||||
|
||||
c3 = c;
|
||||
std::complex<float> fc (1,1);
|
||||
c3 /= fc;
|
||||
assert(c3.real() == 0.5);
|
||||
assert(c3.imag() == -0.5);
|
||||
|
||||
}
|
||||
|
||||
int main()
|
||||
|
@ -28,6 +28,20 @@ test()
|
||||
c -= c2;
|
||||
assert(c.real() == -3);
|
||||
assert(c.imag() == -5);
|
||||
|
||||
std::complex<T> c3;
|
||||
|
||||
c3 = c;
|
||||
std::complex<int> ic (1,1);
|
||||
c3 -= ic;
|
||||
assert(c3.real() == -4);
|
||||
assert(c3.imag() == -6);
|
||||
|
||||
c3 = c;
|
||||
std::complex<float> fc (1,1);
|
||||
c3 -= fc;
|
||||
assert(c3.real() == -4);
|
||||
assert(c3.imag() == -6);
|
||||
}
|
||||
|
||||
int main()
|
||||
|
@ -28,6 +28,20 @@ test()
|
||||
c += c2;
|
||||
assert(c.real() == 3);
|
||||
assert(c.imag() == 5);
|
||||
|
||||
std::complex<T> c3;
|
||||
|
||||
c3 = c;
|
||||
std::complex<int> ic (1,1);
|
||||
c3 += ic;
|
||||
assert(c3.real() == 4);
|
||||
assert(c3.imag() == 6);
|
||||
|
||||
c3 = c;
|
||||
std::complex<float> fc (1,1);
|
||||
c3 += fc;
|
||||
assert(c3.real() == 4);
|
||||
assert(c3.imag() == 6);
|
||||
}
|
||||
|
||||
int main()
|
||||
|
@ -28,6 +28,20 @@ test()
|
||||
c *= c2;
|
||||
assert(c.real() == -4);
|
||||
assert(c.imag() == 7.5);
|
||||
|
||||
std::complex<T> c3;
|
||||
|
||||
c3 = c;
|
||||
std::complex<int> ic (1,1);
|
||||
c3 *= ic;
|
||||
assert(c3.real() == -11.5);
|
||||
assert(c3.imag() == 3.5);
|
||||
|
||||
c3 = c;
|
||||
std::complex<float> fc (1,1);
|
||||
c3 *= fc;
|
||||
assert(c3.real() == -11.5);
|
||||
assert(c3.imag() == 3.5);
|
||||
}
|
||||
|
||||
int main()
|
||||
|
@ -15,6 +15,23 @@
|
||||
#include <complex>
|
||||
#include <cassert>
|
||||
|
||||
template <class T>
|
||||
void
|
||||
test_constexpr()
|
||||
{
|
||||
#if _LIBCPP_STD_VER > 11
|
||||
constexpr std::complex<T> c1;
|
||||
static_assert(c1.real() == 0, "");
|
||||
static_assert(c1.imag() == 0, "");
|
||||
constexpr std::complex<T> c2(3);
|
||||
static_assert(c2.real() == 3, "");
|
||||
static_assert(c2.imag() == 0, "");
|
||||
constexpr std::complex<T> c3(3, 4);
|
||||
static_assert(c3.real() == 3, "");
|
||||
static_assert(c3.imag() == 4, "");
|
||||
#endif
|
||||
}
|
||||
|
||||
template <class T>
|
||||
void
|
||||
test()
|
||||
@ -34,6 +51,8 @@ test()
|
||||
c.imag(-5.5);
|
||||
assert(c.real() == -4.5);
|
||||
assert(c.imag() == -5.5);
|
||||
|
||||
test_constexpr<T> ();
|
||||
}
|
||||
|
||||
int main()
|
||||
@ -41,4 +60,5 @@ int main()
|
||||
test<float>();
|
||||
test<double>();
|
||||
test<long double>();
|
||||
test_constexpr<int> ();
|
||||
}
|
||||
|
@ -18,9 +18,20 @@
|
||||
|
||||
template <class T>
|
||||
void
|
||||
test(const std::complex<T>& lhs, const std::complex<T>& rhs, bool x)
|
||||
test_constexpr()
|
||||
{
|
||||
assert((lhs == rhs) == x);
|
||||
#if _LIBCPP_STD_VER > 11
|
||||
{
|
||||
constexpr std::complex<T> lhs(1.5, 2.5);
|
||||
constexpr std::complex<T> rhs(1.5, -2.5);
|
||||
static_assert( !(lhs == rhs), "");
|
||||
}
|
||||
{
|
||||
constexpr std::complex<T> lhs(1.5, 2.5);
|
||||
constexpr std::complex<T> rhs(1.5, 2.5);
|
||||
static_assert(lhs == rhs, "");
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
template <class T>
|
||||
@ -30,13 +41,14 @@ test()
|
||||
{
|
||||
std::complex<T> lhs(1.5, 2.5);
|
||||
std::complex<T> rhs(1.5, -2.5);
|
||||
test(lhs, rhs, false);
|
||||
assert( !(lhs == rhs));
|
||||
}
|
||||
{
|
||||
std::complex<T> lhs(1.5, 2.5);
|
||||
std::complex<T> rhs(1.5, 2.5);
|
||||
test(lhs, rhs, true);
|
||||
assert(lhs == rhs);
|
||||
}
|
||||
test_constexpr<T> ();
|
||||
}
|
||||
|
||||
int main()
|
||||
@ -44,4 +56,5 @@ int main()
|
||||
test<float>();
|
||||
test<double>();
|
||||
test<long double>();
|
||||
// test_constexpr<int> ();
|
||||
}
|
||||
|
@ -18,9 +18,30 @@
|
||||
|
||||
template <class T>
|
||||
void
|
||||
test(const std::complex<T>& lhs, const T& rhs, bool x)
|
||||
test_constexpr()
|
||||
{
|
||||
assert((lhs == rhs) == x);
|
||||
#if _LIBCPP_STD_VER > 11
|
||||
{
|
||||
constexpr std::complex<T> lhs(1.5, 2.5);
|
||||
constexpr T rhs(-2.5);
|
||||
static_assert(!(lhs == rhs), "");
|
||||
}
|
||||
{
|
||||
constexpr std::complex<T> lhs(1.5, 0);
|
||||
constexpr T rhs(-2.5);
|
||||
static_assert(!(lhs == rhs), "");
|
||||
}
|
||||
{
|
||||
constexpr std::complex<T> lhs(1.5, 2.5);
|
||||
constexpr T rhs(1.5);
|
||||
static_assert(!(lhs == rhs), "");
|
||||
}
|
||||
{
|
||||
constexpr std::complex<T> lhs(1.5, 0);
|
||||
constexpr T rhs(1.5);
|
||||
static_assert( (lhs == rhs), "");
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
template <class T>
|
||||
@ -30,28 +51,31 @@ test()
|
||||
{
|
||||
std::complex<T> lhs(1.5, 2.5);
|
||||
T rhs(-2.5);
|
||||
test(lhs, rhs, false);
|
||||
assert(!(lhs == rhs));
|
||||
}
|
||||
{
|
||||
std::complex<T> lhs(1.5, 0);
|
||||
std::complex<T> lhs(1.5, 0);
|
||||
T rhs(-2.5);
|
||||
test(lhs, rhs, false);
|
||||
assert(!(lhs == rhs));
|
||||
}
|
||||
{
|
||||
std::complex<T> lhs(1.5, 2.5);
|
||||
T rhs(1.5);
|
||||
test(lhs, rhs, false);
|
||||
assert(!(lhs == rhs));
|
||||
}
|
||||
{
|
||||
std::complex<T> lhs(1.5, 0);
|
||||
T rhs(1.5);
|
||||
test(lhs, rhs, true);
|
||||
assert( (lhs == rhs));
|
||||
}
|
||||
|
||||
test_constexpr<T> ();
|
||||
}
|
||||
}
|
||||
|
||||
int main()
|
||||
{
|
||||
test<float>();
|
||||
test<double>();
|
||||
test<long double>();
|
||||
// test_constexpr<int> ();
|
||||
}
|
||||
|
@ -18,11 +18,23 @@
|
||||
|
||||
template <class T>
|
||||
void
|
||||
test(const std::complex<T>& lhs, const std::complex<T>& rhs, bool x)
|
||||
test_constexpr()
|
||||
{
|
||||
assert((lhs != rhs) == x);
|
||||
#if _LIBCPP_STD_VER > 11
|
||||
{
|
||||
constexpr std::complex<T> lhs(1.5, 2.5);
|
||||
constexpr std::complex<T> rhs(1.5, -2.5);
|
||||
static_assert(lhs != rhs, "");
|
||||
}
|
||||
{
|
||||
constexpr std::complex<T> lhs(1.5, 2.5);
|
||||
constexpr std::complex<T> rhs(1.5, 2.5);
|
||||
static_assert(!(lhs != rhs), "" );
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
template <class T>
|
||||
void
|
||||
test()
|
||||
@ -30,18 +42,21 @@ test()
|
||||
{
|
||||
std::complex<T> lhs(1.5, 2.5);
|
||||
std::complex<T> rhs(1.5, -2.5);
|
||||
test(lhs, rhs, true);
|
||||
assert(lhs != rhs);
|
||||
}
|
||||
{
|
||||
std::complex<T> lhs(1.5, 2.5);
|
||||
std::complex<T> rhs(1.5, 2.5);
|
||||
test(lhs, rhs, false);
|
||||
assert(!(lhs != rhs));
|
||||
}
|
||||
}
|
||||
|
||||
test_constexpr<T> ();
|
||||
}
|
||||
|
||||
int main()
|
||||
{
|
||||
test<float>();
|
||||
test<double>();
|
||||
test<long double>();
|
||||
// test_constexpr<int> ();
|
||||
}
|
||||
|
@ -18,9 +18,30 @@
|
||||
|
||||
template <class T>
|
||||
void
|
||||
test(const std::complex<T>& lhs, const T& rhs, bool x)
|
||||
test_constexpr()
|
||||
{
|
||||
assert((lhs != rhs) == x);
|
||||
#if _LIBCPP_STD_VER > 11
|
||||
{
|
||||
constexpr std::complex<T> lhs(1.5, 2.5);
|
||||
constexpr T rhs(-2.5);
|
||||
static_assert(lhs != rhs, "");
|
||||
}
|
||||
{
|
||||
constexpr std::complex<T> lhs(1.5, 0);
|
||||
constexpr T rhs(-2.5);
|
||||
static_assert(lhs != rhs, "");
|
||||
}
|
||||
{
|
||||
constexpr std::complex<T> lhs(1.5, 2.5);
|
||||
constexpr T rhs(1.5);
|
||||
static_assert(lhs != rhs, "");
|
||||
}
|
||||
{
|
||||
constexpr std::complex<T> lhs(1.5, 0);
|
||||
constexpr T rhs(1.5);
|
||||
static_assert( !(lhs != rhs), "");
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
template <class T>
|
||||
@ -30,23 +51,25 @@ test()
|
||||
{
|
||||
std::complex<T> lhs(1.5, 2.5);
|
||||
T rhs(-2.5);
|
||||
test(lhs, rhs, true);
|
||||
assert(lhs != rhs);
|
||||
}
|
||||
{
|
||||
std::complex<T> lhs(1.5, 0);
|
||||
T rhs(-2.5);
|
||||
test(lhs, rhs, true);
|
||||
assert(lhs != rhs);
|
||||
}
|
||||
{
|
||||
std::complex<T> lhs(1.5, 2.5);
|
||||
T rhs(1.5);
|
||||
test(lhs, rhs, true);
|
||||
assert(lhs != rhs);
|
||||
}
|
||||
{
|
||||
std::complex<T> lhs(1.5, 0);
|
||||
T rhs(1.5);
|
||||
test(lhs, rhs, false);
|
||||
assert( !(lhs != rhs));
|
||||
}
|
||||
|
||||
test_constexpr<T> ();
|
||||
}
|
||||
|
||||
int main()
|
||||
@ -54,4 +77,5 @@ int main()
|
||||
test<float>();
|
||||
test<double>();
|
||||
test<long double>();
|
||||
}
|
||||
// test_constexpr<int> ();
|
||||
}
|
||||
|
@ -18,9 +18,30 @@
|
||||
|
||||
template <class T>
|
||||
void
|
||||
test(const T& lhs, const std::complex<T>& rhs, bool x)
|
||||
test_constexpr()
|
||||
{
|
||||
assert((lhs == rhs) == x);
|
||||
#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>
|
||||
@ -30,23 +51,25 @@ test()
|
||||
{
|
||||
T lhs(-2.5);
|
||||
std::complex<T> rhs(1.5, 2.5);
|
||||
test(lhs, rhs, false);
|
||||
assert(!(lhs == rhs));
|
||||
}
|
||||
{
|
||||
T lhs(-2.5);
|
||||
std::complex<T> rhs(1.5, 0);
|
||||
test(lhs, rhs, false);
|
||||
assert(!(lhs == rhs));
|
||||
}
|
||||
{
|
||||
T lhs(1.5);
|
||||
std::complex<T> rhs(1.5, 2.5);
|
||||
test(lhs, rhs, false);
|
||||
assert(!(lhs == rhs));
|
||||
}
|
||||
{
|
||||
T lhs(1.5);
|
||||
std::complex<T> rhs(1.5, 0);
|
||||
test(lhs, rhs, true);
|
||||
assert(lhs == rhs);
|
||||
}
|
||||
|
||||
test_constexpr<T> ();
|
||||
}
|
||||
|
||||
int main()
|
||||
@ -54,4 +77,5 @@ int main()
|
||||
test<float>();
|
||||
test<double>();
|
||||
test<long double>();
|
||||
// test_constexpr<int>();
|
||||
}
|
||||
|
@ -18,9 +18,30 @@
|
||||
|
||||
template <class T>
|
||||
void
|
||||
test(const T& lhs, const std::complex<T>& rhs, bool x)
|
||||
test_constexpr()
|
||||
{
|
||||
assert((lhs != rhs) == x);
|
||||
#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>
|
||||
@ -30,28 +51,31 @@ test()
|
||||
{
|
||||
T lhs(-2.5);
|
||||
std::complex<T> rhs(1.5, 2.5);
|
||||
test(lhs, rhs, true);
|
||||
assert (lhs != rhs);
|
||||
}
|
||||
{
|
||||
T lhs(-2.5);
|
||||
std::complex<T> rhs(1.5, 0);
|
||||
test(lhs, rhs, true);
|
||||
assert (lhs != rhs);
|
||||
}
|
||||
{
|
||||
T lhs(1.5);
|
||||
std::complex<T> rhs(1.5, 2.5);
|
||||
test(lhs, rhs, true);
|
||||
assert (lhs != rhs);
|
||||
}
|
||||
{
|
||||
T lhs(1.5);
|
||||
std::complex<T> rhs(1.5, 0);
|
||||
test(lhs, rhs, false);
|
||||
assert (!(lhs != rhs));
|
||||
}
|
||||
|
||||
test_constexpr<T> ();
|
||||
}
|
||||
}
|
||||
|
||||
int main()
|
||||
{
|
||||
test<float>();
|
||||
test<double>();
|
||||
test<long double>();
|
||||
// test_constexpr<int>();
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user