diff options
author | Marvin Borner | 2020-04-28 19:15:47 +0200 |
---|---|---|
committer | Marvin Borner | 2020-04-28 19:15:47 +0200 |
commit | bfe16de4be67565f1a1e7b1331fcbe3aedf9c54e (patch) | |
tree | 1bc7450acb82410753e34da30cb9f44d19b9e92b /src/userspace/mlibc/stdio/vprintf.c | |
parent | 4b8518b4e791c68154ec52badcc921b62afafb49 (diff) |
Userspace rewrite -> IT WORKS! :)
Finally, after many months of work and rewrites the syscalls with
constant char pointers work now :D
Diffstat (limited to 'src/userspace/mlibc/stdio/vprintf.c')
-rw-r--r-- | src/userspace/mlibc/stdio/vprintf.c | 52 |
1 files changed, 0 insertions, 52 deletions
diff --git a/src/userspace/mlibc/stdio/vprintf.c b/src/userspace/mlibc/stdio/vprintf.c deleted file mode 100644 index 0f5ae68..0000000 --- a/src/userspace/mlibc/stdio/vprintf.c +++ /dev/null @@ -1,52 +0,0 @@ -#include <stdarg.h> -#include <stdint.h> -#include <mlibc/stdio.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); - free(p); - readyToFormat = 0; - } else if (buff == 'd') { - char *p = itoa(va_arg(args, int)); - _writes(p); - free(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 |