[libcxx-commits] [libcxx] 9ff36c2 - [libc++] Guard terminate_successful with TEST_HAS_NO_EXCEPTIONS

Louis Dionne via libcxx-commits libcxx-commits at lists.llvm.org
Wed Jun 21 05:34:56 PDT 2023


Author: Louis Dionne
Date: 2023-06-21T08:34:51-04:00
New Revision: 9ff36c24a04d9aae61ae09f460c3344f16bb40dc

URL: https://github.com/llvm/llvm-project/commit/9ff36c24a04d9aae61ae09f460c3344f16bb40dc
DIFF: https://github.com/llvm/llvm-project/commit/9ff36c24a04d9aae61ae09f460c3344f16bb40dc.diff

LOG: [libc++] Guard terminate_successful with TEST_HAS_NO_EXCEPTIONS

This one is a bit twisted. Some platforms don't have support for
exiting in a clean manner, so they don't provide std::exit(). As
a result, defining `terminate_successful()` on those platforms won't
work, and the PSTL tests that rely on `terminate_successful()` also
won't work.

However, we don't have a notion of "no clean termination" in libc++,
so we can't properly guard this. Since embedded platforms that don't
support clean termination usually also don't enable exceptions, we
don't need to be able to run those `terminate_successful` PSTL tests,
and guarding the definition of `terminate_successful` with
TEST_HAS_NO_EXCEPTIONS works pretty well.

This is kind of a hack for the lack of having a concept of "no clean
termination" in the library and in the test suite.

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

Added: 
    

Modified: 
    libcxx/test/support/test_execution_policies.h

Removed: 
    


################################################################################
diff  --git a/libcxx/test/support/test_execution_policies.h b/libcxx/test/support/test_execution_policies.h
index d0cf0ddb6f0d5..df2ce94c7cc91 100644
--- a/libcxx/test/support/test_execution_policies.h
+++ b/libcxx/test/support/test_execution_policies.h
@@ -58,6 +58,8 @@ struct Bool {
   }
 };
 
+#ifndef TEST_HAS_NO_EXCEPTIONS
 [[noreturn]] inline void terminate_successful() { std::exit(0); }
+#endif
 
 #endif // TEST_SUPPORT_TEST_EXECUTION_POLICIES


        


More information about the libcxx-commits mailing list