aboutsummaryrefslogtreecommitdiff
path: root/src/userspace/mlibc/stdio/vprintf.c
diff options
context:
space:
mode:
authorMarvin Borner2020-04-28 19:15:47 +0200
committerMarvin Borner2020-04-28 19:15:47 +0200
commitbfe16de4be67565f1a1e7b1331fcbe3aedf9c54e (patch)
tree1bc7450acb82410753e34da30cb9f44d19b9e92b /src/userspace/mlibc/stdio/vprintf.c
parent4b8518b4e791c68154ec52badcc921b62afafb49 (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.c52
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