blob: 7081d7ccb6ee411c178254d4158efe15475d2d9f [file] [log] [blame]
The Android Open Source Project1dc9e472009-03-03 19:28:35 -08001/*
2 * Copyright (C) 2008 The Android Open Source Project
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above copyright
11 * notice, this list of conditions and the following disclaimer in
12 * the documentation and/or other materials provided with the
13 * distribution.
14 *
15 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
16 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
17 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
18 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
19 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
20 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
21 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
22 * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
23 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
24 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
25 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26 * SUCH DAMAGE.
27 */
Elliott Hughes76f89162015-01-26 13:34:58 -080028
29#ifndef _STDLIB_H
30#define _STDLIB_H
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080031
Elliott Hughes414dd2d2024-10-16 14:48:30 +000032#include <sys/cdefs.h>
33
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080034#include <alloca.h>
Elliott Hughes21b56eb2017-10-20 17:57:17 -070035#include <bits/wait.h>
Elliott Hughes76f89162015-01-26 13:34:58 -080036#include <malloc.h>
37#include <stddef.h>
Elliott Hughes21b56eb2017-10-20 17:57:17 -070038#include <xlocale.h>
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080039
40__BEGIN_DECLS
41
42#define EXIT_FAILURE 1
43#define EXIT_SUCCESS 0
44
Elliott Hughes504d0482021-06-07 11:20:28 -070045__noreturn void abort(void) __attribute__((__nomerge__));
Elliott Hughesfaa74342017-08-11 17:34:44 -070046__noreturn void exit(int __status);
Elliott Hughes655e4302023-06-16 12:39:33 -070047__noreturn void _Exit(int __status);
Elliott Hughes2f94a292017-09-18 14:40:01 -070048
zijunzhao5a918d92022-11-28 21:05:55 +000049int atexit(void (* _Nonnull __fn)(void));
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080050
Elliott Hughes655e4302023-06-16 12:39:33 -070051int at_quick_exit(void (* _Nonnull __fn)(void));
52void quick_exit(int __status) __noreturn;
Dan Albertb8425c52014-04-29 17:49:06 -070053
zijunzhao5a918d92022-11-28 21:05:55 +000054char* _Nullable getenv(const char* _Nonnull __name);
55int putenv(char* _Nonnull __assignment);
56int setenv(const char* _Nonnull __name, const char* _Nonnull __value, int __overwrite);
57int unsetenv(const char* _Nonnull __name);
Elliott Hughes3b2096a2016-07-22 18:57:12 -070058int clearenv(void);
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080059
zijunzhao5a918d92022-11-28 21:05:55 +000060char* _Nullable mkdtemp(char* _Nonnull __template);
Elliott Hughesa1b5ca22024-04-22 20:10:53 +000061char* _Nullable mktemp(char* _Nonnull __template) __attribute__((__deprecated__("mktemp is unsafe, use mkstemp or tmpfile instead")));
Elliott Hughes31165ed2014-09-23 17:34:29 -070062
Dan Albert02ce4012024-10-25 19:13:49 +000063
64#if __BIONIC_AVAILABILITY_GUARD(23)
zijunzhao5a918d92022-11-28 21:05:55 +000065int mkostemp64(char* _Nonnull __template, int __flags) __INTRODUCED_IN(23);
66int mkostemp(char* _Nonnull __template, int __flags) __INTRODUCED_IN(23);
67int mkostemps64(char* _Nonnull __template, int __suffix_length, int __flags) __INTRODUCED_IN(23);
68int mkostemps(char* _Nonnull __template, int __suffix_length, int __flags) __INTRODUCED_IN(23);
Dan Albert02ce4012024-10-25 19:13:49 +000069#endif /* __BIONIC_AVAILABILITY_GUARD(23) */
70
Elliott Hughes655e4302023-06-16 12:39:33 -070071int mkstemp64(char* _Nonnull __template);
zijunzhao5a918d92022-11-28 21:05:55 +000072int mkstemp(char* _Nonnull __template);
Dan Albert02ce4012024-10-25 19:13:49 +000073
74#if __BIONIC_AVAILABILITY_GUARD(23)
zijunzhao5a918d92022-11-28 21:05:55 +000075int mkstemps64(char* _Nonnull __template, int __flags) __INTRODUCED_IN(23);
Dan Albert02ce4012024-10-25 19:13:49 +000076#endif /* __BIONIC_AVAILABILITY_GUARD(23) */
77
zijunzhao5a918d92022-11-28 21:05:55 +000078int mkstemps(char* _Nonnull __template, int __flags);
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080079
Elliott Hughes655e4302023-06-16 12:39:33 -070080int posix_memalign(void* _Nullable * _Nullable __memptr, size_t __alignment, size_t __size);
Ken Sumrall85aad902011-12-14 20:50:01 -080081
Elliott Hughesc9f344e2024-08-20 15:28:38 +000082/**
83 * [aligned_alloc(3)](https://man7.org/linux/man-pages/man3/aligned_alloc.3.html)
84 * allocates the given number of bytes with the given alignment.
85 *
86 * Returns a pointer to the allocated memory on success and returns a null
87 * pointer and sets `errno` on failure.
88 *
89 * Available since API level 28.
90 */
Dan Albert02ce4012024-10-25 19:13:49 +000091
92#if __BIONIC_AVAILABILITY_GUARD(28)
Elliott Hughesb19df892024-09-06 14:27:41 +000093__nodiscard void* _Nullable aligned_alloc(size_t __alignment, size_t __size) __INTRODUCED_IN(28);
Dan Albert02ce4012024-10-25 19:13:49 +000094#endif /* __BIONIC_AVAILABILITY_GUARD(28) */
95
Christopher Ferriscae21a92018-02-05 18:14:55 -080096
Elliott Hughesb19df892024-09-06 14:27:41 +000097__nodiscard char* _Nullable realpath(const char* _Nonnull __path, char* _Nullable __resolved);
Elliott Hughescc87eec2023-10-26 21:28:12 +000098
99/**
Elliott Hughesbbd39aa2024-08-13 20:59:16 +0000100 * [system(3)](https://man7.org/linux/man-pages/man3/system.3.html) executes
Elliott Hughescc87eec2023-10-26 21:28:12 +0000101 * the given command in a new shell process.
102 *
103 * On Android, the special case of `system(NULL)` always returns 1,
104 * as specified by POSIX. Passing `NULL` to determine whether or
105 * not a shell is available is not portable. Callers should just try
106 * the command they actually want to run, since there are many reasons
107 * why it might fail, both temporarily (for lack of resources, say)
108 * or permanently (for lack of permission, say).
109 *
110 * Returns -1 and sets errno if process creation fails; returns a
Elliott Hughesbbd39aa2024-08-13 20:59:16 +0000111 * [waitpid(2)](https://man7.org/linux/man-pages/man2/waitpid.2.html)
Elliott Hughescc87eec2023-10-26 21:28:12 +0000112 * status otherwise.
113 */
zijunzhao5a918d92022-11-28 21:05:55 +0000114int system(const char* _Nonnull __command);
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800115
Elliott Hughesd4c54b42024-05-31 17:33:33 +0000116/**
Elliott Hughesbbd39aa2024-08-13 20:59:16 +0000117 * [bsearch(3)](https://man7.org/linux/man-pages/man3/bsearch.3.html) searches
Elliott Hughesd4c54b42024-05-31 17:33:33 +0000118 * a sorted array.
119 *
120 * Returns a pointer to a matching item on success,
121 * or NULL if no matching item is found.
122 */
Elliott Hughesb19df892024-09-06 14:27:41 +0000123__nodiscard void* _Nullable bsearch(const void* _Nonnull __key, const void* _Nullable __base, size_t __nmemb, size_t __size, int (* _Nonnull __comparator)(const void* _Nonnull __lhs, const void* _Nonnull __rhs));
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800124
Elliott Hughes5bae5722024-07-30 12:47:33 -0400125/**
Elliott Hughesbbd39aa2024-08-13 20:59:16 +0000126 * [qsort(3)](https://man7.org/linux/man-pages/man3/qsort.3.html) sorts an array
Elliott Hughes5bae5722024-07-30 12:47:33 -0400127 * of n elements each of the given size, using the given comparator.
128 */
129void qsort(void* _Nullable __array, size_t __n, size_t __size, int (* _Nonnull __comparator)(const void* _Nullable __lhs, const void* _Nullable __rhs));
130
131/**
Elliott Hughesbbd39aa2024-08-13 20:59:16 +0000132 * [qsort_r(3)](https://man7.org/linux/man-pages/man3/qsort_r.3.html) sorts an
Elliott Hughes5bae5722024-07-30 12:47:33 -0400133 * array of n elements each of the given size, using the given comparator,
134 * and passing the given context argument to the comparator.
135 *
136 * Available since API level 36.
137 */
Dan Albert02ce4012024-10-25 19:13:49 +0000138
139#if __BIONIC_AVAILABILITY_GUARD(36)
Elliott Hughes5bae5722024-07-30 12:47:33 -0400140void qsort_r(void* _Nullable __array, size_t __n, size_t __size, int (* _Nonnull __comparator)(const void* _Nullable __lhs, const void* _Nullable __rhs, void* _Nullable __context), void* _Nullable __context) __INTRODUCED_IN(36);
Dan Albert02ce4012024-10-25 19:13:49 +0000141#endif /* __BIONIC_AVAILABILITY_GUARD(36) */
142
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800143
Yabin Cuia39f9392014-10-28 12:04:02 -0700144uint32_t arc4random(void);
Elliott Hughesfaa74342017-08-11 17:34:44 -0700145uint32_t arc4random_uniform(uint32_t __upper_bound);
zijunzhao5a918d92022-11-28 21:05:55 +0000146void arc4random_buf(void* _Nonnull __buf, size_t __n);
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800147
148#define RAND_MAX 0x7fffffff
Elliott Hughesa0beeea2014-06-12 11:48:04 -0700149
Elliott Hughes655e4302023-06-16 12:39:33 -0700150int rand_r(unsigned int* _Nonnull __seed_ptr);
Elliott Hughesa0beeea2014-06-12 11:48:04 -0700151
Elliott Hughes274afe82014-11-06 12:40:08 -0800152double drand48(void);
zijunzhao5a918d92022-11-28 21:05:55 +0000153double erand48(unsigned short __xsubi[_Nonnull 3]);
154long jrand48(unsigned short __xsubi[_Nonnull 3]);
Dan Albert02ce4012024-10-25 19:13:49 +0000155
156#if __BIONIC_AVAILABILITY_GUARD(23)
zijunzhao5a918d92022-11-28 21:05:55 +0000157void lcong48(unsigned short __param[_Nonnull 7]) __INTRODUCED_IN(23);
Dan Albert02ce4012024-10-25 19:13:49 +0000158#endif /* __BIONIC_AVAILABILITY_GUARD(23) */
159
Elliott Hughes274afe82014-11-06 12:40:08 -0800160long lrand48(void);
161long mrand48(void);
zijunzhao5a918d92022-11-28 21:05:55 +0000162long nrand48(unsigned short __xsubi[_Nonnull 3]);
163unsigned short* _Nonnull seed48(unsigned short __seed16v[_Nonnull 3]);
Elliott Hughesfaa74342017-08-11 17:34:44 -0700164void srand48(long __seed);
Elliott Hughes274afe82014-11-06 12:40:08 -0800165
Elliott Hughes655e4302023-06-16 12:39:33 -0700166char* _Nullable initstate(unsigned int __seed, char* _Nonnull __state, size_t __n);
167char* _Nullable setstate(char* _Nonnull __state);
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800168
Elliott Hughes49167062014-07-25 17:24:00 -0700169int getpt(void);
Elliott Hughes655e4302023-06-16 12:39:33 -0700170int posix_openpt(int __flags);
zijunzhao5a918d92022-11-28 21:05:55 +0000171char* _Nullable ptsname(int __fd);
172int ptsname_r(int __fd, char* _Nonnull __buf, size_t __n);
Elliott Hughesfaa74342017-08-11 17:34:44 -0700173int unlockpt(int __fd);
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800174
Dan Albert02ce4012024-10-25 19:13:49 +0000175
176#if __BIONIC_AVAILABILITY_GUARD(26)
zijunzhao5a918d92022-11-28 21:05:55 +0000177int getsubopt(char* _Nonnull * _Nonnull __option, char* _Nonnull const* _Nonnull __tokens, char* _Nullable * _Nonnull __value_ptr) __INTRODUCED_IN(26);
Dan Albert02ce4012024-10-25 19:13:49 +0000178#endif /* __BIONIC_AVAILABILITY_GUARD(26) */
179
Elliott Hughesdf143f82016-04-04 17:34:04 -0700180
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800181typedef struct {
Elliott Hughesfaa74342017-08-11 17:34:44 -0700182 int quot;
183 int rem;
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800184} div_t;
185
Elliott Hughesfaa74342017-08-11 17:34:44 -0700186div_t div(int __numerator, int __denominator) __attribute_const__;
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800187
188typedef struct {
Elliott Hughesfaa74342017-08-11 17:34:44 -0700189 long int quot;
190 long int rem;
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800191} ldiv_t;
192
Elliott Hughesfaa74342017-08-11 17:34:44 -0700193ldiv_t ldiv(long __numerator, long __denominator) __attribute_const__;
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800194
195typedef struct {
Elliott Hughesfaa74342017-08-11 17:34:44 -0700196 long long int quot;
197 long long int rem;
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800198} lldiv_t;
199
Elliott Hughesfaa74342017-08-11 17:34:44 -0700200lldiv_t lldiv(long long __numerator, long long __denominator) __attribute_const__;
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800201
Elliott Hughes2d0b28b2018-10-23 11:23:00 -0700202/**
Elliott Hughesbbd39aa2024-08-13 20:59:16 +0000203 * [getloadavg(3)](https://man7.org/linux/man-pages/man3/getloadavg.3.html) queries the
Elliott Hughes2d0b28b2018-10-23 11:23:00 -0700204 * number of runnable processes averaged over time. The Linux kernel supports averages
205 * over the last 1, 5, and 15 minutes.
206 *
207 * Returns the number of samples written to `__averages` (at most 3), and returns -1 on failure.
208 */
Dan Albert02ce4012024-10-25 19:13:49 +0000209
210#if __BIONIC_AVAILABILITY_GUARD(29)
zijunzhao5a918d92022-11-28 21:05:55 +0000211int getloadavg(double __averages[_Nonnull], int __n) __INTRODUCED_IN(29);
Dan Albert02ce4012024-10-25 19:13:49 +0000212#endif /* __BIONIC_AVAILABILITY_GUARD(29) */
213
Elliott Hughes2d0b28b2018-10-23 11:23:00 -0700214
Elliott Hughes692207e2014-02-28 16:23:27 -0800215/* BSD compatibility. */
Elliott Hughes655e4302023-06-16 12:39:33 -0700216const char* _Nullable getprogname(void);
217void setprogname(const char* _Nonnull __name);
Elliott Hughes692207e2014-02-28 16:23:27 -0800218
Dan Albert02ce4012024-10-25 19:13:49 +0000219
220#if __BIONIC_AVAILABILITY_GUARD(26)
Elliott Hughes2f9fe8c2024-08-13 13:42:43 +0000221int mblen(const char* _Nullable __s, size_t __n) __INTRODUCED_IN(26);
Dan Albert02ce4012024-10-25 19:13:49 +0000222#endif /* __BIONIC_AVAILABILITY_GUARD(26) */
223
Elliott Hughes2bdeff42023-06-20 14:32:58 -0700224size_t mbstowcs(wchar_t* _Nullable __dst, const char* _Nullable __src, size_t __n);
225int mbtowc(wchar_t* _Nullable __wc_ptr, const char* _Nullable __s, size_t __n);
226int wctomb(char* _Nullable __dst, wchar_t __wc);
Dan Albertcb0b1432016-09-06 16:51:00 -0700227
Elliott Hughes2bdeff42023-06-20 14:32:58 -0700228size_t wcstombs(char* _Nullable __dst, const wchar_t* _Nullable __src, size_t __n);
David 'Digit' Turnerbb5581a2010-10-09 17:56:55 +0200229
Elliott Hughes655e4302023-06-16 12:39:33 -0700230size_t __ctype_get_mb_cur_max(void);
Dan Albert224ff042014-08-14 13:56:51 -0700231#define MB_CUR_MAX __ctype_get_mb_cur_max()
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800232
George Burgess IVb97049c2017-07-24 15:05:05 -0700233#if defined(__BIONIC_INCLUDE_FORTIFY_HEADERS)
234#include <bits/fortify/stdlib.h>
235#endif
Daniel Micay3244d9f2015-04-18 13:04:19 -0400236
Elliott Hughes655e4302023-06-16 12:39:33 -0700237int abs(int __x) __attribute_const__;
238long labs(long __x) __attribute_const__;
239long long llabs(long long __x) __attribute_const__;
Ryan Prichard51a7fe82018-01-08 16:18:48 -0800240
Elliott Hughes655e4302023-06-16 12:39:33 -0700241int rand(void);
242void srand(unsigned int __seed);
243long random(void);
244void srandom(unsigned int __seed);
245int grantpt(int __fd);
Josh Gao6cd9fb02016-09-23 14:06:05 -0700246
Elliott Hughes14a55882024-08-23 13:39:13 +0000247/**
248 * [atof(3)](https://man7.org/linux/man-pages/man3/atof.3.html) converts a
249 * string to a double.
250 *
251 * Returns the double; use strtof() or strtod() if you need to detect errors.
252 */
253double atof(const char* _Nonnull __s) __attribute_pure__;
254
255/**
256 * [atoi(3)](https://man7.org/linux/man-pages/man3/atoi.3.html) converts a
257 * string to an int.
258 *
259 * Returns the int or 0 on error; use strtol() if you need to detect errors.
260 */
261int atoi(const char* _Nonnull __s) __attribute_pure__;
262
263/**
264 * [atol(3)](https://man7.org/linux/man-pages/man3/atol.3.html) converts a
265 * string to a long.
266 *
267 * Returns the long or 0 on error; use strtol() if you need to detect errors.
268 */
269long atol(const char* _Nonnull __s) __attribute_pure__;
270
271/**
272 * [atoll(3)](https://man7.org/linux/man-pages/man3/atoll.3.html) converts a
273 * string to a long long.
274 *
275 * Returns the long long or 0 on error; use strtol() if you need to detect errors.
276 */
277long long atoll(const char* _Nonnull __s) __attribute_pure__;
278
279/**
280 * [strtol(3)](https://man7.org/linux/man-pages/man3/strtol.3.html) converts a
281 * string to a long.
282 *
283 * Returns the long.
284 * `__end_ptr` is set to the last character in `__s` that was converted.
285 * errno is set to ERANGE if the result overflowed or underflowed.
286 */
287long strtol(const char* _Nonnull __s, char* _Nullable * _Nullable __end_ptr, int __base);
288
289/** Equivalent to strtol() on Android. */
290long strtol_l(const char* _Nonnull __s, char* _Nullable * _Nullable __end_ptr, int, locale_t _Nonnull __l) __RENAME(strtol);
291
292/**
293 * [strtoll(3)](https://man7.org/linux/man-pages/man3/strtoll.3.html) converts a
294 * string to a long long.
295 *
296 * Returns the long long.
297 * `__end_ptr` is set to the last character in `__s` that was converted.
298 * errno is set to ERANGE if the result overflowed or underflowed.
299 */
300long long strtoll(const char* _Nonnull __s, char* _Nullable * _Nullable __end_ptr, int __base);
301
302/** Equivalent to strtoll() on Android. */
Elliott Hughes655e4302023-06-16 12:39:33 -0700303long long strtoll_l(const char* _Nonnull __s, char* _Nullable * _Nullable __end_ptr, int __base, locale_t _Nonnull __l);
Elliott Hughes14a55882024-08-23 13:39:13 +0000304
305/**
306 * [strtoul(3)](https://man7.org/linux/man-pages/man3/strtoul.3.html) converts a
307 * string to an unsigned long.
308 *
309 * Returns the unsigned long.
310 * `__end_ptr` is set to the last character in `__s` that was converted.
311 * errno is set to ERANGE if the result overflowed or underflowed.
312 */
313unsigned long strtoul(const char* _Nonnull __s, char* _Nullable * _Nullable __end_ptr, int __base);
314
315/** Equivalent to strtoul() on Android. */
316unsigned long strtoul_l(const char* _Nonnull __s, char* _Nullable * _Nullable __end_ptr, int __base, locale_t _Nonnull __l) __RENAME(strtoul);
317
318/**
319 * [strtoull(3)](https://man7.org/linux/man-pages/man3/strtoull.3.html) converts a
320 * string to an unsigned long long.
321 *
322 * Returns the unsigned long long.
323 * `__end_ptr` is set to the last character in `__s` that was converted.
324 * errno is set to ERANGE if the result overflowed or underflowed.
325 */
326unsigned long long strtoull(const char* _Nonnull __s, char* _Nullable * _Nullable __end_ptr, int __base);
327
328/** Equivalent to strtoull() on Android. */
Elliott Hughes655e4302023-06-16 12:39:33 -0700329unsigned long long strtoull_l(const char* _Nonnull __s, char* _Nullable * _Nullable __end_ptr, int __base, locale_t _Nonnull __l);
Elliott Hughes14a55882024-08-23 13:39:13 +0000330
331/**
332 * [strtof(3)](https://man7.org/linux/man-pages/man3/strtof.3.html) converts a
333 * string to a float.
334 *
335 * Returns the float.
336 * `__end_ptr` is set to the last character in `__s` that was converted.
337 * errno is set to ERANGE if the result overflowed or underflowed.
338 */
339float strtof(const char* _Nonnull __s, char* _Nullable * _Nullable __end_ptr);
340
341/**
342 * [strtod(3)](https://man7.org/linux/man-pages/man3/strtod.3.html) converts a
343 * string to a double.
344 *
345 * Returns the double.
346 * `__end_ptr` is set to the last character in `__s` that was converted.
347 * errno is set to ERANGE if the result overflowed or underflowed.
348 */
349double strtod(const char* _Nonnull __s, char* _Nullable * _Nullable __end_ptr);
350
351/**
352 * [strtold(3)](https://man7.org/linux/man-pages/man3/strtold.3.html) converts a
353 * string to a long double.
354 *
355 * Returns the long double.
356 * `__end_ptr` is set to the last character in `__s` that was converted.
357 * errno is set to ERANGE if the result overflowed or underflowed.
358 */
359long double strtold(const char* _Nonnull __s, char* _Nullable * _Nullable __end_ptr);
360
361/** Equivalent to strtold() on Android. */
Elliott Hughes655e4302023-06-16 12:39:33 -0700362long double strtold_l(const char* _Nonnull __s, char* _Nullable * _Nullable __end_ptr, locale_t _Nonnull __l);
Josh Gao8778d642016-07-22 15:26:36 -0700363
Elliott Hughes95c6cd72019-12-20 13:26:14 -0800364#if __ANDROID_API__ >= 26
Elliott Hughes14a55882024-08-23 13:39:13 +0000365/** Equivalent to strtod() on Android. */
zijunzhao5a918d92022-11-28 21:05:55 +0000366double strtod_l(const char* _Nonnull __s, char* _Nullable * _Nullable __end_ptr, locale_t _Nonnull __l) __INTRODUCED_IN(26);
Elliott Hughes14a55882024-08-23 13:39:13 +0000367/** Equivalent to strtof() on Android. */
zijunzhao5a918d92022-11-28 21:05:55 +0000368float strtof_l(const char* _Nonnull __s, char* _Nullable * _Nullable __end_ptr, locale_t _Nonnull __l) __INTRODUCED_IN(26);
Josh Gao6cd9fb02016-09-23 14:06:05 -0700369#else
Elliott Hughes4cae5c32017-07-10 11:51:00 -0700370// Implemented as static inlines before 26.
Josh Gao6cd9fb02016-09-23 14:06:05 -0700371#endif
372
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800373__END_DECLS
374
Josh Gaob8e1b7052016-04-13 17:18:20 -0700375#include <android/legacy_stdlib_inlines.h>
376
Elliott Hughes76f89162015-01-26 13:34:58 -0800377#endif /* _STDLIB_H */