summaryrefslogtreecommitdiffstats
path: root/libcxx/test/std/numerics/numarray/template.valarray/valarray.assign/copy_assign.pass.cpp
diff options
context:
space:
mode:
authorMikhail Maltsev <mikhail.maltsev@arm.com>2018-02-08 11:33:48 +0000
committerMikhail Maltsev <mikhail.maltsev@arm.com>2018-02-08 11:33:48 +0000
commit2b20304def44a0e3c4ab4ae90f50d4c4449ce03d (patch)
treefca74d6f819afec7856cb5e37500974845b37d5d /libcxx/test/std/numerics/numarray/template.valarray/valarray.assign/copy_assign.pass.cpp
parent25dc3d27ea816aeff1d30929845efb0db934f0b3 (diff)
downloadbcm5719-llvm-2b20304def44a0e3c4ab4ae90f50d4c4449ce03d.tar.gz
bcm5719-llvm-2b20304def44a0e3c4ab4ae90f50d4c4449ce03d.zip
[libcxx] Avoid spurious construction of valarray elements
Summary: Currently libc++ implements some operations on valarray by using the resize method. This method has a parameter with a default value. Because of this, valarray may spuriously construct and destruct objects of valarray's element type. This patch fixes this issue and adds corresponding test cases. Reviewers: EricWF, mclow.lists Reviewed By: mclow.lists Subscribers: rogfer01, cfe-commits Differential Revision: https://reviews.llvm.org/D41992 llvm-svn: 324596
Diffstat (limited to 'libcxx/test/std/numerics/numarray/template.valarray/valarray.assign/copy_assign.pass.cpp')
-rw-r--r--libcxx/test/std/numerics/numarray/template.valarray/valarray.assign/copy_assign.pass.cpp27
1 files changed, 27 insertions, 0 deletions
diff --git a/libcxx/test/std/numerics/numarray/template.valarray/valarray.assign/copy_assign.pass.cpp b/libcxx/test/std/numerics/numarray/template.valarray/valarray.assign/copy_assign.pass.cpp
index 3803489c303..da1225ae059 100644
--- a/libcxx/test/std/numerics/numarray/template.valarray/valarray.assign/copy_assign.pass.cpp
+++ b/libcxx/test/std/numerics/numarray/template.valarray/valarray.assign/copy_assign.pass.cpp
@@ -17,6 +17,21 @@
#include <cassert>
#include <cstddef>
+struct S
+{
+ S() : x_(0) { default_ctor_called = true; }
+ S(int x) : x_(x) {}
+ int x_;
+ static bool default_ctor_called;
+};
+
+bool S::default_ctor_called = false;
+
+bool operator==(const S& lhs, const S& rhs)
+{
+ return lhs.x_ == rhs.x_;
+}
+
int main()
{
{
@@ -56,4 +71,16 @@ int main()
assert(v2[i][j] == v[i][j]);
}
}
+ {
+ typedef S T;
+ T a[] = {T(1), T(2), T(3), T(4), T(5)};
+ const unsigned N = sizeof(a)/sizeof(a[0]);
+ std::valarray<T> v(a, N);
+ std::valarray<T> v2;
+ v2 = v;
+ assert(v2.size() == v.size());
+ for (std::size_t i = 0; i < v2.size(); ++i)
+ assert(v2[i] == v[i]);
+ assert(!S::default_ctor_called);
+ }
}
OpenPOWER on IntegriCloud