]> git.saurik.com Git - apple/libc.git/blobdiff - include/stdlib.h
Libc-1439.100.3.tar.gz
[apple/libc.git] / include / stdlib.h
index 602a692f98bef9bc550d68314db31455c93a0680..fdc95ad33df483d3618326e92be64ca3be337773 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2000, 2005 Apple Computer, Inc. All rights reserved.
+ * Copyright (c) 2000, 2002 - 2008 Apple Inc. All rights reserved.
  *
  * @APPLE_LICENSE_HEADER_START@
  * 
 #ifndef _STDLIB_H_
 #define _STDLIB_H_
 
-#include <available.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 */
-typedef        __darwin_size_t         size_t;
-#endif
+#include <sys/_types/_size_t.h>
 
 #if !defined(_ANSI_SOURCE) && (!defined(_POSIX_C_SOURCE) || defined(_DARWIN_C_SOURCE))
-#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
+#include <sys/_types/_ct_rune_t.h>
+#include <sys/_types/_rune_t.h>
 #endif /* !_ANSI_SOURCE && (!_POSIX_C_SOURCE || _DARWIN_C_SOURCE) */
 
-#ifndef        __cplusplus
-#ifndef        _WCHAR_T
-#define        _WCHAR_T
-typedef        __darwin_wchar_t        wchar_t;
-#endif /* _WCHAR_T */
-#endif /* __cplusplus */
+#include <sys/_types/_wchar_t.h>
 
 typedef struct {
        int quot;               /* quotient */
@@ -111,12 +99,12 @@ typedef struct {
 } lldiv_t;
 #endif /* !__DARWIN_NO_LONG_LONG */
 
-#ifndef NULL
-#define NULL __DARWIN_NULL
-#endif /* ! NULL */
+#include <sys/_types/_null.h>
 
+#ifndef UNIFDEF_DRIVERKIT
 #define        EXIT_FAILURE    1
 #define        EXIT_SUCCESS    0
+#endif /* UNIFDEF_DRIVERKIT */
 
 #define        RAND_MAX        0x7fffffff
 
@@ -140,11 +128,22 @@ extern int __mb_cur_max;
     && defined(_USE_EXTENDED_LOCALES_) && !defined(MB_CUR_MAX_L)
 #define        MB_CUR_MAX_L(x) (___mb_cur_max_l(x))
 #endif
+//Begin-Libc
+#include "libc_private.h"
+/* f must be a literal string */
+#define LIBC_ABORT(f,...)      abort_report_np("%s:%s:%u: " f, __FILE__, __func__, __LINE__, ## __VA_ARGS__)
+//End-Libc
+
+#ifndef UNIFDEF_DRIVERKIT
+#include <malloc/_malloc.h>
+#endif /* UNIFDEF_DRIVERKIT */
 
 __BEGIN_DECLS
-void    abort(void) __dead2;
+void    abort(void) __cold __dead2;
 int     abs(int) __pure2;
-int     atexit(void (*)(void));
+#ifndef UNIFDEF_DRIVERKIT
+int     atexit(void (* _Nonnull)(void));
+#endif /* UNIFDEF_DRIVERKIT */
 double  atof(const char *);
 int     atoi(const char *);
 long    atol(const char *);
@@ -152,13 +151,17 @@ long       atol(const char *);
 long long
         atoll(const char *);
 #endif /* !__DARWIN_NO_LONG_LONG */
-void   *bsearch(const void *, const void *, size_t,
-           size_t, int (*)(const void *, const void *));
-void   *calloc(size_t, size_t);
+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 */
 div_t   div(int, int) __pure2;
+#ifndef UNIFDEF_DRIVERKIT
 void    exit(int) __dead2;
-void    free(void *);
+/* free is now declared in _malloc.h */
 char   *getenv(const char *);
+#endif /* UNIFDEF_DRIVERKIT */
 long    labs(long) __pure2;
 ldiv_t  ldiv(long, long) __pure2;
 #if !__DARWIN_NO_LONG_LONG
@@ -166,48 +169,71 @@ long long
         llabs(long long);
 lldiv_t         lldiv(long long, long long);
 #endif /* !__DARWIN_NO_LONG_LONG */
-void   *malloc(size_t);
-int     mblen(const char *, size_t);
+#ifndef UNIFDEF_DRIVERKIT
+/* malloc is now declared in _malloc.h */
+#endif /* UNIFDEF_DRIVERKIT */
+int     mblen(const char *__s, size_t __n);
 size_t  mbstowcs(wchar_t * __restrict , const char * __restrict, size_t);
 int     mbtowc(wchar_t * __restrict, const char * __restrict, size_t);
-void    qsort(void *, size_t, size_t,
-           int (*)(const void *, const void *));
-int     rand(void);
-void   *realloc(void *, size_t);
-void    srand(unsigned);
+#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 */
 double  strtod(const char *, char **) __DARWIN_ALIAS(strtod);
 float   strtof(const char *, char **) __DARWIN_ALIAS(strtof);
-long    strtol(const char *, char **, int);
+long    strtol(const char *__str, char **__endptr, int __base);
 long double
-        strtold(const char *, char **) __DARWIN_LDBL_COMPAT(strtold);
+        strtold(const char *, char **);
 #if !__DARWIN_NO_LONG_LONG
 long long 
-        strtoll(const char *, char **, int);
+        strtoll(const char *__str, char **__endptr, int __base);
 #endif /* !__DARWIN_NO_LONG_LONG */
 unsigned long
-        strtoul(const char *, char **, int);
+        strtoul(const char *__str, char **__endptr, int __base);
 #if !__DARWIN_NO_LONG_LONG
 unsigned long long
-        strtoull(const char *, char **, int);
+        strtoull(const char *__str, char **__endptr, int __base);
 #endif /* !__DARWIN_NO_LONG_LONG */
+#ifndef UNIFDEF_DRIVERKIT
 //Begin-Libc
 #ifndef LIBC_ALIAS_SYSTEM
 //End-Libc
+
+#if TARGET_OS_IPHONE
+#define __swift_unavailable_on(osx_msg, ios_msg) __swift_unavailable(ios_msg)
+#else
+#define __swift_unavailable_on(osx_msg, ios_msg) __swift_unavailable(osx_msg)
+#endif
+
+__swift_unavailable_on("Use posix_spawn APIs or NSTask instead.", "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
+
+#undef __swift_unavailable_on
+#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 **);
@@ -217,16 +243,21 @@ char      *initstate(unsigned, char *, size_t); /* no  __DARWIN_ALIAS needed */
 #else /* !__DARWIN_UNIX03 */
 char   *initstate(unsigned long, char *, long);
 #endif /* __DARWIN_UNIX03 */
-long    jrand48(unsigned short[3]);
+long    jrand48(unsigned short[3]) __swift_unavailable("Use arc4random instead.");
 char   *l64a(long);
 void    lcong48(unsigned short[7]);
-long    lrand48(void);
+long    lrand48(void) __swift_unavailable("Use arc4random instead.");
 char   *mktemp(char *);
 int     mkstemp(char *);
-long    mrand48(void)
-long    nrand48(unsigned short[3]);
+long    mrand48(void) __swift_unavailable("Use arc4random instead.");
+long    nrand48(unsigned short[3]) __swift_unavailable("Use arc4random instead.");
 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
@@ -236,8 +267,8 @@ int  putenv(char *) __DARWIN_ALIAS(putenv);
 int     putenv(char *) LIBC_ALIAS(putenv);
 #endif /* !LIBC_ALIAS_PUTENV */
 //End-Libc
-long    random(void);
-int     rand_r(unsigned *);
+long    random(void) __swift_unavailable("Use arc4random instead.");
+int     rand_r(unsigned *) __swift_unavailable("Use arc4random instead.");
 //Begin-Libc
 #ifdef __LIBC__
 #ifndef LIBC_ALIAS_REALPATH
@@ -264,10 +295,10 @@ unsigned short
 //Begin-Libc
 #ifndef LIBC_ALIAS_SETENV
 //End-Libc
-int     setenv(const char *, const char *, int) __DARWIN_ALIAS(setenv);
+int     setenv(const char * __name, const char * __value, int __overwrite) __DARWIN_ALIAS(setenv);
 //Begin-Libc
 #else /* LIBC_ALIAS_SETENV */
-int     setenv(const char *, const char *, int) LIBC_ALIAS(setenv);
+int     setenv(const char * __name, const char * __value, int __overwrite) LIBC_ALIAS(setenv);
 #endif /* !LIBC_ALIAS_SETENV */
 //End-Libc
 #if __DARWIN_UNIX03
@@ -305,25 +336,37 @@ int        unsetenv(const char *) LIBC_ALIAS(unsetenv);
 void    unsetenv(const char *);
 #endif /* __DARWIN_UNIX03 */
 #endif /* !_ANSI_SOURCE */
+#endif /* UNIFDEF_DRIVERKIT */
 
 #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>
 
-#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);
+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);
 void    arc4random_stir(void);
+uint32_t
+        arc4random_uniform(uint32_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 */
+void   *bsearch_b(const void *__key, const void *__base, size_t __nel,
+           size_t __width, int (^ _Nonnull __compar)(const void *, const void *)) __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);
@@ -336,36 +379,82 @@ int        cgetset(const char *);
 int     cgetstr(char *, const char *, char **);
 int     cgetustr(char *, const char *, char **);
 
-int     daemon(int, int) __DARWIN_1050(daemon) __AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER_BUT_DEPRECATED_IN_MAC_OS_X_VERSION_10_5;
+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;
 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 *));
-int     mergesort(void *, size_t, size_t,
-           int (*)(const void *, const void *));
-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 *);
-int     sradixsort(const unsigned char **, int, const unsigned char *,
-           unsigned);
+#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
 void    sranddev(void);
 void    srandomdev(void);
-void   *reallocf(void *, size_t);
+void   *reallocf(void *__ptr, size_t __size) __alloc_size(2);
+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 *, char **, int);
+        strtoq(const char *__str, char **__endptr, int __base);
 unsigned long long
-        strtouq(const char *, char **, int);
+        strtouq(const char *__str, char **__endptr, int __base);
 #endif /* !__DARWIN_NO_LONG_LONG */
+#ifndef UNIFDEF_DRIVERKIT
 extern char *suboptarg;                /* getsubopt(3) external variable */
-void   *valloc(size_t);
+/* valloc is now declared in _malloc.h */
+#endif /* UNIFDEF_DRIVERKIT */
 #endif /* !_ANSI_SOURCE && !_POSIX_SOURCE */
 
 /* Poison the following routines if -fshort-wchar is set */