
Currently, the library-internal feature test macros are only defined if the feature is not available, and always have the prefix `_LIBCPP_HAS_NO_`. This patch changes that, so that they are always defined and have the prefix `_LIBCPP_HAS_` instead. This changes the canonical use of these macros to `#if _LIBCPP_HAS_FEATURE`, which means that using an undefined macro (e.g. due to a missing include) is diagnosed now. While this is rather unlikely currently, a similar change in `<__configuration/availability.h>` caught a few bugs. This also improves readability, since it removes the double-negation of `#ifndef _LIBCPP_HAS_NO_FEATURE`. The current patch only touches the macros defined in `<__config>`. If people are happy with this approach, I'll make a follow-up PR to also change the macros defined in `<__config_site>`.
31 lines
1.1 KiB
C++
31 lines
1.1 KiB
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
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// UNSUPPORTED: c++03
|
|
|
|
#include <uchar.h>
|
|
|
|
#include "test_macros.h"
|
|
|
|
// When C++ char8_t support is not enabled, definitions of these functions that
|
|
// match the C2X declarations may still be present in the global namespace with
|
|
// a char8_t typedef substituted for the C++ char8_t type. If so, these are not
|
|
// the declarations we are looking for, so don't test for them.
|
|
#if !defined(TEST_HAS_NO_CHAR8_T)
|
|
using U = decltype(::c8rtomb);
|
|
using V = decltype(::mbrtoc8);
|
|
# if !_LIBCPP_HAS_C8RTOMB_MBRTOC8
|
|
// expected-error@-3 {{no member named 'c8rtomb' in the global namespace}}
|
|
// expected-error@-3 {{no member named 'mbrtoc8' in the global namespace}}
|
|
# else
|
|
// expected-no-diagnostics
|
|
# endif
|
|
#else
|
|
// expected-no-diagnostics
|
|
#endif
|