Files
libcxx/test/std/depr/exception.unexpected/set.unexpected/get_unexpected.pass.cpp
Eric Fiselier 515ba559b9 [libcxx] Remove unexpected handlers in C++17
Summary:
This patch implements [P0003R5](http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2016/p0003r5.html) which removes exception specifications from C++17.

The only changes to the library are removing `set_unexpected`, `get_unexpected`, `unexpected`, and `unexpected_handler`. These functions can be re-enabled in C++17 using `_LIBCPP_ENABLE_CXX17_REMOVED_UNEXPECTED_FUNCTIONS`.

@mclow.lists what do you think about removing stuff is this way?

Reviewers: mclow.lists

Reviewed By: mclow.lists

Subscribers: mclow.lists, cfe-commits

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

git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@295406 91177308-0d34-0410-b5e6-96231b3b80d8
2017-02-17 03:25:08 +00:00

42 lines
991 B
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.
//
//===----------------------------------------------------------------------===//
// REQUIRES: c++98 || c++03 || c++11 || c++14
// test get_unexpected
#include <exception>
#include <cassert>
#include <cstdlib>
void f1() {}
void f2() {}
void f3()
{
std::exit(0);
}
int main()
{
std::unexpected_handler old = std::get_unexpected();
// verify there is a previous unexpected handler
assert(old);
std::set_unexpected(f1);
assert(std::get_unexpected() == f1);
// verify f1 was replace with f2
std::set_unexpected(f2);
assert(std::get_unexpected() == f2);
// verify calling original unexpected handler calls terminate
std::set_terminate(f3);
(*old)();
assert(0);
}