diff options
author | Marshall Clow <mclow.lists@gmail.com> | 2017-03-24 03:40:36 +0000 |
---|---|---|
committer | Marshall Clow <mclow.lists@gmail.com> | 2017-03-24 03:40:36 +0000 |
commit | 6015dd11c875b9467c93221f19e5d59b0522757a (patch) | |
tree | dde732f117aad6ed353d8d067f047f1d0ce663e6 /libcxx/test/std/thread/thread.mutex/thread.lock/thread.lock.scoped/assign.fail.cpp | |
parent | 36f2e0eee834fca853e6e0df6b4fa76b06c0f329 (diff) | |
download | bcm5719-llvm-6015dd11c875b9467c93221f19e5d59b0522757a.tar.gz bcm5719-llvm-6015dd11c875b9467c93221f19e5d59b0522757a.zip |
Implement Pp0156r2: 'Variadic Lock Guard, version 5' Reviewed as https://reviews.llvm.org/D31163.
llvm-svn: 298681
Diffstat (limited to 'libcxx/test/std/thread/thread.mutex/thread.lock/thread.lock.scoped/assign.fail.cpp')
-rw-r--r-- | libcxx/test/std/thread/thread.mutex/thread.lock/thread.lock.scoped/assign.fail.cpp | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/libcxx/test/std/thread/thread.mutex/thread.lock/thread.lock.scoped/assign.fail.cpp b/libcxx/test/std/thread/thread.mutex/thread.lock/thread.lock.scoped/assign.fail.cpp new file mode 100644 index 00000000000..a0547293552 --- /dev/null +++ b/libcxx/test/std/thread/thread.mutex/thread.lock/thread.lock.scoped/assign.fail.cpp @@ -0,0 +1,50 @@ +//===----------------------------------------------------------------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is dual licensed under the MIT and the University of Illinois Open +// Source Licenses. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// + +// UNSUPPORTED: libcpp-has-no-threads +// UNSUPPORTED: c++98, c++03, c++11, c++14 + +// <mutex> + +// template <class ...Mutex> class scoped_lock; + +// scoped_lock& operator=(scoped_lock const&) = delete; + +#include <mutex> +#include "test_macros.h" + +int main() +{ + using M = std::mutex; + M m0, m1, m2; + M om0, om1, om2; + { + using LG = std::scoped_lock<>; + LG lg1, lg2; + lg1 = lg2; // expected-error{{overload resolution selected deleted operator '='}} + } + { + using LG = std::scoped_lock<M>; + LG lg1(m0); + LG lg2(om0); + lg1 = lg2; // expected-error{{overload resolution selected deleted operator '='}} + } + { + using LG = std::scoped_lock<M, M>; + LG lg1(m0, m1); + LG lg2(om0, om1); + lg1 = lg2; // expected-error{{overload resolution selected deleted operator '='}} + } + { + using LG = std::scoped_lock<M, M, M>; + LG lg1(m0, m1, m2); + LG lg2(om0, om1, om2); + lg1 = lg2; // expected-error{{overload resolution selected deleted operator '='}} + } +} |