This reverts commit 68c04b0ae6.
This disables the IWYU mapping that caused the failure, since
the headers aren't reachable for now.
This is the first part of the "Freezing C++03 headers" proposal
explained in
https://discourse.llvm.org/t/rfc-freezing-c-03-headers-in-libc/77319/58.
This patch mechanically copies the headers as of the LLVM 19.1 release
into a subdirectory of libc++ so that we can start using these headers
when building in C++03 mode. We are going to be backporting important
changes to that copy of the headers until the LLVM 21 release. After the
LLVM 21 release, only critical bugfixes will be fixed in the C++03 copy
of the headers.
This patch only performs a copy of the headers -- these headers are
still unused by the rest of the codebase.
86 lines
2.8 KiB
C++
86 lines
2.8 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_SOURCE_LOCATION
|
|
#define _LIBCPP_SOURCE_LOCATION
|
|
|
|
/* source_location synopsis
|
|
|
|
namespace std {
|
|
struct source_location {
|
|
static consteval source_location current() noexcept;
|
|
constexpr source_location() noexcept;
|
|
|
|
constexpr uint_least32_t line() const noexcept;
|
|
constexpr uint_least32_t column() const noexcept;
|
|
constexpr const char* file_name() const noexcept;
|
|
constexpr const char* function_name() const noexcept;
|
|
};
|
|
}
|
|
*/
|
|
|
|
#include <__config>
|
|
#include <cstdint>
|
|
#include <version>
|
|
|
|
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
|
|
# pragma GCC system_header
|
|
#endif
|
|
|
|
_LIBCPP_BEGIN_NAMESPACE_STD
|
|
|
|
#if _LIBCPP_STD_VER >= 20
|
|
|
|
class source_location {
|
|
// The names source_location::__impl, _M_file_name, _M_function_name, _M_line, and _M_column
|
|
// are hard-coded in the compiler and must not be changed here.
|
|
struct __impl {
|
|
const char* _M_file_name;
|
|
const char* _M_function_name;
|
|
unsigned _M_line;
|
|
unsigned _M_column;
|
|
};
|
|
const __impl* __ptr_ = nullptr;
|
|
// GCC returns the type 'const void*' from the builtin, while clang returns
|
|
// `const __impl*`. Per C++ [expr.const], casts from void* are not permitted
|
|
// in constant evaluation, so we don't want to use `void*` as the argument
|
|
// type unless the builtin returned that, anyhow, and the invalid cast is
|
|
// unavoidable.
|
|
using __bsl_ty = decltype(__builtin_source_location());
|
|
|
|
public:
|
|
// The defaulted __ptr argument is necessary so that the builtin is evaluated
|
|
// in the context of the caller. An explicit value should never be provided.
|
|
static consteval source_location current(__bsl_ty __ptr = __builtin_source_location()) noexcept {
|
|
source_location __sl;
|
|
__sl.__ptr_ = static_cast<const __impl*>(__ptr);
|
|
return __sl;
|
|
}
|
|
_LIBCPP_HIDE_FROM_ABI constexpr source_location() noexcept = default;
|
|
|
|
_LIBCPP_HIDE_FROM_ABI constexpr uint_least32_t line() const noexcept {
|
|
return __ptr_ != nullptr ? __ptr_->_M_line : 0;
|
|
}
|
|
_LIBCPP_HIDE_FROM_ABI constexpr uint_least32_t column() const noexcept {
|
|
return __ptr_ != nullptr ? __ptr_->_M_column : 0;
|
|
}
|
|
_LIBCPP_HIDE_FROM_ABI constexpr const char* file_name() const noexcept {
|
|
return __ptr_ != nullptr ? __ptr_->_M_file_name : "";
|
|
}
|
|
_LIBCPP_HIDE_FROM_ABI constexpr const char* function_name() const noexcept {
|
|
return __ptr_ != nullptr ? __ptr_->_M_function_name : "";
|
|
}
|
|
};
|
|
|
|
#endif // _LIBCPP_STD_VER >= 20
|
|
|
|
_LIBCPP_END_NAMESPACE_STD
|
|
|
|
#endif // _LIBCPP_SOURCE_LOCATION
|