diff --git a/libcxxabi/include/cxxabi.h b/libcxxabi/include/cxxabi.h index 767acfef5673..f29253ce1b6c 100644 --- a/libcxxabi/include/cxxabi.h +++ b/libcxxabi/include/cxxabi.h @@ -20,7 +20,7 @@ #include <__cxxabi_config.h> -#define _LIBCPPABI_VERSION 1001 +#define _LIBCPPABI_VERSION 1002 #define LIBCXXABI_NORETURN __attribute__((noreturn)) #ifdef __cplusplus @@ -161,8 +161,9 @@ extern void __cxa_rethrow_primary_exception(void* primary_exception); extern void __cxa_increment_exception_refcount(void* primary_exception) throw(); extern void __cxa_decrement_exception_refcount(void* primary_exception) throw(); -// Apple addition to support std::uncaught_exception() -extern bool __cxa_uncaught_exception() throw(); +// Apple extension to support std::uncaught_exception() +extern bool __cxa_uncaught_exception () throw(); +extern unsigned int __cxa_uncaught_exceptions() throw(); #ifdef __linux__ // Linux TLS support. Not yet an official part of the Itanium ABI. diff --git a/libcxxabi/src/cxa_exception.cpp b/libcxxabi/src/cxa_exception.cpp index b7a33d716c43..ae2b39ca60ab 100644 --- a/libcxxabi/src/cxa_exception.cpp +++ b/libcxxabi/src/cxa_exception.cpp @@ -710,13 +710,16 @@ __cxa_rethrow_primary_exception(void* thrown_object) } bool -__cxa_uncaught_exception() throw() +__cxa_uncaught_exception() throw() { return __cxa_uncaught_exceptions() != 0; } + +unsigned int +__cxa_uncaught_exceptions() throw() { // This does not report foreign exceptions in flight __cxa_eh_globals* globals = __cxa_get_globals_fast(); if (globals == 0) - return false; - return globals->uncaughtExceptions != 0; + return 0; + return globals->uncaughtExceptions; } } // extern "C" diff --git a/libcxxabi/test/uncaught_exceptions.pass.cpp b/libcxxabi/test/uncaught_exceptions.pass.cpp new file mode 100644 index 000000000000..fd4b8f416460 --- /dev/null +++ b/libcxxabi/test/uncaught_exceptions.pass.cpp @@ -0,0 +1,36 @@ +//===------------------- uncaught_exceptions.pass.cpp ---------------------===// +// +// 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. +// +//===----------------------------------------------------------------------===// + +#include +#include +#include + +// namespace __cxxabiv1 { +// extern bool __cxa_uncaught_exception () throw(); +// extern unsigned int __cxa_uncaught_exceptions() throw(); +// } + +struct A { + ~A() { assert( __cxxabiv1::__cxa_uncaught_exception()); } + }; + +struct B { + B(int cnt) : data_(cnt) {} + ~B() { assert( data_ == __cxxabiv1::__cxa_uncaught_exceptions()); } + int data_; + }; + +int main () +{ + try { A a; throw 3; assert (false); } + catch (int) {} + + try { B b(1); throw 3; assert (false); } + catch (int) {} +}