*** UNIX MANUAL PAGE BROWSER ***

A Nergahak database for man pages research.

Navigation

Directory Browser

1Browse 4.4BSD4.4BSD
1Browse Digital UNIXDigital UNIX 4.0e
1Browse FreeBSDFreeBSD 14.3
1Browse MINIXMINIX 3.4.0rc6-d5e4fc0
1Browse NetBSDNetBSD 10.1
1Browse OpenBSDOpenBSD 7.7
1Browse UNIX v7Version 7 UNIX
1Browse UNIX v10Version 10 UNIX

Manual Page Search

Manual Page Result

0 Command: wcsrtombs | Section: 3 | Source: OpenBSD | File: wcsrtombs.3
WCSRTOMBS(3) FreeBSD Library Functions Manual WCSRTOMBS(3) NAME wcsrtombs, wcsnrtombs - converts a wide-character string to a multibyte character string (restartable) SYNOPSIS #include <wchar.h> size_t wcsrtombs(const char * restrict dst, const wchar_t ** restrict src, size_t len, mbstate_t * restrict ps); size_t wcsnrtombs(const char * restrict dst, const wchar_t ** restrict src, size_t nwc, size_t len, mbstate_t * restrict ps); DESCRIPTION The wcsrtombs() function converts the wide-character string indirectly pointed to by src to the corresponding multibyte character string and stores it to the array pointed to by dst. The conversion stops due to the following reasons: o The conversion reaches a null wide character. In this case, the null wide character is also converted. o The conversion has already stored len bytes to the array pointed to by dst. o The conversion encounters an invalid character. The wcsnrtombs() function is equivalent to wcsrtombs() except that it additionally stops the conversion after processing nwc wide characters. Each character will be converted as if wcrtomb(3) is continuously called, except the internal state of wcrtomb(3) will not be affected. After conversion, if dst is not a null pointer, the pointer object pointed to by src is a null pointer (if the conversion is stopped due to reaching a null wide character) or the address just past the last wide character processed. If dst is not a null pointer and the conversion is stopped due to reaching a null wide character, the state object pointed to by ps is set to an initial state after the conversion has taken place. The behaviour of the wcsrtombs() and wcsnrtombs() functions is affected by the LC_CTYPE category of the current locale. There are two special cases: dst == NULL The conversion takes place, but the resulting multibyte string is discarded. In this case, the pointer object pointed to by src is not modified and len is ignored. ps == NULL The wcsrtombs() and wcsnrtombs() functions use their own internal state objects to keep the conversion state, instead of ps as mentioned in this manual page. Calling any other functions in libc never change these internal states, which are initialized at startup time of the program. RETURN VALUES The wcsrtombs() and wcsnrtombs() functions return: 0 or positive Number of bytes stored to the array pointed to by dst, except for a null byte. There is no cases that the value returned is greater than len (unless dst is a null pointer). If the return value is equal to len, the string pointed to by dst will not be null-terminated. (size_t)-1 src points to the string containing invalid wide character. In this case, errno is set to indicate the error. ERRORS The wcsrtombs() and wcsnrtombs() functions may return the following errors: [EILSEQ] src points to the string containing an invalid wide character. [EINVAL] ps points to an invalid or uninitialized mbstate_t object. SEE ALSO setlocale(3), wcrtomb(3), wcstombs(3) STANDARDS The wcsrtombs() function conforms to ANSI X3.159-1989 ("ANSI C89"). The restrict qualifier is added at ISO/IEC 9899/AMD1:1995 ("ISO C99"). The wcsnrtombs() function conforms to IEEE Std 1003.1-2008 ("POSIX.1"). FreeBSD 14.1-RELEASE-p8 June 5, 2013 FreeBSD 14.1-RELEASE-p8

Navigation Options