[RISCV] Fix mgather -> riscv.masked.strided.load combine not extending indices (...
[llvm-project.git] / libcxx / test / std / thread / thread.mutex / thread.lock / thread.lock.unique / thread.lock.unique.cons / move_assign.pass.cpp
blob0af918c1e20eee073c8ad267b1a4ceca68efbc7c
1 //===----------------------------------------------------------------------===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
8 //
9 // UNSUPPORTED: no-threads, c++03
11 // <mutex>
13 // template <class Mutex> class unique_lock;
15 // unique_lock& operator=(unique_lock&& u);
17 #include <mutex>
18 #include <cassert>
19 #include "nasty_containers.h"
21 #include "test_macros.h"
23 int main(int, char**)
26 typedef std::mutex M;
27 M m0;
28 M m1;
29 std::unique_lock<M> lk0(m0);
30 std::unique_lock<M> lk1(m1);
31 lk1 = std::move(lk0);
32 assert(lk1.mutex() == std::addressof(m0));
33 assert(lk1.owns_lock() == true);
34 assert(lk0.mutex() == nullptr);
35 assert(lk0.owns_lock() == false);
38 typedef nasty_mutex M;
39 M m0;
40 M m1;
41 std::unique_lock<M> lk0(m0);
42 std::unique_lock<M> lk1(m1);
43 lk1 = std::move(lk0);
44 assert(lk1.mutex() == std::addressof(m0));
45 assert(lk1.owns_lock() == true);
46 assert(lk0.mutex() == nullptr);
47 assert(lk0.owns_lock() == false);
50 return 0;