aboutsummaryrefslogtreecommitdiff
path: root/lib/libc/stdio.c
blob: 698700b899b51d3743aff0239a1f33b99fdd859c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
/*
 * Copyright (c) 2013 Travis Geiselbrecht
 *
 * Permission is hereby granted, free of charge, to any person obtaining
 * a copy of this software and associated documentation files
 * (the "Software"), to deal in the Software without restriction,
 * including without limitation the rights to use, copy, modify, merge,
 * publish, distribute, sublicense, and/or sell copies of the Software,
 * and to permit persons to whom the Software is furnished to do so,
 * subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be
 * included in all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
 * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
 * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
 * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
 * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 */
#include <debug.h>
#include <stdio.h>
#include <stdarg.h>
#include <sys/types.h>
#include <platform/debug.h>

int fputc(int c, FILE *fp)
{
	return fp->fputc(fp->ctx, c);
}

int putchar(int c)
{
	return fputc(c, stdout);
}

int puts(const char *str)
{
	int err = fputs(str, stdout);
	if (err >= 0)
		err = fputc('\n', stdout);
	return err;
}

int fputs(const char *s, FILE *fp)
{
	return fp->fputs(fp->ctx, s);
}

int getc(FILE *fp)
{
	return fp->fgetc(fp->ctx);
}

int getchar(void)
{
	return getc(stdin);
}

int _printf(const char *fmt, ...)
{
	int err;
	FILE *fp = stdout;

	va_list ap;
	va_start(ap, fmt);
	err = fp->vfprintf(fp->ctx, fmt, ap);
	va_end(ap);

	return err;
}