This patch implements the forwarding to frozen C++03 headers as discussed in https://discourse.llvm.org/t/rfc-freezing-c-03-headers-in-libc. In the RFC, we initially proposed selecting the right headers from the Clang driver, however consensus seemed to steer towards handling this in the library itself. This patch implements that direction. At a high level, the changes basically amount to making each public header look like this: ``` // inside <vector> #ifdef _LIBCPP_CXX03_LANG # include <__cxx03/vector> #else // normal <vector> content #endif ``` In most cases, public headers are simple umbrella headers so there isn't much code in the #else branch. In other cases, the #else branch contains the actual implementation of the header.
63 lines
2.0 KiB
C++
63 lines
2.0 KiB
C++
// -*- C++ -*-
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef _LIBCPP_FLAT_MAP
|
|
#define _LIBCPP_FLAT_MAP
|
|
|
|
/*
|
|
Header <flat_map> synopsis
|
|
|
|
#include <compare> // see [compare.syn]
|
|
#include <initializer_list> // see [initializer.list.syn]
|
|
|
|
namespace std {
|
|
// [flat.map], class template flat_map
|
|
template<class Key, class T, class Compare = less<Key>,
|
|
class KeyContainer = vector<Key>, class MappedContainer = vector<T>>
|
|
class flat_map;
|
|
|
|
struct sorted_unique_t { explicit sorted_unique_t() = default; };
|
|
inline constexpr sorted_unique_t sorted_unique{};
|
|
|
|
template<class Key, class T, class Compare, class KeyContainer, class MappedContainer,
|
|
class Allocator>
|
|
struct uses_allocator<flat_map<Key, T, Compare, KeyContainer, MappedContainer>,
|
|
Allocator>;
|
|
|
|
// [flat.map.erasure], erasure for flat_map
|
|
template<class Key, class T, class Compare, class KeyContainer, class MappedContainer,
|
|
class Predicate>
|
|
typename flat_map<Key, T, Compare, KeyContainer, MappedContainer>::size_type
|
|
erase_if(flat_map<Key, T, Compare, KeyContainer, MappedContainer>& c, Predicate pred);
|
|
*/
|
|
|
|
#if __cplusplus < 201103L && defined(_LIBCPP_USE_FROZEN_CXX03_HEADERS)
|
|
# include <__cxx03/__config>
|
|
#else
|
|
# include <__config>
|
|
|
|
# if _LIBCPP_STD_VER >= 23
|
|
# include <__flat_map/flat_map.h>
|
|
# include <__flat_map/sorted_unique.h>
|
|
# endif
|
|
|
|
// for feature-test macros
|
|
# include <version>
|
|
|
|
// standard required includes
|
|
# include <compare>
|
|
# include <initializer_list>
|
|
|
|
# if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
|
|
# pragma GCC system_header
|
|
# endif
|
|
#endif // __cplusplus < 201103L && defined(_LIBCPP_USE_FROZEN_CXX03_HEADERS)
|
|
|
|
#endif // _LIBCPP_FLAT_MAP
|