2022-10-01 18:59:22 +00:00
|
|
|
#ifndef _STDIO_H
|
|
|
|
#define _STDIO_H
|
|
|
|
|
|
|
|
#include <stdarg.h>
|
|
|
|
#include <stddef.h>
|
2022-10-22 10:39:37 +00:00
|
|
|
#include <sys/types.h>
|
2022-10-01 18:59:22 +00:00
|
|
|
|
2022-10-12 13:37:29 +00:00
|
|
|
#include <bits/seek.h>
|
2022-10-01 18:59:22 +00:00
|
|
|
|
2022-10-25 17:27:24 +00:00
|
|
|
#define FOPEN_MAX 32 // Maximum number of files that can be simultaneously opened with fopen().
|
2022-10-26 18:54:47 +00:00
|
|
|
#define BUFSIZ 1024 // Standard buffer size.
|
2022-10-23 09:17:22 +00:00
|
|
|
#define FILENAME_MAX 1024 // Dummy value, we don't have a limit for filenames right now.
|
2022-10-15 12:31:55 +00:00
|
|
|
|
2022-10-25 17:27:24 +00:00
|
|
|
/* A stream representing a file. */
|
2022-10-01 18:59:22 +00:00
|
|
|
typedef struct
|
|
|
|
{
|
2022-10-11 14:57:08 +00:00
|
|
|
int f_fd;
|
|
|
|
int f_eof;
|
|
|
|
int f_err;
|
2022-10-22 09:38:16 +00:00
|
|
|
char* f_buf;
|
|
|
|
long f_bufsize;
|
|
|
|
long f_bufoff;
|
|
|
|
long f_bufrsize;
|
2022-10-01 18:59:22 +00:00
|
|
|
} FILE;
|
|
|
|
|
2022-10-14 17:23:14 +00:00
|
|
|
extern FILE* stderr;
|
|
|
|
extern FILE* stdout;
|
2022-10-19 18:43:04 +00:00
|
|
|
extern FILE* stdin;
|
2022-10-14 17:23:14 +00:00
|
|
|
|
2022-10-25 17:27:24 +00:00
|
|
|
#define stdin stdin // The standard input stream.
|
|
|
|
#define stdout stdout // The standard output stream.
|
|
|
|
#define stderr stderr // The standard error stream.
|
2022-10-22 09:38:16 +00:00
|
|
|
|
2022-10-25 17:27:24 +00:00
|
|
|
#define EOF -1 // End of file.
|
2022-10-23 08:09:20 +00:00
|
|
|
|
2022-10-25 17:27:24 +00:00
|
|
|
#define _IONBF 0 // Not buffered.
|
|
|
|
#define _IOLBF 1 // Line buffered.
|
|
|
|
#define _IOFBF 2 // Fully buffered.
|
|
|
|
|
|
|
|
typedef off_t fpos_t; // An offset into a file.
|
2022-10-14 17:12:40 +00:00
|
|
|
|
2022-10-01 18:59:22 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C"
|
|
|
|
{
|
|
|
|
#endif
|
2022-10-12 09:51:32 +00:00
|
|
|
|
|
|
|
/* Closes the file handle stream. */
|
|
|
|
int fclose(FILE* stream);
|
|
|
|
|
|
|
|
/* Does not do anything for now, since buffered IO is not implemented yet. */
|
|
|
|
int fflush(FILE* stream);
|
|
|
|
|
2022-10-12 09:58:07 +00:00
|
|
|
/* Opens the file specified by pathname. Returns the file handle on success, or NULL on error. */
|
2022-10-12 09:51:32 +00:00
|
|
|
FILE* fopen(const char* pathname, const char* mode);
|
|
|
|
|
2022-10-12 18:19:13 +00:00
|
|
|
/* Returns a new file associated with the file descriptor fd. */
|
|
|
|
FILE* fdopen(int fd, const char* mode);
|
|
|
|
|
2022-10-19 15:32:59 +00:00
|
|
|
/* Opens the file specified by pathname and points the file handle stream to it. */
|
|
|
|
FILE* freopen(const char* pathname, const char* mode, FILE* stream);
|
|
|
|
|
2022-10-15 08:28:52 +00:00
|
|
|
/* Returns the file descriptor associated with the file stream. */
|
|
|
|
int fileno(FILE* stream);
|
|
|
|
|
2022-10-12 09:51:32 +00:00
|
|
|
/* Writes formatted output according to the string format to the file stream. */
|
|
|
|
int fprintf(FILE* stream, const char* format, ...);
|
|
|
|
|
|
|
|
/* Reads nmemb items of size size from the file stream into buf. */
|
|
|
|
size_t fread(void* buf, size_t size, size_t nmemb, FILE* stream);
|
|
|
|
|
2022-10-12 13:56:03 +00:00
|
|
|
/* Moves stream's read/write offset by offset, depending on whence. */
|
|
|
|
int fseek(FILE* stream, long offset, int whence);
|
|
|
|
|
2022-10-22 10:41:15 +00:00
|
|
|
/* Moves stream's read/write offset by offset, depending on whence. */
|
|
|
|
int fseeko(FILE* stream, off_t offset, int whence);
|
|
|
|
|
2022-10-14 17:12:40 +00:00
|
|
|
/* Moves stream's read/write offset to the offset stored in the pos structure. */
|
|
|
|
int fsetpos(FILE* stream, const fpos_t* pos);
|
|
|
|
|
2022-10-12 13:56:03 +00:00
|
|
|
/* Returns the current offset for stream. */
|
|
|
|
long ftell(FILE* stream);
|
|
|
|
|
2022-10-22 10:41:15 +00:00
|
|
|
/* Returns the current offset for stream. */
|
|
|
|
off_t ftello(FILE* stream);
|
|
|
|
|
2022-10-14 17:12:40 +00:00
|
|
|
/* Stores the current offset for stream in the pos structure. */
|
|
|
|
int fgetpos(FILE* stream, fpos_t* pos);
|
|
|
|
|
2022-10-12 13:56:03 +00:00
|
|
|
/* Rewinds stream's offset to start of file. */
|
|
|
|
void rewind(FILE* stream);
|
2022-10-12 09:51:32 +00:00
|
|
|
|
|
|
|
/* Writes nmemb items of size size from buf into the file stream. */
|
|
|
|
size_t fwrite(const void* buf, size_t size, size_t nmemb, FILE* stream);
|
|
|
|
|
2022-10-22 09:38:16 +00:00
|
|
|
/* Reads a line from stream into buf. */
|
|
|
|
char* fgets(char* buf, int size, FILE* stream);
|
|
|
|
|
|
|
|
/* Retrieves a character from stream. */
|
|
|
|
int fgetc(FILE* stream);
|
|
|
|
|
|
|
|
/* Retrieves a character from stream. */
|
|
|
|
int getc(FILE* stream);
|
|
|
|
|
2022-10-23 08:34:49 +00:00
|
|
|
int ungetc(int, FILE*); // Not implemented.
|
|
|
|
|
2022-10-22 09:38:16 +00:00
|
|
|
/* Retrieves a character from standard input. */
|
|
|
|
int getchar();
|
|
|
|
|
2022-10-12 09:51:32 +00:00
|
|
|
/* Returns nonzero if the error flag in stream was set. */
|
|
|
|
int ferror(FILE* stream);
|
|
|
|
|
|
|
|
/* Returns nonzero if the end-of-file flag in stream was set. */
|
|
|
|
int feof(FILE* stream);
|
|
|
|
|
|
|
|
/* Clears the error and end-of-file flags from stream. */
|
|
|
|
void clearerr(FILE* stream);
|
|
|
|
|
2022-10-23 08:09:20 +00:00
|
|
|
void setbuf(FILE*, char*); // Not implemented.
|
|
|
|
int setvbuf(FILE*, char*, int, size_t); // Not implemented.
|
2022-10-12 09:51:32 +00:00
|
|
|
|
|
|
|
/* Writes formatted output according to the string format to the file stream. */
|
|
|
|
int vfprintf(FILE* stream, const char* format, va_list ap);
|
|
|
|
|
|
|
|
/* Writes formatted output according to the string format to standard output. */
|
|
|
|
int printf(const char* format, ...);
|
|
|
|
|
|
|
|
/* Writes formatted output according to the string format to standard output. */
|
|
|
|
int vprintf(const char* format, va_list ap);
|
|
|
|
|
|
|
|
/* Writes formatted output according to the string format to the string str. This function is unsafe, use snprintf
|
|
|
|
* instead. */
|
|
|
|
int sprintf(char* str, const char* format, ...);
|
|
|
|
|
|
|
|
/* Writes at most max bytes of formatted output according to the string format to the string str.*/
|
|
|
|
int snprintf(char* str, size_t max, const char* format, ...);
|
|
|
|
|
|
|
|
/* Writes formatted output according to the string format to the string str. This function is unsafe, use vsnprintf
|
|
|
|
* instead. */
|
|
|
|
int vsprintf(char* str, const char* format, va_list ap);
|
|
|
|
|
|
|
|
/* Writes at most max bytes of formatted output according to the string format to the string str. */
|
|
|
|
int vsnprintf(char* str, size_t max, const char* format, va_list ap);
|
|
|
|
|
2022-10-23 09:16:36 +00:00
|
|
|
int sscanf(const char*, const char*, ...); // Not implemented.
|
2022-10-29 07:39:12 +00:00
|
|
|
int fscanf(FILE*, const char*, ...); // Not implemented.
|
2022-10-23 09:16:36 +00:00
|
|
|
|
2022-10-12 09:51:32 +00:00
|
|
|
/* Writes the string str followed by a trailing newline to stdout. */
|
|
|
|
int puts(const char* str);
|
|
|
|
|
|
|
|
/* Writes the string str to the file stream. */
|
|
|
|
int fputs(const char* str, FILE* stream);
|
|
|
|
|
|
|
|
/* Writes the character c to the file stream. */
|
|
|
|
int fputc(int c, FILE* stream);
|
|
|
|
|
|
|
|
/* Writes the character c to the file stream. */
|
|
|
|
int putc(int c, FILE* stream);
|
|
|
|
|
|
|
|
/* Writes the character c to standard output. */
|
|
|
|
int putchar(int c);
|
|
|
|
|
|
|
|
/* Prints a message to standard error consisting of the string str followed by a colon and the string representation
|
|
|
|
* of the last error encountered during a call to a system or library function. */
|
|
|
|
void perror(const char* str);
|
2022-10-01 18:59:22 +00:00
|
|
|
|
2022-11-03 15:52:41 +00:00
|
|
|
int remove(const char* pathname); // Not implemented.
|
|
|
|
int rename(const char* oldpath, const char* newpath); // Not implemented.
|
2022-10-22 10:20:05 +00:00
|
|
|
|
2022-10-23 16:58:48 +00:00
|
|
|
FILE* tmpfile(void); // Not implemented.
|
|
|
|
|
2022-10-01 18:59:22 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif
|