source: mainline/uspace/lib/c/include/stdio.h@ 82374b2

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 82374b2 was 9ac2013, checked in by Martin Decky <martin@…>, 15 years ago

add format checking to more printf-like functions (fault_if_from_uspace, panic_common, fprintf, snprintf, asprintf)

  • Property mode set to 100644
File size: 4.7 KB
RevLine 
[3eddaff]1/*
[df4ed85]2 * Copyright (c) 2005 Martin Decky
[3eddaff]3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * - Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * - Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * - The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
[fadd381]29/** @addtogroup libc
[b2951e2]30 * @{
31 */
32/** @file
33 */
34
[fadd381]35#ifndef LIBC_STDIO_H_
36#define LIBC_STDIO_H_
[3eddaff]37
[5d4e90f0]38#include <sys/types.h>
[3214a20]39#include <stdarg.h>
[19f857a]40#include <str.h>
[d9c8c81]41#include <adt/list.h>
[3eddaff]42
[9ac2013]43#ifndef NVERIFY_PRINTF
44
45#define PRINTF_ATTRIBUTE(start, end) \
46 __attribute__((format(gnu_printf, start, end)))
47
48#else /* NVERIFY_PRINTF */
49
50#define PRINTF_ATTRIBUTE(start, end)
51
52#endif /* NVERIFY_PRINTF */
53
[2595dab]54#define EOF (-1)
[37458472]55
[ef8bcc6]56/** Default size for stream I/O buffers */
[db24058]57#define BUFSIZ 4096
[ef8bcc6]58
[1d0d06a]59#define DEBUG(fmt, ...) \
[db24058]60 { \
61 char _buf[256]; \
62 int _n = snprintf(_buf, sizeof(_buf), fmt, ##__VA_ARGS__); \
63 if (_n > 0) \
64 (void) __SYSCALL3(SYS_KLOG, 1, (sysarg_t) _buf, str_size(_buf)); \
65 }
[d681c17]66
[2595dab]67#ifndef SEEK_SET
68 #define SEEK_SET 0
[ed903174]69#endif
70
71#ifndef SEEK_CUR
[2595dab]72 #define SEEK_CUR 1
[ed903174]73#endif
74
75#ifndef SEEK_END
[2595dab]76 #define SEEK_END 2
77#endif
78
[ef8bcc6]79enum _buffer_type {
80 /** No buffering */
81 _IONBF,
82 /** Line buffering */
83 _IOLBF,
84 /** Full buffering */
85 _IOFBF
86};
87
[facebd56]88enum _buffer_state {
89 /** Buffer is empty */
90 _bs_empty,
91
92 /** Buffer contains data to be written */
93 _bs_write,
94
95 /** Buffer contains prefetched data for reading */
96 _bs_read
97};
98
[04b687b]99typedef struct {
[a68f737]100 /** Linked list pointer. */
101 link_t link;
102
[04b687b]103 /** Underlying file descriptor. */
104 int fd;
[2595dab]105
[04b687b]106 /** Error indicator. */
107 int error;
[2595dab]108
[04b687b]109 /** End-of-file indicator. */
110 int eof;
[2595dab]111
112 /** Klog indicator */
113 int klog;
114
115 /** Phone to the file provider */
116 int phone;
[ef8bcc6]117
[facebd56]118 /**
119 * Non-zero if the stream needs sync on fflush(). XXX change
120 * console semantics so that sync is not needed.
121 */
122 int need_sync;
123
[ef8bcc6]124 /** Buffering type */
125 enum _buffer_type btype;
[facebd56]126
[ef8bcc6]127 /** Buffer */
128 uint8_t *buf;
[facebd56]129
[ef8bcc6]130 /** Buffer size */
131 size_t buf_size;
[facebd56]132
133 /** Buffer state */
134 enum _buffer_state buf_state;
135
[ef8bcc6]136 /** Buffer I/O pointer */
137 uint8_t *buf_head;
[facebd56]138
139 /** Points to end of occupied space when in read mode. */
140 uint8_t *buf_tail;
[04b687b]141} FILE;
142
[2595dab]143extern FILE *stdin;
144extern FILE *stdout;
145extern FILE *stderr;
146
147/* Character and string input functions */
148extern int fgetc(FILE *);
[c62d2e1]149extern char *fgets(char *, int, FILE *);
[1c1002a]150
[b27a97bb]151extern int getchar(void);
[2595dab]152extern char *gets(char *, size_t);
[b27a97bb]153
[2595dab]154/* Character and string output functions */
155extern int fputc(wchar_t, FILE *);
156extern int fputs(const char *, FILE *);
157
158extern int putchar(wchar_t);
[ab00d5a]159extern int puts(const char *);
[3eddaff]160
[2595dab]161/* Formatted string output functions */
[9ac2013]162extern int fprintf(FILE *, const char*, ...)
163 PRINTF_ATTRIBUTE(2, 3);
[2595dab]164extern int vfprintf(FILE *, const char *, va_list);
[3214a20]165
[9ac2013]166extern int printf(const char *, ...)
167 PRINTF_ATTRIBUTE(1, 2);
[ab00d5a]168extern int vprintf(const char *, va_list);
[3214a20]169
[9ac2013]170extern int snprintf(char *, size_t , const char *, ...)
171 PRINTF_ATTRIBUTE(3, 4);
172extern int asprintf(char **, const char *, ...)
173 PRINTF_ATTRIBUTE(2, 3);
[2595dab]174extern int vsnprintf(char *, size_t, const char *, va_list);
[a8e9ab8d]175
[2595dab]176/* File stream functions */
[04b687b]177extern FILE *fopen(const char *, const char *);
[080ad7f]178extern FILE *fdopen(int, const char *);
[04b687b]179extern int fclose(FILE *);
[2595dab]180
[04b687b]181extern size_t fread(void *, size_t, size_t, FILE *);
182extern size_t fwrite(const void *, size_t, size_t, FILE *);
[2595dab]183
[ed903174]184extern int fseek(FILE *, off64_t, int);
[080ad7f]185extern void rewind(FILE *);
[ed903174]186extern off64_t ftell(FILE *);
[04b687b]187extern int feof(FILE *);
[3629481]188extern int fileno(FILE *);
[2595dab]189
190extern int fflush(FILE *);
[04b687b]191extern int ferror(FILE *);
192extern void clearerr(FILE *);
193
[ef8bcc6]194extern void setvbuf(FILE *, void *, int, size_t);
195
[2595dab]196/* Misc file functions */
197extern int rename(const char *, const char *);
[63088cc1]198
[3eddaff]199#endif
[b2951e2]200
[fadd381]201/** @}
[b2951e2]202 */
Note: See TracBrowser for help on using the repository browser.