mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-26 12:26:08 +00:00

As discussed on cfe-dev [1], use the using_if_exists Clang attribute when the compiler supports it. This makes it easier to port libc++ on top of new platforms that don't fully support the C Standard library. Previously, libc++ would fail to build when trying to import a missing declaration in a <cXXXX> header. With the attribute, the declaration will simply not be imported into namespace std, and hence it won't be available for libc++ to use. In many cases, the declarations were *not* actually required for libc++ to work (they were only surfaced for users to use them as std::XXXX), so not importing them into namespace std is acceptable. The same thing could be achieved by conscious usage of `#ifdef` along with platform detection, however that quickly creates a maintenance problem as libc++ is ported to new platforms. Furthermore, this problem is exacerbated when mixed with vendor internal-only platforms, which can lead to difficulties maintaining a downstream fork of the library. For the time being, we only use the using_if_exists attribute when it is supported. At some point in the future, we will start removing #ifdef paths that are unnecessary when the attribute is supported, and folks who need those #ifdef paths will be required to use a compiler that supports the attribute. [1]: http://lists.llvm.org/pipermail/cfe-dev/2020-June/066038.html Differential Revision: https://reviews.llvm.org/D90257
82 lines
1.9 KiB
C++
82 lines
1.9 KiB
C++
// -*- C++ -*-
|
|
//===---------------------------- cfenv -----------------------------------===//
|
|
//
|
|
// 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_CFENV
|
|
#define _LIBCPP_CFENV
|
|
|
|
/*
|
|
cfenv synopsis
|
|
|
|
This entire header is C99 / C++0X
|
|
|
|
Macros:
|
|
|
|
FE_DIVBYZERO
|
|
FE_INEXACT
|
|
FE_INVALID
|
|
FE_OVERFLOW
|
|
FE_UNDERFLOW
|
|
FE_ALL_EXCEPT
|
|
FE_DOWNWARD
|
|
FE_TONEAREST
|
|
FE_TOWARDZERO
|
|
FE_UPWARD
|
|
FE_DFL_ENV
|
|
|
|
namespace std
|
|
{
|
|
|
|
Types:
|
|
|
|
fenv_t
|
|
fexcept_t
|
|
|
|
int feclearexcept(int excepts);
|
|
int fegetexceptflag(fexcept_t* flagp, int excepts);
|
|
int feraiseexcept(int excepts);
|
|
int fesetexceptflag(const fexcept_t* flagp, int excepts);
|
|
int fetestexcept(int excepts);
|
|
int fegetround();
|
|
int fesetround(int round);
|
|
int fegetenv(fenv_t* envp);
|
|
int feholdexcept(fenv_t* envp);
|
|
int fesetenv(const fenv_t* envp);
|
|
int feupdateenv(const fenv_t* envp);
|
|
|
|
} // std
|
|
*/
|
|
|
|
#include <__config>
|
|
#include <fenv.h>
|
|
|
|
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
|
|
#pragma GCC system_header
|
|
#endif
|
|
|
|
_LIBCPP_BEGIN_NAMESPACE_STD
|
|
|
|
using ::fenv_t _LIBCPP_USING_IF_EXISTS;
|
|
using ::fexcept_t _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::feclearexcept _LIBCPP_USING_IF_EXISTS;
|
|
using ::fegetexceptflag _LIBCPP_USING_IF_EXISTS;
|
|
using ::feraiseexcept _LIBCPP_USING_IF_EXISTS;
|
|
using ::fesetexceptflag _LIBCPP_USING_IF_EXISTS;
|
|
using ::fetestexcept _LIBCPP_USING_IF_EXISTS;
|
|
using ::fegetround _LIBCPP_USING_IF_EXISTS;
|
|
using ::fesetround _LIBCPP_USING_IF_EXISTS;
|
|
using ::fegetenv _LIBCPP_USING_IF_EXISTS;
|
|
using ::feholdexcept _LIBCPP_USING_IF_EXISTS;
|
|
using ::fesetenv _LIBCPP_USING_IF_EXISTS;
|
|
using ::feupdateenv _LIBCPP_USING_IF_EXISTS;
|
|
|
|
_LIBCPP_END_NAMESPACE_STD
|
|
|
|
#endif // _LIBCPP_CFENV
|