Fixes a small omission in libcxx that prevents libcxx being built when -DLIBCXX_ENABLE_EXCEPTIONS=0 is specified. This patch adds XFAILS to all those tests that are currently failing on the new -fno-exceptions library variant. Follow-up patches will update the tests (progressively) to cope with the new library variant. Change-Id: I4b801bd8d8e4fe7193df9e55f39f1f393a8ba81a git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@252598 91177308-0d34-0410-b5e6-96231b3b80d8
58 lines
1.1 KiB
C++
58 lines
1.1 KiB
C++
//===----------------------------------------------------------------------===//
|
|
//
|
|
// 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.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// XFAIL: libcpp-no-exceptions
|
|
// UNSUPPORTED: libcpp-has-no-threads
|
|
|
|
// <mutex>
|
|
|
|
// template <class Mutex> class unique_lock;
|
|
|
|
// void unlock();
|
|
|
|
#include <mutex>
|
|
#include <cassert>
|
|
|
|
bool unlock_called = false;
|
|
|
|
struct mutex
|
|
{
|
|
void lock() {}
|
|
void unlock() {unlock_called = true;}
|
|
};
|
|
|
|
mutex m;
|
|
|
|
int main()
|
|
{
|
|
std::unique_lock<mutex> lk(m);
|
|
lk.unlock();
|
|
assert(unlock_called == true);
|
|
assert(lk.owns_lock() == false);
|
|
try
|
|
{
|
|
lk.unlock();
|
|
assert(false);
|
|
}
|
|
catch (std::system_error& e)
|
|
{
|
|
assert(e.code().value() == EPERM);
|
|
}
|
|
lk.release();
|
|
try
|
|
{
|
|
lk.unlock();
|
|
assert(false);
|
|
}
|
|
catch (std::system_error& e)
|
|
{
|
|
assert(e.code().value() == EPERM);
|
|
}
|
|
}
|