diff options
author | Mikhail Maltsev <mikhail.maltsev@arm.com> | 2018-02-08 11:33:48 +0000 |
---|---|---|
committer | Mikhail Maltsev <mikhail.maltsev@arm.com> | 2018-02-08 11:33:48 +0000 |
commit | 2b20304def44a0e3c4ab4ae90f50d4c4449ce03d (patch) | |
tree | fca74d6f819afec7856cb5e37500974845b37d5d /libcxx/test/std/numerics/numarray/template.valarray/valarray.assign/copy_assign.pass.cpp | |
parent | 25dc3d27ea816aeff1d30929845efb0db934f0b3 (diff) | |
download | bcm5719-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.cpp | 27 |
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); + } } |