2010-05-12 03:42:16 +08:00
|
|
|
// -*- C++ -*-
|
2021-11-18 05:25:01 +08:00
|
|
|
//===----------------------------------------------------------------------===//
|
2010-05-12 03:42:16 +08:00
|
|
|
//
|
2019-01-19 18:56:40 +08:00
|
|
|
// 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
|
2010-05-12 03:42:16 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#ifndef _LIBCPP_CSTDLIB
|
|
|
|
#define _LIBCPP_CSTDLIB
|
|
|
|
|
|
|
|
/*
|
|
|
|
cstdlib synopsis
|
|
|
|
|
|
|
|
Macros:
|
|
|
|
|
|
|
|
EXIT_FAILURE
|
|
|
|
EXIT_SUCCESS
|
|
|
|
MB_CUR_MAX
|
|
|
|
NULL
|
|
|
|
RAND_MAX
|
2010-08-22 08:02:43 +08:00
|
|
|
|
2010-05-12 03:42:16 +08:00
|
|
|
namespace std
|
|
|
|
{
|
|
|
|
|
|
|
|
Types:
|
|
|
|
|
|
|
|
size_t
|
|
|
|
div_t
|
|
|
|
ldiv_t
|
|
|
|
lldiv_t // C99
|
|
|
|
|
|
|
|
double atof (const char* nptr);
|
|
|
|
int atoi (const char* nptr);
|
|
|
|
long atol (const char* nptr);
|
|
|
|
long long atoll(const char* nptr); // C99
|
|
|
|
double strtod (const char* restrict nptr, char** restrict endptr);
|
|
|
|
float strtof (const char* restrict nptr, char** restrict endptr); // C99
|
|
|
|
long double strtold (const char* restrict nptr, char** restrict endptr); // C99
|
|
|
|
long strtol (const char* restrict nptr, char** restrict endptr, int base);
|
|
|
|
long long strtoll (const char* restrict nptr, char** restrict endptr, int base); // C99
|
|
|
|
unsigned long strtoul (const char* restrict nptr, char** restrict endptr, int base);
|
|
|
|
unsigned long long strtoull(const char* restrict nptr, char** restrict endptr, int base); // C99
|
|
|
|
int rand(void);
|
|
|
|
void srand(unsigned int seed);
|
|
|
|
void* calloc(size_t nmemb, size_t size);
|
|
|
|
void free(void* ptr);
|
|
|
|
void* malloc(size_t size);
|
|
|
|
void* realloc(void* ptr, size_t size);
|
|
|
|
void abort(void);
|
|
|
|
int atexit(void (*func)(void));
|
|
|
|
void exit(int status);
|
|
|
|
void _Exit(int status);
|
|
|
|
char* getenv(const char* name);
|
|
|
|
int system(const char* string);
|
|
|
|
void* bsearch(const void* key, const void* base, size_t nmemb, size_t size,
|
|
|
|
int (*compar)(const void *, const void *));
|
|
|
|
void qsort(void* base, size_t nmemb, size_t size,
|
|
|
|
int (*compar)(const void *, const void *));
|
|
|
|
int abs( int j);
|
|
|
|
long abs( long j);
|
|
|
|
long long abs(long long j); // C++0X
|
|
|
|
long labs( long j);
|
|
|
|
long long llabs(long long j); // C99
|
|
|
|
div_t div( int numer, int denom);
|
|
|
|
ldiv_t div( long numer, long denom);
|
2010-08-22 08:02:43 +08:00
|
|
|
lldiv_t div(long long numer, long long denom); // C++0X
|
2010-05-12 03:42:16 +08:00
|
|
|
ldiv_t ldiv( long numer, long denom);
|
|
|
|
lldiv_t lldiv(long long numer, long long denom); // C99
|
|
|
|
int mblen(const char* s, size_t n);
|
|
|
|
int mbtowc(wchar_t* restrict pwc, const char* restrict s, size_t n);
|
|
|
|
int wctomb(char* s, wchar_t wchar);
|
|
|
|
size_t mbstowcs(wchar_t* restrict pwcs, const char* restrict s, size_t n);
|
|
|
|
size_t wcstombs(char* restrict s, const wchar_t* restrict pwcs, size_t n);
|
2012-10-14 02:03:53 +08:00
|
|
|
int at_quick_exit(void (*func)(void)) // C++11
|
|
|
|
void quick_exit(int status); // C++11
|
|
|
|
void *aligned_alloc(size_t alignment, size_t size); // C11
|
2010-05-12 03:42:16 +08:00
|
|
|
|
|
|
|
} // std
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <__config>
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
2011-10-18 04:05:10 +08:00
|
|
|
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
|
2010-05-12 03:42:16 +08:00
|
|
|
#pragma GCC system_header
|
2011-10-18 04:05:10 +08:00
|
|
|
#endif
|
2010-05-12 03:42:16 +08:00
|
|
|
|
2016-08-30 04:43:38 +08:00
|
|
|
#ifdef __GNUC__
|
|
|
|
#define _LIBCPP_UNREACHABLE() __builtin_unreachable()
|
|
|
|
#else
|
|
|
|
#define _LIBCPP_UNREACHABLE() _VSTD::abort()
|
|
|
|
#endif
|
|
|
|
|
2010-05-12 03:42:16 +08:00
|
|
|
_LIBCPP_BEGIN_NAMESPACE_STD
|
|
|
|
|
[libc++] Use the using_if_exists attribute when provided
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
2021-06-02 22:41:37 +08:00
|
|
|
using ::size_t _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::div_t _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::ldiv_t _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::lldiv_t _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::atof _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::atoi _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::atol _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::atoll _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::strtod _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::strtof _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::strtold _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::strtol _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::strtoll _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::strtoul _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::strtoull _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::rand _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::srand _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::calloc _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::free _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::malloc _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::realloc _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::abort _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::atexit _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::exit _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::_Exit _LIBCPP_USING_IF_EXISTS;
|
2017-04-06 12:47:49 +08:00
|
|
|
#ifndef _LIBCPP_WINDOWS_STORE_APP
|
[libc++] Use the using_if_exists attribute when provided
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
2021-06-02 22:41:37 +08:00
|
|
|
using ::getenv _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::system _LIBCPP_USING_IF_EXISTS;
|
2017-04-06 12:47:49 +08:00
|
|
|
#endif
|
[libc++] Use the using_if_exists attribute when provided
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
2021-06-02 22:41:37 +08:00
|
|
|
using ::bsearch _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::qsort _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::abs _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::labs _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::llabs _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::div _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::ldiv _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::lldiv _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::mblen _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::mbtowc _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::wctomb _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::mbstowcs _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::wcstombs _LIBCPP_USING_IF_EXISTS;
|
2018-08-16 05:19:08 +08:00
|
|
|
#if !defined(_LIBCPP_CXX03_LANG) && defined(_LIBCPP_HAS_QUICK_EXIT)
|
[libc++] Use the using_if_exists attribute when provided
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
2021-06-02 22:41:37 +08:00
|
|
|
using ::at_quick_exit _LIBCPP_USING_IF_EXISTS;
|
|
|
|
using ::quick_exit _LIBCPP_USING_IF_EXISTS;
|
2012-03-14 22:10:37 +08:00
|
|
|
#endif
|
Fix _LIBCPP_HAS_ definitions for Android.
Summary:
Android added quick_exit()/at_quick_exit() in API level 21,
aligned_alloc() in API level 28, and timespec_get() in API level 29,
but has the other C11 features at all API levels (since they're basically
just coming from clang directly).
_LIBCPP_HAS_QUICK_EXIT and _LIBCPP_HAS_TIMESPEC_GET already existed,
so we can reuse them. (And use _LIBCPP_HAS_TIMESPEC_GET in a few more
places where _LIBCPP_HAS_C11_FEATURES has been used as a proxy. This
isn't correct for Android.)
_LIBCPP_HAS_ALIGNED_ALLOC is added, to cover aligned_alloc() (obviously).
Add a missing std:: before aligned_alloc in a cstdlib test, and remove a
couple of !defined(_WIN32)s now that we're explicitly testing
TEST_HAS_ALIGNED_ALLOC rather than TEST_HAS_C11_FEATURES.
Reviewers: danalbert, EricWF, mclow.lists
Reviewed By: danalbert
Subscribers: srhines, christof, libcxx-commits
Tags: #libc
Differential Revision: https://reviews.llvm.org/D69929
2019-11-19 04:16:45 +08:00
|
|
|
#if _LIBCPP_STD_VER > 14 && defined(_LIBCPP_HAS_ALIGNED_ALLOC)
|
[libc++] Use the using_if_exists attribute when provided
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
2021-06-02 22:41:37 +08:00
|
|
|
using ::aligned_alloc _LIBCPP_USING_IF_EXISTS;
|
2012-10-14 02:03:53 +08:00
|
|
|
#endif
|
2010-05-12 03:42:16 +08:00
|
|
|
|
|
|
|
_LIBCPP_END_NAMESPACE_STD
|
|
|
|
|
2021-04-21 00:03:32 +08:00
|
|
|
#endif // _LIBCPP_CSTDLIB
|