1
/* A GNU-like <stdlib.h>.
3
Copyright (C) 1995, 2001-2004, 2006-2010 Free Software Foundation, Inc.
5
This program is free software: you can redistribute it and/or modify
6
it under the terms of the GNU General Public License as published by
7
the Free Software Foundation; either version 3 of the License, or
8
(at your option) any later version.
10
This program is distributed in the hope that it will be useful,
11
but WITHOUT ANY WARRANTY; without even the implied warranty of
12
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13
GNU General Public License for more details.
15
You should have received a copy of the GNU General Public License
16
along with this program. If not, see <http://www.gnu.org/licenses/>. */
19
@PRAGMA_SYSTEM_HEADER@
22
#if defined __need_malloc_and_calloc
23
/* Special invocation convention inside glibc header files. */
25
#@INCLUDE_NEXT@ @NEXT_STDLIB_H@
28
/* Normal invocation convention. */
32
/* The include_next requires a split double-inclusion guard. */
33
#@INCLUDE_NEXT@ @NEXT_STDLIB_H@
38
/* NetBSD 5.0 mis-defines NULL. */
41
/* Solaris declares getloadavg() in <sys/loadavg.h>. */
42
#if (@GNULIB_GETLOADAVG@ || defined GNULIB_POSIXCHECK) && @HAVE_SYS_LOADAVG_H@
43
# include <sys/loadavg.h>
46
/* OSF/1 5.1 declares 'struct random_data' in <random.h>, which is included
47
from <stdlib.h> if _REENTRANT is defined. Include it always. */
52
#if !@HAVE_STRUCT_RANDOM_DATA@ || (@GNULIB_RANDOM_R@ && !@HAVE_RANDOM_R@) \
53
|| defined GNULIB_POSIXCHECK
57
#if !@HAVE_STRUCT_RANDOM_DATA@
60
int32_t *fptr; /* Front pointer. */
61
int32_t *rptr; /* Rear pointer. */
62
int32_t *state; /* Array of state values. */
63
int rand_type; /* Type of random number generator. */
64
int rand_deg; /* Degree of random number generator. */
65
int rand_sep; /* Distance between front and rear. */
66
int32_t *end_ptr; /* Pointer behind state table. */
70
#if (@GNULIB_MKSTEMP@ || @GNULIB_GETSUBOPT@ || defined GNULIB_POSIXCHECK) && ! defined __GLIBC__
71
/* On MacOS X 10.3, only <unistd.h> declares mkstemp. */
72
/* On Cygwin 1.7.1, only <unistd.h> declares getsubopt. */
73
/* But avoid namespace pollution on glibc systems. */
77
/* The definition of _GL_ARG_NONNULL is copied here. */
79
/* The definition of _GL_WARN_ON_USE is copied here. */
82
/* Some systems do not define EXIT_*, despite otherwise supporting C89. */
84
# define EXIT_SUCCESS 0
86
/* Tandem/NSK and other platforms that define EXIT_FAILURE as -1 interfere
87
with proper operation of xargs. */
89
# define EXIT_FAILURE 1
90
#elif EXIT_FAILURE != 1
92
# define EXIT_FAILURE 1
102
/* Parse a signed decimal integer.
103
Returns the value of the integer. Errors are not detected. */
104
extern long long atoll (const char *string) _GL_ARG_NONNULL ((1));
106
#elif defined GNULIB_POSIXCHECK
108
# if HAVE_RAW_DECL_ATOLL
109
_GL_WARN_ON_USE (atoll, "atoll is unportable - "
110
"use gnulib module atoll for portability");
114
#if @GNULIB_CALLOC_POSIX@
115
# if !@HAVE_CALLOC_POSIX@
117
# define calloc rpl_calloc
118
extern void * calloc (size_t nmemb, size_t size);
120
#elif defined GNULIB_POSIXCHECK
122
/* Assume calloc is always declared. */
123
_GL_WARN_ON_USE (calloc, "calloc is not POSIX compliant everywhere - "
124
"use gnulib module calloc-posix for portability");
127
#if @GNULIB_CANONICALIZE_FILE_NAME@
128
# if @REPLACE_CANONICALIZE_FILE_NAME@
129
# define canonicalize_file_name rpl_canonicalize_file_name
131
# if !@HAVE_CANONICALIZE_FILE_NAME@ || @REPLACE_CANONICALIZE_FILE_NAME@
132
extern char *canonicalize_file_name (const char *name) _GL_ARG_NONNULL ((1));
134
#elif defined GNULIB_POSIXCHECK
135
# undef canonicalize_file_name
136
# if HAVE_RAW_DECL_CANONICALIZE_FILE_NAME
137
_GL_WARN_ON_USE (canonicalize_file_name, "canonicalize_file_name is unportable - "
138
"use gnulib module canonicalize-lgpl for portability");
142
#if @GNULIB_GETLOADAVG@
143
# if !@HAVE_DECL_GETLOADAVG@
144
/* Store max(NELEM,3) load average numbers in LOADAVG[].
145
The three numbers are the load average of the last 1 minute, the last 5
146
minutes, and the last 15 minutes, respectively.
147
LOADAVG is an array of NELEM numbers. */
148
extern int getloadavg (double loadavg[], int nelem) _GL_ARG_NONNULL ((1));
150
#elif defined GNULIB_POSIXCHECK
152
# if HAVE_RAW_DECL_GETLOADAVG
153
_GL_WARN_ON_USE (getloadavg, "getloadavg is not portable - "
154
"use gnulib module getloadavg for portability");
158
#if @GNULIB_GETSUBOPT@
159
/* Assuming *OPTIONP is a comma separated list of elements of the form
160
"token" or "token=value", getsubopt parses the first of these elements.
161
If the first element refers to a "token" that is member of the given
162
NULL-terminated array of tokens:
163
- It replaces the comma with a NUL byte, updates *OPTIONP to point past
164
the first option and the comma, sets *VALUEP to the value of the
165
element (or NULL if it doesn't contain an "=" sign),
166
- It returns the index of the "token" in the given array of tokens.
167
Otherwise it returns -1, and *OPTIONP and *VALUEP are undefined.
168
For more details see the POSIX:2001 specification.
169
http://www.opengroup.org/susv3xsh/getsubopt.html */
170
# if !@HAVE_GETSUBOPT@
171
extern int getsubopt (char **optionp, char *const *tokens, char **valuep)
172
_GL_ARG_NONNULL ((1, 2, 3));
174
#elif defined GNULIB_POSIXCHECK
176
# if HAVE_RAW_DECL_GETSUBOPT
177
_GL_WARN_ON_USE (getsubopt, "getsubopt is unportable - "
178
"use gnulib module getsubopt for portability");
182
#if @GNULIB_MALLOC_POSIX@
183
# if !@HAVE_MALLOC_POSIX@
185
# define malloc rpl_malloc
186
extern void * malloc (size_t size);
188
#elif defined GNULIB_POSIXCHECK
190
/* Assume malloc is always declared. */
191
_GL_WARN_ON_USE (malloc, "malloc is not POSIX compliant everywhere - "
192
"use gnulib module malloc-posix for portability");
197
/* Create a unique temporary directory from TEMPLATE.
198
The last six characters of TEMPLATE must be "XXXXXX";
199
they are replaced with a string that makes the directory name unique.
200
Returns TEMPLATE, or a null pointer if it cannot get a unique name.
201
The directory is created mode 700. */
202
extern char * mkdtemp (char * /*template*/) _GL_ARG_NONNULL ((1));
204
#elif defined GNULIB_POSIXCHECK
206
# if HAVE_RAW_DECL_MKDTEMP
207
_GL_WARN_ON_USE (mkdtemp, "mkdtemp is unportable - "
208
"use gnulib module mkdtemp for portability");
212
#if @GNULIB_MKOSTEMP@
213
# if !@HAVE_MKOSTEMP@
214
/* Create a unique temporary file from TEMPLATE.
215
The last six characters of TEMPLATE must be "XXXXXX";
216
they are replaced with a string that makes the file name unique.
217
The flags are a bitmask, possibly including O_CLOEXEC (defined in <fcntl.h>)
218
and O_TEXT, O_BINARY (defined in "binary-io.h").
219
The file is then created, with the specified flags, ensuring it didn't exist
221
The file is created read-write (mask at least 0600 & ~umask), but it may be
222
world-readable and world-writable (mask 0666 & ~umask), depending on the
224
Returns the open file descriptor if successful, otherwise -1 and errno
226
extern int mkostemp (char * /*template*/, int /*flags*/) _GL_ARG_NONNULL ((1));
228
#elif defined GNULIB_POSIXCHECK
230
# if HAVE_RAW_DECL_MKOSTEMP
231
_GL_WARN_ON_USE (mkostemp, "mkostemp is unportable - "
232
"use gnulib module mkostemp for portability");
236
#if @GNULIB_MKOSTEMPS@
237
# if !@HAVE_MKOSTEMPS@
238
/* Create a unique temporary file from TEMPLATE.
239
The last six characters of TEMPLATE before a suffix of length
240
SUFFIXLEN must be "XXXXXX";
241
they are replaced with a string that makes the file name unique.
242
The flags are a bitmask, possibly including O_CLOEXEC (defined in <fcntl.h>)
243
and O_TEXT, O_BINARY (defined in "binary-io.h").
244
The file is then created, with the specified flags, ensuring it didn't exist
246
The file is created read-write (mask at least 0600 & ~umask), but it may be
247
world-readable and world-writable (mask 0666 & ~umask), depending on the
249
Returns the open file descriptor if successful, otherwise -1 and errno
251
extern int mkostemps (char * /*template*/, int /*suffixlen*/, int /*flags*/)
252
_GL_ARG_NONNULL ((1));
254
#elif defined GNULIB_POSIXCHECK
256
# if HAVE_RAW_DECL_MKOSTEMPS
257
_GL_WARN_ON_USE (mkostemps, "mkostemps is unportable - "
258
"use gnulib module mkostemps for portability");
263
# if @REPLACE_MKSTEMP@
264
/* Create a unique temporary file from TEMPLATE.
265
The last six characters of TEMPLATE must be "XXXXXX";
266
they are replaced with a string that makes the file name unique.
267
The file is then created, ensuring it didn't exist before.
268
The file is created read-write (mask at least 0600 & ~umask), but it may be
269
world-readable and world-writable (mask 0666 & ~umask), depending on the
271
Returns the open file descriptor if successful, otherwise -1 and errno
273
# define mkstemp rpl_mkstemp
274
extern int mkstemp (char * /*template*/) _GL_ARG_NONNULL ((1));
276
#elif defined GNULIB_POSIXCHECK
278
# if HAVE_RAW_DECL_MKSTEMP
279
_GL_WARN_ON_USE (mkstemp, "mkstemp is unportable - "
280
"use gnulib module mkstemp for portability");
284
#if @GNULIB_MKSTEMPS@
285
# if !@HAVE_MKSTEMPS@
286
/* Create a unique temporary file from TEMPLATE.
287
The last six characters of TEMPLATE prior to a suffix of length
288
SUFFIXLEN must be "XXXXXX";
289
they are replaced with a string that makes the file name unique.
290
The file is then created, ensuring it didn't exist before.
291
The file is created read-write (mask at least 0600 & ~umask), but it may be
292
world-readable and world-writable (mask 0666 & ~umask), depending on the
294
Returns the open file descriptor if successful, otherwise -1 and errno
296
extern int mkstemps (char * /*template*/, int /*suffixlen*/)
297
_GL_ARG_NONNULL ((1));
299
#elif defined GNULIB_POSIXCHECK
301
# if HAVE_RAW_DECL_MKSTEMPS
302
_GL_WARN_ON_USE (mkstemps, "mkstemps is unportable - "
303
"use gnulib module mkstemps for portability");
308
# if @REPLACE_PUTENV@
310
# define putenv rpl_putenv
311
extern int putenv (char *string) _GL_ARG_NONNULL ((1));
315
#if @GNULIB_RANDOM_R@
316
# if !@HAVE_RANDOM_R@
319
# define RAND_MAX 2147483647
322
int srandom_r (unsigned int seed, struct random_data *rand_state)
323
_GL_ARG_NONNULL ((2));
324
int initstate_r (unsigned int seed, char *buf, size_t buf_size,
325
struct random_data *rand_state)
326
_GL_ARG_NONNULL ((2, 4));
327
int setstate_r (char *arg_state, struct random_data *rand_state)
328
_GL_ARG_NONNULL ((1, 2));
329
int random_r (struct random_data *buf, int32_t *result)
330
_GL_ARG_NONNULL ((1, 2));
332
#elif defined GNULIB_POSIXCHECK
334
# if HAVE_RAW_DECL_RANDOM_R
335
_GL_WARN_ON_USE (random_r, "random_r is unportable - "
336
"use gnulib module random_r for portability");
339
# if HAVE_RAW_DECL_INITSTATE_R
340
_GL_WARN_ON_USE (initstate_r, "initstate_r is unportable - "
341
"use gnulib module random_r for portability");
344
# if HAVE_RAW_DECL_SRANDOM_R
345
_GL_WARN_ON_USE (srandom_r, "srandom_r is unportable - "
346
"use gnulib module random_r for portability");
349
# if HAVE_RAW_DECL_SETSTATE_R
350
_GL_WARN_ON_USE (setstate_r, "setstate_r is unportable - "
351
"use gnulib module random_r for portability");
355
#if @GNULIB_REALLOC_POSIX@
356
# if !@HAVE_REALLOC_POSIX@
358
# define realloc rpl_realloc
359
extern void * realloc (void *ptr, size_t size);
361
#elif defined GNULIB_POSIXCHECK
363
/* Assume realloc is always declared. */
364
_GL_WARN_ON_USE (realloc, "realloc is not POSIX compliant everywhere - "
365
"use gnulib module realloc-posix for portability");
368
#if @GNULIB_REALPATH@
369
# if @REPLACE_REALPATH@
370
# define realpath rpl_realpath
372
# if !@HAVE_REALPATH@ || @REPLACE_REALPATH@
373
extern char *realpath (const char *name, char *resolved) _GL_ARG_NONNULL ((1));
375
#elif defined GNULIB_POSIXCHECK
377
# if HAVE_RAW_DECL_REALPATH
378
_GL_WARN_ON_USE (realpath, "realpath is unportable - use gnulib module "
379
"canonicalize or canonicalize-lgpl for portability");
385
/* Test a user response to a question.
386
Return 1 if it is affirmative, 0 if it is negative, or -1 if not clear. */
387
extern int rpmatch (const char *response) _GL_ARG_NONNULL ((1));
389
#elif defined GNULIB_POSIXCHECK
391
# if HAVE_RAW_DECL_RPMATCH
392
_GL_WARN_ON_USE (rpmatch, "rpmatch is unportable - "
393
"use gnulib module rpmatch for portability");
398
# if @REPLACE_SETENV@
400
# define setenv rpl_setenv
402
# if !@HAVE_SETENV@ || @REPLACE_SETENV@
403
/* Set NAME to VALUE in the environment.
404
If REPLACE is nonzero, overwrite an existing value. */
405
extern int setenv (const char *name, const char *value, int replace)
406
_GL_ARG_NONNULL ((1));
408
#elif defined GNULIB_POSIXCHECK
410
# if HAVE_RAW_DECL_SETENV
411
_GL_WARN_ON_USE (setenv, "setenv is unportable - "
412
"use gnulib module setenv for portability");
417
# if @REPLACE_STRTOD@
418
# define strtod rpl_strtod
420
# if !@HAVE_STRTOD@ || @REPLACE_STRTOD@
421
/* Parse a double from STRING, updating ENDP if appropriate. */
422
extern double strtod (const char *str, char **endp) _GL_ARG_NONNULL ((1));
424
#elif defined GNULIB_POSIXCHECK
426
# if HAVE_RAW_DECL_STRTOD
427
_GL_WARN_ON_USE (strtod, "strtod is unportable - "
428
"use gnulib module strtod for portability");
434
/* Parse a signed integer whose textual representation starts at STRING.
435
The integer is expected to be in base BASE (2 <= BASE <= 36); if BASE == 0,
436
it may be decimal or octal (with prefix "0") or hexadecimal (with prefix
438
If ENDPTR is not NULL, the address of the first byte after the integer is
440
Upon overflow, the return value is LLONG_MAX or LLONG_MIN, and errno is set
442
extern long long strtoll (const char *string, char **endptr, int base)
443
_GL_ARG_NONNULL ((1));
445
#elif defined GNULIB_POSIXCHECK
447
# if HAVE_RAW_DECL_STRTOLL
448
_GL_WARN_ON_USE (strtoll, "strtoll is unportable - "
449
"use gnulib module strtoll for portability");
453
#if @GNULIB_STRTOULL@
454
# if !@HAVE_STRTOULL@
455
/* Parse an unsigned integer whose textual representation starts at STRING.
456
The integer is expected to be in base BASE (2 <= BASE <= 36); if BASE == 0,
457
it may be decimal or octal (with prefix "0") or hexadecimal (with prefix
459
If ENDPTR is not NULL, the address of the first byte after the integer is
461
Upon overflow, the return value is ULLONG_MAX, and errno is set to
463
extern unsigned long long strtoull (const char *string, char **endptr, int base)
464
_GL_ARG_NONNULL ((1));
466
#elif defined GNULIB_POSIXCHECK
468
# if HAVE_RAW_DECL_STRTOULL
469
_GL_WARN_ON_USE (strtoull, "strtoull is unportable - "
470
"use gnulib module strtoull for portability");
474
#if @GNULIB_UNSETENV@
475
# if @REPLACE_UNSETENV@
477
# define unsetenv rpl_unsetenv
479
# if !@HAVE_UNSETENV@ || @REPLACE_UNSETENV@
480
/* Remove the variable NAME from the environment. */
481
extern int unsetenv (const char *name) _GL_ARG_NONNULL ((1));
483
#elif defined GNULIB_POSIXCHECK
485
# if HAVE_RAW_DECL_UNSETENV
486
_GL_WARN_ON_USE (unsetenv, "unsetenv is unportable - "
487
"use gnulib module unsetenv for portability");
495
#endif /* _GL_STDLIB_H */
496
#endif /* _GL_STDLIB_H */