aboutsummaryrefslogtreecommitdiff
path: root/src/mlibc/stdio/vprintf.c
diff options
context:
space:
mode:
authorMarvin Borner2019-12-07 13:40:28 +0100
committerMarvin Borner2019-12-07 13:40:28 +0100
commitd94b024b73aeca06de417e0fd3c502495312a8b2 (patch)
treebff5cc1b757eeed7f58878cc13551c63464c5a31 /src/mlibc/stdio/vprintf.c
parent322167ceab19588473f9074e761390fdeb701790 (diff)
Added userspace libc and began userspace based shell
Diffstat (limited to 'src/mlibc/stdio/vprintf.c')
-rw-r--r--src/mlibc/stdio/vprintf.c52
1 files changed, 0 insertions, 52 deletions
diff --git a/src/mlibc/stdio/vprintf.c b/src/mlibc/stdio/vprintf.c
deleted file mode 100644
index 81efce2..0000000
--- a/src/mlibc/stdio/vprintf.c
+++ /dev/null
@@ -1,52 +0,0 @@
-#include <stdarg.h>
-#include <stdint.h>
-#include <mlibc/stdio.h>
-#include <mlibc/string.h>
-#include <mlibc/stdlib.h>
-
-void __writes(const char *data)
-{
- for (size_t i = 0; i < strlen(data); i++) writec(data[i]);
-}
-
-void vprintf(const char *fmt, va_list args)
-{
- uint8_t readyToFormat = 0;
-
- char buff = 0;
-
- for (; *fmt; fmt++) {
- if (readyToFormat) {
- if (*fmt == '%') {
- writec('%');
- readyToFormat = 0;
- continue;
- }
-
- buff = *fmt;
- if (buff == 's') {
- const char *str = va_arg(args, const char*);
- __writes(str);
- readyToFormat = 0;
- } else if (buff == 'x') {
- char *p = htoa((uint32_t) va_arg(args, int));
- __writes(p);
- kfree(p);
- readyToFormat = 0;
- } else if (buff == 'd') {
- char *p = itoa(va_arg(args, int));
- __writes(p);
- kfree(p);
- readyToFormat = 0;
- } else if (buff == 'c') {
- writec((char) va_arg(args, int));
- readyToFormat = 0;
- }
- } else {
- if (*fmt == '%')
- readyToFormat = 1;
- else
- writec(*fmt);
- }
- }
-} \ No newline at end of file