New module 'pclose'.
[gnulib.git] / lib / stdio.in.h
1 /* A GNU-like <stdio.h>.
2
3    Copyright (C) 2004, 2007-2011 Free Software Foundation, Inc.
4
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 2, or (at your option)
8    any later version.
9
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.
14
15    You should have received a copy of the GNU General Public License
16    along with this program; if not, write to the Free Software Foundation,
17    Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.  */
18
19 #if __GNUC__ >= 3
20 @PRAGMA_SYSTEM_HEADER@
21 #endif
22 @PRAGMA_COLUMNS@
23
24 #if defined __need_FILE || defined __need___FILE || defined _GL_ALREADY_INCLUDING_STDIO_H
25 /* Special invocation convention:
26    - Inside glibc header files.
27    - On OSF/1 5.1 we have a sequence of nested includes
28      <stdio.h> -> <getopt.h> -> <ctype.h> -> <sys/localedef.h> ->
29      <sys/lc_core.h> -> <nl_types.h> -> <mesg.h> -> <stdio.h>.
30      In this situation, the functions are not yet declared, therefore we cannot
31      provide the C++ aliases.  */
32
33 #@INCLUDE_NEXT@ @NEXT_STDIO_H@
34
35 #else
36 /* Normal invocation convention.  */
37
38 #ifndef _@GUARD_PREFIX@_STDIO_H
39
40 #define _GL_ALREADY_INCLUDING_STDIO_H
41
42 /* The include_next requires a split double-inclusion guard.  */
43 #@INCLUDE_NEXT@ @NEXT_STDIO_H@
44
45 #undef _GL_ALREADY_INCLUDING_STDIO_H
46
47 #ifndef _@GUARD_PREFIX@_STDIO_H
48 #define _@GUARD_PREFIX@_STDIO_H
49
50 /* Get va_list.  Needed on many systems, including glibc 2.8.  */
51 #include <stdarg.h>
52
53 #include <stddef.h>
54
55 /* Get off_t and ssize_t.  Needed on many systems, including glibc 2.8
56    and eglibc 2.11.2.  */
57 #include <sys/types.h>
58
59 /* The __attribute__ feature is available in gcc versions 2.5 and later.
60    The __-protected variants of the attributes 'format' and 'printf' are
61    accepted by gcc versions 2.6.4 (effectively 2.7) and later.
62    We enable _GL_ATTRIBUTE_FORMAT only if these are supported too, because
63    gnulib and libintl do '#define printf __printf__' when they override
64    the 'printf' function.  */
65 #if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 7)
66 # define _GL_ATTRIBUTE_FORMAT(spec) __attribute__ ((__format__ spec))
67 #else
68 # define _GL_ATTRIBUTE_FORMAT(spec) /* empty */
69 #endif
70
71 /* _GL_ATTRIBUTE_FORMAT_PRINTF
72    indicates to GCC that the function takes a format string and arguments,
73    where the format string directives are the ones standardized by ISO C99
74    and POSIX.  */
75 #if __GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 4)
76 # define _GL_ATTRIBUTE_FORMAT_PRINTF(formatstring_parameter, first_argument) \
77    _GL_ATTRIBUTE_FORMAT ((__gnu_printf__, formatstring_parameter, first_argument))
78 #else
79 # define _GL_ATTRIBUTE_FORMAT_PRINTF(formatstring_parameter, first_argument) \
80    _GL_ATTRIBUTE_FORMAT ((__printf__, formatstring_parameter, first_argument))
81 #endif
82
83 /* _GL_ATTRIBUTE_FORMAT_PRINTF_SYSTEM is like _GL_ATTRIBUTE_FORMAT_PRINTF,
84    except that it indicates to GCC that the supported format string directives
85    are the ones of the system printf(), rather than the ones standardized by
86    ISO C99 and POSIX.  */
87 #define _GL_ATTRIBUTE_FORMAT_PRINTF_SYSTEM(formatstring_parameter, first_argument) \
88   _GL_ATTRIBUTE_FORMAT ((__printf__, formatstring_parameter, first_argument))
89
90 /* _GL_ATTRIBUTE_FORMAT_SCANF
91    indicates to GCC that the function takes a format string and arguments,
92    where the format string directives are the ones standardized by ISO C99
93    and POSIX.  */
94 #if __GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 4)
95 # define _GL_ATTRIBUTE_FORMAT_SCANF(formatstring_parameter, first_argument) \
96    _GL_ATTRIBUTE_FORMAT ((__gnu_scanf__, formatstring_parameter, first_argument))
97 #else
98 # define _GL_ATTRIBUTE_FORMAT_SCANF(formatstring_parameter, first_argument) \
99    _GL_ATTRIBUTE_FORMAT ((__scanf__, formatstring_parameter, first_argument))
100 #endif
101
102 /* _GL_ATTRIBUTE_FORMAT_SCANF_SYSTEM is like _GL_ATTRIBUTE_FORMAT_SCANF,
103    except that it indicates to GCC that the supported format string directives
104    are the ones of the system scanf(), rather than the ones standardized by
105    ISO C99 and POSIX.  */
106 #define _GL_ATTRIBUTE_FORMAT_SCANF_SYSTEM(formatstring_parameter, first_argument) \
107   _GL_ATTRIBUTE_FORMAT ((__scanf__, formatstring_parameter, first_argument))
108
109 /* Solaris 10 declares renameat in <unistd.h>, not in <stdio.h>.  */
110 /* But in any case avoid namespace pollution on glibc systems.  */
111 #if (@GNULIB_RENAMEAT@ || defined GNULIB_POSIXCHECK) && defined __sun \
112     && ! defined __GLIBC__
113 # include <unistd.h>
114 #endif
115
116
117 /* The definitions of _GL_FUNCDECL_RPL etc. are copied here.  */
118
119 /* The definition of _GL_ARG_NONNULL is copied here.  */
120
121 /* The definition of _GL_WARN_ON_USE is copied here.  */
122
123 /* Macros for stringification.  */
124 #define _GL_STDIO_STRINGIZE(token) #token
125 #define _GL_STDIO_MACROEXPAND_AND_STRINGIZE(token) _GL_STDIO_STRINGIZE(token)
126
127
128 #if @GNULIB_DPRINTF@
129 # if @REPLACE_DPRINTF@
130 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
131 #   define dprintf rpl_dprintf
132 #  endif
133 _GL_FUNCDECL_RPL (dprintf, int, (int fd, const char *format, ...)
134                                 _GL_ATTRIBUTE_FORMAT_PRINTF (2, 3)
135                                 _GL_ARG_NONNULL ((2)));
136 _GL_CXXALIAS_RPL (dprintf, int, (int fd, const char *format, ...));
137 # else
138 #  if !@HAVE_DPRINTF@
139 _GL_FUNCDECL_SYS (dprintf, int, (int fd, const char *format, ...)
140                                 _GL_ATTRIBUTE_FORMAT_PRINTF (2, 3)
141                                 _GL_ARG_NONNULL ((2)));
142 #  endif
143 _GL_CXXALIAS_SYS (dprintf, int, (int fd, const char *format, ...));
144 # endif
145 _GL_CXXALIASWARN (dprintf);
146 #elif defined GNULIB_POSIXCHECK
147 # undef dprintf
148 # if HAVE_RAW_DECL_DPRINTF
149 _GL_WARN_ON_USE (dprintf, "dprintf is unportable - "
150                  "use gnulib module dprintf for portability");
151 # endif
152 #endif
153
154 #if @GNULIB_FCLOSE@
155 /* Close STREAM and its underlying file descriptor.  */
156 # if @REPLACE_FCLOSE@
157 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
158 #   define fclose rpl_fclose
159 #  endif
160 _GL_FUNCDECL_RPL (fclose, int, (FILE *stream) _GL_ARG_NONNULL ((1)));
161 _GL_CXXALIAS_RPL (fclose, int, (FILE *stream));
162 # else
163 _GL_CXXALIAS_SYS (fclose, int, (FILE *stream));
164 # endif
165 _GL_CXXALIASWARN (fclose);
166 #elif defined GNULIB_POSIXCHECK
167 # undef fclose
168 /* Assume fclose is always declared.  */
169 _GL_WARN_ON_USE (fclose, "fclose is not always POSIX compliant - "
170                  "use gnulib module fclose for portable POSIX compliance");
171 #endif
172
173 #if @GNULIB_FFLUSH@
174 /* Flush all pending data on STREAM according to POSIX rules.  Both
175    output and seekable input streams are supported.
176    Note! LOSS OF DATA can occur if fflush is applied on an input stream
177    that is _not_seekable_ or on an update stream that is _not_seekable_
178    and in which the most recent operation was input.  Seekability can
179    be tested with lseek(fileno(fp),0,SEEK_CUR).  */
180 # if @REPLACE_FFLUSH@
181 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
182 #   define fflush rpl_fflush
183 #  endif
184 _GL_FUNCDECL_RPL (fflush, int, (FILE *gl_stream));
185 _GL_CXXALIAS_RPL (fflush, int, (FILE *gl_stream));
186 # else
187 _GL_CXXALIAS_SYS (fflush, int, (FILE *gl_stream));
188 # endif
189 _GL_CXXALIASWARN (fflush);
190 #elif defined GNULIB_POSIXCHECK
191 # undef fflush
192 /* Assume fflush is always declared.  */
193 _GL_WARN_ON_USE (fflush, "fflush is not always POSIX compliant - "
194                  "use gnulib module fflush for portable POSIX compliance");
195 #endif
196
197 #if @GNULIB_FGETC@
198 # if @REPLACE_STDIO_READ_FUNCS@ && @GNULIB_STDIO_H_NONBLOCKING@
199 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
200 #   undef fgetc
201 #   define fgetc rpl_fgetc
202 #  endif
203 _GL_FUNCDECL_RPL (fgetc, int, (FILE *stream) _GL_ARG_NONNULL ((1)));
204 _GL_CXXALIAS_RPL (fgetc, int, (FILE *stream));
205 # else
206 _GL_CXXALIAS_SYS (fgetc, int, (FILE *stream));
207 # endif
208 _GL_CXXALIASWARN (fgetc);
209 #endif
210
211 #if @GNULIB_FGETS@
212 # if @REPLACE_STDIO_READ_FUNCS@ && @GNULIB_STDIO_H_NONBLOCKING@
213 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
214 #   undef fgets
215 #   define fgets rpl_fgets
216 #  endif
217 _GL_FUNCDECL_RPL (fgets, char *, (char *s, int n, FILE *stream)
218                                  _GL_ARG_NONNULL ((1, 3)));
219 _GL_CXXALIAS_RPL (fgets, char *, (char *s, int n, FILE *stream));
220 # else
221 _GL_CXXALIAS_SYS (fgets, char *, (char *s, int n, FILE *stream));
222 # endif
223 _GL_CXXALIASWARN (fgets);
224 #endif
225
226 #if @GNULIB_FOPEN@
227 # if @REPLACE_FOPEN@
228 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
229 #   undef fopen
230 #   define fopen rpl_fopen
231 #  endif
232 _GL_FUNCDECL_RPL (fopen, FILE *, (const char *filename, const char *mode)
233                                  _GL_ARG_NONNULL ((1, 2)));
234 _GL_CXXALIAS_RPL (fopen, FILE *, (const char *filename, const char *mode));
235 # else
236 _GL_CXXALIAS_SYS (fopen, FILE *, (const char *filename, const char *mode));
237 # endif
238 _GL_CXXALIASWARN (fopen);
239 #elif defined GNULIB_POSIXCHECK
240 # undef fopen
241 /* Assume fopen is always declared.  */
242 _GL_WARN_ON_USE (fopen, "fopen on Win32 platforms is not POSIX compatible - "
243                  "use gnulib module fopen for portability");
244 #endif
245
246 #if @GNULIB_FPRINTF_POSIX@ || @GNULIB_FPRINTF@
247 # if (@GNULIB_FPRINTF_POSIX@ && @REPLACE_FPRINTF@) \
248      || (@GNULIB_FPRINTF@ && @REPLACE_STDIO_WRITE_FUNCS@ && (@GNULIB_STDIO_H_NONBLOCKING@ || @GNULIB_STDIO_H_SIGPIPE@))
249 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
250 #   define fprintf rpl_fprintf
251 #  endif
252 #  define GNULIB_overrides_fprintf 1
253 #  if @GNULIB_FPRINTF_POSIX@ || @GNULIB_VFPRINTF_POSIX@
254 _GL_FUNCDECL_RPL (fprintf, int, (FILE *fp, const char *format, ...)
255                                 _GL_ATTRIBUTE_FORMAT_PRINTF (2, 3)
256                                 _GL_ARG_NONNULL ((1, 2)));
257 #  else
258 _GL_FUNCDECL_RPL (fprintf, int, (FILE *fp, const char *format, ...)
259                                 _GL_ATTRIBUTE_FORMAT_PRINTF_SYSTEM (2, 3)
260                                 _GL_ARG_NONNULL ((1, 2)));
261 #  endif
262 _GL_CXXALIAS_RPL (fprintf, int, (FILE *fp, const char *format, ...));
263 # else
264 _GL_CXXALIAS_SYS (fprintf, int, (FILE *fp, const char *format, ...));
265 # endif
266 _GL_CXXALIASWARN (fprintf);
267 #endif
268 #if !@GNULIB_FPRINTF_POSIX@ && defined GNULIB_POSIXCHECK
269 # if !GNULIB_overrides_fprintf
270 #  undef fprintf
271 # endif
272 /* Assume fprintf is always declared.  */
273 _GL_WARN_ON_USE (fprintf, "fprintf is not always POSIX compliant - "
274                  "use gnulib module fprintf-posix for portable "
275                  "POSIX compliance");
276 #endif
277
278 #if @GNULIB_FPURGE@
279 /* Discard all pending buffered I/O data on STREAM.
280    STREAM must not be wide-character oriented.
281    When discarding pending output, the file position is set back to where it
282    was before the write calls.  When discarding pending input, the file
283    position is advanced to match the end of the previously read input.
284    Return 0 if successful.  Upon error, return -1 and set errno.  */
285 # if @REPLACE_FPURGE@
286 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
287 #   define fpurge rpl_fpurge
288 #  endif
289 _GL_FUNCDECL_RPL (fpurge, int, (FILE *gl_stream) _GL_ARG_NONNULL ((1)));
290 _GL_CXXALIAS_RPL (fpurge, int, (FILE *gl_stream));
291 # else
292 #  if !@HAVE_DECL_FPURGE@
293 _GL_FUNCDECL_SYS (fpurge, int, (FILE *gl_stream) _GL_ARG_NONNULL ((1)));
294 #  endif
295 _GL_CXXALIAS_SYS (fpurge, int, (FILE *gl_stream));
296 # endif
297 _GL_CXXALIASWARN (fpurge);
298 #elif defined GNULIB_POSIXCHECK
299 # undef fpurge
300 # if HAVE_RAW_DECL_FPURGE
301 _GL_WARN_ON_USE (fpurge, "fpurge is not always present - "
302                  "use gnulib module fpurge for portability");
303 # endif
304 #endif
305
306 #if @GNULIB_FPUTC@
307 # if @REPLACE_STDIO_WRITE_FUNCS@ && (@GNULIB_STDIO_H_NONBLOCKING@ || @GNULIB_STDIO_H_SIGPIPE@)
308 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
309 #   undef fputc
310 #   define fputc rpl_fputc
311 #  endif
312 _GL_FUNCDECL_RPL (fputc, int, (int c, FILE *stream) _GL_ARG_NONNULL ((2)));
313 _GL_CXXALIAS_RPL (fputc, int, (int c, FILE *stream));
314 # else
315 _GL_CXXALIAS_SYS (fputc, int, (int c, FILE *stream));
316 # endif
317 _GL_CXXALIASWARN (fputc);
318 #endif
319
320 #if @GNULIB_FPUTS@
321 # if @REPLACE_STDIO_WRITE_FUNCS@ && (@GNULIB_STDIO_H_NONBLOCKING@ || @GNULIB_STDIO_H_SIGPIPE@)
322 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
323 #   undef fputs
324 #   define fputs rpl_fputs
325 #  endif
326 _GL_FUNCDECL_RPL (fputs, int, (const char *string, FILE *stream)
327                               _GL_ARG_NONNULL ((1, 2)));
328 _GL_CXXALIAS_RPL (fputs, int, (const char *string, FILE *stream));
329 # else
330 _GL_CXXALIAS_SYS (fputs, int, (const char *string, FILE *stream));
331 # endif
332 _GL_CXXALIASWARN (fputs);
333 #endif
334
335 #if @GNULIB_FREAD@
336 # if @REPLACE_STDIO_READ_FUNCS@ && @GNULIB_STDIO_H_NONBLOCKING@
337 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
338 #   undef fread
339 #   define fread rpl_fread
340 #  endif
341 _GL_FUNCDECL_RPL (fread, size_t, (void *ptr, size_t s, size_t n, FILE *stream)
342                                  _GL_ARG_NONNULL ((4)));
343 _GL_CXXALIAS_RPL (fread, size_t, (void *ptr, size_t s, size_t n, FILE *stream));
344 # else
345 _GL_CXXALIAS_SYS (fread, size_t, (void *ptr, size_t s, size_t n, FILE *stream));
346 # endif
347 _GL_CXXALIASWARN (fread);
348 #endif
349
350 #if @GNULIB_FREOPEN@
351 # if @REPLACE_FREOPEN@
352 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
353 #   undef freopen
354 #   define freopen rpl_freopen
355 #  endif
356 _GL_FUNCDECL_RPL (freopen, FILE *,
357                   (const char *filename, const char *mode, FILE *stream)
358                   _GL_ARG_NONNULL ((2, 3)));
359 _GL_CXXALIAS_RPL (freopen, FILE *,
360                   (const char *filename, const char *mode, FILE *stream));
361 # else
362 _GL_CXXALIAS_SYS (freopen, FILE *,
363                   (const char *filename, const char *mode, FILE *stream));
364 # endif
365 _GL_CXXALIASWARN (freopen);
366 #elif defined GNULIB_POSIXCHECK
367 # undef freopen
368 /* Assume freopen is always declared.  */
369 _GL_WARN_ON_USE (freopen,
370                  "freopen on Win32 platforms is not POSIX compatible - "
371                  "use gnulib module freopen for portability");
372 #endif
373
374 #if @GNULIB_FSCANF@
375 # if @REPLACE_STDIO_READ_FUNCS@ && @GNULIB_STDIO_H_NONBLOCKING@
376 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
377 #   undef fscanf
378 #   define fscanf rpl_fscanf
379 #  endif
380 _GL_FUNCDECL_RPL (fscanf, int, (FILE *stream, const char *format, ...)
381                                _GL_ATTRIBUTE_FORMAT_SCANF_SYSTEM (2, 3)
382                                _GL_ARG_NONNULL ((1, 2)));
383 _GL_CXXALIAS_RPL (fscanf, int, (FILE *stream, const char *format, ...));
384 # else
385 _GL_CXXALIAS_SYS (fscanf, int, (FILE *stream, const char *format, ...));
386 # endif
387 _GL_CXXALIASWARN (fscanf);
388 #endif
389
390
391 /* Set up the following warnings, based on which modules are in use.
392    GNU Coding Standards discourage the use of fseek, since it imposes
393    an arbitrary limitation on some 32-bit hosts.  Remember that the
394    fseek module depends on the fseeko module, so we only have three
395    cases to consider:
396
397    1. The developer is not using either module.  Issue a warning under
398    GNULIB_POSIXCHECK for both functions, to remind them that both
399    functions have bugs on some systems.  _GL_NO_LARGE_FILES has no
400    impact on this warning.
401
402    2. The developer is using both modules.  They may be unaware of the
403    arbitrary limitations of fseek, so issue a warning under
404    GNULIB_POSIXCHECK.  On the other hand, they may be using both
405    modules intentionally, so the developer can define
406    _GL_NO_LARGE_FILES in the compilation units where the use of fseek
407    is safe, to silence the warning.
408
409    3. The developer is using the fseeko module, but not fseek.  Gnulib
410    guarantees that fseek will still work around platform bugs in that
411    case, but we presume that the developer is aware of the pitfalls of
412    fseek and was trying to avoid it, so issue a warning even when
413    GNULIB_POSIXCHECK is undefined.  Again, _GL_NO_LARGE_FILES can be
414    defined to silence the warning in particular compilation units.
415    In C++ compilations with GNULIB_NAMESPACE, in order to avoid that
416    fseek gets defined as a macro, it is recommended that the developer
417    uses the fseek module, even if he is not calling the fseek function.
418
419    Most gnulib clients that perform stream operations should fall into
420    category 3.  */
421
422 #if @GNULIB_FSEEK@
423 # if defined GNULIB_POSIXCHECK && !defined _GL_NO_LARGE_FILES
424 #  define _GL_FSEEK_WARN /* Category 2, above.  */
425 #  undef fseek
426 # endif
427 # if @REPLACE_FSEEK@
428 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
429 #   undef fseek
430 #   define fseek rpl_fseek
431 #  endif
432 _GL_FUNCDECL_RPL (fseek, int, (FILE *fp, long offset, int whence)
433                               _GL_ARG_NONNULL ((1)));
434 _GL_CXXALIAS_RPL (fseek, int, (FILE *fp, long offset, int whence));
435 # else
436 _GL_CXXALIAS_SYS (fseek, int, (FILE *fp, long offset, int whence));
437 # endif
438 _GL_CXXALIASWARN (fseek);
439 #endif
440
441 #if @GNULIB_FSEEKO@
442 # if !@GNULIB_FSEEK@ && !defined _GL_NO_LARGE_FILES
443 #  define _GL_FSEEK_WARN /* Category 3, above.  */
444 #  undef fseek
445 # endif
446 # if @REPLACE_FSEEKO@
447 /* Provide an fseeko function that is aware of a preceding fflush(), and which
448    detects pipes.  */
449 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
450 #   undef fseeko
451 #   define fseeko rpl_fseeko
452 #  endif
453 _GL_FUNCDECL_RPL (fseeko, int, (FILE *fp, off_t offset, int whence)
454                                _GL_ARG_NONNULL ((1)));
455 _GL_CXXALIAS_RPL (fseeko, int, (FILE *fp, off_t offset, int whence));
456 # else
457 #  if ! @HAVE_DECL_FSEEKO@
458 _GL_FUNCDECL_SYS (fseeko, int, (FILE *fp, off_t offset, int whence)
459                                _GL_ARG_NONNULL ((1)));
460 #  endif
461 _GL_CXXALIAS_SYS (fseeko, int, (FILE *fp, off_t offset, int whence));
462 # endif
463 _GL_CXXALIASWARN (fseeko);
464 #elif defined GNULIB_POSIXCHECK
465 # define _GL_FSEEK_WARN /* Category 1, above.  */
466 # undef fseek
467 # undef fseeko
468 # if HAVE_RAW_DECL_FSEEKO
469 _GL_WARN_ON_USE (fseeko, "fseeko is unportable - "
470                  "use gnulib module fseeko for portability");
471 # endif
472 #endif
473
474 #ifdef _GL_FSEEK_WARN
475 # undef _GL_FSEEK_WARN
476 /* Here, either fseek is undefined (but C89 guarantees that it is
477    declared), or it is defined as rpl_fseek (declared above).  */
478 _GL_WARN_ON_USE (fseek, "fseek cannot handle files larger than 4 GB "
479                  "on 32-bit platforms - "
480                  "use fseeko function for handling of large files");
481 #endif
482
483
484 /* ftell, ftello.  See the comments on fseek/fseeko.  */
485
486 #if @GNULIB_FTELL@
487 # if defined GNULIB_POSIXCHECK && !defined _GL_NO_LARGE_FILES
488 #  define _GL_FTELL_WARN /* Category 2, above.  */
489 #  undef ftell
490 # endif
491 # if @REPLACE_FTELL@
492 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
493 #   undef ftell
494 #   define ftell rpl_ftell
495 #  endif
496 _GL_FUNCDECL_RPL (ftell, long, (FILE *fp) _GL_ARG_NONNULL ((1)));
497 _GL_CXXALIAS_RPL (ftell, long, (FILE *fp));
498 # else
499 _GL_CXXALIAS_SYS (ftell, long, (FILE *fp));
500 # endif
501 _GL_CXXALIASWARN (ftell);
502 #endif
503
504 #if @GNULIB_FTELLO@
505 # if !@GNULIB_FTELL@ && !defined _GL_NO_LARGE_FILES
506 #  define _GL_FTELL_WARN /* Category 3, above.  */
507 #  undef ftell
508 # endif
509 # if @REPLACE_FTELLO@
510 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
511 #   undef ftello
512 #   define ftello rpl_ftello
513 #  endif
514 _GL_FUNCDECL_RPL (ftello, off_t, (FILE *fp) _GL_ARG_NONNULL ((1)));
515 _GL_CXXALIAS_RPL (ftello, off_t, (FILE *fp));
516 # else
517 #  if ! @HAVE_DECL_FTELLO@
518 _GL_FUNCDECL_SYS (ftello, off_t, (FILE *fp) _GL_ARG_NONNULL ((1)));
519 #  endif
520 _GL_CXXALIAS_SYS (ftello, off_t, (FILE *fp));
521 # endif
522 _GL_CXXALIASWARN (ftello);
523 #elif defined GNULIB_POSIXCHECK
524 # define _GL_FTELL_WARN /* Category 1, above.  */
525 # undef ftell
526 # undef ftello
527 # if HAVE_RAW_DECL_FTELLO
528 _GL_WARN_ON_USE (ftello, "ftello is unportable - "
529                  "use gnulib module ftello for portability");
530 # endif
531 #endif
532
533 #ifdef _GL_FTELL_WARN
534 # undef _GL_FTELL_WARN
535 /* Here, either ftell is undefined (but C89 guarantees that it is
536    declared), or it is defined as rpl_ftell (declared above).  */
537 _GL_WARN_ON_USE (ftell, "ftell cannot handle files larger than 4 GB "
538                  "on 32-bit platforms - "
539                  "use ftello function for handling of large files");
540 #endif
541
542
543 #if @GNULIB_FWRITE@
544 # if @REPLACE_STDIO_WRITE_FUNCS@ && (@GNULIB_STDIO_H_NONBLOCKING@ || @GNULIB_STDIO_H_SIGPIPE@)
545 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
546 #   undef fwrite
547 #   define fwrite rpl_fwrite
548 #  endif
549 _GL_FUNCDECL_RPL (fwrite, size_t,
550                   (const void *ptr, size_t s, size_t n, FILE *stream)
551                   _GL_ARG_NONNULL ((1, 4)));
552 _GL_CXXALIAS_RPL (fwrite, size_t,
553                   (const void *ptr, size_t s, size_t n, FILE *stream));
554 # else
555 _GL_CXXALIAS_SYS (fwrite, size_t,
556                   (const void *ptr, size_t s, size_t n, FILE *stream));
557
558 /* Work around glibc bug 11959
559    <http://sources.redhat.com/bugzilla/show_bug.cgi?id=11959>,
560    which sometimes causes an unwanted diagnostic for fwrite calls.
561    This affects only function declaration attributes, so it's not
562    needed for C++.  */
563 #  if !defined __cplusplus && 0 < __USE_FORTIFY_LEVEL
564 static inline size_t _GL_ARG_NONNULL ((1, 4))
565 rpl_fwrite (const void *ptr, size_t s, size_t n, FILE *stream)
566 {
567   size_t r = fwrite (ptr, s, n, stream);
568   (void) r;
569   return r;
570 }
571 #   undef fwrite
572 #   define fwrite rpl_fwrite
573 #  endif
574 # endif
575 _GL_CXXALIASWARN (fwrite);
576 #endif
577
578 #if @GNULIB_GETC@
579 # if @REPLACE_STDIO_READ_FUNCS@ && @GNULIB_STDIO_H_NONBLOCKING@
580 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
581 #   undef getc
582 #   define getc rpl_fgetc
583 #  endif
584 _GL_FUNCDECL_RPL (fgetc, int, (FILE *stream) _GL_ARG_NONNULL ((1)));
585 _GL_CXXALIAS_RPL_1 (getc, rpl_fgetc, int, (FILE *stream));
586 # else
587 _GL_CXXALIAS_SYS (getc, int, (FILE *stream));
588 # endif
589 _GL_CXXALIASWARN (getc);
590 #endif
591
592 #if @GNULIB_GETCHAR@
593 # if @REPLACE_STDIO_READ_FUNCS@ && @GNULIB_STDIO_H_NONBLOCKING@
594 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
595 #   undef getchar
596 #   define getchar rpl_getchar
597 #  endif
598 _GL_FUNCDECL_RPL (getchar, int, (void));
599 _GL_CXXALIAS_RPL (getchar, int, (void));
600 # else
601 _GL_CXXALIAS_SYS (getchar, int, (void));
602 # endif
603 _GL_CXXALIASWARN (getchar);
604 #endif
605
606 #if @GNULIB_GETDELIM@
607 /* Read input, up to (and including) the next occurrence of DELIMITER, from
608    STREAM, store it in *LINEPTR (and NUL-terminate it).
609    *LINEPTR is a pointer returned from malloc (or NULL), pointing to *LINESIZE
610    bytes of space.  It is realloc'd as necessary.
611    Return the number of bytes read and stored at *LINEPTR (not including the
612    NUL terminator), or -1 on error or EOF.  */
613 # if @REPLACE_GETDELIM@
614 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
615 #   undef getdelim
616 #   define getdelim rpl_getdelim
617 #  endif
618 _GL_FUNCDECL_RPL (getdelim, ssize_t,
619                   (char **lineptr, size_t *linesize, int delimiter,
620                    FILE *stream)
621                   _GL_ARG_NONNULL ((1, 2, 4)));
622 _GL_CXXALIAS_RPL (getdelim, ssize_t,
623                   (char **lineptr, size_t *linesize, int delimiter,
624                    FILE *stream));
625 # else
626 #  if !@HAVE_DECL_GETDELIM@
627 _GL_FUNCDECL_SYS (getdelim, ssize_t,
628                   (char **lineptr, size_t *linesize, int delimiter,
629                    FILE *stream)
630                   _GL_ARG_NONNULL ((1, 2, 4)));
631 #  endif
632 _GL_CXXALIAS_SYS (getdelim, ssize_t,
633                   (char **lineptr, size_t *linesize, int delimiter,
634                    FILE *stream));
635 # endif
636 _GL_CXXALIASWARN (getdelim);
637 #elif defined GNULIB_POSIXCHECK
638 # undef getdelim
639 # if HAVE_RAW_DECL_GETDELIM
640 _GL_WARN_ON_USE (getdelim, "getdelim is unportable - "
641                  "use gnulib module getdelim for portability");
642 # endif
643 #endif
644
645 #if @GNULIB_GETLINE@
646 /* Read a line, up to (and including) the next newline, from STREAM, store it
647    in *LINEPTR (and NUL-terminate it).
648    *LINEPTR is a pointer returned from malloc (or NULL), pointing to *LINESIZE
649    bytes of space.  It is realloc'd as necessary.
650    Return the number of bytes read and stored at *LINEPTR (not including the
651    NUL terminator), or -1 on error or EOF.  */
652 # if @REPLACE_GETLINE@
653 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
654 #   undef getline
655 #   define getline rpl_getline
656 #  endif
657 _GL_FUNCDECL_RPL (getline, ssize_t,
658                   (char **lineptr, size_t *linesize, FILE *stream)
659                   _GL_ARG_NONNULL ((1, 2, 3)));
660 _GL_CXXALIAS_RPL (getline, ssize_t,
661                   (char **lineptr, size_t *linesize, FILE *stream));
662 # else
663 #  if !@HAVE_DECL_GETLINE@
664 _GL_FUNCDECL_SYS (getline, ssize_t,
665                   (char **lineptr, size_t *linesize, FILE *stream)
666                   _GL_ARG_NONNULL ((1, 2, 3)));
667 #  endif
668 _GL_CXXALIAS_SYS (getline, ssize_t,
669                   (char **lineptr, size_t *linesize, FILE *stream));
670 # endif
671 # if @HAVE_DECL_GETLINE@
672 _GL_CXXALIASWARN (getline);
673 # endif
674 #elif defined GNULIB_POSIXCHECK
675 # undef getline
676 # if HAVE_RAW_DECL_GETLINE
677 _GL_WARN_ON_USE (getline, "getline is unportable - "
678                  "use gnulib module getline for portability");
679 # endif
680 #endif
681
682 #if @GNULIB_GETS@
683 # if @REPLACE_STDIO_READ_FUNCS@ && @GNULIB_STDIO_H_NONBLOCKING@
684 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
685 #   undef gets
686 #   define gets rpl_gets
687 #  endif
688 _GL_FUNCDECL_RPL (gets, char *, (char *s) _GL_ARG_NONNULL ((1)));
689 _GL_CXXALIAS_RPL (gets, char *, (char *s));
690 # else
691 _GL_CXXALIAS_SYS (gets, char *, (char *s));
692 #  undef gets
693 # endif
694 _GL_CXXALIASWARN (gets);
695 /* It is very rare that the developer ever has full control of stdin,
696    so any use of gets warrants an unconditional warning.  Assume it is
697    always declared, since it is required by C89.  */
698 _GL_WARN_ON_USE (gets, "gets is a security hole - use fgets instead");
699 #endif
700
701
702 #if @GNULIB_OBSTACK_PRINTF@ || @GNULIB_OBSTACK_PRINTF_POSIX@
703 struct obstack;
704 /* Grow an obstack with formatted output.  Return the number of
705    bytes added to OBS.  No trailing nul byte is added, and the
706    object should be closed with obstack_finish before use.  Upon
707    memory allocation error, call obstack_alloc_failed_handler.  Upon
708    other error, return -1.  */
709 # if @REPLACE_OBSTACK_PRINTF@
710 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
711 #   define obstack_printf rpl_obstack_printf
712 #  endif
713 _GL_FUNCDECL_RPL (obstack_printf, int,
714                   (struct obstack *obs, const char *format, ...)
715                   _GL_ATTRIBUTE_FORMAT_PRINTF (2, 3)
716                   _GL_ARG_NONNULL ((1, 2)));
717 _GL_CXXALIAS_RPL (obstack_printf, int,
718                   (struct obstack *obs, const char *format, ...));
719 # else
720 #  if !@HAVE_DECL_OBSTACK_PRINTF@
721 _GL_FUNCDECL_SYS (obstack_printf, int,
722                   (struct obstack *obs, const char *format, ...)
723                   _GL_ATTRIBUTE_FORMAT_PRINTF (2, 3)
724                   _GL_ARG_NONNULL ((1, 2)));
725 #  endif
726 _GL_CXXALIAS_SYS (obstack_printf, int,
727                   (struct obstack *obs, const char *format, ...));
728 # endif
729 _GL_CXXALIASWARN (obstack_printf);
730 # if @REPLACE_OBSTACK_PRINTF@
731 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
732 #   define obstack_vprintf rpl_obstack_vprintf
733 #  endif
734 _GL_FUNCDECL_RPL (obstack_vprintf, int,
735                   (struct obstack *obs, const char *format, va_list args)
736                   _GL_ATTRIBUTE_FORMAT_PRINTF (2, 0)
737                   _GL_ARG_NONNULL ((1, 2)));
738 _GL_CXXALIAS_RPL (obstack_vprintf, int,
739                   (struct obstack *obs, const char *format, va_list args));
740 # else
741 #  if !@HAVE_DECL_OBSTACK_PRINTF@
742 _GL_FUNCDECL_SYS (obstack_vprintf, int,
743                   (struct obstack *obs, const char *format, va_list args)
744                   _GL_ATTRIBUTE_FORMAT_PRINTF (2, 0)
745                   _GL_ARG_NONNULL ((1, 2)));
746 #  endif
747 _GL_CXXALIAS_SYS (obstack_vprintf, int,
748                   (struct obstack *obs, const char *format, va_list args));
749 # endif
750 _GL_CXXALIASWARN (obstack_vprintf);
751 #endif
752
753 #if @GNULIB_PCLOSE@
754 # if !@HAVE_PCLOSE@
755 _GL_FUNCDECL_SYS (pclose, int, (FILE *stream) _GL_ARG_NONNULL ((1)));
756 # endif
757 _GL_CXXALIAS_SYS (pclose, int, (FILE *stream));
758 _GL_CXXALIASWARN (pclose);
759 #elif defined GNULIB_POSIXCHECK
760 # undef pclose
761 # if HAVE_RAW_DECL_PCLOSE
762 _GL_WARN_ON_USE (pclose, "popen is unportable - "
763                  "use gnulib module pclose for more portability");
764 # endif
765 #endif
766
767 #if @GNULIB_PERROR@
768 /* Print a message to standard error, describing the value of ERRNO,
769    (if STRING is not NULL and not empty) prefixed with STRING and ": ",
770    and terminated with a newline.  */
771 # if @REPLACE_PERROR@
772 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
773 #   define perror rpl_perror
774 #  endif
775 _GL_FUNCDECL_RPL (perror, void, (const char *string));
776 _GL_CXXALIAS_RPL (perror, void, (const char *string));
777 # else
778 _GL_CXXALIAS_SYS (perror, void, (const char *string));
779 # endif
780 _GL_CXXALIASWARN (perror);
781 #elif defined GNULIB_POSIXCHECK
782 # undef perror
783 /* Assume perror is always declared.  */
784 _GL_WARN_ON_USE (perror, "perror is not always POSIX compliant - "
785                  "use gnulib module perror for portability");
786 #endif
787
788 #if @GNULIB_POPEN@
789 # if @REPLACE_POPEN@
790 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
791 #   undef popen
792 #   define popen rpl_popen
793 #  endif
794 _GL_FUNCDECL_RPL (popen, FILE *, (const char *cmd, const char *mode)
795                                  _GL_ARG_NONNULL ((1, 2)));
796 _GL_CXXALIAS_RPL (popen, FILE *, (const char *cmd, const char *mode));
797 # else
798 #  if !@HAVE_POPEN@
799 _GL_FUNCDECL_SYS (popen, FILE *, (const char *cmd, const char *mode)
800                                  _GL_ARG_NONNULL ((1, 2)));
801 #  endif
802 _GL_CXXALIAS_SYS (popen, FILE *, (const char *cmd, const char *mode));
803 # endif
804 _GL_CXXALIASWARN (popen);
805 #elif defined GNULIB_POSIXCHECK
806 # undef popen
807 # if HAVE_RAW_DECL_POPEN
808 _GL_WARN_ON_USE (popen, "popen is buggy on some platforms - "
809                  "use gnulib module popen or pipe for more portability");
810 # endif
811 #endif
812
813 #if @GNULIB_PRINTF_POSIX@ || @GNULIB_PRINTF@
814 # if (@GNULIB_PRINTF_POSIX@ && @REPLACE_PRINTF@) \
815      || (@GNULIB_PRINTF@ && @REPLACE_STDIO_WRITE_FUNCS@ && (@GNULIB_STDIO_H_NONBLOCKING@ || @GNULIB_STDIO_H_SIGPIPE@))
816 #  if defined __GNUC__
817 #   if !(defined __cplusplus && defined GNULIB_NAMESPACE)
818 /* Don't break __attribute__((format(printf,M,N))).  */
819 #    define printf __printf__
820 #   endif
821 #   if @GNULIB_PRINTF_POSIX@ || @GNULIB_VFPRINTF_POSIX@
822 _GL_FUNCDECL_RPL_1 (__printf__, int,
823                     (const char *format, ...)
824                     __asm__ (@ASM_SYMBOL_PREFIX@
825                              _GL_STDIO_MACROEXPAND_AND_STRINGIZE(rpl_printf))
826                     _GL_ATTRIBUTE_FORMAT_PRINTF (1, 2)
827                     _GL_ARG_NONNULL ((1)));
828 #   else
829 _GL_FUNCDECL_RPL_1 (__printf__, int,
830                     (const char *format, ...)
831                     __asm__ (@ASM_SYMBOL_PREFIX@
832                              _GL_STDIO_MACROEXPAND_AND_STRINGIZE(rpl_printf))
833                     _GL_ATTRIBUTE_FORMAT_PRINTF_SYSTEM (1, 2)
834                     _GL_ARG_NONNULL ((1)));
835 #   endif
836 _GL_CXXALIAS_RPL_1 (printf, __printf__, int, (const char *format, ...));
837 #  else
838 #   if !(defined __cplusplus && defined GNULIB_NAMESPACE)
839 #    define printf rpl_printf
840 #   endif
841 _GL_FUNCDECL_RPL (printf, int,
842                   (const char *format, ...)
843                   _GL_ATTRIBUTE_FORMAT_PRINTF (1, 2)
844                   _GL_ARG_NONNULL ((1)));
845 _GL_CXXALIAS_RPL (printf, int, (const char *format, ...));
846 #  endif
847 #  define GNULIB_overrides_printf 1
848 # else
849 _GL_CXXALIAS_SYS (printf, int, (const char *format, ...));
850 # endif
851 _GL_CXXALIASWARN (printf);
852 #endif
853 #if !@GNULIB_PRINTF_POSIX@ && defined GNULIB_POSIXCHECK
854 # if !GNULIB_overrides_printf
855 #  undef printf
856 # endif
857 /* Assume printf is always declared.  */
858 _GL_WARN_ON_USE (printf, "printf is not always POSIX compliant - "
859                  "use gnulib module printf-posix for portable "
860                  "POSIX compliance");
861 #endif
862
863 #if @GNULIB_PUTC@
864 # if @REPLACE_STDIO_WRITE_FUNCS@ && (@GNULIB_STDIO_H_NONBLOCKING@ || @GNULIB_STDIO_H_SIGPIPE@)
865 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
866 #   undef putc
867 #   define putc rpl_fputc
868 #  endif
869 _GL_FUNCDECL_RPL (fputc, int, (int c, FILE *stream) _GL_ARG_NONNULL ((2)));
870 _GL_CXXALIAS_RPL_1 (putc, rpl_fputc, int, (int c, FILE *stream));
871 # else
872 _GL_CXXALIAS_SYS (putc, int, (int c, FILE *stream));
873 # endif
874 _GL_CXXALIASWARN (putc);
875 #endif
876
877 #if @GNULIB_PUTCHAR@
878 # if @REPLACE_STDIO_WRITE_FUNCS@ && (@GNULIB_STDIO_H_NONBLOCKING@ || @GNULIB_STDIO_H_SIGPIPE@)
879 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
880 #   undef putchar
881 #   define putchar rpl_putchar
882 #  endif
883 _GL_FUNCDECL_RPL (putchar, int, (int c));
884 _GL_CXXALIAS_RPL (putchar, int, (int c));
885 # else
886 _GL_CXXALIAS_SYS (putchar, int, (int c));
887 # endif
888 _GL_CXXALIASWARN (putchar);
889 #endif
890
891 #if @GNULIB_PUTS@
892 # if @REPLACE_STDIO_WRITE_FUNCS@ && (@GNULIB_STDIO_H_NONBLOCKING@ || @GNULIB_STDIO_H_SIGPIPE@)
893 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
894 #   undef puts
895 #   define puts rpl_puts
896 #  endif
897 _GL_FUNCDECL_RPL (puts, int, (const char *string) _GL_ARG_NONNULL ((1)));
898 _GL_CXXALIAS_RPL (puts, int, (const char *string));
899 # else
900 _GL_CXXALIAS_SYS (puts, int, (const char *string));
901 # endif
902 _GL_CXXALIASWARN (puts);
903 #endif
904
905 #if @GNULIB_REMOVE@
906 # if @REPLACE_REMOVE@
907 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
908 #   undef remove
909 #   define remove rpl_remove
910 #  endif
911 _GL_FUNCDECL_RPL (remove, int, (const char *name) _GL_ARG_NONNULL ((1)));
912 _GL_CXXALIAS_RPL (remove, int, (const char *name));
913 # else
914 _GL_CXXALIAS_SYS (remove, int, (const char *name));
915 # endif
916 _GL_CXXALIASWARN (remove);
917 #elif defined GNULIB_POSIXCHECK
918 # undef remove
919 /* Assume remove is always declared.  */
920 _GL_WARN_ON_USE (remove, "remove cannot handle directories on some platforms - "
921                  "use gnulib module remove for more portability");
922 #endif
923
924 #if @GNULIB_RENAME@
925 # if @REPLACE_RENAME@
926 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
927 #   undef rename
928 #   define rename rpl_rename
929 #  endif
930 _GL_FUNCDECL_RPL (rename, int,
931                   (const char *old_filename, const char *new_filename)
932                   _GL_ARG_NONNULL ((1, 2)));
933 _GL_CXXALIAS_RPL (rename, int,
934                   (const char *old_filename, const char *new_filename));
935 # else
936 _GL_CXXALIAS_SYS (rename, int,
937                   (const char *old_filename, const char *new_filename));
938 # endif
939 _GL_CXXALIASWARN (rename);
940 #elif defined GNULIB_POSIXCHECK
941 # undef rename
942 /* Assume rename is always declared.  */
943 _GL_WARN_ON_USE (rename, "rename is buggy on some platforms - "
944                  "use gnulib module rename for more portability");
945 #endif
946
947 #if @GNULIB_RENAMEAT@
948 # if @REPLACE_RENAMEAT@
949 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
950 #   undef renameat
951 #   define renameat rpl_renameat
952 #  endif
953 _GL_FUNCDECL_RPL (renameat, int,
954                   (int fd1, char const *file1, int fd2, char const *file2)
955                   _GL_ARG_NONNULL ((2, 4)));
956 _GL_CXXALIAS_RPL (renameat, int,
957                   (int fd1, char const *file1, int fd2, char const *file2));
958 # else
959 #  if !@HAVE_RENAMEAT@
960 _GL_FUNCDECL_SYS (renameat, int,
961                   (int fd1, char const *file1, int fd2, char const *file2)
962                   _GL_ARG_NONNULL ((2, 4)));
963 #  endif
964 _GL_CXXALIAS_SYS (renameat, int,
965                   (int fd1, char const *file1, int fd2, char const *file2));
966 # endif
967 _GL_CXXALIASWARN (renameat);
968 #elif defined GNULIB_POSIXCHECK
969 # undef renameat
970 # if HAVE_RAW_DECL_RENAMEAT
971 _GL_WARN_ON_USE (renameat, "renameat is not portable - "
972                  "use gnulib module renameat for portability");
973 # endif
974 #endif
975
976 #if @GNULIB_SCANF@
977 # if @REPLACE_STDIO_READ_FUNCS@ && @GNULIB_STDIO_H_NONBLOCKING@
978 #  if defined __GNUC__
979 #   if !(defined __cplusplus && defined GNULIB_NAMESPACE)
980 #    undef scanf
981 /* Don't break __attribute__((format(scanf,M,N))).  */
982 #    define scanf __scanf__
983 #   endif
984 _GL_FUNCDECL_RPL_1 (__scanf__, int,
985                     (const char *format, ...)
986                     __asm__ (@ASM_SYMBOL_PREFIX@
987                              _GL_STDIO_MACROEXPAND_AND_STRINGIZE(rpl_scanf))
988                     _GL_ATTRIBUTE_FORMAT_SCANF_SYSTEM (1, 2)
989                     _GL_ARG_NONNULL ((1)));
990 _GL_CXXALIAS_RPL_1 (scanf, __scanf__, int, (const char *format, ...));
991 #  else
992 #   if !(defined __cplusplus && defined GNULIB_NAMESPACE)
993 #    undef scanf
994 #    define scanf rpl_scanf
995 #   endif
996 _GL_FUNCDECL_RPL (scanf, int, (const char *format, ...)
997                               _GL_ATTRIBUTE_FORMAT_SCANF_SYSTEM (1, 2)
998                               _GL_ARG_NONNULL ((1)));
999 _GL_CXXALIAS_RPL (scanf, int, (const char *format, ...));
1000 #  endif
1001 # else
1002 _GL_CXXALIAS_SYS (scanf, int, (const char *format, ...));
1003 # endif
1004 _GL_CXXALIASWARN (scanf);
1005 #endif
1006
1007 #if @GNULIB_SNPRINTF@
1008 # if @REPLACE_SNPRINTF@
1009 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
1010 #   define snprintf rpl_snprintf
1011 #  endif
1012 _GL_FUNCDECL_RPL (snprintf, int,
1013                   (char *str, size_t size, const char *format, ...)
1014                   _GL_ATTRIBUTE_FORMAT_PRINTF (3, 4)
1015                   _GL_ARG_NONNULL ((3)));
1016 _GL_CXXALIAS_RPL (snprintf, int,
1017                   (char *str, size_t size, const char *format, ...));
1018 # else
1019 #  if !@HAVE_DECL_SNPRINTF@
1020 _GL_FUNCDECL_SYS (snprintf, int,
1021                   (char *str, size_t size, const char *format, ...)
1022                   _GL_ATTRIBUTE_FORMAT_PRINTF (3, 4)
1023                   _GL_ARG_NONNULL ((3)));
1024 #  endif
1025 _GL_CXXALIAS_SYS (snprintf, int,
1026                   (char *str, size_t size, const char *format, ...));
1027 # endif
1028 _GL_CXXALIASWARN (snprintf);
1029 #elif defined GNULIB_POSIXCHECK
1030 # undef snprintf
1031 # if HAVE_RAW_DECL_SNPRINTF
1032 _GL_WARN_ON_USE (snprintf, "snprintf is unportable - "
1033                  "use gnulib module snprintf for portability");
1034 # endif
1035 #endif
1036
1037 /* Some people would argue that sprintf should be handled like gets
1038    (for example, OpenBSD issues a link warning for both functions),
1039    since both can cause security holes due to buffer overruns.
1040    However, we believe that sprintf can be used safely, and is more
1041    efficient than snprintf in those safe cases; and as proof of our
1042    belief, we use sprintf in several gnulib modules.  So this header
1043    intentionally avoids adding a warning to sprintf except when
1044    GNULIB_POSIXCHECK is defined.  */
1045
1046 #if @GNULIB_SPRINTF_POSIX@
1047 # if @REPLACE_SPRINTF@
1048 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
1049 #   define sprintf rpl_sprintf
1050 #  endif
1051 _GL_FUNCDECL_RPL (sprintf, int, (char *str, const char *format, ...)
1052                                 _GL_ATTRIBUTE_FORMAT_PRINTF (2, 3)
1053                                 _GL_ARG_NONNULL ((1, 2)));
1054 _GL_CXXALIAS_RPL (sprintf, int, (char *str, const char *format, ...));
1055 # else
1056 _GL_CXXALIAS_SYS (sprintf, int, (char *str, const char *format, ...));
1057 # endif
1058 _GL_CXXALIASWARN (sprintf);
1059 #elif defined GNULIB_POSIXCHECK
1060 # undef sprintf
1061 /* Assume sprintf is always declared.  */
1062 _GL_WARN_ON_USE (sprintf, "sprintf is not always POSIX compliant - "
1063                  "use gnulib module sprintf-posix for portable "
1064                  "POSIX compliance");
1065 #endif
1066
1067 #if @GNULIB_TMPFILE@
1068 # if @REPLACE_TMPFILE@
1069 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
1070 #   define tmpfile rpl_tmpfile
1071 #  endif
1072 _GL_FUNCDECL_RPL (tmpfile, FILE *, (void));
1073 _GL_CXXALIAS_RPL (tmpfile, FILE *, (void));
1074 # else
1075 _GL_CXXALIAS_SYS (tmpfile, FILE *, (void));
1076 # endif
1077 _GL_CXXALIASWARN (tmpfile);
1078 #elif defined GNULIB_POSIXCHECK
1079 # undef tmpfile
1080 # if HAVE_RAW_DECL_TMPFILE
1081 _GL_WARN_ON_USE (tmpfile, "tmpfile is not usable on mingw - "
1082                  "use gnulib module tmpfile for portability");
1083 # endif
1084 #endif
1085
1086 #if @GNULIB_VASPRINTF@
1087 /* Write formatted output to a string dynamically allocated with malloc().
1088    If the memory allocation succeeds, store the address of the string in
1089    *RESULT and return the number of resulting bytes, excluding the trailing
1090    NUL.  Upon memory allocation error, or some other error, return -1.  */
1091 # if @REPLACE_VASPRINTF@
1092 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
1093 #   define asprintf rpl_asprintf
1094 #  endif
1095 _GL_FUNCDECL_RPL (asprintf, int,
1096                   (char **result, const char *format, ...)
1097                   _GL_ATTRIBUTE_FORMAT_PRINTF (2, 3)
1098                   _GL_ARG_NONNULL ((1, 2)));
1099 _GL_CXXALIAS_RPL (asprintf, int,
1100                   (char **result, const char *format, ...));
1101 # else
1102 #  if !@HAVE_VASPRINTF@
1103 _GL_FUNCDECL_SYS (asprintf, int,
1104                   (char **result, const char *format, ...)
1105                   _GL_ATTRIBUTE_FORMAT_PRINTF (2, 3)
1106                   _GL_ARG_NONNULL ((1, 2)));
1107 #  endif
1108 _GL_CXXALIAS_SYS (asprintf, int,
1109                   (char **result, const char *format, ...));
1110 # endif
1111 _GL_CXXALIASWARN (asprintf);
1112 # if @REPLACE_VASPRINTF@
1113 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
1114 #   define vasprintf rpl_vasprintf
1115 #  endif
1116 _GL_FUNCDECL_RPL (vasprintf, int,
1117                   (char **result, const char *format, va_list args)
1118                   _GL_ATTRIBUTE_FORMAT_PRINTF (2, 0)
1119                   _GL_ARG_NONNULL ((1, 2)));
1120 _GL_CXXALIAS_RPL (vasprintf, int,
1121                   (char **result, const char *format, va_list args));
1122 # else
1123 #  if !@HAVE_VASPRINTF@
1124 _GL_FUNCDECL_SYS (vasprintf, int,
1125                   (char **result, const char *format, va_list args)
1126                   _GL_ATTRIBUTE_FORMAT_PRINTF (2, 0)
1127                   _GL_ARG_NONNULL ((1, 2)));
1128 #  endif
1129 _GL_CXXALIAS_SYS (vasprintf, int,
1130                   (char **result, const char *format, va_list args));
1131 # endif
1132 _GL_CXXALIASWARN (vasprintf);
1133 #endif
1134
1135 #if @GNULIB_VDPRINTF@
1136 # if @REPLACE_VDPRINTF@
1137 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
1138 #   define vdprintf rpl_vdprintf
1139 #  endif
1140 _GL_FUNCDECL_RPL (vdprintf, int, (int fd, const char *format, va_list args)
1141                                  _GL_ATTRIBUTE_FORMAT_PRINTF (2, 0)
1142                                  _GL_ARG_NONNULL ((2)));
1143 _GL_CXXALIAS_RPL (vdprintf, int, (int fd, const char *format, va_list args));
1144 # else
1145 #  if !@HAVE_VDPRINTF@
1146 _GL_FUNCDECL_SYS (vdprintf, int, (int fd, const char *format, va_list args)
1147                                  _GL_ATTRIBUTE_FORMAT_PRINTF (2, 0)
1148                                  _GL_ARG_NONNULL ((2)));
1149 #  endif
1150 /* Need to cast, because on Solaris, the third parameter will likely be
1151                                                     __va_list args.  */
1152 _GL_CXXALIAS_SYS_CAST (vdprintf, int,
1153                        (int fd, const char *format, va_list args));
1154 # endif
1155 _GL_CXXALIASWARN (vdprintf);
1156 #elif defined GNULIB_POSIXCHECK
1157 # undef vdprintf
1158 # if HAVE_RAW_DECL_VDPRINTF
1159 _GL_WARN_ON_USE (vdprintf, "vdprintf is unportable - "
1160                  "use gnulib module vdprintf for portability");
1161 # endif
1162 #endif
1163
1164 #if @GNULIB_VFPRINTF_POSIX@ || @GNULIB_VFPRINTF@
1165 # if (@GNULIB_VFPRINTF_POSIX@ && @REPLACE_VFPRINTF@) \
1166      || (@GNULIB_VFPRINTF@ && @REPLACE_STDIO_WRITE_FUNCS@ && (@GNULIB_STDIO_H_NONBLOCKING@ || @GNULIB_STDIO_H_SIGPIPE@))
1167 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
1168 #   define vfprintf rpl_vfprintf
1169 #  endif
1170 #  define GNULIB_overrides_vfprintf 1
1171 #  if @GNULIB_VFPRINTF_POSIX@
1172 _GL_FUNCDECL_RPL (vfprintf, int, (FILE *fp, const char *format, va_list args)
1173                                  _GL_ATTRIBUTE_FORMAT_PRINTF (2, 0)
1174                                  _GL_ARG_NONNULL ((1, 2)));
1175 #  else
1176 _GL_FUNCDECL_RPL (vfprintf, int, (FILE *fp, const char *format, va_list args)
1177                                  _GL_ATTRIBUTE_FORMAT_PRINTF_SYSTEM (2, 0)
1178                                  _GL_ARG_NONNULL ((1, 2)));
1179 #  endif
1180 _GL_CXXALIAS_RPL (vfprintf, int, (FILE *fp, const char *format, va_list args));
1181 # else
1182 /* Need to cast, because on Solaris, the third parameter is
1183                                                       __va_list args
1184    and GCC's fixincludes did not change this to __gnuc_va_list.  */
1185 _GL_CXXALIAS_SYS_CAST (vfprintf, int,
1186                        (FILE *fp, const char *format, va_list args));
1187 # endif
1188 _GL_CXXALIASWARN (vfprintf);
1189 #endif
1190 #if !@GNULIB_VFPRINTF_POSIX@ && defined GNULIB_POSIXCHECK
1191 # if !GNULIB_overrides_vfprintf
1192 #  undef vfprintf
1193 # endif
1194 /* Assume vfprintf is always declared.  */
1195 _GL_WARN_ON_USE (vfprintf, "vfprintf is not always POSIX compliant - "
1196                  "use gnulib module vfprintf-posix for portable "
1197                       "POSIX compliance");
1198 #endif
1199
1200 #if @GNULIB_VFSCANF@
1201 # if @REPLACE_STDIO_READ_FUNCS@ && @GNULIB_STDIO_H_NONBLOCKING@
1202 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
1203 #   undef vfscanf
1204 #   define vfscanf rpl_vfscanf
1205 #  endif
1206 _GL_FUNCDECL_RPL (vfscanf, int,
1207                   (FILE *stream, const char *format, va_list args)
1208                   _GL_ATTRIBUTE_FORMAT_SCANF_SYSTEM (2, 0)
1209                   _GL_ARG_NONNULL ((1, 2)));
1210 _GL_CXXALIAS_RPL (vfscanf, int,
1211                   (FILE *stream, const char *format, va_list args));
1212 # else
1213 _GL_CXXALIAS_SYS (vfscanf, int,
1214                   (FILE *stream, const char *format, va_list args));
1215 # endif
1216 _GL_CXXALIASWARN (vfscanf);
1217 #endif
1218
1219 #if @GNULIB_VPRINTF_POSIX@ || @GNULIB_VPRINTF@
1220 # if (@GNULIB_VPRINTF_POSIX@ && @REPLACE_VPRINTF@) \
1221      || (@GNULIB_VPRINTF@ && @REPLACE_STDIO_WRITE_FUNCS@ && (@GNULIB_STDIO_H_NONBLOCKING@ || @GNULIB_STDIO_H_SIGPIPE@))
1222 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
1223 #   define vprintf rpl_vprintf
1224 #  endif
1225 #  define GNULIB_overrides_vprintf 1
1226 #  if @GNULIB_VPRINTF_POSIX@ || @GNULIB_VFPRINTF_POSIX@
1227 _GL_FUNCDECL_RPL (vprintf, int, (const char *format, va_list args)
1228                                 _GL_ATTRIBUTE_FORMAT_PRINTF (1, 0)
1229                                 _GL_ARG_NONNULL ((1)));
1230 #  else
1231 _GL_FUNCDECL_RPL (vprintf, int, (const char *format, va_list args)
1232                                 _GL_ATTRIBUTE_FORMAT_PRINTF_SYSTEM (1, 0)
1233                                 _GL_ARG_NONNULL ((1)));
1234 #  endif
1235 _GL_CXXALIAS_RPL (vprintf, int, (const char *format, va_list args));
1236 # else
1237 /* Need to cast, because on Solaris, the second parameter is
1238                                                           __va_list args
1239    and GCC's fixincludes did not change this to __gnuc_va_list.  */
1240 _GL_CXXALIAS_SYS_CAST (vprintf, int, (const char *format, va_list args));
1241 # endif
1242 _GL_CXXALIASWARN (vprintf);
1243 #endif
1244 #if !@GNULIB_VPRINTF_POSIX@ && defined GNULIB_POSIXCHECK
1245 # if !GNULIB_overrides_vprintf
1246 #  undef vprintf
1247 # endif
1248 /* Assume vprintf is always declared.  */
1249 _GL_WARN_ON_USE (vprintf, "vprintf is not always POSIX compliant - "
1250                  "use gnulib module vprintf-posix for portable "
1251                  "POSIX compliance");
1252 #endif
1253
1254 #if @GNULIB_VSCANF@
1255 # if @REPLACE_STDIO_READ_FUNCS@ && @GNULIB_STDIO_H_NONBLOCKING@
1256 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
1257 #   undef vscanf
1258 #   define vscanf rpl_vscanf
1259 #  endif
1260 _GL_FUNCDECL_RPL (vscanf, int, (const char *format, va_list args)
1261                                _GL_ATTRIBUTE_FORMAT_SCANF_SYSTEM (1, 0)
1262                                _GL_ARG_NONNULL ((1)));
1263 _GL_CXXALIAS_RPL (vscanf, int, (const char *format, va_list args));
1264 # else
1265 _GL_CXXALIAS_SYS (vscanf, int, (const char *format, va_list args));
1266 # endif
1267 _GL_CXXALIASWARN (vscanf);
1268 #endif
1269
1270 #if @GNULIB_VSNPRINTF@
1271 # if @REPLACE_VSNPRINTF@
1272 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
1273 #   define vsnprintf rpl_vsnprintf
1274 #  endif
1275 _GL_FUNCDECL_RPL (vsnprintf, int,
1276                   (char *str, size_t size, const char *format, va_list args)
1277                   _GL_ATTRIBUTE_FORMAT_PRINTF (3, 0)
1278                   _GL_ARG_NONNULL ((3)));
1279 _GL_CXXALIAS_RPL (vsnprintf, int,
1280                   (char *str, size_t size, const char *format, va_list args));
1281 # else
1282 #  if !@HAVE_DECL_VSNPRINTF@
1283 _GL_FUNCDECL_SYS (vsnprintf, int,
1284                   (char *str, size_t size, const char *format, va_list args)
1285                   _GL_ATTRIBUTE_FORMAT_PRINTF (3, 0)
1286                   _GL_ARG_NONNULL ((3)));
1287 #  endif
1288 _GL_CXXALIAS_SYS (vsnprintf, int,
1289                   (char *str, size_t size, const char *format, va_list args));
1290 # endif
1291 _GL_CXXALIASWARN (vsnprintf);
1292 #elif defined GNULIB_POSIXCHECK
1293 # undef vsnprintf
1294 # if HAVE_RAW_DECL_VSNPRINTF
1295 _GL_WARN_ON_USE (vsnprintf, "vsnprintf is unportable - "
1296                  "use gnulib module vsnprintf for portability");
1297 # endif
1298 #endif
1299
1300 #if @GNULIB_VSPRINTF_POSIX@
1301 # if @REPLACE_VSPRINTF@
1302 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
1303 #   define vsprintf rpl_vsprintf
1304 #  endif
1305 _GL_FUNCDECL_RPL (vsprintf, int,
1306                   (char *str, const char *format, va_list args)
1307                   _GL_ATTRIBUTE_FORMAT_PRINTF (2, 0)
1308                   _GL_ARG_NONNULL ((1, 2)));
1309 _GL_CXXALIAS_RPL (vsprintf, int,
1310                   (char *str, const char *format, va_list args));
1311 # else
1312 /* Need to cast, because on Solaris, the third parameter is
1313                                                        __va_list args
1314    and GCC's fixincludes did not change this to __gnuc_va_list.  */
1315 _GL_CXXALIAS_SYS_CAST (vsprintf, int,
1316                        (char *str, const char *format, va_list args));
1317 # endif
1318 _GL_CXXALIASWARN (vsprintf);
1319 #elif defined GNULIB_POSIXCHECK
1320 # undef vsprintf
1321 /* Assume vsprintf is always declared.  */
1322 _GL_WARN_ON_USE (vsprintf, "vsprintf is not always POSIX compliant - "
1323                  "use gnulib module vsprintf-posix for portable "
1324                       "POSIX compliance");
1325 #endif
1326
1327
1328 #endif /* _@GUARD_PREFIX@_STDIO_H */
1329 #endif /* _@GUARD_PREFIX@_STDIO_H */
1330 #endif