diff options
author | 2005-04-30 09:25:17 +0000 | |
---|---|---|
committer | 2005-04-30 09:25:17 +0000 | |
commit | 685aea3ce6ed0cd7feff41ab14280ea9d93c3718 (patch) | |
tree | 04651561fbab26ee3dc6f113131ba97c7e5bb1dc /lib/libc/stdio/snprintf.c | |
parent | isw* classification functions from citrus, with a `stub' implementation (diff) | |
download | wireguard-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.c | 5 |
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; |