snprintf.c (1e98f88776fc606df245a382685b1ac634a81389) snprintf.c (1b0181df2f46ef73a41ea8c9b7026718f8eec3a1)
1/*-
2 * Copyright (c) 1990, 1993
3 * The Regents of the University of California. All rights reserved.
4 *
5 * This code is derived from software contributed to Berkeley by
6 * Chris Torek.
7 *
8 * Redistribution and use in source and binary forms, with or without

--- 34 unchanged lines hidden (view full) ---

43#include "local.h"
44
45int
46snprintf(char * __restrict str, size_t n, char const * __restrict fmt, ...)
47{
48 size_t on;
49 int ret;
50 va_list ap;
1/*-
2 * Copyright (c) 1990, 1993
3 * The Regents of the University of California. All rights reserved.
4 *
5 * This code is derived from software contributed to Berkeley by
6 * Chris Torek.
7 *
8 * Redistribution and use in source and binary forms, with or without

--- 34 unchanged lines hidden (view full) ---

43#include "local.h"
44
45int
46snprintf(char * __restrict str, size_t n, char const * __restrict fmt, ...)
47{
48 size_t on;
49 int ret;
50 va_list ap;
51 FILE f;
51 FILE f = FAKE_FILE;
52
53 on = n;
54 if (n != 0)
55 n--;
56 if (n > INT_MAX)
57 n = INT_MAX;
58 va_start(ap, fmt);
52
53 on = n;
54 if (n != 0)
55 n--;
56 if (n > INT_MAX)
57 n = INT_MAX;
58 va_start(ap, fmt);
59 f._file = -1;
60 f._flags = __SWR | __SSTR;
61 f._bf._base = f._p = (unsigned char *)str;
62 f._bf._size = f._w = n;
59 f._flags = __SWR | __SSTR;
60 f._bf._base = f._p = (unsigned char *)str;
61 f._bf._size = f._w = n;
63 f._orientation = 0;
64 memset(&f._mbstate, 0, sizeof(mbstate_t));
65 ret = __vfprintf(&f, fmt, ap);
66 if (on > 0)
67 *f._p = '\0';
68 va_end(ap);
69 return (ret);
70}
62 ret = __vfprintf(&f, fmt, ap);
63 if (on > 0)
64 *f._p = '\0';
65 va_end(ap);
66 return (ret);
67}