summaryrefslogtreecommitdiff
path: root/lib/libc/src/stdio
diff options
context:
space:
mode:
Diffstat (limited to 'lib/libc/src/stdio')
-rw-r--r--lib/libc/src/stdio/snprintf.c15
-rw-r--r--lib/libc/src/stdio/vsnprintf.c6
2 files changed, 21 insertions, 0 deletions
diff --git a/lib/libc/src/stdio/snprintf.c b/lib/libc/src/stdio/snprintf.c
index e343b77..2387950 100644
--- a/lib/libc/src/stdio/snprintf.c
+++ b/lib/libc/src/stdio/snprintf.c
@@ -30,6 +30,7 @@
#include <sys/types.h>
#include <stdio.h>
#include <stddef.h>
+#include <unistd.h>
/* TODO FIXME: Use stdarg.h */
#define __va_start(ap, fmt) __builtin_va_start(ap, fmt)
@@ -46,3 +47,17 @@ snprintf(char *s, size_t size, const char *fmt, ...)
__va_end(ap);
return ret;
}
+
+int
+printf(const char *__restrict fmt, ...)
+{
+ char buf[512];
+ va_list ap;
+ int ret;
+
+ __va_start(ap, fmt);
+ ret = vsnprintf(buf, sizeof(buf), fmt, ap);
+ write(stdout->fd, buf, ret);
+ __va_end(ap);
+ return ret;
+}
diff --git a/lib/libc/src/stdio/vsnprintf.c b/lib/libc/src/stdio/vsnprintf.c
index 0e29600..24b2df6 100644
--- a/lib/libc/src/stdio/vsnprintf.c
+++ b/lib/libc/src/stdio/vsnprintf.c
@@ -123,6 +123,12 @@ vsnprintf(char *s, size_t size, const char *fmt, va_list ap)
num = __va_arg(ap, uint64_t);
itoa(num, num_buf, 16);
tmp_len = strlen(num_buf);
+ if (pad_width > 0) {
+ num_len = strlen(num_buf);
+ for (size_t i = num_len; i < pad_width; ++i)
+ printc(s, size, &off, '0');
+ pad_width = 0;
+ }
printstr(s, size, &off, num_buf + 2);
break;
case 's':