The truncating vsnwprintf_s
function composes a wide string with same test that would be printed if format was used on wprintf
.
Instead of being printed, the content is stored in dest. With SAFECLIB_STR_NULL_SLACK
defined all elements following the terminating null character (if any) written by vsnwprintf_s
in the array of dmax wide characters pointed to by dest
are nulled when vsnwprintf_s
returns. Warning: Unlike the safe variant vswprintf_s
, vsnwprintf_s
does not guarantee that the buffer will be null-terminated unless the buffer size is zero.
- Note
- POSIX specifies that
errno
is set on error. However, the safeclib extended ES*
errors do not set errno
, only when the underlying system vswprintf
or vsnwprintf
call fails, errno
is set.
- Parameters
-
[out] | dest | pointer to wide string that will be written into. |
[in] | dmax | restricted maximum length of dest |
[in] | fmt | format-control wide string. |
[in] | ap | optional arguments |
- Precondition
- Neither dest nor fmt shall be a null pointer.
-
dmax shall not be greater than RSIZE_MAX_WSTR.
-
dmax shall not equal zero.
-
dmax shall be greater than wcsnlen_s(dest, dmax).
-
fmt shall not contain the conversion specifier n
-
None of the arguments corresponding to s is a null pointer. (not yet)
-
No encoding error shall occur.
- Note
- C11 uses RSIZE_MAX, not RSIZE_MAX_WSTR.
-
While narrow strings provide
snprintf
, which makes it possible to determine the required output buffer size, there is no equivalent for wide strings (until C11's snwprintf_s
), and in order to determine the buffer size, the program may need to call swprintf
, check the result value, and reallocate a larger buffer, trying again until successful.
-
snwprintf_s
, unlike swprintf_s
, will truncate the result to fit within the array pointed to by buffer, even though truncation is treated as an error by most bounds-checked functions.
- Returns
- On success the total number of wide characters written is returned.
-
On failure a negative number is returned.
-
If the buffer dest is too small for the formatted text, including the terminating null, then the buffer is set to an empty string by placing a null wide character at dest[0], and the invalid parameter handler is invoked. Unlike
vsnwprintf
, vswprintf_s
guarantees that the buffer will be null-terminated unless the buffer size is zero.
- Return values
-
-ESLEMAX | when dmax > RSIZE_MAX_WSTR |
-ESNULLP | when dest/fmt is NULL pointer |
-ESZEROL | when dmax = 0 |
-EINVAL | when fmt contains n |
-1 | on some other error. errno is set then |
- See also
- vswprintf_s(), snwprintf_s(), vsnprintf_s()