teak-llvm/libcxx/test/std/language.support/support.exception/except.nested/assign.pass.cpp
Eric Fiselier 3e254a6ece [libc++] Implement exception_ptr on Windows
Summary:
This patch implements exception_ptr on Windows using the `__ExceptionPtrFoo` functions provided by MSVC.

The `__ExceptionPtrFoo` functions are defined inside the C++ standard library, `msvcprt`, which is unfortunate because it requires libc++ to link to the MSVC STL. However this doesn't seem to cause any immediate problems. However to be safe I kept all usages within the libc++ dylib so that user programs wouldn't have to link to MSVCPRT as well.

Note there are still 2 outstanding exception_ptr/nested_exception test failures.

* `current_exception.pass.cpp` needs to be rewritten for the Windows exception_ptr semantics which copy the exception every time.
* `rethrow_if_nested.pass.cpp` need investigation. It hits a stack overflow, likely from recursion.

This patch also gets most of the `<future>` tests passing as well.

Reviewers: mclow.lists, compnerd, bcraig, rmaprath, majnemer, BillyONeal, STL_MSFT

Subscribers: mgorny, cfe-commits

Differential Revision: https://reviews.llvm.org/D32927

llvm-svn: 302393
2017-05-08 01:17:50 +00:00

64 lines
1.4 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.
//
//===----------------------------------------------------------------------===//
// <exception>
// class nested_exception;
// nested_exception& operator=(const nested_exception&) throw() = default;
#include <exception>
#include <cassert>
#include "test_macros.h"
class A
{
int data_;
public:
explicit A(int data) : data_(data) {}
friend bool operator==(const A& x, const A& y) {return x.data_ == y.data_;}
};
int main()
{
{
std::nested_exception e0;
std::nested_exception e;
e = e0;
assert(e.nested_ptr() == nullptr);
}
#ifndef TEST_HAS_NO_EXCEPTIONS
{
try
{
throw A(2);
assert(false);
}
catch (const A&)
{
std::nested_exception e0;
std::nested_exception e;
e = e0;
assert(e.nested_ptr() != nullptr);
try
{
rethrow_exception(e.nested_ptr());
assert(false);
}
catch (const A& a)
{
assert(a == A(2));
}
}
}
#endif
}