WCRTOMB(3) OpenBSD Programmer's Manual WCRTOMB(3)NAMEwcrtomb - converts a wide character to a multibyte character
(restartable)
SYNOPSIS
#include <wchar.h>
size_t
wcrtomb(const char * restrict s, wchar_t wc, mbstate_t * restrict ps);
DESCRIPTIONwcrtomb() converts the wide character given by wc to the corresponding
multibyte character, and stores it in the array pointed to by s unless s
is a null pointer. This function will modify the first at most
MB_CUR_MAX bytes of the array pointed by s.
The behaviour of wcrtomb() is affected by the LC_CTYPE category of the
current locale.
These are the special cases:
wc == 0 For state-dependent encodings, wcrtomb() stores a null byte
preceded by a special byte sequence (if any) to return to
an initial state to the array pointed by s, and the state
object pointed by ps also returned to an initial state.
s == NULL wcrtomb() just places ps into an initial state. It is
equivalent to the following call:
wcrtomb(buf, L'\0', ps);
Here, buf is a dummy buffer. In this case, wc is ignored.
ps == NULL mbrtowc() uses its own internal state object to keep the
conversion state, instead of ps mentioned in this manual
page.
Calling any other functions in libc never change the
internal state of mbrtowc(), which is initialized at
startup time of the program.
RETURN VALUESwcrtomb() returns:
positive The number of bytes (including any shift sequences) which
are stored in the array.
(size_t)-1 wc is not a valid wide character. In this case, wcrtomb()
also sets errno to indicate error.
ERRORSwcrtomb() may cause an error in the following cases:
[EILSEQ] wc is not a valid wide character.
[EINVAL] ps points to an invalid or uninitialized mbstate_t object.
SEE ALSOsetlocale(3), wctomb(3)STANDARDS
The wcrtomb() function conforms to ISO/IEC 9899/AMD1:1995 (``ISO C90,
Amendment 1''). The restrict qualifier is added at ISO/IEC 9899/1999
(``ISO C99'').
OpenBSD 4.9 March 26, 2010 OpenBSD 4.9