Loading...
--- Libc/Libc-1583.0.14/include/stdlib.h
+++ Libc/Libc-763.13/include/stdlib.h
@@ -59,28 +59,40 @@
#define _STDLIB_H_
#include <Availability.h>
-#include <sys/cdefs.h>
#include <_types.h>
#if !defined(_ANSI_SOURCE)
-#ifndef UNIFDEF_DRIVERKIT
#include <sys/wait.h>
-#endif /* UNIFDEF_DRIVERKIT */
#if (!defined(_POSIX_C_SOURCE) || defined(_DARWIN_C_SOURCE))
#include <alloca.h>
#endif /* (!_POSIX_C_SOURCE || _DARWIN_C_SOURCE) */
#endif /* !_ANSI_SOURCE */
+#ifndef _SIZE_T
+#define _SIZE_T
/* DO NOT REMOVE THIS COMMENT: fixincludes needs to see:
* _GCC_SIZE_T */
-#include <sys/_types/_size_t.h>
+typedef __darwin_size_t size_t;
+#endif
#if !defined(_ANSI_SOURCE) && (!defined(_POSIX_C_SOURCE) || defined(_DARWIN_C_SOURCE))
-#include <sys/_types/_ct_rune_t.h>
-#include <sys/_types/_rune_t.h>
+#ifndef _CT_RUNE_T
+#define _CT_RUNE_T
+typedef __darwin_ct_rune_t ct_rune_t;
+#endif
+
+#ifndef _RUNE_T
+#define _RUNE_T
+typedef __darwin_rune_t rune_t;
+#endif
#endif /* !_ANSI_SOURCE && (!_POSIX_C_SOURCE || _DARWIN_C_SOURCE) */
-#include <sys/_types/_wchar_t.h>
+#ifndef __cplusplus
+#ifndef _WCHAR_T
+#define _WCHAR_T
+typedef __darwin_wchar_t wchar_t;
+#endif /* _WCHAR_T */
+#endif /* __cplusplus */
typedef struct {
int quot; /* quotient */
@@ -99,12 +111,12 @@
} lldiv_t;
#endif /* !__DARWIN_NO_LONG_LONG */
-#include <sys/_types/_null.h>
-
-#ifndef UNIFDEF_DRIVERKIT
+#ifndef NULL
+#define NULL __DARWIN_NULL
+#endif /* ! NULL */
+
#define EXIT_FAILURE 1
#define EXIT_SUCCESS 0
-#endif /* UNIFDEF_DRIVERKIT */
#define RAND_MAX 0x7fffffff
@@ -128,17 +140,19 @@
&& defined(_USE_EXTENDED_LOCALES_) && !defined(MB_CUR_MAX_L)
#define MB_CUR_MAX_L(x) (___mb_cur_max_l(x))
#endif
-
-#ifndef UNIFDEF_DRIVERKIT
-#include <malloc/_malloc.h>
-#endif /* UNIFDEF_DRIVERKIT */
+//Begin-Libc
+/* f must be a literal string */
+#define LIBC_ABORT(f,...) abort_report_np("%s:%s:%u: " f, __FILE__, __func__, __LINE__, ## __VA_ARGS__)
+//End-Libc
__BEGIN_DECLS
-void abort(void) __cold __dead2;
+void abort(void) __dead2;
+//Begin-Libc
+__private_extern__
+void abort_report_np(const char *, ...) __dead2 __printflike(1, 2);
+//End-Libc
int abs(int) __pure2;
-#ifndef UNIFDEF_DRIVERKIT
-int atexit(void (* _Nonnull)(void));
-#endif /* UNIFDEF_DRIVERKIT */
+int atexit(void (*)(void));
double atof(const char *);
int atoi(const char *);
long atol(const char *);
@@ -146,17 +160,13 @@
long long
atoll(const char *);
#endif /* !__DARWIN_NO_LONG_LONG */
-void *bsearch(const void *__key, const void *__base, size_t __nel,
- size_t __width, int (* _Nonnull __compar)(const void *, const void *));
-#ifndef UNIFDEF_DRIVERKIT
-/* calloc is now declared in _malloc.h */
-#endif /* UNIFDEF_DRIVERKIT */
+void *bsearch(const void *, const void *, size_t,
+ size_t, int (*)(const void *, const void *));
+void *calloc(size_t, size_t);
div_t div(int, int) __pure2;
-#ifndef UNIFDEF_DRIVERKIT
void exit(int) __dead2;
-/* free is now declared in _malloc.h */
+void free(void *);
char *getenv(const char *);
-#endif /* UNIFDEF_DRIVERKIT */
long labs(long) __pure2;
ldiv_t ldiv(long, long) __pure2;
#if !__DARWIN_NO_LONG_LONG
@@ -164,64 +174,49 @@
llabs(long long);
lldiv_t lldiv(long long, long long);
#endif /* !__DARWIN_NO_LONG_LONG */
-#ifndef UNIFDEF_DRIVERKIT
-/* malloc is now declared in _malloc.h */
-#endif /* UNIFDEF_DRIVERKIT */
-int mblen(const char *__s, size_t __n);
+void *malloc(size_t);
+int mblen(const char *, size_t);
size_t mbstowcs(wchar_t * __restrict , const char * __restrict, size_t);
int mbtowc(wchar_t * __restrict, const char * __restrict, size_t);
-#ifndef UNIFDEF_DRIVERKIT
-/* posix_memalign is now declared in _malloc.h */
-#endif /* UNIFDEF_DRIVERKIT */
-void qsort(void *__base, size_t __nel, size_t __width,
- int (* _Nonnull __compar)(const void *, const void *));
-#ifndef UNIFDEF_DRIVERKIT
-int rand(void) __swift_unavailable("Use arc4random instead.");
-/* realloc is now declared in _malloc.h */
-void srand(unsigned) __swift_unavailable("Use arc4random instead.");
-#endif /* UNIFDEF_DRIVERKIT */
+int posix_memalign(void **, size_t, size_t) __OSX_AVAILABLE_STARTING(__MAC_10_6, __IPHONE_3_0);
+void qsort(void *, size_t, size_t,
+ int (*)(const void *, const void *));
+int rand(void);
+void *realloc(void *, size_t);
+void srand(unsigned);
double strtod(const char *, char **) __DARWIN_ALIAS(strtod);
float strtof(const char *, char **) __DARWIN_ALIAS(strtof);
-long strtol(const char *__str, char **__endptr, int __base);
+long strtol(const char *, char **, int);
long double
- strtold(const char *, char **);
+ strtold(const char *, char **) __DARWIN_LDBL_COMPAT(strtold);
#if !__DARWIN_NO_LONG_LONG
long long
- strtoll(const char *__str, char **__endptr, int __base);
+ strtoll(const char *, char **, int);
#endif /* !__DARWIN_NO_LONG_LONG */
unsigned long
- strtoul(const char *__str, char **__endptr, int __base);
+ strtoul(const char *, char **, int);
#if !__DARWIN_NO_LONG_LONG
unsigned long long
- strtoull(const char *__str, char **__endptr, int __base);
-#endif /* !__DARWIN_NO_LONG_LONG */
-#ifndef UNIFDEF_DRIVERKIT
+ strtoull(const char *, char **, int);
+#endif /* !__DARWIN_NO_LONG_LONG */
//Begin-Libc
#ifndef LIBC_ALIAS_SYSTEM
//End-Libc
-
-__swift_unavailable("Use posix_spawn APIs or NSTask instead. (On iOS, process spawning is unavailable.)")
-__API_AVAILABLE(macos(10.0)) __IOS_PROHIBITED
-__WATCHOS_PROHIBITED __TVOS_PROHIBITED
int system(const char *) __DARWIN_ALIAS_C(system);
//Begin-Libc
#else /* LIBC_ALIAS_SYSTEM */
int system(const char *) LIBC_ALIAS_C(system);
#endif /* !LIBC_ALIAS_SYSTEM */
//End-Libc
-
-#endif /* UNIFDEF_DRIVERKIT */
-
size_t wcstombs(char * __restrict, const wchar_t * __restrict, size_t);
int wctomb(char *, wchar_t);
-#ifndef UNIFDEF_DRIVERKIT
#ifndef _ANSI_SOURCE
void _Exit(int) __dead2;
long a64l(const char *);
double drand48(void);
char *ecvt(double, int, int *__restrict, int *__restrict); /* LEGACY */
-double erand48(unsigned short[3]);
+double erand48(unsigned short[3]);
char *fcvt(double, int, int *__restrict, int *__restrict); /* LEGACY */
char *gcvt(double, int, char *); /* LEGACY */
int getsubopt(char **, char * const *, char **);
@@ -231,24 +226,16 @@
#else /* !__DARWIN_UNIX03 */
char *initstate(unsigned long, char *, long);
#endif /* __DARWIN_UNIX03 */
-long jrand48(unsigned short[3]) __swift_unavailable("Use arc4random instead.");
+long jrand48(unsigned short[3]);
char *l64a(long);
void lcong48(unsigned short[7]);
-long lrand48(void) __swift_unavailable("Use arc4random instead.");
-#if !defined(_POSIX_C_SOURCE)
-__deprecated_msg("This function is provided for compatibility reasons only. Due to security concerns inherent in the design of mktemp(3), it is highly recommended that you use mkstemp(3) instead.")
-#endif
+long lrand48(void);
char *mktemp(char *);
int mkstemp(char *);
-long mrand48(void) __swift_unavailable("Use arc4random instead.");
-long nrand48(unsigned short[3]) __swift_unavailable("Use arc4random instead.");
+long mrand48(void);
+long nrand48(unsigned short[3]);
int posix_openpt(int);
char *ptsname(int);
-
-#if (!defined(_POSIX_C_SOURCE) || defined(_DARWIN_C_SOURCE))
-int ptsname_r(int fildes, char *buffer, size_t buflen) __API_AVAILABLE(macos(10.13.4), ios(11.3), tvos(11.3), watchos(4.3));
-#endif
-
//Begin-Libc
#ifndef LIBC_ALIAS_PUTENV
//End-Libc
@@ -258,8 +245,8 @@
int putenv(char *) LIBC_ALIAS(putenv);
#endif /* !LIBC_ALIAS_PUTENV */
//End-Libc
-long random(void) __swift_unavailable("Use arc4random instead.");
-int rand_r(unsigned *) __swift_unavailable("Use arc4random instead.");
+long random(void);
+int rand_r(unsigned *);
//Begin-Libc
#ifdef __LIBC__
#ifndef LIBC_ALIAS_REALPATH
@@ -286,10 +273,10 @@
//Begin-Libc
#ifndef LIBC_ALIAS_SETENV
//End-Libc
-int setenv(const char * __name, const char * __value, int __overwrite) __DARWIN_ALIAS(setenv);
+int setenv(const char *, const char *, int) __DARWIN_ALIAS(setenv);
//Begin-Libc
#else /* LIBC_ALIAS_SETENV */
-int setenv(const char * __name, const char * __value, int __overwrite) LIBC_ALIAS(setenv);
+int setenv(const char *, const char *, int) LIBC_ALIAS(setenv);
#endif /* !LIBC_ALIAS_SETENV */
//End-Libc
#if __DARWIN_UNIX03
@@ -327,48 +314,33 @@
void unsetenv(const char *);
#endif /* __DARWIN_UNIX03 */
#endif /* !_ANSI_SOURCE */
-#endif /* UNIFDEF_DRIVERKIT */
-__END_DECLS
#if !defined(_ANSI_SOURCE) && (!defined(_POSIX_C_SOURCE) || defined(_DARWIN_C_SOURCE))
#include <machine/types.h>
-#ifndef UNIFDEF_DRIVERKIT
-#include <sys/_types/_dev_t.h>
-#include <sys/_types/_mode_t.h>
-#endif /* UNIFDEF_DRIVERKIT */
-#include <_types/_uint32_t.h>
-
-__BEGIN_DECLS
-uint32_t arc4random(void);
-#ifndef UNIFDEF_DRIVERKIT
-void arc4random_addrandom(unsigned char * /*dat*/, int /*datlen*/)
- __OSX_DEPRECATED(10.0, 10.12, "use arc4random_stir")
- __IOS_DEPRECATED(2.0, 10.0, "use arc4random_stir")
- __TVOS_DEPRECATED(2.0, 10.0, "use arc4random_stir")
- __WATCHOS_DEPRECATED(1.0, 3.0, "use arc4random_stir");
-#endif /* UNIFDEF_DRIVERKIT */
-void arc4random_buf(void * __buf, size_t __nbytes) __OSX_AVAILABLE_STARTING(__MAC_10_7, __IPHONE_4_3);
+
+#ifndef _DEV_T
+typedef __darwin_dev_t dev_t;
+#define _DEV_T
+#endif
+
+#ifndef _MODE_T
+typedef __darwin_mode_t mode_t;
+#define _MODE_T
+#endif
+
+u_int32_t
+ arc4random(void);
+void arc4random_addrandom(unsigned char * /*dat*/, int /*datlen*/);
+void arc4random_buf(void * /*buf*/, size_t /*nbytes*/) __OSX_AVAILABLE_STARTING(__MAC_10_7, __IPHONE_4_3);
void arc4random_stir(void);
-uint32_t
- arc4random_uniform(uint32_t __upper_bound) __OSX_AVAILABLE_STARTING(__MAC_10_7, __IPHONE_4_3);
+u_int32_t
+ arc4random_uniform(u_int32_t /*upper_bound*/) __OSX_AVAILABLE_STARTING(__MAC_10_7, __IPHONE_4_3);
#ifdef __BLOCKS__
-#ifndef UNIFDEF_DRIVERKIT
-int atexit_b(void (^ _Nonnull)(void)) __OSX_AVAILABLE_STARTING(__MAC_10_6, __IPHONE_3_2);
-#endif /* UNIFDEF_DRIVERKIT */
-
-#ifdef __BLOCKS__
-#if __has_attribute(noescape)
-#define __bsearch_noescape __attribute__((__noescape__))
-#else
-#define __bsearch_noescape
-#endif
+int atexit_b(void (^)(void)) __OSX_AVAILABLE_STARTING(__MAC_10_6, __IPHONE_3_2);
+void *bsearch_b(const void *, const void *, size_t,
+ size_t, int (^)(const void *, const void *)) __OSX_AVAILABLE_STARTING(__MAC_10_6, __IPHONE_3_2);
#endif /* __BLOCKS__ */
-void *bsearch_b(const void *__key, const void *__base, size_t __nel,
- size_t __width, int (^ _Nonnull __compar)(const void *, const void *) __bsearch_noescape)
- __OSX_AVAILABLE_STARTING(__MAC_10_6, __IPHONE_3_2);
-#endif /* __BLOCKS__ */
-
-#ifndef UNIFDEF_DRIVERKIT
+
/* getcap(3) functions */
char *cgetcap(char *, const char *, int);
int cgetclose(void);
@@ -381,86 +353,58 @@
int cgetstr(char *, const char *, char **);
int cgetustr(char *, const char *, char **);
-int daemon(int, int) __DARWIN_1050(daemon) __OSX_AVAILABLE_BUT_DEPRECATED_MSG(__MAC_10_0, __MAC_10_5, __IPHONE_2_0, __IPHONE_2_0, "Use posix_spawn APIs instead.") __WATCHOS_PROHIBITED __TVOS_PROHIBITED;
+int daemon(int, int) __DARWIN_1050(daemon) __OSX_AVAILABLE_BUT_DEPRECATED(__MAC_10_0, __MAC_10_5, __IPHONE_2_0, __IPHONE_2_0);
char *devname(dev_t, mode_t);
char *devname_r(dev_t, mode_t, char *buf, int len);
char *getbsize(int *, long *);
int getloadavg(double [], int);
const char
*getprogname(void);
+
+int heapsort(void *, size_t, size_t,
+ int (*)(const void *, const void *));
+#ifdef __BLOCKS__
+int heapsort_b(void *, size_t, size_t,
+ int (^)(const void *, const void *)) __OSX_AVAILABLE_STARTING(__MAC_10_6, __IPHONE_3_2);
+#endif /* __BLOCKS__ */
+int mergesort(void *, size_t, size_t,
+ int (*)(const void *, const void *));
+#ifdef __BLOCKS__
+int mergesort_b(void *, size_t, size_t,
+ int (^)(const void *, const void *)) __OSX_AVAILABLE_STARTING(__MAC_10_6, __IPHONE_3_2);
+#endif /* __BLOCKS__ */
+void psort(void *, size_t, size_t,
+ int (*)(const void *, const void *)) __OSX_AVAILABLE_STARTING(__MAC_10_6, __IPHONE_3_2);
+#ifdef __BLOCKS__
+void psort_b(void *, size_t, size_t,
+ int (^)(const void *, const void *)) __OSX_AVAILABLE_STARTING(__MAC_10_6, __IPHONE_3_2);
+#endif /* __BLOCKS__ */
+void psort_r(void *, size_t, size_t, void *,
+ int (*)(void *, const void *, const void *)) __OSX_AVAILABLE_STARTING(__MAC_10_6, __IPHONE_3_2);
+#ifdef __BLOCKS__
+void qsort_b(void *, size_t, size_t,
+ int (^)(const void *, const void *)) __OSX_AVAILABLE_STARTING(__MAC_10_6, __IPHONE_3_2);
+#endif /* __BLOCKS__ */
+void qsort_r(void *, size_t, size_t, void *,
+ int (*)(void *, const void *, const void *));
+int radixsort(const unsigned char **, int, const unsigned char *,
+ unsigned);
void setprogname(const char *);
-#endif /* UNIFDEF_DRIVERKIT */
-
-#ifdef __BLOCKS__
-#if __has_attribute(noescape)
-#define __sort_noescape __attribute__((__noescape__))
-#else
-#define __sort_noescape
-#endif
-#endif /* __BLOCKS__ */
-
-int heapsort(void *__base, size_t __nel, size_t __width,
- int (* _Nonnull __compar)(const void *, const void *));
-#ifdef __BLOCKS__
-int heapsort_b(void *__base, size_t __nel, size_t __width,
- int (^ _Nonnull __compar)(const void *, const void *) __sort_noescape)
- __OSX_AVAILABLE_STARTING(__MAC_10_6, __IPHONE_3_2);
-#endif /* __BLOCKS__ */
-int mergesort(void *__base, size_t __nel, size_t __width,
- int (* _Nonnull __compar)(const void *, const void *));
-#ifdef __BLOCKS__
-int mergesort_b(void *__base, size_t __nel, size_t __width,
- int (^ _Nonnull __compar)(const void *, const void *) __sort_noescape)
- __OSX_AVAILABLE_STARTING(__MAC_10_6, __IPHONE_3_2);
-#endif /* __BLOCKS__ */
-#ifndef UNIFDEF_DRIVERKIT
-void psort(void *__base, size_t __nel, size_t __width,
- int (* _Nonnull __compar)(const void *, const void *))
- __OSX_AVAILABLE_STARTING(__MAC_10_6, __IPHONE_3_2);
-#ifdef __BLOCKS__
-void psort_b(void *__base, size_t __nel, size_t __width,
- int (^ _Nonnull __compar)(const void *, const void *) __sort_noescape)
- __OSX_AVAILABLE_STARTING(__MAC_10_6, __IPHONE_3_2);
-#endif /* __BLOCKS__ */
-void psort_r(void *__base, size_t __nel, size_t __width, void *,
- int (* _Nonnull __compar)(void *, const void *, const void *))
- __OSX_AVAILABLE_STARTING(__MAC_10_6, __IPHONE_3_2);
-#endif /* UNIFDEF_DRIVERKIT */
-#ifdef __BLOCKS__
-void qsort_b(void *__base, size_t __nel, size_t __width,
- int (^ _Nonnull __compar)(const void *, const void *) __sort_noescape)
- __OSX_AVAILABLE_STARTING(__MAC_10_6, __IPHONE_3_2);
-#endif /* __BLOCKS__ */
-void qsort_r(void *__base, size_t __nel, size_t __width, void *,
- int (* _Nonnull __compar)(void *, const void *, const void *));
-int radixsort(const unsigned char **__base, int __nel, const unsigned char *__table,
- unsigned __endbyte);
-int rpmatch(const char *)
- __API_AVAILABLE(macos(10.15), ios(13.0), tvos(13.0), watchos(6.0));
-int sradixsort(const unsigned char **__base, int __nel, const unsigned char *__table,
- unsigned __endbyte);
-#ifndef UNIFDEF_DRIVERKIT
+int sradixsort(const unsigned char **, int, const unsigned char *,
+ unsigned);
void sranddev(void);
void srandomdev(void);
-void *reallocf(void *__ptr, size_t __size) __alloc_size(2);
+void *reallocf(void *, size_t);
+#if !__DARWIN_NO_LONG_LONG
long long
- strtonum(const char *__numstr, long long __minval, long long __maxval, const char **__errstrp)
- __API_AVAILABLE(macos(10.16), ios(14.0), tvos(14.0), watchos(7.0));
-#endif /* UNIFDEF_DRIVERKIT */
-#if !__DARWIN_NO_LONG_LONG
-long long
- strtoq(const char *__str, char **__endptr, int __base);
+ strtoq(const char *, char **, int);
unsigned long long
- strtouq(const char *__str, char **__endptr, int __base);
-#endif /* !__DARWIN_NO_LONG_LONG */
-#ifndef UNIFDEF_DRIVERKIT
+ strtouq(const char *, char **, int);
+#endif /* !__DARWIN_NO_LONG_LONG */
extern char *suboptarg; /* getsubopt(3) external variable */
-/* valloc is now declared in _malloc.h */
-#endif /* UNIFDEF_DRIVERKIT */
-__END_DECLS
+void *valloc(size_t);
#endif /* !_ANSI_SOURCE && !_POSIX_SOURCE */
-__BEGIN_DECLS
/* Poison the following routines if -fshort-wchar is set */
#if !defined(__cplusplus) && defined(__WCHAR_MAX__) && __WCHAR_MAX__ <= 0xffffU
#pragma GCC poison mbstowcs mbtowc wcstombs wctomb