summaryrefslogtreecommitdiffstats
path: root/lib/libc/stdio/snprintf.c
diff options
context:
space:
mode:
authorespie <espie@openbsd.org>2005-04-30 09:25:17 +0000
committerespie <espie@openbsd.org>2005-04-30 09:25:17 +0000
commit685aea3ce6ed0cd7feff41ab14280ea9d93c3718 (patch)
tree04651561fbab26ee3dc6f113131ba97c7e5bb1dc /lib/libc/stdio/snprintf.c
parentisw* classification functions from citrus, with a `stub' implementation (diff)
downloadwireguard-openbsd-685aea3ce6ed0cd7feff41ab14280ea9d93c3718.tar.xz
wireguard-openbsd-685aea3ce6ed0cd7feff41ab14280ea9d93c3718.zip
Change internals of FILE: reuse the unget buffer field to access an
extended attribute data structure (pimpl idiom). Idea taken from citrus. Much discussion with deraadt@, otto@, millert@... This is the least disruptive way to extend FILE, since its size can't really change without this being a flag day. So the size doesn't change. Actual additions to the structure will come in separate steps, since this change is nasty enough on its own. Tests by otto@ and others, careful reading of code by otto@ and millert@. This is definitely a major bump, and has been checked to not impact a full ports build.
Diffstat (limited to 'lib/libc/stdio/snprintf.c')
-rw-r--r--lib/libc/stdio/snprintf.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/lib/libc/stdio/snprintf.c b/lib/libc/stdio/snprintf.c
index 738232abc30..653d0f01f08 100644
--- a/lib/libc/stdio/snprintf.c
+++ b/lib/libc/stdio/snprintf.c
@@ -31,12 +31,13 @@
*/
#if defined(LIBC_SCCS) && !defined(lint)
-static char rcsid[] = "$OpenBSD: snprintf.c,v 1.10 2005/03/31 18:36:29 pat Exp $";
+static char rcsid[] = "$OpenBSD: snprintf.c,v 1.11 2005/04/30 09:25:17 espie Exp $";
#endif /* LIBC_SCCS and not lint */
#include <limits.h>
#include <stdio.h>
#include <stdarg.h>
+#include "local.h"
int
snprintf(char *str, size_t n, const char *fmt, ...)
@@ -45,6 +46,7 @@ snprintf(char *str, size_t n, const char *fmt, ...)
int ret;
char dummy;
FILE f;
+ struct __sfileext fext;
/* While snprintf(3) specifies size_t stdio uses an int internally */
if (n > INT_MAX)
@@ -55,6 +57,7 @@ snprintf(char *str, size_t n, const char *fmt, ...)
n = 1;
}
va_start(ap, fmt);
+ _FILEEXT_SETUP(&f, &fext);
f._file = -1;
f._flags = __SWR | __SSTR;
f._bf._base = f._p = (unsigned char *)str;