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} |