From 85d3a702da8f937ab1a818411a2c3ba7df294279 Mon Sep 17 00:00:00 2001 From: Volodymyr Sapsai Date: Tue, 15 May 2018 22:38:31 +0000 Subject: [PATCH] Emit an error when include after C11 defines `kill_dependency` as a macro in . When you include after , the macro clashes with `std::kill_dependency` and causes multiple errors. Explicit error should help in diagnosing those errors. No change for working code that includes before . rdar://problem/27435938 Reviewers: rsmith, EricWF, mclow.lists, jfb Reviewed By: jfb Subscribers: jfb, jkorous-apple, christof, bumblebritches57, JonChesterfield, smeenai, cfe-commits Differential Revision: https://reviews.llvm.org/D45470 llvm-svn: 332413 --- libcxx/include/atomic | 3 +++ 1 file changed, 3 insertions(+) diff --git a/libcxx/include/atomic b/libcxx/include/atomic index 34a2a58b20c1..dfca76b1626c 100644 --- a/libcxx/include/atomic +++ b/libcxx/include/atomic @@ -555,6 +555,9 @@ void atomic_signal_fence(memory_order m) noexcept; #if !defined(_LIBCPP_HAS_C_ATOMIC_IMP) && !defined(_LIBCPP_HAS_GCC_ATOMIC_IMP) #error is not implemented #endif +#ifdef kill_dependency +#error C++ standard library is incompatible with +#endif #if _LIBCPP_STD_VER > 14 # define __cpp_lib_atomic_is_always_lock_free 201603L