From ee22e255648ee9b056280484b4b70d4542bc807e Mon Sep 17 00:00:00 2001 From: Nikolas Klauser Date: Sat, 9 Mar 2024 12:49:36 +0100 Subject: [libc++] Remove include from (#83742) This reduces the include time of `` from 122ms to 78ms. --- libcxx/include/__fwd/array.h | 6 ++++++ libcxx/include/span | 16 ++++++++-------- libcxx/test/libcxx/transitive_includes/cxx23.csv | 1 - libcxx/test/libcxx/transitive_includes/cxx26.csv | 1 - .../range.subrange/operator.pair_like.pass.cpp | 1 + 5 files changed, 15 insertions(+), 10 deletions(-) diff --git a/libcxx/include/__fwd/array.h b/libcxx/include/__fwd/array.h index ff3a3ee..b429d0c 100644 --- a/libcxx/include/__fwd/array.h +++ b/libcxx/include/__fwd/array.h @@ -35,6 +35,12 @@ template _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX14 const _Tp&& get(const array<_Tp, _Size>&&) _NOEXCEPT; #endif +template +struct __is_std_array : false_type {}; + +template +struct __is_std_array > : true_type {}; + _LIBCPP_END_NAMESPACE_STD #endif // _LIBCPP___FWD_ARRAY_H diff --git a/libcxx/include/span b/libcxx/include/span index cfeef35..c0fe25d 100644 --- a/libcxx/include/span +++ b/libcxx/include/span @@ -130,10 +130,12 @@ template #include <__assert> #include <__config> +#include <__fwd/array.h> #include <__fwd/span.h> #include <__iterator/bounded_iter.h> #include <__iterator/concepts.h> #include <__iterator/iterator_traits.h> +#include <__iterator/reverse_iterator.h> #include <__iterator/wrap_iter.h> #include <__memory/pointer_traits.h> #include <__ranges/concepts.h> @@ -141,13 +143,16 @@ template #include <__ranges/enable_borrowed_range.h> #include <__ranges/enable_view.h> #include <__ranges/size.h> +#include <__type_traits/is_array.h> +#include <__type_traits/is_const.h> #include <__type_traits/is_convertible.h> +#include <__type_traits/remove_cv.h> #include <__type_traits/remove_cvref.h> #include <__type_traits/remove_reference.h> #include <__type_traits/type_identity.h> #include <__utility/forward.h> -#include // for array -#include // for byte +#include // for byte +#include #include #include @@ -172,12 +177,6 @@ _LIBCPP_BEGIN_NAMESPACE_STD #if _LIBCPP_STD_VER >= 20 template -struct __is_std_array : false_type {}; - -template -struct __is_std_array> : true_type {}; - -template struct __is_std_span : false_type {}; template @@ -586,6 +585,7 @@ _LIBCPP_END_NAMESPACE_STD _LIBCPP_POP_MACROS #if !defined(_LIBCPP_REMOVE_TRANSITIVE_INCLUDES) && _LIBCPP_STD_VER <= 20 +# include # include # include # include diff --git a/libcxx/test/libcxx/transitive_includes/cxx23.csv b/libcxx/test/libcxx/transitive_includes/cxx23.csv index 64ff926..043d23d 100644 --- a/libcxx/test/libcxx/transitive_includes/cxx23.csv +++ b/libcxx/test/libcxx/transitive_includes/cxx23.csv @@ -509,7 +509,6 @@ shared_mutex string shared_mutex version source_location cstdint source_location version -span array span cstddef span initializer_list span limits diff --git a/libcxx/test/libcxx/transitive_includes/cxx26.csv b/libcxx/test/libcxx/transitive_includes/cxx26.csv index 64ff926..043d23d 100644 --- a/libcxx/test/libcxx/transitive_includes/cxx26.csv +++ b/libcxx/test/libcxx/transitive_includes/cxx26.csv @@ -509,7 +509,6 @@ shared_mutex string shared_mutex version source_location cstdint source_location version -span array span cstddef span initializer_list span limits diff --git a/libcxx/test/std/ranges/range.utility/range.subrange/operator.pair_like.pass.cpp b/libcxx/test/std/ranges/range.utility/range.subrange/operator.pair_like.pass.cpp index 1d0dfd0..2641a9a 100644 --- a/libcxx/test/std/ranges/range.utility/range.subrange/operator.pair_like.pass.cpp +++ b/libcxx/test/std/ranges/range.utility/range.subrange/operator.pair_like.pass.cpp @@ -13,6 +13,7 @@ // requires pair-like-convertible-from // constexpr operator PairLike() const; +#include #include #include #include -- cgit v1.1