summaryrefslogtreecommitdiffstats
path: root/libcxx/include
diff options
context:
space:
mode:
authorMarshall Clow <mclow.lists@gmail.com>2018-09-12 19:41:40 +0000
committerMarshall Clow <mclow.lists@gmail.com>2018-09-12 19:41:40 +0000
commitf56972e22489c92028e5147344ab8b31b0b4fed5 (patch)
tree1b8db08c4b4b7c9af60308554e38e84655330228 /libcxx/include
parent956ff0f8bf8c0eaea965056fb97a2a592ebdd1d0 (diff)
downloadbcm5719-llvm-f56972e22489c92028e5147344ab8b31b0b4fed5.tar.gz
bcm5719-llvm-f56972e22489c92028e5147344ab8b31b0b4fed5.zip
Implement the infrastructure for feature-test macros. Very few actual feature test macros, though. Reviewed as: https://reviews.llvm.org/D51955
llvm-svn: 342073
Diffstat (limited to 'libcxx/include')
-rw-r--r--libcxx/include/algorithm1
-rw-r--r--libcxx/include/any1
-rw-r--r--libcxx/include/array1
-rw-r--r--libcxx/include/atomic5
-rw-r--r--libcxx/include/bit1
-rw-r--r--libcxx/include/chrono1
-rw-r--r--libcxx/include/cmath1
-rw-r--r--libcxx/include/complex1
-rw-r--r--libcxx/include/cstddef1
-rw-r--r--libcxx/include/deque1
-rw-r--r--libcxx/include/exception1
-rw-r--r--libcxx/include/filesystem5
-rw-r--r--libcxx/include/forward_list1
-rw-r--r--libcxx/include/functional3
-rw-r--r--libcxx/include/iomanip1
-rw-r--r--libcxx/include/iterator1
-rw-r--r--libcxx/include/list1
-rw-r--r--libcxx/include/map1
-rw-r--r--libcxx/include/memory1
-rw-r--r--libcxx/include/mutex1
-rw-r--r--libcxx/include/new1
-rw-r--r--libcxx/include/numeric1
-rw-r--r--libcxx/include/optional1
-rw-r--r--libcxx/include/regex1
-rw-r--r--libcxx/include/scoped_allocator1
-rw-r--r--libcxx/include/set1
-rw-r--r--libcxx/include/shared_mutex1
-rw-r--r--libcxx/include/string1
-rw-r--r--libcxx/include/string_view1
-rw-r--r--libcxx/include/tuple1
-rw-r--r--libcxx/include/type_traits2
-rw-r--r--libcxx/include/unordered_map1
-rw-r--r--libcxx/include/unordered_set1
-rw-r--r--libcxx/include/utility1
-rw-r--r--libcxx/include/variant1
-rw-r--r--libcxx/include/vector1
-rw-r--r--libcxx/include/version13
37 files changed, 49 insertions, 11 deletions
diff --git a/libcxx/include/algorithm b/libcxx/include/algorithm
index 55e1f9fc113..1359fda53b5 100644
--- a/libcxx/include/algorithm
+++ b/libcxx/include/algorithm
@@ -646,6 +646,7 @@ template <class BidirectionalIterator, class Compare>
#include <iterator>
#include <cstddef>
#include <bit>
+#include <version>
#include <__debug>
diff --git a/libcxx/include/any b/libcxx/include/any
index e6e0b6ea695..e2945bdfa98 100644
--- a/libcxx/include/any
+++ b/libcxx/include/any
@@ -87,6 +87,7 @@ namespace std {
#include <typeinfo>
#include <type_traits>
#include <cstdlib>
+#include <version>
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
#pragma GCC system_header
diff --git a/libcxx/include/array b/libcxx/include/array
index ba4ff4260ed..8f4e111acbb 100644
--- a/libcxx/include/array
+++ b/libcxx/include/array
@@ -112,6 +112,7 @@ template <size_t I, class T, size_t N> const T&& get(const array<T, N>&&) noexce
#include <algorithm>
#include <stdexcept>
#include <cstdlib> // for _LIBCPP_UNREACHABLE
+#include <version>
#include <__debug>
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
diff --git a/libcxx/include/atomic b/libcxx/include/atomic
index 809f78a06d3..d37e7b4b035 100644
--- a/libcxx/include/atomic
+++ b/libcxx/include/atomic
@@ -544,6 +544,7 @@ void atomic_signal_fence(memory_order m) noexcept;
#include <cstddef>
#include <cstdint>
#include <type_traits>
+#include <version>
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
#pragma GCC system_header
@@ -559,10 +560,6 @@ void atomic_signal_fence(memory_order m) noexcept;
#error C++ standard library is incompatible with <stdatomic.h>
#endif
-#if _LIBCPP_STD_VER > 14
-# define __cpp_lib_atomic_is_always_lock_free 201603L
-#endif
-
#define _LIBCPP_CHECK_STORE_MEMORY_ORDER(__m) \
_LIBCPP_DIAGNOSE_WARNING(__m == memory_order_consume || \
__m == memory_order_acquire || \
diff --git a/libcxx/include/bit b/libcxx/include/bit
index 5bf5214f330..db3812e5b5b 100644
--- a/libcxx/include/bit
+++ b/libcxx/include/bit
@@ -21,6 +21,7 @@ namespace std {
*/
#include <__config>
+#include <version>
#if defined(__IBMCPP__)
#include "support/ibm/support.h"
diff --git a/libcxx/include/chrono b/libcxx/include/chrono
index b9709b37365..0691101010f 100644
--- a/libcxx/include/chrono
+++ b/libcxx/include/chrono
@@ -798,6 +798,7 @@ constexpr chrono::year operator ""y(unsigned lo
#include <type_traits>
#include <ratio>
#include <limits>
+#include <version>
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
#pragma GCC system_header
diff --git a/libcxx/include/cmath b/libcxx/include/cmath
index ffb1c46c7b6..f5f62adcfb8 100644
--- a/libcxx/include/cmath
+++ b/libcxx/include/cmath
@@ -303,6 +303,7 @@ long double truncl(long double x);
#include <__config>
#include <math.h>
+#include <version>
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
#pragma GCC system_header
diff --git a/libcxx/include/complex b/libcxx/include/complex
index d692ee31920..8cf6a946d71 100644
--- a/libcxx/include/complex
+++ b/libcxx/include/complex
@@ -245,6 +245,7 @@ template<class T, class charT, class traits>
#include <stdexcept>
#include <cmath>
#include <sstream>
+#include <version>
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
#pragma GCC system_header
diff --git a/libcxx/include/cstddef b/libcxx/include/cstddef
index b45dbe21df2..b4c42b19ddb 100644
--- a/libcxx/include/cstddef
+++ b/libcxx/include/cstddef
@@ -35,6 +35,7 @@ Types:
*/
#include <__config>
+#include <version>
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
#pragma GCC system_header
diff --git a/libcxx/include/deque b/libcxx/include/deque
index bfbd3a5ef54..414c7a85972 100644
--- a/libcxx/include/deque
+++ b/libcxx/include/deque
@@ -161,6 +161,7 @@ template <class T, class Allocator>
#include <iterator>
#include <algorithm>
#include <stdexcept>
+#include <version>
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
#pragma GCC system_header
diff --git a/libcxx/include/exception b/libcxx/include/exception
index b517486b5a8..7fd92798bff 100644
--- a/libcxx/include/exception
+++ b/libcxx/include/exception
@@ -81,6 +81,7 @@ template <class E> void rethrow_if_nested(const E& e);
#include <cstddef>
#include <cstdlib>
#include <type_traits>
+#include <version>
#if defined(_LIBCPP_ABI_MICROSOFT) && !defined(_LIBCPP_NO_VCRUNTIME)
#include <vcruntime_exception.h>
diff --git a/libcxx/include/filesystem b/libcxx/include/filesystem
index aa1d7180072..7547e6c5a69 100644
--- a/libcxx/include/filesystem
+++ b/libcxx/include/filesystem
@@ -244,6 +244,7 @@
#include <utility>
#include <iomanip> // for quoted
#include <string_view>
+#include <version>
#include <__debug>
@@ -256,10 +257,6 @@ _LIBCPP_PUSH_MACROS
#ifndef _LIBCPP_CXX03_LANG
-#if _LIBCPP_STD_VER >= 17
-#define __cpp_lib_filesystem 201703
-#endif
-
_LIBCPP_BEGIN_NAMESPACE_FILESYSTEM
struct _FilesystemClock {
diff --git a/libcxx/include/forward_list b/libcxx/include/forward_list
index 571afdc925b..f9a71f0330a 100644
--- a/libcxx/include/forward_list
+++ b/libcxx/include/forward_list
@@ -177,6 +177,7 @@ template <class T, class Allocator>
#include <limits>
#include <iterator>
#include <algorithm>
+#include <version>
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
#pragma GCC system_header
diff --git a/libcxx/include/functional b/libcxx/include/functional
index b91fd75421f..41beb404bb8 100644
--- a/libcxx/include/functional
+++ b/libcxx/include/functional
@@ -487,6 +487,7 @@ POLICY: For non-variadic implementations, the number of arguments is limited
#include <memory>
#include <tuple>
#include <utility>
+#include <version>
#include <__functional_base>
@@ -2340,8 +2341,6 @@ bind(_Fp&& __f, _BoundArgs&&... __bound_args)
#if _LIBCPP_STD_VER > 14
-#define __cpp_lib_invoke 201411
-
template <class _Fn, class ..._Args>
result_of_t<_Fn&&(_Args&&...)>
invoke(_Fn&& __f, _Args&&... __args)
diff --git a/libcxx/include/iomanip b/libcxx/include/iomanip
index a6bee736f45..36c11167a44 100644
--- a/libcxx/include/iomanip
+++ b/libcxx/include/iomanip
@@ -46,6 +46,7 @@ template <class charT, class traits, class Allocator>
#include <__config>
#include <__string>
#include <istream>
+#include <version>
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
#pragma GCC system_header
diff --git a/libcxx/include/iterator b/libcxx/include/iterator
index 9415e0b8396..aed0525dbf8 100644
--- a/libcxx/include/iterator
+++ b/libcxx/include/iterator
@@ -418,6 +418,7 @@ template <class E> constexpr const E* data(initializer_list<E> il) noexcept;
#include <type_traits>
#include <cstddef>
#include <initializer_list>
+#include <version>
#ifdef __APPLE__
#include <Availability.h>
#endif
diff --git a/libcxx/include/list b/libcxx/include/list
index 49e2e1e1b48..8f0e1db1fed 100644
--- a/libcxx/include/list
+++ b/libcxx/include/list
@@ -181,6 +181,7 @@ template <class T, class Alloc>
#include <iterator>
#include <algorithm>
#include <type_traits>
+#include <version>
#include <__debug>
diff --git a/libcxx/include/map b/libcxx/include/map
index 4700a09eda2..cfd82805870 100644
--- a/libcxx/include/map
+++ b/libcxx/include/map
@@ -460,6 +460,7 @@ swap(multimap<Key, T, Compare, Allocator>& x,
#include <functional>
#include <initializer_list>
#include <type_traits>
+#include <version>
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
#pragma GCC system_header
diff --git a/libcxx/include/memory b/libcxx/include/memory
index de3f52d6ae4..276b3b763f8 100644
--- a/libcxx/include/memory
+++ b/libcxx/include/memory
@@ -667,6 +667,7 @@ void* align(size_t alignment, size_t size, void*& ptr, size_t& space);
#if !defined(_LIBCPP_HAS_NO_ATOMIC_HEADER)
# include <atomic>
#endif
+#include <version>
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
#pragma GCC system_header
diff --git a/libcxx/include/mutex b/libcxx/include/mutex
index 52e39b0fb1f..9c55c7cc164 100644
--- a/libcxx/include/mutex
+++ b/libcxx/include/mutex
@@ -194,6 +194,7 @@ template<class Callable, class ...Args>
#ifndef _LIBCPP_CXX03_LANG
#include <tuple>
#endif
+#include <version>
#include <__threading_support>
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
diff --git a/libcxx/include/new b/libcxx/include/new
index d27ff298221..8d72ba5c880 100644
--- a/libcxx/include/new
+++ b/libcxx/include/new
@@ -91,6 +91,7 @@ void operator delete[](void* ptr, void*) noexcept;
#include <exception>
#include <type_traits>
#include <cstddef>
+#include <version>
#ifdef _LIBCPP_NO_EXCEPTIONS
#include <cstdlib>
#endif
diff --git a/libcxx/include/numeric b/libcxx/include/numeric
index 70ef173ea48..4e68239d059 100644
--- a/libcxx/include/numeric
+++ b/libcxx/include/numeric
@@ -142,6 +142,7 @@ template <class M, class N>
#include <iterator>
#include <limits> // for numeric_limits
#include <functional>
+#include <version>
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
#pragma GCC system_header
diff --git a/libcxx/include/optional b/libcxx/include/optional
index a76f8d18976..9ef0aac3999 100644
--- a/libcxx/include/optional
+++ b/libcxx/include/optional
@@ -156,6 +156,7 @@ template<class T>
#include <stdexcept>
#include <type_traits>
#include <utility>
+#include <version>
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
#pragma GCC system_header
diff --git a/libcxx/include/regex b/libcxx/include/regex
index dcdb14af9af..db15f78e410 100644
--- a/libcxx/include/regex
+++ b/libcxx/include/regex
@@ -769,6 +769,7 @@ typedef regex_token_iterator<wstring::const_iterator> wsregex_token_iterator;
#include <memory>
#include <vector>
#include <deque>
+#include <version>
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
#pragma GCC system_header
diff --git a/libcxx/include/scoped_allocator b/libcxx/include/scoped_allocator
index 4760d946def..bdbb0136b5c 100644
--- a/libcxx/include/scoped_allocator
+++ b/libcxx/include/scoped_allocator
@@ -108,6 +108,7 @@ template <class OuterA1, class OuterA2, class... InnerAllocs>
#include <__config>
#include <memory>
+#include <version>
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
#pragma GCC system_header
diff --git a/libcxx/include/set b/libcxx/include/set
index 108a9e97f88..f2ce6ea2f36 100644
--- a/libcxx/include/set
+++ b/libcxx/include/set
@@ -402,6 +402,7 @@ swap(multiset<Key, Compare, Allocator>& x, multiset<Key, Compare, Allocator>& y)
#include <__tree>
#include <__node_handle>
#include <functional>
+#include <version>
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
#pragma GCC system_header
diff --git a/libcxx/include/shared_mutex b/libcxx/include/shared_mutex
index a7735d6732c..fbde0cf137a 100644
--- a/libcxx/include/shared_mutex
+++ b/libcxx/include/shared_mutex
@@ -124,6 +124,7 @@ template <class Mutex>
*/
#include <__config>
+#include <version>
_LIBCPP_PUSH_MACROS
#include <__undef_macros>
diff --git a/libcxx/include/string b/libcxx/include/string
index 162e54058c4..c79164cb232 100644
--- a/libcxx/include/string
+++ b/libcxx/include/string
@@ -510,6 +510,7 @@ basic_string<char32_t> operator "" s( const char32_t *str, size_t len ); // C++1
#include <type_traits>
#include <initializer_list>
#include <__functional_base>
+#include <version>
#ifndef _LIBCPP_HAS_NO_UNICODE_CHARS
#include <cstdint>
#endif
diff --git a/libcxx/include/string_view b/libcxx/include/string_view
index 6377aeb6d64..55dce7271b4 100644
--- a/libcxx/include/string_view
+++ b/libcxx/include/string_view
@@ -178,6 +178,7 @@ namespace std {
#include <iterator>
#include <limits>
#include <stdexcept>
+#include <version>
#include <__debug>
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
diff --git a/libcxx/include/tuple b/libcxx/include/tuple
index b3a17e7b735..fb5428ec1c3 100644
--- a/libcxx/include/tuple
+++ b/libcxx/include/tuple
@@ -141,6 +141,7 @@ template <class... Types>
#include <type_traits>
#include <__functional_base>
#include <utility>
+#include <version>
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
#pragma GCC system_header
diff --git a/libcxx/include/type_traits b/libcxx/include/type_traits
index e413d2656e3..7ff67bfdb73 100644
--- a/libcxx/include/type_traits
+++ b/libcxx/include/type_traits
@@ -404,6 +404,7 @@ namespace std
*/
#include <__config>
#include <cstddef>
+#include <version>
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
#pragma GCC system_header
@@ -4758,7 +4759,6 @@ struct __has_operator_addressof
#if _LIBCPP_STD_VER > 14
-#define __cpp_lib_void_t 201411
template <class...> using void_t = void;
# ifndef _LIBCPP_HAS_NO_VARIADICS
diff --git a/libcxx/include/unordered_map b/libcxx/include/unordered_map
index 348f57923b5..fc3cfb6a950 100644
--- a/libcxx/include/unordered_map
+++ b/libcxx/include/unordered_map
@@ -386,6 +386,7 @@ template <class Key, class T, class Hash, class Pred, class Alloc>
#include <functional>
#include <stdexcept>
#include <tuple>
+#include <version>
#include <__debug>
diff --git a/libcxx/include/unordered_set b/libcxx/include/unordered_set
index 9b8560da494..a219fa60912 100644
--- a/libcxx/include/unordered_set
+++ b/libcxx/include/unordered_set
@@ -338,6 +338,7 @@ template <class Value, class Hash, class Pred, class Alloc>
#include <__hash_table>
#include <__node_handle>
#include <functional>
+#include <version>
#include <__debug>
diff --git a/libcxx/include/utility b/libcxx/include/utility
index ed9bf030d49..570ec05ae81 100644
--- a/libcxx/include/utility
+++ b/libcxx/include/utility
@@ -203,6 +203,7 @@ template <size_t I>
#include <cstddef>
#include <cstring>
#include <cstdint>
+#include <version>
#include <__debug>
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
diff --git a/libcxx/include/variant b/libcxx/include/variant
index 6c7dca21588..6a523569e20 100644
--- a/libcxx/include/variant
+++ b/libcxx/include/variant
@@ -208,6 +208,7 @@ namespace std {
#include <type_traits>
#include <utility>
#include <limits>
+#include <version>
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
#pragma GCC system_header
diff --git a/libcxx/include/vector b/libcxx/include/vector
index 9245ba18ce9..e7aaa4df6c0 100644
--- a/libcxx/include/vector
+++ b/libcxx/include/vector
@@ -276,6 +276,7 @@ void swap(vector<T,Allocator>& x, vector<T,Allocator>& y)
#include <stdexcept>
#include <algorithm>
#include <cstring>
+#include <version>
#include <__split_buffer>
#include <__functional_base>
diff --git a/libcxx/include/version b/libcxx/include/version
index 6d10411484e..80c27971f02 100644
--- a/libcxx/include/version
+++ b/libcxx/include/version
@@ -101,4 +101,17 @@ __cpp_lib_void_t 201411L <type_traits>
#pragma GCC system_header
#endif
+#if _LIBCPP_STD_VER > 11
+#endif
+
+#if _LIBCPP_STD_VER > 14
+# define __cpp_lib_atomic_is_always_lock_free 201603L
+# define __cpp_lib_filesystem 201703L
+# define __cpp_lib_invoke 201411L
+# define __cpp_lib_void_t 201411L
+#endif
+
+#if _LIBCPP_STD_VER > 17
+#endif
+
#endif // _LIBCPP_VERSIONH
OpenPOWER on IntegriCloud