line |
stmt |
bran |
cond |
sub |
pod |
time |
code |
1
|
|
|
|
|
|
|
/* Define ISO C stdio on top of C++ iostreams. |
2
|
|
|
|
|
|
|
Copyright (C) 1991-2016 Free Software Foundation, Inc. |
3
|
|
|
|
|
|
|
This file is part of the GNU C Library. |
4
|
|
|
|
|
|
|
|
5
|
|
|
|
|
|
|
The GNU C Library is free software; you can redistribute it and/or |
6
|
|
|
|
|
|
|
modify it under the terms of the GNU Lesser General Public |
7
|
|
|
|
|
|
|
License as published by the Free Software Foundation; either |
8
|
|
|
|
|
|
|
version 2.1 of the License, or (at your option) any later version. |
9
|
|
|
|
|
|
|
|
10
|
|
|
|
|
|
|
The GNU C Library 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 GNU |
13
|
|
|
|
|
|
|
Lesser General Public License for more details. |
14
|
|
|
|
|
|
|
|
15
|
|
|
|
|
|
|
You should have received a copy of the GNU Lesser General Public |
16
|
|
|
|
|
|
|
License along with the GNU C Library; if not, see |
17
|
|
|
|
|
|
|
. */ |
18
|
|
|
|
|
|
|
|
19
|
|
|
|
|
|
|
/* |
20
|
|
|
|
|
|
|
* ISO C99 Standard: 7.19 Input/output |
21
|
|
|
|
|
|
|
*/ |
22
|
|
|
|
|
|
|
|
23
|
|
|
|
|
|
|
#ifndef _STDIO_H |
24
|
|
|
|
|
|
|
|
25
|
|
|
|
|
|
|
#if !defined __need_FILE && !defined __need___FILE |
26
|
|
|
|
|
|
|
# define _STDIO_H 1 |
27
|
|
|
|
|
|
|
# include |
28
|
|
|
|
|
|
|
|
29
|
|
|
|
|
|
|
__BEGIN_DECLS |
30
|
|
|
|
|
|
|
|
31
|
|
|
|
|
|
|
# define __need_size_t |
32
|
|
|
|
|
|
|
# define __need_NULL |
33
|
|
|
|
|
|
|
# include |
34
|
|
|
|
|
|
|
|
35
|
|
|
|
|
|
|
# include |
36
|
|
|
|
|
|
|
# define __need_FILE |
37
|
|
|
|
|
|
|
# define __need___FILE |
38
|
|
|
|
|
|
|
#endif /* Don't need FILE. */ |
39
|
|
|
|
|
|
|
|
40
|
|
|
|
|
|
|
|
41
|
|
|
|
|
|
|
#if !defined __FILE_defined && defined __need_FILE |
42
|
|
|
|
|
|
|
|
43
|
|
|
|
|
|
|
/* Define outside of namespace so the C++ is happy. */ |
44
|
|
|
|
|
|
|
struct _IO_FILE; |
45
|
|
|
|
|
|
|
|
46
|
|
|
|
|
|
|
__BEGIN_NAMESPACE_STD |
47
|
|
|
|
|
|
|
/* The opaque type of streams. This is the definition used elsewhere. */ |
48
|
|
|
|
|
|
|
typedef struct _IO_FILE FILE; |
49
|
|
|
|
|
|
|
__END_NAMESPACE_STD |
50
|
|
|
|
|
|
|
#if defined __USE_LARGEFILE64 || defined __USE_POSIX \ |
51
|
|
|
|
|
|
|
|| defined __USE_ISOC99 || defined __USE_XOPEN \ |
52
|
|
|
|
|
|
|
|| defined __USE_POSIX2 |
53
|
|
|
|
|
|
|
__USING_NAMESPACE_STD(FILE) |
54
|
|
|
|
|
|
|
#endif |
55
|
|
|
|
|
|
|
|
56
|
|
|
|
|
|
|
# define __FILE_defined 1 |
57
|
|
|
|
|
|
|
#endif /* FILE not defined. */ |
58
|
|
|
|
|
|
|
#undef __need_FILE |
59
|
|
|
|
|
|
|
|
60
|
|
|
|
|
|
|
|
61
|
|
|
|
|
|
|
#if !defined ____FILE_defined && defined __need___FILE |
62
|
|
|
|
|
|
|
|
63
|
|
|
|
|
|
|
/* The opaque type of streams. This is the definition used elsewhere. */ |
64
|
|
|
|
|
|
|
typedef struct _IO_FILE __FILE; |
65
|
|
|
|
|
|
|
|
66
|
|
|
|
|
|
|
# define ____FILE_defined 1 |
67
|
|
|
|
|
|
|
#endif /* __FILE not defined. */ |
68
|
|
|
|
|
|
|
#undef __need___FILE |
69
|
|
|
|
|
|
|
|
70
|
|
|
|
|
|
|
|
71
|
|
|
|
|
|
|
#ifdef _STDIO_H |
72
|
|
|
|
|
|
|
#define _STDIO_USES_IOSTREAM |
73
|
|
|
|
|
|
|
|
74
|
|
|
|
|
|
|
#include |
75
|
|
|
|
|
|
|
|
76
|
|
|
|
|
|
|
#if defined __USE_XOPEN || defined __USE_XOPEN2K8 |
77
|
|
|
|
|
|
|
# ifdef __GNUC__ |
78
|
|
|
|
|
|
|
# ifndef _VA_LIST_DEFINED |
79
|
|
|
|
|
|
|
typedef _G_va_list va_list; |
80
|
|
|
|
|
|
|
# define _VA_LIST_DEFINED |
81
|
|
|
|
|
|
|
# endif |
82
|
|
|
|
|
|
|
# else |
83
|
|
|
|
|
|
|
# include |
84
|
|
|
|
|
|
|
# endif |
85
|
|
|
|
|
|
|
#endif |
86
|
|
|
|
|
|
|
|
87
|
|
|
|
|
|
|
#ifdef __USE_XOPEN2K8 |
88
|
|
|
|
|
|
|
# ifndef __off_t_defined |
89
|
|
|
|
|
|
|
# ifndef __USE_FILE_OFFSET64 |
90
|
|
|
|
|
|
|
typedef __off_t off_t; |
91
|
|
|
|
|
|
|
# else |
92
|
|
|
|
|
|
|
typedef __off64_t off_t; |
93
|
|
|
|
|
|
|
# endif |
94
|
|
|
|
|
|
|
# define __off_t_defined |
95
|
|
|
|
|
|
|
# endif |
96
|
|
|
|
|
|
|
# if defined __USE_LARGEFILE64 && !defined __off64_t_defined |
97
|
|
|
|
|
|
|
typedef __off64_t off64_t; |
98
|
|
|
|
|
|
|
# define __off64_t_defined |
99
|
|
|
|
|
|
|
# endif |
100
|
|
|
|
|
|
|
|
101
|
|
|
|
|
|
|
# ifndef __ssize_t_defined |
102
|
|
|
|
|
|
|
typedef __ssize_t ssize_t; |
103
|
|
|
|
|
|
|
# define __ssize_t_defined |
104
|
|
|
|
|
|
|
# endif |
105
|
|
|
|
|
|
|
#endif |
106
|
|
|
|
|
|
|
|
107
|
|
|
|
|
|
|
/* The type of the second argument to `fgetpos' and `fsetpos'. */ |
108
|
|
|
|
|
|
|
__BEGIN_NAMESPACE_STD |
109
|
|
|
|
|
|
|
#ifndef __USE_FILE_OFFSET64 |
110
|
|
|
|
|
|
|
typedef _G_fpos_t fpos_t; |
111
|
|
|
|
|
|
|
#else |
112
|
|
|
|
|
|
|
typedef _G_fpos64_t fpos_t; |
113
|
|
|
|
|
|
|
#endif |
114
|
|
|
|
|
|
|
__END_NAMESPACE_STD |
115
|
|
|
|
|
|
|
#ifdef __USE_LARGEFILE64 |
116
|
|
|
|
|
|
|
typedef _G_fpos64_t fpos64_t; |
117
|
|
|
|
|
|
|
#endif |
118
|
|
|
|
|
|
|
|
119
|
|
|
|
|
|
|
/* The possibilities for the third argument to `setvbuf'. */ |
120
|
|
|
|
|
|
|
#define _IOFBF 0 /* Fully buffered. */ |
121
|
|
|
|
|
|
|
#define _IOLBF 1 /* Line buffered. */ |
122
|
|
|
|
|
|
|
#define _IONBF 2 /* No buffering. */ |
123
|
|
|
|
|
|
|
|
124
|
|
|
|
|
|
|
|
125
|
|
|
|
|
|
|
/* Default buffer size. */ |
126
|
|
|
|
|
|
|
#ifndef BUFSIZ |
127
|
|
|
|
|
|
|
# define BUFSIZ _IO_BUFSIZ |
128
|
|
|
|
|
|
|
#endif |
129
|
|
|
|
|
|
|
|
130
|
|
|
|
|
|
|
|
131
|
|
|
|
|
|
|
/* End of file character. |
132
|
|
|
|
|
|
|
Some things throughout the library rely on this being -1. */ |
133
|
|
|
|
|
|
|
#ifndef EOF |
134
|
|
|
|
|
|
|
# define EOF (-1) |
135
|
|
|
|
|
|
|
#endif |
136
|
|
|
|
|
|
|
|
137
|
|
|
|
|
|
|
|
138
|
|
|
|
|
|
|
/* The possibilities for the third argument to `fseek'. |
139
|
|
|
|
|
|
|
These values should not be changed. */ |
140
|
|
|
|
|
|
|
#define SEEK_SET 0 /* Seek from beginning of file. */ |
141
|
|
|
|
|
|
|
#define SEEK_CUR 1 /* Seek from current position. */ |
142
|
|
|
|
|
|
|
#define SEEK_END 2 /* Seek from end of file. */ |
143
|
|
|
|
|
|
|
#ifdef __USE_GNU |
144
|
|
|
|
|
|
|
# define SEEK_DATA 3 /* Seek to next data. */ |
145
|
|
|
|
|
|
|
# define SEEK_HOLE 4 /* Seek to next hole. */ |
146
|
|
|
|
|
|
|
#endif |
147
|
|
|
|
|
|
|
|
148
|
|
|
|
|
|
|
|
149
|
|
|
|
|
|
|
#if defined __USE_MISC || defined __USE_XOPEN |
150
|
|
|
|
|
|
|
/* Default path prefix for `tempnam' and `tmpnam'. */ |
151
|
|
|
|
|
|
|
# define P_tmpdir "/tmp" |
152
|
|
|
|
|
|
|
#endif |
153
|
|
|
|
|
|
|
|
154
|
|
|
|
|
|
|
|
155
|
|
|
|
|
|
|
/* Get the values: |
156
|
|
|
|
|
|
|
L_tmpnam How long an array of chars must be to be passed to `tmpnam'. |
157
|
|
|
|
|
|
|
TMP_MAX The minimum number of unique filenames generated by tmpnam |
158
|
|
|
|
|
|
|
(and tempnam when it uses tmpnam's name space), |
159
|
|
|
|
|
|
|
or tempnam (the two are separate). |
160
|
|
|
|
|
|
|
L_ctermid How long an array to pass to `ctermid'. |
161
|
|
|
|
|
|
|
L_cuserid How long an array to pass to `cuserid'. |
162
|
|
|
|
|
|
|
FOPEN_MAX Minimum number of files that can be open at once. |
163
|
|
|
|
|
|
|
FILENAME_MAX Maximum length of a filename. */ |
164
|
|
|
|
|
|
|
#include |
165
|
|
|
|
|
|
|
|
166
|
|
|
|
|
|
|
|
167
|
|
|
|
|
|
|
/* Standard streams. */ |
168
|
|
|
|
|
|
|
extern struct _IO_FILE *stdin; /* Standard input stream. */ |
169
|
|
|
|
|
|
|
extern struct _IO_FILE *stdout; /* Standard output stream. */ |
170
|
|
|
|
|
|
|
extern struct _IO_FILE *stderr; /* Standard error output stream. */ |
171
|
|
|
|
|
|
|
/* C89/C99 say they're macros. Make them happy. */ |
172
|
|
|
|
|
|
|
#define stdin stdin |
173
|
|
|
|
|
|
|
#define stdout stdout |
174
|
|
|
|
|
|
|
#define stderr stderr |
175
|
|
|
|
|
|
|
|
176
|
|
|
|
|
|
|
__BEGIN_NAMESPACE_STD |
177
|
|
|
|
|
|
|
/* Remove file FILENAME. */ |
178
|
|
|
|
|
|
|
extern int remove (const char *__filename) __THROW; |
179
|
|
|
|
|
|
|
/* Rename file OLD to NEW. */ |
180
|
|
|
|
|
|
|
extern int rename (const char *__old, const char *__new) __THROW; |
181
|
|
|
|
|
|
|
__END_NAMESPACE_STD |
182
|
|
|
|
|
|
|
|
183
|
|
|
|
|
|
|
#ifdef __USE_ATFILE |
184
|
|
|
|
|
|
|
/* Rename file OLD relative to OLDFD to NEW relative to NEWFD. */ |
185
|
|
|
|
|
|
|
extern int renameat (int __oldfd, const char *__old, int __newfd, |
186
|
|
|
|
|
|
|
const char *__new) __THROW; |
187
|
|
|
|
|
|
|
#endif |
188
|
|
|
|
|
|
|
|
189
|
|
|
|
|
|
|
__BEGIN_NAMESPACE_STD |
190
|
|
|
|
|
|
|
/* Create a temporary file and open it read/write. |
191
|
|
|
|
|
|
|
|
192
|
|
|
|
|
|
|
This function is a possible cancellation point and therefore not |
193
|
|
|
|
|
|
|
marked with __THROW. */ |
194
|
|
|
|
|
|
|
#ifndef __USE_FILE_OFFSET64 |
195
|
|
|
|
|
|
|
extern FILE *tmpfile (void) __wur; |
196
|
|
|
|
|
|
|
#else |
197
|
|
|
|
|
|
|
# ifdef __REDIRECT |
198
|
|
|
|
|
|
|
extern FILE *__REDIRECT (tmpfile, (void), tmpfile64) __wur; |
199
|
|
|
|
|
|
|
# else |
200
|
|
|
|
|
|
|
# define tmpfile tmpfile64 |
201
|
|
|
|
|
|
|
# endif |
202
|
|
|
|
|
|
|
#endif |
203
|
|
|
|
|
|
|
|
204
|
|
|
|
|
|
|
#ifdef __USE_LARGEFILE64 |
205
|
|
|
|
|
|
|
extern FILE *tmpfile64 (void) __wur; |
206
|
|
|
|
|
|
|
#endif |
207
|
|
|
|
|
|
|
|
208
|
|
|
|
|
|
|
/* Generate a temporary filename. */ |
209
|
|
|
|
|
|
|
extern char *tmpnam (char *__s) __THROW __wur; |
210
|
|
|
|
|
|
|
__END_NAMESPACE_STD |
211
|
|
|
|
|
|
|
|
212
|
|
|
|
|
|
|
#ifdef __USE_MISC |
213
|
|
|
|
|
|
|
/* This is the reentrant variant of `tmpnam'. The only difference is |
214
|
|
|
|
|
|
|
that it does not allow S to be NULL. */ |
215
|
|
|
|
|
|
|
extern char *tmpnam_r (char *__s) __THROW __wur; |
216
|
|
|
|
|
|
|
#endif |
217
|
|
|
|
|
|
|
|
218
|
|
|
|
|
|
|
|
219
|
|
|
|
|
|
|
#if defined __USE_MISC || defined __USE_XOPEN |
220
|
|
|
|
|
|
|
/* Generate a unique temporary filename using up to five characters of PFX |
221
|
|
|
|
|
|
|
if it is not NULL. The directory to put this file in is searched for |
222
|
|
|
|
|
|
|
as follows: First the environment variable "TMPDIR" is checked. |
223
|
|
|
|
|
|
|
If it contains the name of a writable directory, that directory is used. |
224
|
|
|
|
|
|
|
If not and if DIR is not NULL, that value is checked. If that fails, |
225
|
|
|
|
|
|
|
P_tmpdir is tried and finally "/tmp". The storage for the filename |
226
|
|
|
|
|
|
|
is allocated by `malloc'. */ |
227
|
|
|
|
|
|
|
extern char *tempnam (const char *__dir, const char *__pfx) |
228
|
|
|
|
|
|
|
__THROW __attribute_malloc__ __wur; |
229
|
|
|
|
|
|
|
#endif |
230
|
|
|
|
|
|
|
|
231
|
|
|
|
|
|
|
|
232
|
|
|
|
|
|
|
__BEGIN_NAMESPACE_STD |
233
|
|
|
|
|
|
|
/* Close STREAM. |
234
|
|
|
|
|
|
|
|
235
|
|
|
|
|
|
|
This function is a possible cancellation point and therefore not |
236
|
|
|
|
|
|
|
marked with __THROW. */ |
237
|
|
|
|
|
|
|
extern int fclose (FILE *__stream); |
238
|
|
|
|
|
|
|
/* Flush STREAM, or all streams if STREAM is NULL. |
239
|
|
|
|
|
|
|
|
240
|
|
|
|
|
|
|
This function is a possible cancellation point and therefore not |
241
|
|
|
|
|
|
|
marked with __THROW. */ |
242
|
|
|
|
|
|
|
extern int fflush (FILE *__stream); |
243
|
|
|
|
|
|
|
__END_NAMESPACE_STD |
244
|
|
|
|
|
|
|
|
245
|
|
|
|
|
|
|
#ifdef __USE_MISC |
246
|
|
|
|
|
|
|
/* Faster versions when locking is not required. |
247
|
|
|
|
|
|
|
|
248
|
|
|
|
|
|
|
This function is not part of POSIX and therefore no official |
249
|
|
|
|
|
|
|
cancellation point. But due to similarity with an POSIX interface |
250
|
|
|
|
|
|
|
or due to the implementation it is a cancellation point and |
251
|
|
|
|
|
|
|
therefore not marked with __THROW. */ |
252
|
|
|
|
|
|
|
extern int fflush_unlocked (FILE *__stream); |
253
|
|
|
|
|
|
|
#endif |
254
|
|
|
|
|
|
|
|
255
|
|
|
|
|
|
|
#ifdef __USE_GNU |
256
|
|
|
|
|
|
|
/* Close all streams. |
257
|
|
|
|
|
|
|
|
258
|
|
|
|
|
|
|
This function is not part of POSIX and therefore no official |
259
|
|
|
|
|
|
|
cancellation point. But due to similarity with an POSIX interface |
260
|
|
|
|
|
|
|
or due to the implementation it is a cancellation point and |
261
|
|
|
|
|
|
|
therefore not marked with __THROW. */ |
262
|
|
|
|
|
|
|
extern int fcloseall (void); |
263
|
|
|
|
|
|
|
#endif |
264
|
|
|
|
|
|
|
|
265
|
|
|
|
|
|
|
|
266
|
|
|
|
|
|
|
__BEGIN_NAMESPACE_STD |
267
|
|
|
|
|
|
|
#ifndef __USE_FILE_OFFSET64 |
268
|
|
|
|
|
|
|
/* Open a file and create a new stream for it. |
269
|
|
|
|
|
|
|
|
270
|
|
|
|
|
|
|
This function is a possible cancellation point and therefore not |
271
|
|
|
|
|
|
|
marked with __THROW. */ |
272
|
|
|
|
|
|
|
extern FILE *fopen (const char *__restrict __filename, |
273
|
|
|
|
|
|
|
const char *__restrict __modes) __wur; |
274
|
|
|
|
|
|
|
/* Open a file, replacing an existing stream with it. |
275
|
|
|
|
|
|
|
|
276
|
|
|
|
|
|
|
This function is a possible cancellation point and therefore not |
277
|
|
|
|
|
|
|
marked with __THROW. */ |
278
|
|
|
|
|
|
|
extern FILE *freopen (const char *__restrict __filename, |
279
|
|
|
|
|
|
|
const char *__restrict __modes, |
280
|
|
|
|
|
|
|
FILE *__restrict __stream) __wur; |
281
|
|
|
|
|
|
|
#else |
282
|
|
|
|
|
|
|
# ifdef __REDIRECT |
283
|
|
|
|
|
|
|
extern FILE *__REDIRECT (fopen, (const char *__restrict __filename, |
284
|
|
|
|
|
|
|
const char *__restrict __modes), fopen64) |
285
|
|
|
|
|
|
|
__wur; |
286
|
|
|
|
|
|
|
extern FILE *__REDIRECT (freopen, (const char *__restrict __filename, |
287
|
|
|
|
|
|
|
const char *__restrict __modes, |
288
|
|
|
|
|
|
|
FILE *__restrict __stream), freopen64) |
289
|
|
|
|
|
|
|
__wur; |
290
|
|
|
|
|
|
|
# else |
291
|
|
|
|
|
|
|
# define fopen fopen64 |
292
|
|
|
|
|
|
|
# define freopen freopen64 |
293
|
|
|
|
|
|
|
# endif |
294
|
|
|
|
|
|
|
#endif |
295
|
|
|
|
|
|
|
__END_NAMESPACE_STD |
296
|
|
|
|
|
|
|
#ifdef __USE_LARGEFILE64 |
297
|
|
|
|
|
|
|
extern FILE *fopen64 (const char *__restrict __filename, |
298
|
|
|
|
|
|
|
const char *__restrict __modes) __wur; |
299
|
|
|
|
|
|
|
extern FILE *freopen64 (const char *__restrict __filename, |
300
|
|
|
|
|
|
|
const char *__restrict __modes, |
301
|
|
|
|
|
|
|
FILE *__restrict __stream) __wur; |
302
|
|
|
|
|
|
|
#endif |
303
|
|
|
|
|
|
|
|
304
|
|
|
|
|
|
|
#ifdef __USE_POSIX |
305
|
|
|
|
|
|
|
/* Create a new stream that refers to an existing system file descriptor. */ |
306
|
|
|
|
|
|
|
extern FILE *fdopen (int __fd, const char *__modes) __THROW __wur; |
307
|
|
|
|
|
|
|
#endif |
308
|
|
|
|
|
|
|
|
309
|
|
|
|
|
|
|
#ifdef __USE_GNU |
310
|
|
|
|
|
|
|
/* Create a new stream that refers to the given magic cookie, |
311
|
|
|
|
|
|
|
and uses the given functions for input and output. */ |
312
|
|
|
|
|
|
|
extern FILE *fopencookie (void *__restrict __magic_cookie, |
313
|
|
|
|
|
|
|
const char *__restrict __modes, |
314
|
|
|
|
|
|
|
_IO_cookie_io_functions_t __io_funcs) __THROW __wur; |
315
|
|
|
|
|
|
|
#endif |
316
|
|
|
|
|
|
|
|
317
|
|
|
|
|
|
|
#ifdef __USE_XOPEN2K8 |
318
|
|
|
|
|
|
|
/* Create a new stream that refers to a memory buffer. */ |
319
|
|
|
|
|
|
|
extern FILE *fmemopen (void *__s, size_t __len, const char *__modes) |
320
|
|
|
|
|
|
|
__THROW __wur; |
321
|
|
|
|
|
|
|
|
322
|
|
|
|
|
|
|
/* Open a stream that writes into a malloc'd buffer that is expanded as |
323
|
|
|
|
|
|
|
necessary. *BUFLOC and *SIZELOC are updated with the buffer's location |
324
|
|
|
|
|
|
|
and the number of characters written on fflush or fclose. */ |
325
|
|
|
|
|
|
|
extern FILE *open_memstream (char **__bufloc, size_t *__sizeloc) __THROW __wur; |
326
|
|
|
|
|
|
|
#endif |
327
|
|
|
|
|
|
|
|
328
|
|
|
|
|
|
|
|
329
|
|
|
|
|
|
|
__BEGIN_NAMESPACE_STD |
330
|
|
|
|
|
|
|
/* If BUF is NULL, make STREAM unbuffered. |
331
|
|
|
|
|
|
|
Else make it use buffer BUF, of size BUFSIZ. */ |
332
|
|
|
|
|
|
|
extern void setbuf (FILE *__restrict __stream, char *__restrict __buf) __THROW; |
333
|
|
|
|
|
|
|
/* Make STREAM use buffering mode MODE. |
334
|
|
|
|
|
|
|
If BUF is not NULL, use N bytes of it for buffering; |
335
|
|
|
|
|
|
|
else allocate an internal buffer N bytes long. */ |
336
|
|
|
|
|
|
|
extern int setvbuf (FILE *__restrict __stream, char *__restrict __buf, |
337
|
|
|
|
|
|
|
int __modes, size_t __n) __THROW; |
338
|
|
|
|
|
|
|
__END_NAMESPACE_STD |
339
|
|
|
|
|
|
|
|
340
|
|
|
|
|
|
|
#ifdef __USE_MISC |
341
|
|
|
|
|
|
|
/* If BUF is NULL, make STREAM unbuffered. |
342
|
|
|
|
|
|
|
Else make it use SIZE bytes of BUF for buffering. */ |
343
|
|
|
|
|
|
|
extern void setbuffer (FILE *__restrict __stream, char *__restrict __buf, |
344
|
|
|
|
|
|
|
size_t __size) __THROW; |
345
|
|
|
|
|
|
|
|
346
|
|
|
|
|
|
|
/* Make STREAM line-buffered. */ |
347
|
|
|
|
|
|
|
extern void setlinebuf (FILE *__stream) __THROW; |
348
|
|
|
|
|
|
|
#endif |
349
|
|
|
|
|
|
|
|
350
|
|
|
|
|
|
|
|
351
|
|
|
|
|
|
|
__BEGIN_NAMESPACE_STD |
352
|
|
|
|
|
|
|
/* Write formatted output to STREAM. |
353
|
|
|
|
|
|
|
|
354
|
|
|
|
|
|
|
This function is a possible cancellation point and therefore not |
355
|
|
|
|
|
|
|
marked with __THROW. */ |
356
|
|
|
|
|
|
|
extern int fprintf (FILE *__restrict __stream, |
357
|
|
|
|
|
|
|
const char *__restrict __format, ...); |
358
|
|
|
|
|
|
|
/* Write formatted output to stdout. |
359
|
|
|
|
|
|
|
|
360
|
|
|
|
|
|
|
This function is a possible cancellation point and therefore not |
361
|
|
|
|
|
|
|
marked with __THROW. */ |
362
|
|
|
|
|
|
|
extern int printf (const char *__restrict __format, ...); |
363
|
|
|
|
|
|
|
/* Write formatted output to S. */ |
364
|
|
|
|
|
|
|
extern int sprintf (char *__restrict __s, |
365
|
|
|
|
|
|
|
const char *__restrict __format, ...) __THROWNL; |
366
|
|
|
|
|
|
|
|
367
|
|
|
|
|
|
|
/* Write formatted output to S from argument list ARG. |
368
|
|
|
|
|
|
|
|
369
|
|
|
|
|
|
|
This function is a possible cancellation point and therefore not |
370
|
|
|
|
|
|
|
marked with __THROW. */ |
371
|
|
|
|
|
|
|
extern int vfprintf (FILE *__restrict __s, const char *__restrict __format, |
372
|
|
|
|
|
|
|
_G_va_list __arg); |
373
|
|
|
|
|
|
|
/* Write formatted output to stdout from argument list ARG. |
374
|
|
|
|
|
|
|
|
375
|
|
|
|
|
|
|
This function is a possible cancellation point and therefore not |
376
|
|
|
|
|
|
|
marked with __THROW. */ |
377
|
|
|
|
|
|
|
extern int vprintf (const char *__restrict __format, _G_va_list __arg); |
378
|
|
|
|
|
|
|
/* Write formatted output to S from argument list ARG. */ |
379
|
|
|
|
|
|
|
extern int vsprintf (char *__restrict __s, const char *__restrict __format, |
380
|
|
|
|
|
|
|
_G_va_list __arg) __THROWNL; |
381
|
|
|
|
|
|
|
__END_NAMESPACE_STD |
382
|
|
|
|
|
|
|
|
383
|
|
|
|
|
|
|
#if defined __USE_ISOC99 || defined __USE_UNIX98 |
384
|
|
|
|
|
|
|
__BEGIN_NAMESPACE_C99 |
385
|
|
|
|
|
|
|
/* Maximum chars of output to write in MAXLEN. */ |
386
|
|
|
|
|
|
|
extern int snprintf (char *__restrict __s, size_t __maxlen, |
387
|
|
|
|
|
|
|
const char *__restrict __format, ...) |
388
|
|
|
|
|
|
|
__THROWNL __attribute__ ((__format__ (__printf__, 3, 4))); |
389
|
|
|
|
|
|
|
|
390
|
|
|
|
|
|
|
extern int vsnprintf (char *__restrict __s, size_t __maxlen, |
391
|
|
|
|
|
|
|
const char *__restrict __format, _G_va_list __arg) |
392
|
|
|
|
|
|
|
__THROWNL __attribute__ ((__format__ (__printf__, 3, 0))); |
393
|
|
|
|
|
|
|
__END_NAMESPACE_C99 |
394
|
|
|
|
|
|
|
#endif |
395
|
|
|
|
|
|
|
|
396
|
|
|
|
|
|
|
#ifdef __USE_GNU |
397
|
|
|
|
|
|
|
/* Write formatted output to a string dynamically allocated with `malloc'. |
398
|
|
|
|
|
|
|
Store the address of the string in *PTR. */ |
399
|
0
|
|
|
|
|
|
extern int vasprintf (char **__restrict __ptr, const char *__restrict __f, |
400
|
|
|
|
|
|
|
_G_va_list __arg) |
401
|
|
|
|
|
|
|
__THROWNL __attribute__ ((__format__ (__printf__, 2, 0))) __wur; |
402
|
|
|
|
|
|
|
extern int __asprintf (char **__restrict __ptr, |
403
|
|
|
|
|
|
|
const char *__restrict __fmt, ...) |
404
|
|
|
|
|
|
|
__THROWNL __attribute__ ((__format__ (__printf__, 2, 3))) __wur; |
405
|
|
|
|
|
|
|
extern int asprintf (char **__restrict __ptr, |
406
|
|
|
|
|
|
|
const char *__restrict __fmt, ...) |
407
|
|
|
|
|
|
|
__THROWNL __attribute__ ((__format__ (__printf__, 2, 3))) __wur; |
408
|
|
|
|
|
|
|
#endif |
409
|
|
|
|
|
|
|
|
410
|
|
|
|
|
|
|
#ifdef __USE_XOPEN2K8 |
411
|
|
|
|
|
|
|
/* Write formatted output to a file descriptor. */ |
412
|
|
|
|
|
|
|
extern int vdprintf (int __fd, const char *__restrict __fmt, |
413
|
|
|
|
|
|
|
_G_va_list __arg) |
414
|
|
|
|
|
|
|
__attribute__ ((__format__ (__printf__, 2, 0))); |
415
|
|
|
|
|
|
|
extern int dprintf (int __fd, const char *__restrict __fmt, ...) |
416
|
|
|
|
|
|
|
__attribute__ ((__format__ (__printf__, 2, 3))); |
417
|
|
|
|
|
|
|
#endif |
418
|
|
|
|
|
|
|
|
419
|
|
|
|
|
|
|
|
420
|
|
|
|
|
|
|
__BEGIN_NAMESPACE_STD |
421
|
|
|
|
|
|
|
/* Read formatted input from STREAM. |
422
|
|
|
|
|
|
|
|
423
|
|
|
|
|
|
|
This function is a possible cancellation point and therefore not |
424
|
|
|
|
|
|
|
marked with __THROW. */ |
425
|
|
|
|
|
|
|
extern int fscanf (FILE *__restrict __stream, |
426
|
|
|
|
|
|
|
const char *__restrict __format, ...) __wur; |
427
|
|
|
|
|
|
|
/* Read formatted input from stdin. |
428
|
|
|
|
|
|
|
|
429
|
|
|
|
|
|
|
This function is a possible cancellation point and therefore not |
430
|
|
|
|
|
|
|
marked with __THROW. */ |
431
|
|
|
|
|
|
|
extern int scanf (const char *__restrict __format, ...) __wur; |
432
|
|
|
|
|
|
|
/* Read formatted input from S. */ |
433
|
|
|
|
|
|
|
extern int sscanf (const char *__restrict __s, |
434
|
|
|
|
|
|
|
const char *__restrict __format, ...) __THROW; |
435
|
|
|
|
|
|
|
|
436
|
|
|
|
|
|
|
#if defined __USE_ISOC99 && !defined __USE_GNU \ |
437
|
|
|
|
|
|
|
&& (!defined __LDBL_COMPAT || !defined __REDIRECT) \ |
438
|
|
|
|
|
|
|
&& (defined __STRICT_ANSI__ || defined __USE_XOPEN2K) |
439
|
|
|
|
|
|
|
# ifdef __REDIRECT |
440
|
|
|
|
|
|
|
/* For strict ISO C99 or POSIX compliance disallow %as, %aS and %a[ |
441
|
|
|
|
|
|
|
GNU extension which conflicts with valid %a followed by letter |
442
|
|
|
|
|
|
|
s, S or [. */ |
443
|
|
|
|
|
|
|
extern int __REDIRECT (fscanf, (FILE *__restrict __stream, |
444
|
|
|
|
|
|
|
const char *__restrict __format, ...), |
445
|
|
|
|
|
|
|
__isoc99_fscanf) __wur; |
446
|
|
|
|
|
|
|
extern int __REDIRECT (scanf, (const char *__restrict __format, ...), |
447
|
|
|
|
|
|
|
__isoc99_scanf) __wur; |
448
|
|
|
|
|
|
|
extern int __REDIRECT_NTH (sscanf, (const char *__restrict __s, |
449
|
|
|
|
|
|
|
const char *__restrict __format, ...), |
450
|
|
|
|
|
|
|
__isoc99_sscanf); |
451
|
|
|
|
|
|
|
# else |
452
|
|
|
|
|
|
|
extern int __isoc99_fscanf (FILE *__restrict __stream, |
453
|
|
|
|
|
|
|
const char *__restrict __format, ...) __wur; |
454
|
|
|
|
|
|
|
extern int __isoc99_scanf (const char *__restrict __format, ...) __wur; |
455
|
|
|
|
|
|
|
extern int __isoc99_sscanf (const char *__restrict __s, |
456
|
|
|
|
|
|
|
const char *__restrict __format, ...) __THROW; |
457
|
|
|
|
|
|
|
# define fscanf __isoc99_fscanf |
458
|
|
|
|
|
|
|
# define scanf __isoc99_scanf |
459
|
|
|
|
|
|
|
# define sscanf __isoc99_sscanf |
460
|
|
|
|
|
|
|
# endif |
461
|
|
|
|
|
|
|
#endif |
462
|
|
|
|
|
|
|
|
463
|
|
|
|
|
|
|
__END_NAMESPACE_STD |
464
|
|
|
|
|
|
|
|
465
|
|
|
|
|
|
|
#ifdef __USE_ISOC99 |
466
|
|
|
|
|
|
|
__BEGIN_NAMESPACE_C99 |
467
|
|
|
|
|
|
|
/* Read formatted input from S into argument list ARG. |
468
|
|
|
|
|
|
|
|
469
|
|
|
|
|
|
|
This function is a possible cancellation point and therefore not |
470
|
|
|
|
|
|
|
marked with __THROW. */ |
471
|
|
|
|
|
|
|
extern int vfscanf (FILE *__restrict __s, const char *__restrict __format, |
472
|
|
|
|
|
|
|
_G_va_list __arg) |
473
|
|
|
|
|
|
|
__attribute__ ((__format__ (__scanf__, 2, 0))) __wur; |
474
|
|
|
|
|
|
|
|
475
|
|
|
|
|
|
|
/* Read formatted input from stdin into argument list ARG. |
476
|
|
|
|
|
|
|
|
477
|
|
|
|
|
|
|
This function is a possible cancellation point and therefore not |
478
|
|
|
|
|
|
|
marked with __THROW. */ |
479
|
|
|
|
|
|
|
extern int vscanf (const char *__restrict __format, _G_va_list __arg) |
480
|
|
|
|
|
|
|
__attribute__ ((__format__ (__scanf__, 1, 0))) __wur; |
481
|
|
|
|
|
|
|
|
482
|
|
|
|
|
|
|
/* Read formatted input from S into argument list ARG. */ |
483
|
|
|
|
|
|
|
extern int vsscanf (const char *__restrict __s, |
484
|
|
|
|
|
|
|
const char *__restrict __format, _G_va_list __arg) |
485
|
|
|
|
|
|
|
__THROW __attribute__ ((__format__ (__scanf__, 2, 0))); |
486
|
|
|
|
|
|
|
|
487
|
|
|
|
|
|
|
# if !defined __USE_GNU \ |
488
|
|
|
|
|
|
|
&& (!defined __LDBL_COMPAT || !defined __REDIRECT) \ |
489
|
|
|
|
|
|
|
&& (defined __STRICT_ANSI__ || defined __USE_XOPEN2K) |
490
|
|
|
|
|
|
|
# ifdef __REDIRECT |
491
|
|
|
|
|
|
|
/* For strict ISO C99 or POSIX compliance disallow %as, %aS and %a[ |
492
|
|
|
|
|
|
|
GNU extension which conflicts with valid %a followed by letter |
493
|
|
|
|
|
|
|
s, S or [. */ |
494
|
|
|
|
|
|
|
extern int __REDIRECT (vfscanf, |
495
|
|
|
|
|
|
|
(FILE *__restrict __s, |
496
|
|
|
|
|
|
|
const char *__restrict __format, _G_va_list __arg), |
497
|
|
|
|
|
|
|
__isoc99_vfscanf) |
498
|
|
|
|
|
|
|
__attribute__ ((__format__ (__scanf__, 2, 0))) __wur; |
499
|
|
|
|
|
|
|
extern int __REDIRECT (vscanf, (const char *__restrict __format, |
500
|
|
|
|
|
|
|
_G_va_list __arg), __isoc99_vscanf) |
501
|
|
|
|
|
|
|
__attribute__ ((__format__ (__scanf__, 1, 0))) __wur; |
502
|
|
|
|
|
|
|
extern int __REDIRECT_NTH (vsscanf, |
503
|
|
|
|
|
|
|
(const char *__restrict __s, |
504
|
|
|
|
|
|
|
const char *__restrict __format, |
505
|
|
|
|
|
|
|
_G_va_list __arg), __isoc99_vsscanf) |
506
|
|
|
|
|
|
|
__attribute__ ((__format__ (__scanf__, 2, 0))); |
507
|
|
|
|
|
|
|
# else |
508
|
|
|
|
|
|
|
extern int __isoc99_vfscanf (FILE *__restrict __s, |
509
|
|
|
|
|
|
|
const char *__restrict __format, |
510
|
|
|
|
|
|
|
_G_va_list __arg) __wur; |
511
|
|
|
|
|
|
|
extern int __isoc99_vscanf (const char *__restrict __format, |
512
|
|
|
|
|
|
|
_G_va_list __arg) __wur; |
513
|
|
|
|
|
|
|
extern int __isoc99_vsscanf (const char *__restrict __s, |
514
|
|
|
|
|
|
|
const char *__restrict __format, |
515
|
|
|
|
|
|
|
_G_va_list __arg) __THROW; |
516
|
|
|
|
|
|
|
# define vfscanf __isoc99_vfscanf |
517
|
|
|
|
|
|
|
# define vscanf __isoc99_vscanf |
518
|
|
|
|
|
|
|
# define vsscanf __isoc99_vsscanf |
519
|
|
|
|
|
|
|
# endif |
520
|
|
|
|
|
|
|
# endif |
521
|
|
|
|
|
|
|
|
522
|
|
|
|
|
|
|
__END_NAMESPACE_C99 |
523
|
|
|
|
|
|
|
#endif /* Use ISO C9x. */ |
524
|
|
|
|
|
|
|
|
525
|
|
|
|
|
|
|
|
526
|
|
|
|
|
|
|
__BEGIN_NAMESPACE_STD |
527
|
|
|
|
|
|
|
/* Read a character from STREAM. |
528
|
|
|
|
|
|
|
|
529
|
|
|
|
|
|
|
These functions are possible cancellation points and therefore not |
530
|
|
|
|
|
|
|
marked with __THROW. */ |
531
|
|
|
|
|
|
|
extern int fgetc (FILE *__stream); |
532
|
|
|
|
|
|
|
extern int getc (FILE *__stream); |
533
|
|
|
|
|
|
|
|
534
|
|
|
|
|
|
|
/* Read a character from stdin. |
535
|
|
|
|
|
|
|
|
536
|
|
|
|
|
|
|
This function is a possible cancellation point and therefore not |
537
|
|
|
|
|
|
|
marked with __THROW. */ |
538
|
|
|
|
|
|
|
extern int getchar (void); |
539
|
|
|
|
|
|
|
__END_NAMESPACE_STD |
540
|
|
|
|
|
|
|
|
541
|
|
|
|
|
|
|
/* The C standard explicitly says this is a macro, so we always do the |
542
|
|
|
|
|
|
|
optimization for it. */ |
543
|
|
|
|
|
|
|
#define getc(_fp) _IO_getc (_fp) |
544
|
|
|
|
|
|
|
|
545
|
|
|
|
|
|
|
#ifdef __USE_POSIX |
546
|
|
|
|
|
|
|
/* These are defined in POSIX.1:1996. |
547
|
|
|
|
|
|
|
|
548
|
|
|
|
|
|
|
These functions are possible cancellation points and therefore not |
549
|
|
|
|
|
|
|
marked with __THROW. */ |
550
|
|
|
|
|
|
|
extern int getc_unlocked (FILE *__stream); |
551
|
|
|
|
|
|
|
extern int getchar_unlocked (void); |
552
|
|
|
|
|
|
|
#endif /* Use POSIX. */ |
553
|
|
|
|
|
|
|
|
554
|
|
|
|
|
|
|
#ifdef __USE_MISC |
555
|
|
|
|
|
|
|
/* Faster version when locking is not necessary. |
556
|
|
|
|
|
|
|
|
557
|
|
|
|
|
|
|
This function is not part of POSIX and therefore no official |
558
|
|
|
|
|
|
|
cancellation point. But due to similarity with an POSIX interface |
559
|
|
|
|
|
|
|
or due to the implementation it is a cancellation point and |
560
|
|
|
|
|
|
|
therefore not marked with __THROW. */ |
561
|
|
|
|
|
|
|
extern int fgetc_unlocked (FILE *__stream); |
562
|
|
|
|
|
|
|
#endif /* Use MISC. */ |
563
|
|
|
|
|
|
|
|
564
|
|
|
|
|
|
|
|
565
|
|
|
|
|
|
|
__BEGIN_NAMESPACE_STD |
566
|
|
|
|
|
|
|
/* Write a character to STREAM. |
567
|
|
|
|
|
|
|
|
568
|
|
|
|
|
|
|
These functions are possible cancellation points and therefore not |
569
|
|
|
|
|
|
|
marked with __THROW. |
570
|
|
|
|
|
|
|
|
571
|
|
|
|
|
|
|
These functions is a possible cancellation point and therefore not |
572
|
|
|
|
|
|
|
marked with __THROW. */ |
573
|
|
|
|
|
|
|
extern int fputc (int __c, FILE *__stream); |
574
|
|
|
|
|
|
|
extern int putc (int __c, FILE *__stream); |
575
|
|
|
|
|
|
|
|
576
|
|
|
|
|
|
|
/* Write a character to stdout. |
577
|
|
|
|
|
|
|
|
578
|
|
|
|
|
|
|
This function is a possible cancellation point and therefore not |
579
|
|
|
|
|
|
|
marked with __THROW. */ |
580
|
|
|
|
|
|
|
extern int putchar (int __c); |
581
|
|
|
|
|
|
|
__END_NAMESPACE_STD |
582
|
|
|
|
|
|
|
|
583
|
|
|
|
|
|
|
/* The C standard explicitly says this can be a macro, |
584
|
|
|
|
|
|
|
so we always do the optimization for it. */ |
585
|
|
|
|
|
|
|
#define putc(_ch, _fp) _IO_putc (_ch, _fp) |
586
|
|
|
|
|
|
|
|
587
|
|
|
|
|
|
|
#ifdef __USE_MISC |
588
|
|
|
|
|
|
|
/* Faster version when locking is not necessary. |
589
|
|
|
|
|
|
|
|
590
|
|
|
|
|
|
|
This function is not part of POSIX and therefore no official |
591
|
|
|
|
|
|
|
cancellation point. But due to similarity with an POSIX interface |
592
|
|
|
|
|
|
|
or due to the implementation it is a cancellation point and |
593
|
|
|
|
|
|
|
therefore not marked with __THROW. */ |
594
|
|
|
|
|
|
|
extern int fputc_unlocked (int __c, FILE *__stream); |
595
|
|
|
|
|
|
|
#endif /* Use MISC. */ |
596
|
|
|
|
|
|
|
|
597
|
|
|
|
|
|
|
#ifdef __USE_POSIX |
598
|
|
|
|
|
|
|
/* These are defined in POSIX.1:1996. |
599
|
|
|
|
|
|
|
|
600
|
|
|
|
|
|
|
These functions are possible cancellation points and therefore not |
601
|
|
|
|
|
|
|
marked with __THROW. */ |
602
|
|
|
|
|
|
|
extern int putc_unlocked (int __c, FILE *__stream); |
603
|
|
|
|
|
|
|
extern int putchar_unlocked (int __c); |
604
|
|
|
|
|
|
|
#endif /* Use POSIX. */ |
605
|
|
|
|
|
|
|
|
606
|
|
|
|
|
|
|
|
607
|
|
|
|
|
|
|
#if defined __USE_MISC \ |
608
|
|
|
|
|
|
|
|| (defined __USE_XOPEN && !defined __USE_XOPEN2K) |
609
|
|
|
|
|
|
|
/* Get a word (int) from STREAM. */ |
610
|
|
|
|
|
|
|
extern int getw (FILE *__stream); |
611
|
|
|
|
|
|
|
|
612
|
|
|
|
|
|
|
/* Write a word (int) to STREAM. */ |
613
|
|
|
|
|
|
|
extern int putw (int __w, FILE *__stream); |
614
|
|
|
|
|
|
|
#endif |
615
|
|
|
|
|
|
|
|
616
|
|
|
|
|
|
|
|
617
|
|
|
|
|
|
|
__BEGIN_NAMESPACE_STD |
618
|
|
|
|
|
|
|
/* Get a newline-terminated string of finite length from STREAM. |
619
|
|
|
|
|
|
|
|
620
|
|
|
|
|
|
|
This function is a possible cancellation point and therefore not |
621
|
|
|
|
|
|
|
marked with __THROW. */ |
622
|
|
|
|
|
|
|
extern char *fgets (char *__restrict __s, int __n, FILE *__restrict __stream) |
623
|
|
|
|
|
|
|
__wur; |
624
|
|
|
|
|
|
|
|
625
|
|
|
|
|
|
|
#if !defined __USE_ISOC11 \ |
626
|
|
|
|
|
|
|
|| (defined __cplusplus && __cplusplus <= 201103L) |
627
|
|
|
|
|
|
|
/* Get a newline-terminated string from stdin, removing the newline. |
628
|
|
|
|
|
|
|
DO NOT USE THIS FUNCTION!! There is no limit on how much it will read. |
629
|
|
|
|
|
|
|
|
630
|
|
|
|
|
|
|
The function has been officially removed in ISO C11. This opportunity |
631
|
|
|
|
|
|
|
is used to also remove it from the GNU feature list. It is now only |
632
|
|
|
|
|
|
|
available when explicitly using an old ISO C, Unix, or POSIX standard. |
633
|
|
|
|
|
|
|
GCC defines _GNU_SOURCE when building C++ code and the function is still |
634
|
|
|
|
|
|
|
in C++11, so it is also available for C++. |
635
|
|
|
|
|
|
|
|
636
|
|
|
|
|
|
|
This function is a possible cancellation point and therefore not |
637
|
|
|
|
|
|
|
marked with __THROW. */ |
638
|
|
|
|
|
|
|
extern char *gets (char *__s) __wur __attribute_deprecated__; |
639
|
|
|
|
|
|
|
#endif |
640
|
|
|
|
|
|
|
__END_NAMESPACE_STD |
641
|
|
|
|
|
|
|
|
642
|
|
|
|
|
|
|
#ifdef __USE_GNU |
643
|
|
|
|
|
|
|
/* This function does the same as `fgets' but does not lock the stream. |
644
|
|
|
|
|
|
|
|
645
|
|
|
|
|
|
|
This function is not part of POSIX and therefore no official |
646
|
|
|
|
|
|
|
cancellation point. But due to similarity with an POSIX interface |
647
|
|
|
|
|
|
|
or due to the implementation it is a cancellation point and |
648
|
|
|
|
|
|
|
therefore not marked with __THROW. */ |
649
|
|
|
|
|
|
|
extern char *fgets_unlocked (char *__restrict __s, int __n, |
650
|
|
|
|
|
|
|
FILE *__restrict __stream) __wur; |
651
|
|
|
|
|
|
|
#endif |
652
|
|
|
|
|
|
|
|
653
|
|
|
|
|
|
|
|
654
|
|
|
|
|
|
|
#ifdef __USE_XOPEN2K8 |
655
|
|
|
|
|
|
|
/* Read up to (and including) a DELIMITER from STREAM into *LINEPTR |
656
|
|
|
|
|
|
|
(and null-terminate it). *LINEPTR is a pointer returned from malloc (or |
657
|
|
|
|
|
|
|
NULL), pointing to *N characters of space. It is realloc'd as |
658
|
|
|
|
|
|
|
necessary. Returns the number of characters read (not including the |
659
|
|
|
|
|
|
|
null terminator), or -1 on error or EOF. |
660
|
|
|
|
|
|
|
|
661
|
|
|
|
|
|
|
These functions are not part of POSIX and therefore no official |
662
|
|
|
|
|
|
|
cancellation point. But due to similarity with an POSIX interface |
663
|
|
|
|
|
|
|
or due to the implementation they are cancellation points and |
664
|
|
|
|
|
|
|
therefore not marked with __THROW. */ |
665
|
|
|
|
|
|
|
extern _IO_ssize_t __getdelim (char **__restrict __lineptr, |
666
|
|
|
|
|
|
|
size_t *__restrict __n, int __delimiter, |
667
|
|
|
|
|
|
|
FILE *__restrict __stream) __wur; |
668
|
|
|
|
|
|
|
extern _IO_ssize_t getdelim (char **__restrict __lineptr, |
669
|
|
|
|
|
|
|
size_t *__restrict __n, int __delimiter, |
670
|
|
|
|
|
|
|
FILE *__restrict __stream) __wur; |
671
|
|
|
|
|
|
|
|
672
|
|
|
|
|
|
|
/* Like `getdelim', but reads up to a newline. |
673
|
|
|
|
|
|
|
|
674
|
|
|
|
|
|
|
This function is not part of POSIX and therefore no official |
675
|
|
|
|
|
|
|
cancellation point. But due to similarity with an POSIX interface |
676
|
|
|
|
|
|
|
or due to the implementation it is a cancellation point and |
677
|
|
|
|
|
|
|
therefore not marked with __THROW. */ |
678
|
|
|
|
|
|
|
extern _IO_ssize_t getline (char **__restrict __lineptr, |
679
|
|
|
|
|
|
|
size_t *__restrict __n, |
680
|
|
|
|
|
|
|
FILE *__restrict __stream) __wur; |
681
|
|
|
|
|
|
|
#endif |
682
|
|
|
|
|
|
|
|
683
|
|
|
|
|
|
|
|
684
|
|
|
|
|
|
|
__BEGIN_NAMESPACE_STD |
685
|
|
|
|
|
|
|
/* Write a string to STREAM. |
686
|
|
|
|
|
|
|
|
687
|
|
|
|
|
|
|
This function is a possible cancellation point and therefore not |
688
|
|
|
|
|
|
|
marked with __THROW. */ |
689
|
|
|
|
|
|
|
extern int fputs (const char *__restrict __s, FILE *__restrict __stream); |
690
|
|
|
|
|
|
|
|
691
|
|
|
|
|
|
|
/* Write a string, followed by a newline, to stdout. |
692
|
|
|
|
|
|
|
|
693
|
|
|
|
|
|
|
This function is a possible cancellation point and therefore not |
694
|
|
|
|
|
|
|
marked with __THROW. */ |
695
|
|
|
|
|
|
|
extern int puts (const char *__s); |
696
|
|
|
|
|
|
|
|
697
|
|
|
|
|
|
|
|
698
|
|
|
|
|
|
|
/* Push a character back onto the input buffer of STREAM. |
699
|
|
|
|
|
|
|
|
700
|
|
|
|
|
|
|
This function is a possible cancellation point and therefore not |
701
|
|
|
|
|
|
|
marked with __THROW. */ |
702
|
|
|
|
|
|
|
extern int ungetc (int __c, FILE *__stream); |
703
|
|
|
|
|
|
|
|
704
|
|
|
|
|
|
|
|
705
|
|
|
|
|
|
|
/* Read chunks of generic data from STREAM. |
706
|
|
|
|
|
|
|
|
707
|
|
|
|
|
|
|
This function is a possible cancellation point and therefore not |
708
|
|
|
|
|
|
|
marked with __THROW. */ |
709
|
|
|
|
|
|
|
extern size_t fread (void *__restrict __ptr, size_t __size, |
710
|
|
|
|
|
|
|
size_t __n, FILE *__restrict __stream) __wur; |
711
|
|
|
|
|
|
|
/* Write chunks of generic data to STREAM. |
712
|
|
|
|
|
|
|
|
713
|
|
|
|
|
|
|
This function is a possible cancellation point and therefore not |
714
|
|
|
|
|
|
|
marked with __THROW. */ |
715
|
|
|
|
|
|
|
extern size_t fwrite (const void *__restrict __ptr, size_t __size, |
716
|
|
|
|
|
|
|
size_t __n, FILE *__restrict __s); |
717
|
|
|
|
|
|
|
__END_NAMESPACE_STD |
718
|
|
|
|
|
|
|
|
719
|
|
|
|
|
|
|
#ifdef __USE_GNU |
720
|
|
|
|
|
|
|
/* This function does the same as `fputs' but does not lock the stream. |
721
|
|
|
|
|
|
|
|
722
|
|
|
|
|
|
|
This function is not part of POSIX and therefore no official |
723
|
|
|
|
|
|
|
cancellation point. But due to similarity with an POSIX interface |
724
|
|
|
|
|
|
|
or due to the implementation it is a cancellation point and |
725
|
|
|
|
|
|
|
therefore not marked with __THROW. */ |
726
|
|
|
|
|
|
|
extern int fputs_unlocked (const char *__restrict __s, |
727
|
|
|
|
|
|
|
FILE *__restrict __stream); |
728
|
|
|
|
|
|
|
#endif |
729
|
|
|
|
|
|
|
|
730
|
|
|
|
|
|
|
#ifdef __USE_MISC |
731
|
|
|
|
|
|
|
/* Faster versions when locking is not necessary. |
732
|
|
|
|
|
|
|
|
733
|
|
|
|
|
|
|
These functions are not part of POSIX and therefore no official |
734
|
|
|
|
|
|
|
cancellation point. But due to similarity with an POSIX interface |
735
|
|
|
|
|
|
|
or due to the implementation they are cancellation points and |
736
|
|
|
|
|
|
|
therefore not marked with __THROW. */ |
737
|
|
|
|
|
|
|
extern size_t fread_unlocked (void *__restrict __ptr, size_t __size, |
738
|
|
|
|
|
|
|
size_t __n, FILE *__restrict __stream) __wur; |
739
|
|
|
|
|
|
|
extern size_t fwrite_unlocked (const void *__restrict __ptr, size_t __size, |
740
|
|
|
|
|
|
|
size_t __n, FILE *__restrict __stream); |
741
|
|
|
|
|
|
|
#endif |
742
|
|
|
|
|
|
|
|
743
|
|
|
|
|
|
|
|
744
|
|
|
|
|
|
|
__BEGIN_NAMESPACE_STD |
745
|
|
|
|
|
|
|
/* Seek to a certain position on STREAM. |
746
|
|
|
|
|
|
|
|
747
|
|
|
|
|
|
|
This function is a possible cancellation point and therefore not |
748
|
|
|
|
|
|
|
marked with __THROW. */ |
749
|
|
|
|
|
|
|
extern int fseek (FILE *__stream, long int __off, int __whence); |
750
|
|
|
|
|
|
|
/* Return the current position of STREAM. |
751
|
|
|
|
|
|
|
|
752
|
|
|
|
|
|
|
This function is a possible cancellation point and therefore not |
753
|
|
|
|
|
|
|
marked with __THROW. */ |
754
|
|
|
|
|
|
|
extern long int ftell (FILE *__stream) __wur; |
755
|
|
|
|
|
|
|
/* Rewind to the beginning of STREAM. |
756
|
|
|
|
|
|
|
|
757
|
|
|
|
|
|
|
This function is a possible cancellation point and therefore not |
758
|
|
|
|
|
|
|
marked with __THROW. */ |
759
|
|
|
|
|
|
|
extern void rewind (FILE *__stream); |
760
|
|
|
|
|
|
|
__END_NAMESPACE_STD |
761
|
|
|
|
|
|
|
|
762
|
|
|
|
|
|
|
/* The Single Unix Specification, Version 2, specifies an alternative, |
763
|
|
|
|
|
|
|
more adequate interface for the two functions above which deal with |
764
|
|
|
|
|
|
|
file offset. `long int' is not the right type. These definitions |
765
|
|
|
|
|
|
|
are originally defined in the Large File Support API. */ |
766
|
|
|
|
|
|
|
|
767
|
|
|
|
|
|
|
#if defined __USE_LARGEFILE || defined __USE_XOPEN2K |
768
|
|
|
|
|
|
|
# ifndef __USE_FILE_OFFSET64 |
769
|
|
|
|
|
|
|
/* Seek to a certain position on STREAM. |
770
|
|
|
|
|
|
|
|
771
|
|
|
|
|
|
|
This function is a possible cancellation point and therefore not |
772
|
|
|
|
|
|
|
marked with __THROW. */ |
773
|
|
|
|
|
|
|
extern int fseeko (FILE *__stream, __off_t __off, int __whence); |
774
|
|
|
|
|
|
|
/* Return the current position of STREAM. |
775
|
|
|
|
|
|
|
|
776
|
|
|
|
|
|
|
This function is a possible cancellation point and therefore not |
777
|
|
|
|
|
|
|
marked with __THROW. */ |
778
|
|
|
|
|
|
|
extern __off_t ftello (FILE *__stream) __wur; |
779
|
|
|
|
|
|
|
# else |
780
|
|
|
|
|
|
|
# ifdef __REDIRECT |
781
|
|
|
|
|
|
|
extern int __REDIRECT (fseeko, |
782
|
|
|
|
|
|
|
(FILE *__stream, __off64_t __off, int __whence), |
783
|
|
|
|
|
|
|
fseeko64); |
784
|
|
|
|
|
|
|
extern __off64_t __REDIRECT (ftello, (FILE *__stream), ftello64); |
785
|
|
|
|
|
|
|
# else |
786
|
|
|
|
|
|
|
# define fseeko fseeko64 |
787
|
|
|
|
|
|
|
# define ftello ftello64 |
788
|
|
|
|
|
|
|
# endif |
789
|
|
|
|
|
|
|
# endif |
790
|
|
|
|
|
|
|
#endif |
791
|
|
|
|
|
|
|
|
792
|
|
|
|
|
|
|
__BEGIN_NAMESPACE_STD |
793
|
|
|
|
|
|
|
#ifndef __USE_FILE_OFFSET64 |
794
|
|
|
|
|
|
|
/* Get STREAM's position. |
795
|
|
|
|
|
|
|
|
796
|
|
|
|
|
|
|
This function is a possible cancellation point and therefore not |
797
|
|
|
|
|
|
|
marked with __THROW. */ |
798
|
|
|
|
|
|
|
extern int fgetpos (FILE *__restrict __stream, fpos_t *__restrict __pos); |
799
|
|
|
|
|
|
|
/* Set STREAM's position. |
800
|
|
|
|
|
|
|
|
801
|
|
|
|
|
|
|
This function is a possible cancellation point and therefore not |
802
|
|
|
|
|
|
|
marked with __THROW. */ |
803
|
|
|
|
|
|
|
extern int fsetpos (FILE *__stream, const fpos_t *__pos); |
804
|
|
|
|
|
|
|
#else |
805
|
|
|
|
|
|
|
# ifdef __REDIRECT |
806
|
|
|
|
|
|
|
extern int __REDIRECT (fgetpos, (FILE *__restrict __stream, |
807
|
|
|
|
|
|
|
fpos_t *__restrict __pos), fgetpos64); |
808
|
|
|
|
|
|
|
extern int __REDIRECT (fsetpos, |
809
|
|
|
|
|
|
|
(FILE *__stream, const fpos_t *__pos), fsetpos64); |
810
|
|
|
|
|
|
|
# else |
811
|
|
|
|
|
|
|
# define fgetpos fgetpos64 |
812
|
|
|
|
|
|
|
# define fsetpos fsetpos64 |
813
|
|
|
|
|
|
|
# endif |
814
|
|
|
|
|
|
|
#endif |
815
|
|
|
|
|
|
|
__END_NAMESPACE_STD |
816
|
|
|
|
|
|
|
|
817
|
|
|
|
|
|
|
#ifdef __USE_LARGEFILE64 |
818
|
|
|
|
|
|
|
extern int fseeko64 (FILE *__stream, __off64_t __off, int __whence); |
819
|
|
|
|
|
|
|
extern __off64_t ftello64 (FILE *__stream) __wur; |
820
|
|
|
|
|
|
|
extern int fgetpos64 (FILE *__restrict __stream, fpos64_t *__restrict __pos); |
821
|
|
|
|
|
|
|
extern int fsetpos64 (FILE *__stream, const fpos64_t *__pos); |
822
|
|
|
|
|
|
|
#endif |
823
|
|
|
|
|
|
|
|
824
|
|
|
|
|
|
|
__BEGIN_NAMESPACE_STD |
825
|
|
|
|
|
|
|
/* Clear the error and EOF indicators for STREAM. */ |
826
|
|
|
|
|
|
|
extern void clearerr (FILE *__stream) __THROW; |
827
|
|
|
|
|
|
|
/* Return the EOF indicator for STREAM. */ |
828
|
|
|
|
|
|
|
extern int feof (FILE *__stream) __THROW __wur; |
829
|
|
|
|
|
|
|
/* Return the error indicator for STREAM. */ |
830
|
|
|
|
|
|
|
extern int ferror (FILE *__stream) __THROW __wur; |
831
|
|
|
|
|
|
|
__END_NAMESPACE_STD |
832
|
|
|
|
|
|
|
|
833
|
|
|
|
|
|
|
#ifdef __USE_MISC |
834
|
|
|
|
|
|
|
/* Faster versions when locking is not required. */ |
835
|
|
|
|
|
|
|
extern void clearerr_unlocked (FILE *__stream) __THROW; |
836
|
|
|
|
|
|
|
extern int feof_unlocked (FILE *__stream) __THROW __wur; |
837
|
|
|
|
|
|
|
extern int ferror_unlocked (FILE *__stream) __THROW __wur; |
838
|
|
|
|
|
|
|
#endif |
839
|
|
|
|
|
|
|
|
840
|
|
|
|
|
|
|
|
841
|
|
|
|
|
|
|
__BEGIN_NAMESPACE_STD |
842
|
|
|
|
|
|
|
/* Print a message describing the meaning of the value of errno. |
843
|
|
|
|
|
|
|
|
844
|
|
|
|
|
|
|
This function is a possible cancellation point and therefore not |
845
|
|
|
|
|
|
|
marked with __THROW. */ |
846
|
|
|
|
|
|
|
extern void perror (const char *__s); |
847
|
|
|
|
|
|
|
__END_NAMESPACE_STD |
848
|
|
|
|
|
|
|
|
849
|
|
|
|
|
|
|
/* Provide the declarations for `sys_errlist' and `sys_nerr' if they |
850
|
|
|
|
|
|
|
are available on this system. Even if available, these variables |
851
|
|
|
|
|
|
|
should not be used directly. The `strerror' function provides |
852
|
|
|
|
|
|
|
all the necessary functionality. */ |
853
|
|
|
|
|
|
|
#include |
854
|
|
|
|
|
|
|
|
855
|
|
|
|
|
|
|
|
856
|
|
|
|
|
|
|
#ifdef __USE_POSIX |
857
|
|
|
|
|
|
|
/* Return the system file descriptor for STREAM. */ |
858
|
|
|
|
|
|
|
extern int fileno (FILE *__stream) __THROW __wur; |
859
|
|
|
|
|
|
|
#endif /* Use POSIX. */ |
860
|
|
|
|
|
|
|
|
861
|
|
|
|
|
|
|
#ifdef __USE_MISC |
862
|
|
|
|
|
|
|
/* Faster version when locking is not required. */ |
863
|
|
|
|
|
|
|
extern int fileno_unlocked (FILE *__stream) __THROW __wur; |
864
|
|
|
|
|
|
|
#endif |
865
|
|
|
|
|
|
|
|
866
|
|
|
|
|
|
|
|
867
|
|
|
|
|
|
|
#ifdef __USE_POSIX2 |
868
|
|
|
|
|
|
|
/* Create a new stream connected to a pipe running the given command. |
869
|
|
|
|
|
|
|
|
870
|
|
|
|
|
|
|
This function is a possible cancellation point and therefore not |
871
|
|
|
|
|
|
|
marked with __THROW. */ |
872
|
|
|
|
|
|
|
extern FILE *popen (const char *__command, const char *__modes) __wur; |
873
|
|
|
|
|
|
|
|
874
|
|
|
|
|
|
|
/* Close a stream opened by popen and return the status of its child. |
875
|
|
|
|
|
|
|
|
876
|
|
|
|
|
|
|
This function is a possible cancellation point and therefore not |
877
|
|
|
|
|
|
|
marked with __THROW. */ |
878
|
|
|
|
|
|
|
extern int pclose (FILE *__stream); |
879
|
|
|
|
|
|
|
#endif |
880
|
|
|
|
|
|
|
|
881
|
|
|
|
|
|
|
|
882
|
|
|
|
|
|
|
#ifdef __USE_POSIX |
883
|
|
|
|
|
|
|
/* Return the name of the controlling terminal. */ |
884
|
|
|
|
|
|
|
extern char *ctermid (char *__s) __THROW; |
885
|
|
|
|
|
|
|
#endif /* Use POSIX. */ |
886
|
|
|
|
|
|
|
|
887
|
|
|
|
|
|
|
|
888
|
|
|
|
|
|
|
#ifdef __USE_XOPEN |
889
|
|
|
|
|
|
|
/* Return the name of the current user. */ |
890
|
|
|
|
|
|
|
extern char *cuserid (char *__s); |
891
|
|
|
|
|
|
|
#endif /* Use X/Open, but not issue 6. */ |
892
|
|
|
|
|
|
|
|
893
|
|
|
|
|
|
|
|
894
|
|
|
|
|
|
|
#ifdef __USE_GNU |
895
|
|
|
|
|
|
|
struct obstack; /* See . */ |
896
|
|
|
|
|
|
|
|
897
|
|
|
|
|
|
|
/* Write formatted output to an obstack. */ |
898
|
|
|
|
|
|
|
extern int obstack_printf (struct obstack *__restrict __obstack, |
899
|
|
|
|
|
|
|
const char *__restrict __format, ...) |
900
|
|
|
|
|
|
|
__THROWNL __attribute__ ((__format__ (__printf__, 2, 3))); |
901
|
|
|
|
|
|
|
extern int obstack_vprintf (struct obstack *__restrict __obstack, |
902
|
|
|
|
|
|
|
const char *__restrict __format, |
903
|
|
|
|
|
|
|
_G_va_list __args) |
904
|
|
|
|
|
|
|
__THROWNL __attribute__ ((__format__ (__printf__, 2, 0))); |
905
|
|
|
|
|
|
|
#endif /* Use GNU. */ |
906
|
|
|
|
|
|
|
|
907
|
|
|
|
|
|
|
|
908
|
|
|
|
|
|
|
#ifdef __USE_POSIX |
909
|
|
|
|
|
|
|
/* These are defined in POSIX.1:1996. */ |
910
|
|
|
|
|
|
|
|
911
|
|
|
|
|
|
|
/* Acquire ownership of STREAM. */ |
912
|
|
|
|
|
|
|
extern void flockfile (FILE *__stream) __THROW; |
913
|
|
|
|
|
|
|
|
914
|
|
|
|
|
|
|
/* Try to acquire ownership of STREAM but do not block if it is not |
915
|
|
|
|
|
|
|
possible. */ |
916
|
|
|
|
|
|
|
extern int ftrylockfile (FILE *__stream) __THROW __wur; |
917
|
|
|
|
|
|
|
|
918
|
|
|
|
|
|
|
/* Relinquish the ownership granted for STREAM. */ |
919
|
|
|
|
|
|
|
extern void funlockfile (FILE *__stream) __THROW; |
920
|
|
|
|
|
|
|
#endif /* POSIX */ |
921
|
|
|
|
|
|
|
|
922
|
|
|
|
|
|
|
#if defined __USE_XOPEN && !defined __USE_XOPEN2K && !defined __USE_GNU |
923
|
|
|
|
|
|
|
/* The X/Open standard requires some functions and variables to be |
924
|
|
|
|
|
|
|
declared here which do not belong into this header. But we have to |
925
|
|
|
|
|
|
|
follow. In GNU mode we don't do this nonsense. */ |
926
|
|
|
|
|
|
|
# define __need_getopt |
927
|
|
|
|
|
|
|
# include |
928
|
|
|
|
|
|
|
#endif /* X/Open, but not issue 6 and not for GNU. */ |
929
|
|
|
|
|
|
|
|
930
|
|
|
|
|
|
|
/* If we are compiling with optimizing read this file. It contains |
931
|
|
|
|
|
|
|
several optimizing inline functions and macros. */ |
932
|
|
|
|
|
|
|
#ifdef __USE_EXTERN_INLINES |
933
|
|
|
|
|
|
|
# include |
934
|
|
|
|
|
|
|
#endif |
935
|
|
|
|
|
|
|
#if __USE_FORTIFY_LEVEL > 0 && defined __fortify_function |
936
|
|
|
|
|
|
|
# include |
937
|
|
|
|
|
|
|
#endif |
938
|
|
|
|
|
|
|
#ifdef __LDBL_COMPAT |
939
|
|
|
|
|
|
|
# include |
940
|
|
|
|
|
|
|
#endif |
941
|
|
|
|
|
|
|
|
942
|
|
|
|
|
|
|
__END_DECLS |
943
|
|
|
|
|
|
|
|
944
|
|
|
|
|
|
|
#endif /* included. */ |
945
|
|
|
|
|
|
|
|
946
|
|
|
|
|
|
|
#endif /* !_STDIO_H */ |