From 332da1c283564489c874737d3a9f2b103c15755c Mon Sep 17 00:00:00 2001 From: Christopher Di Bella Date: Sat, 12 Jun 2021 06:13:44 +0000 Subject: [PATCH] [libcxx][iwyu] ensures we IWYU as prep for modules This has been broken out of D104170 since it should be merged whether or not we go ahead with the module map changes. Differential Revision: https://reviews.llvm.org/D104175 --- libcxx/include/__iterator/advance.h | 1 + libcxx/include/__iterator/next.h | 3 +++ libcxx/include/__iterator/prev.h | 3 +++ libcxx/include/__memory/allocation_guard.h | 1 + libcxx/include/__memory/allocator_traits.h | 2 ++ libcxx/include/__memory/auto_ptr.h | 1 + libcxx/include/__memory/pointer_safety.h | 1 + libcxx/include/__memory/pointer_traits.h | 1 + libcxx/include/__ranges/access.h | 2 ++ libcxx/include/__ranges/concepts.h | 6 ++++++ libcxx/include/__ranges/data.h | 1 + libcxx/include/__ranges/empty.h | 1 + libcxx/include/__ranges/size.h | 1 + libcxx/include/__ranges/view_interface.h | 3 +++ .../thread.lock.shared.cons/mutex_duration.pass.cpp | 8 +++++--- .../thread.lock.shared.cons/mutex_time_point.pass.cpp | 8 +++++--- .../thread.sharedtimedmutex.class/lock.pass.cpp | 4 +++- .../thread.sharedtimedmutex.class/lock_shared.pass.cpp | 8 +++++--- .../try_lock_shared_until.pass.cpp | 8 +++++--- .../format.formatter/format.parse.ctx/advance_to.pass.cpp | 2 ++ .../format.formatter/format.parse.ctx/begin.pass.cpp | 2 ++ .../format.parse.ctx/check_arg_id.pass.cpp | 2 ++ .../format.formatter/format.parse.ctx/ctor.pass.cpp | 2 ++ .../format/format.formatter/format.parse.ctx/end.pass.cpp | 2 ++ .../format.parse.ctx/next_arg_id.pass.cpp | 2 ++ .../format.parse.ctx/types.compile.pass.cpp | 2 ++ .../atomic_compare_exchange_strong.pass.cpp | 2 ++ .../atomic_compare_exchange_strong_explicit.pass.cpp | 2 ++ .../atomic_compare_exchange_weak_explicit.pass.cpp | 2 ++ .../atomic_exchange_explicit.pass.cpp | 2 ++ .../atomic_load_explicit.pass.cpp | 2 ++ .../atomic_store_explicit.pass.cpp | 2 ++ 32 files changed, 76 insertions(+), 13 deletions(-) diff --git a/libcxx/include/__iterator/advance.h b/libcxx/include/__iterator/advance.h index 5ff6d39f5bc4..fdac109f3a86 100644 --- a/libcxx/include/__iterator/advance.h +++ b/libcxx/include/__iterator/advance.h @@ -15,6 +15,7 @@ #include <__function_like.h> #include <__iterator/concepts.h> #include <__iterator/incrementable_traits.h> +#include <__iterator/iterator_traits.h> #include #include #include diff --git a/libcxx/include/__iterator/next.h b/libcxx/include/__iterator/next.h index 57cd5bab09f3..af719e3cab11 100644 --- a/libcxx/include/__iterator/next.h +++ b/libcxx/include/__iterator/next.h @@ -11,10 +11,13 @@ #define _LIBCPP___ITERATOR_NEXT_H #include <__config> +#include <__debug> #include <__function_like.h> #include <__iterator/advance.h> #include <__iterator/concepts.h> #include <__iterator/incrementable_traits.h> +#include <__iterator/iterator_traits.h> +#include #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) #pragma GCC system_header diff --git a/libcxx/include/__iterator/prev.h b/libcxx/include/__iterator/prev.h index 3a32f368cb07..f1ba2be5ff95 100644 --- a/libcxx/include/__iterator/prev.h +++ b/libcxx/include/__iterator/prev.h @@ -11,10 +11,13 @@ #define _LIBCPP___ITERATOR_PREV_H #include <__config> +#include <__debug> #include <__function_like.h> #include <__iterator/advance.h> #include <__iterator/concepts.h> #include <__iterator/incrementable_traits.h> +#include <__iterator/iterator_traits.h> +#include #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) #pragma GCC system_header diff --git a/libcxx/include/__memory/allocation_guard.h b/libcxx/include/__memory/allocation_guard.h index 9d8d2d6e1a8f..4987af293d14 100644 --- a/libcxx/include/__memory/allocation_guard.h +++ b/libcxx/include/__memory/allocation_guard.h @@ -13,6 +13,7 @@ #include <__config> #include <__memory/allocator_traits.h> #include +#include #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) #pragma GCC system_header diff --git a/libcxx/include/__memory/allocator_traits.h b/libcxx/include/__memory/allocator_traits.h index a5d151043b4a..dfef264a6492 100644 --- a/libcxx/include/__memory/allocator_traits.h +++ b/libcxx/include/__memory/allocator_traits.h @@ -361,6 +361,8 @@ struct __rebind_alloc_helper { template struct __is_default_allocator : false_type { }; +template class allocator; + template struct __is_default_allocator > : true_type { }; diff --git a/libcxx/include/__memory/auto_ptr.h b/libcxx/include/__memory/auto_ptr.h index 58ff708a8f44..f8d2b507b4c6 100644 --- a/libcxx/include/__memory/auto_ptr.h +++ b/libcxx/include/__memory/auto_ptr.h @@ -11,6 +11,7 @@ #define _LIBCPP___MEMORY_AUTO_PTR_H #include <__config> +#include <__nullptr> #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) #pragma GCC system_header diff --git a/libcxx/include/__memory/pointer_safety.h b/libcxx/include/__memory/pointer_safety.h index bdfed3fa3a30..87a6a9659e0c 100644 --- a/libcxx/include/__memory/pointer_safety.h +++ b/libcxx/include/__memory/pointer_safety.h @@ -11,6 +11,7 @@ #define _LIBCPP___MEMORY_POINTER_SAFETY_H #include <__config> +#include #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) #pragma GCC system_header diff --git a/libcxx/include/__memory/pointer_traits.h b/libcxx/include/__memory/pointer_traits.h index 6730066edc31..d5442b84e2aa 100644 --- a/libcxx/include/__memory/pointer_traits.h +++ b/libcxx/include/__memory/pointer_traits.h @@ -11,6 +11,7 @@ #define _LIBCPP___MEMORY_POINTER_TRAITS_H #include <__config> +#include <__memory/addressof.h> #include #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) diff --git a/libcxx/include/__ranges/access.h b/libcxx/include/__ranges/access.h index a7c352f0273f..9e9fb52477d7 100644 --- a/libcxx/include/__ranges/access.h +++ b/libcxx/include/__ranges/access.h @@ -11,7 +11,9 @@ #include <__config> #include <__iterator/concepts.h> +#include <__iterator/readable_traits.h> #include <__ranges/enable_borrowed_range.h> +#include #include #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) diff --git a/libcxx/include/__ranges/concepts.h b/libcxx/include/__ranges/concepts.h index 80de5d4cdaf5..25fd0ef51047 100644 --- a/libcxx/include/__ranges/concepts.h +++ b/libcxx/include/__ranges/concepts.h @@ -11,9 +11,15 @@ #include <__config> #include <__iterator/concepts.h> +#include <__iterator/incrementable_traits.h> +#include <__iterator/iter_move.h> +#include <__iterator/iterator_traits.h> +#include <__iterator/readable_traits.h> #include <__ranges/access.h> +#include <__ranges/enable_borrowed_range.h> #include <__ranges/enable_view.h> #include <__ranges/size.h> +#include #include #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) diff --git a/libcxx/include/__ranges/data.h b/libcxx/include/__ranges/data.h index 04715bd863f7..99d1811f2c24 100644 --- a/libcxx/include/__ranges/data.h +++ b/libcxx/include/__ranges/data.h @@ -12,6 +12,7 @@ #include <__config> #include <__iterator/concepts.h> #include <__iterator/iterator_traits.h> +#include <__memory/pointer_traits.h> #include <__ranges/access.h> #include #include diff --git a/libcxx/include/__ranges/empty.h b/libcxx/include/__ranges/empty.h index bc3f9c4559db..05f492c5ddbf 100644 --- a/libcxx/include/__ranges/empty.h +++ b/libcxx/include/__ranges/empty.h @@ -11,6 +11,7 @@ #include <__config> #include <__iterator/concepts.h> +#include <__ranges/access.h> #include <__ranges/size.h> #include diff --git a/libcxx/include/__ranges/size.h b/libcxx/include/__ranges/size.h index 9291c980e2e6..0d3685adf5c6 100644 --- a/libcxx/include/__ranges/size.h +++ b/libcxx/include/__ranges/size.h @@ -13,6 +13,7 @@ #include <__iterator/concepts.h> #include <__iterator/iterator_traits.h> #include <__ranges/access.h> +#include #include #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) diff --git a/libcxx/include/__ranges/view_interface.h b/libcxx/include/__ranges/view_interface.h index 5d70a1e1c0df..6105763ab087 100644 --- a/libcxx/include/__ranges/view_interface.h +++ b/libcxx/include/__ranges/view_interface.h @@ -13,9 +13,12 @@ #include <__iterator/concepts.h> #include <__iterator/iterator_traits.h> #include <__iterator/prev.h> +#include <__memory/pointer_traits.h> #include <__ranges/access.h> +#include <__ranges/concepts.h> #include <__ranges/empty.h> #include <__ranges/enable_view.h> +#include #include #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) diff --git a/libcxx/test/std/thread/thread.mutex/thread.lock/thread.lock.shared/thread.lock.shared.cons/mutex_duration.pass.cpp b/libcxx/test/std/thread/thread.mutex/thread.lock/thread.lock.shared/thread.lock.shared.cons/mutex_duration.pass.cpp index cd09f0dea3bd..29160d5e76a8 100644 --- a/libcxx/test/std/thread/thread.mutex/thread.lock/thread.lock.shared/thread.lock.shared.cons/mutex_duration.pass.cpp +++ b/libcxx/test/std/thread/thread.mutex/thread.lock/thread.lock.shared/thread.lock.shared.cons/mutex_duration.pass.cpp @@ -21,11 +21,13 @@ // template // shared_lock(mutex_type& m, const chrono::duration& rel_time); -#include #include -#include -#include + +#include #include +#include +#include +#include #include "make_test_thread.h" #include "test_macros.h" diff --git a/libcxx/test/std/thread/thread.mutex/thread.lock/thread.lock.shared/thread.lock.shared.cons/mutex_time_point.pass.cpp b/libcxx/test/std/thread/thread.mutex/thread.lock/thread.lock.shared/thread.lock.shared.cons/mutex_time_point.pass.cpp index f6bbf80d86af..9f242f484a48 100644 --- a/libcxx/test/std/thread/thread.mutex/thread.lock/thread.lock.shared/thread.lock.shared.cons/mutex_time_point.pass.cpp +++ b/libcxx/test/std/thread/thread.mutex/thread.lock/thread.lock.shared/thread.lock.shared.cons/mutex_time_point.pass.cpp @@ -21,11 +21,13 @@ // template // shared_lock(mutex_type& m, const chrono::time_point& abs_time); -#include #include -#include -#include + +#include #include +#include +#include +#include #include "make_test_thread.h" #include "test_macros.h" diff --git a/libcxx/test/std/thread/thread.mutex/thread.mutex.requirements/thread.sharedtimedmutex.requirements/thread.sharedtimedmutex.class/lock.pass.cpp b/libcxx/test/std/thread/thread.mutex/thread.mutex.requirements/thread.sharedtimedmutex.requirements/thread.sharedtimedmutex.class/lock.pass.cpp index c90a3584bf94..ef0c39729df7 100644 --- a/libcxx/test/std/thread/thread.mutex/thread.mutex.requirements/thread.sharedtimedmutex.requirements/thread.sharedtimedmutex.class/lock.pass.cpp +++ b/libcxx/test/std/thread/thread.mutex/thread.mutex.requirements/thread.sharedtimedmutex.requirements/thread.sharedtimedmutex.class/lock.pass.cpp @@ -20,10 +20,12 @@ // void lock(); -#include #include + +#include #include #include +#include #include "make_test_thread.h" #include "test_macros.h" diff --git a/libcxx/test/std/thread/thread.mutex/thread.mutex.requirements/thread.sharedtimedmutex.requirements/thread.sharedtimedmutex.class/lock_shared.pass.cpp b/libcxx/test/std/thread/thread.mutex/thread.mutex.requirements/thread.sharedtimedmutex.requirements/thread.sharedtimedmutex.class/lock_shared.pass.cpp index cb9a32a1b7f8..ac2f702db4b1 100644 --- a/libcxx/test/std/thread/thread.mutex/thread.mutex.requirements/thread.sharedtimedmutex.requirements/thread.sharedtimedmutex.class/lock_shared.pass.cpp +++ b/libcxx/test/std/thread/thread.mutex/thread.mutex.requirements/thread.sharedtimedmutex.requirements/thread.sharedtimedmutex.class/lock_shared.pass.cpp @@ -20,11 +20,13 @@ // void lock_shared(); -#include #include -#include -#include + +#include #include +#include +#include +#include #include "make_test_thread.h" #include "test_macros.h" diff --git a/libcxx/test/std/thread/thread.mutex/thread.mutex.requirements/thread.sharedtimedmutex.requirements/thread.sharedtimedmutex.class/try_lock_shared_until.pass.cpp b/libcxx/test/std/thread/thread.mutex/thread.mutex.requirements/thread.sharedtimedmutex.requirements/thread.sharedtimedmutex.class/try_lock_shared_until.pass.cpp index 27522cc537c8..324870a50e3b 100644 --- a/libcxx/test/std/thread/thread.mutex/thread.mutex.requirements/thread.sharedtimedmutex.requirements/thread.sharedtimedmutex.class/try_lock_shared_until.pass.cpp +++ b/libcxx/test/std/thread/thread.mutex/thread.mutex.requirements/thread.sharedtimedmutex.requirements/thread.sharedtimedmutex.class/try_lock_shared_until.pass.cpp @@ -23,11 +23,13 @@ // template // bool try_lock_shared_until(const chrono::time_point& abs_time); -#include #include -#include -#include + +#include #include +#include +#include +#include #include "make_test_thread.h" #include "test_macros.h" diff --git a/libcxx/test/std/utilities/format/format.formatter/format.parse.ctx/advance_to.pass.cpp b/libcxx/test/std/utilities/format/format.formatter/format.parse.ctx/advance_to.pass.cpp index 324b9c739745..a4e219f2df53 100644 --- a/libcxx/test/std/utilities/format/format.formatter/format.parse.ctx/advance_to.pass.cpp +++ b/libcxx/test/std/utilities/format/format.formatter/format.parse.ctx/advance_to.pass.cpp @@ -13,7 +13,9 @@ // constexpr void advance_to(const_iterator it); #include + #include +#include #include "test_macros.h" diff --git a/libcxx/test/std/utilities/format/format.formatter/format.parse.ctx/begin.pass.cpp b/libcxx/test/std/utilities/format/format.formatter/format.parse.ctx/begin.pass.cpp index b462f9b52491..bcc11c68c826 100644 --- a/libcxx/test/std/utilities/format/format.formatter/format.parse.ctx/begin.pass.cpp +++ b/libcxx/test/std/utilities/format/format.formatter/format.parse.ctx/begin.pass.cpp @@ -13,7 +13,9 @@ // constexpr begin() const noexcept; #include + #include +#include #include "test_macros.h" diff --git a/libcxx/test/std/utilities/format/format.formatter/format.parse.ctx/check_arg_id.pass.cpp b/libcxx/test/std/utilities/format/format.formatter/format.parse.ctx/check_arg_id.pass.cpp index 6f2a7fa2a86e..68e99578b0c9 100644 --- a/libcxx/test/std/utilities/format/format.formatter/format.parse.ctx/check_arg_id.pass.cpp +++ b/libcxx/test/std/utilities/format/format.formatter/format.parse.ctx/check_arg_id.pass.cpp @@ -23,7 +23,9 @@ // constexpr void check_arg_id(size_t id); #include + #include +#include #include "test_macros.h" diff --git a/libcxx/test/std/utilities/format/format.formatter/format.parse.ctx/ctor.pass.cpp b/libcxx/test/std/utilities/format/format.formatter/format.parse.ctx/ctor.pass.cpp index 0df74aa8ccfb..1644ff6d7896 100644 --- a/libcxx/test/std/utilities/format/format.formatter/format.parse.ctx/ctor.pass.cpp +++ b/libcxx/test/std/utilities/format/format.formatter/format.parse.ctx/ctor.pass.cpp @@ -15,7 +15,9 @@ // size_t num_args = 0) noexcept #include + #include +#include #include #include "test_macros.h" diff --git a/libcxx/test/std/utilities/format/format.formatter/format.parse.ctx/end.pass.cpp b/libcxx/test/std/utilities/format/format.formatter/format.parse.ctx/end.pass.cpp index d493f9245054..4026079205a9 100644 --- a/libcxx/test/std/utilities/format/format.formatter/format.parse.ctx/end.pass.cpp +++ b/libcxx/test/std/utilities/format/format.formatter/format.parse.ctx/end.pass.cpp @@ -13,7 +13,9 @@ // constexpr end() const noexcept; #include + #include +#include #include "test_macros.h" diff --git a/libcxx/test/std/utilities/format/format.formatter/format.parse.ctx/next_arg_id.pass.cpp b/libcxx/test/std/utilities/format/format.formatter/format.parse.ctx/next_arg_id.pass.cpp index 227c4a88fc26..3b2304f61f5e 100644 --- a/libcxx/test/std/utilities/format/format.formatter/format.parse.ctx/next_arg_id.pass.cpp +++ b/libcxx/test/std/utilities/format/format.formatter/format.parse.ctx/next_arg_id.pass.cpp @@ -23,7 +23,9 @@ // constexpr size_t next_arg_id(); #include + #include +#include #include "test_macros.h" diff --git a/libcxx/test/std/utilities/format/format.formatter/format.parse.ctx/types.compile.pass.cpp b/libcxx/test/std/utilities/format/format.formatter/format.parse.ctx/types.compile.pass.cpp index df05f55aa7a5..b632f75aeb7b 100644 --- a/libcxx/test/std/utilities/format/format.formatter/format.parse.ctx/types.compile.pass.cpp +++ b/libcxx/test/std/utilities/format/format.formatter/format.parse.ctx/types.compile.pass.cpp @@ -24,6 +24,8 @@ // using wformat_parse_context = basic_format_parse_context; #include + +#include #include #include "test_macros.h" diff --git a/libcxx/test/std/utilities/memory/util.smartptr/util.smartptr.shared.atomic/atomic_compare_exchange_strong.pass.cpp b/libcxx/test/std/utilities/memory/util.smartptr/util.smartptr.shared.atomic/atomic_compare_exchange_strong.pass.cpp index 74843becc9f4..f37b6e0d1919 100644 --- a/libcxx/test/std/utilities/memory/util.smartptr/util.smartptr.shared.atomic/atomic_compare_exchange_strong.pass.cpp +++ b/libcxx/test/std/utilities/memory/util.smartptr/util.smartptr.shared.atomic/atomic_compare_exchange_strong.pass.cpp @@ -20,6 +20,8 @@ // UNSUPPORTED: c++03 #include + +#include #include #include "test_macros.h" diff --git a/libcxx/test/std/utilities/memory/util.smartptr/util.smartptr.shared.atomic/atomic_compare_exchange_strong_explicit.pass.cpp b/libcxx/test/std/utilities/memory/util.smartptr/util.smartptr.shared.atomic/atomic_compare_exchange_strong_explicit.pass.cpp index 1932a5a564b2..32cce75a4874 100644 --- a/libcxx/test/std/utilities/memory/util.smartptr/util.smartptr.shared.atomic/atomic_compare_exchange_strong_explicit.pass.cpp +++ b/libcxx/test/std/utilities/memory/util.smartptr/util.smartptr.shared.atomic/atomic_compare_exchange_strong_explicit.pass.cpp @@ -21,6 +21,8 @@ // UNSUPPORTED: c++03 #include + +#include #include #include "test_macros.h" diff --git a/libcxx/test/std/utilities/memory/util.smartptr/util.smartptr.shared.atomic/atomic_compare_exchange_weak_explicit.pass.cpp b/libcxx/test/std/utilities/memory/util.smartptr/util.smartptr.shared.atomic/atomic_compare_exchange_weak_explicit.pass.cpp index 1643e0edcef1..7f697fcbca84 100644 --- a/libcxx/test/std/utilities/memory/util.smartptr/util.smartptr.shared.atomic/atomic_compare_exchange_weak_explicit.pass.cpp +++ b/libcxx/test/std/utilities/memory/util.smartptr/util.smartptr.shared.atomic/atomic_compare_exchange_weak_explicit.pass.cpp @@ -21,6 +21,8 @@ // UNSUPPORTED: c++03 #include + +#include #include #include "test_macros.h" diff --git a/libcxx/test/std/utilities/memory/util.smartptr/util.smartptr.shared.atomic/atomic_exchange_explicit.pass.cpp b/libcxx/test/std/utilities/memory/util.smartptr/util.smartptr.shared.atomic/atomic_exchange_explicit.pass.cpp index 5ae0b70edaa2..c38c47a2b315 100644 --- a/libcxx/test/std/utilities/memory/util.smartptr/util.smartptr.shared.atomic/atomic_exchange_explicit.pass.cpp +++ b/libcxx/test/std/utilities/memory/util.smartptr/util.smartptr.shared.atomic/atomic_exchange_explicit.pass.cpp @@ -19,6 +19,8 @@ // UNSUPPORTED: c++03 #include + +#include #include #include "test_macros.h" diff --git a/libcxx/test/std/utilities/memory/util.smartptr/util.smartptr.shared.atomic/atomic_load_explicit.pass.cpp b/libcxx/test/std/utilities/memory/util.smartptr/util.smartptr.shared.atomic/atomic_load_explicit.pass.cpp index f09b27f649f7..565f66433db7 100644 --- a/libcxx/test/std/utilities/memory/util.smartptr/util.smartptr.shared.atomic/atomic_load_explicit.pass.cpp +++ b/libcxx/test/std/utilities/memory/util.smartptr/util.smartptr.shared.atomic/atomic_load_explicit.pass.cpp @@ -19,6 +19,8 @@ // UNSUPPORTED: c++03 #include + +#include #include #include "test_macros.h" diff --git a/libcxx/test/std/utilities/memory/util.smartptr/util.smartptr.shared.atomic/atomic_store_explicit.pass.cpp b/libcxx/test/std/utilities/memory/util.smartptr/util.smartptr.shared.atomic/atomic_store_explicit.pass.cpp index b0eda4f3cc97..8e05844a6d32 100644 --- a/libcxx/test/std/utilities/memory/util.smartptr/util.smartptr.shared.atomic/atomic_store_explicit.pass.cpp +++ b/libcxx/test/std/utilities/memory/util.smartptr/util.smartptr.shared.atomic/atomic_store_explicit.pass.cpp @@ -19,6 +19,8 @@ // UNSUPPORTED: c++03 #include + +#include #include #include "test_macros.h"