#include <wchar.h>
|
size_t
wcsrtombs (char * restrict dst, const wchar_t ** restrict src, size_t len, mbstate_t * restrict ps); |
size_t
wcsnrtombs (char * restrict dst, const wchar_t ** restrict src, size_t nwc, size_t len, ,, mbstate_t, *, restrict, ps); |
If dst is NULL, no characters are stored.
If dst is not NULL, the pointer pointed to by src is updated to point to the character after the one that conversion stopped at. If conversion stops because a null character is encountered, *src is set to NULL.
The mbstate_t argument, ps, is used to keep track of the shift state. If it is NULL, wcsrtombs uses an internal, static mbstate_t object, which is initialized to the initial conversion state at program startup.
The wcsnrtombs function behaves identically to wcsrtombs, except that conversion stops after reading at most nwc characters from the buffer pointed to by src. The behavior of the wcsrtombs and wcsrntombs is affected by LC_CTYPE category of the current locale.
#include <stdlib.h> #include <wchar.h> /* Illustrates how to use wcsrtombs API */ size_t example_wcsrtombs(wchar_t *wcs, char *s, size_t n) { size_t len; mstate_t mbs; /* converting multibyte string to a wide-char string */ len = wcsrtombs(s, &wcs, n, &mbs); /* returning no of bytes that make up the multibyte sequence */ return (len;); }
#include <stdlib.h> #include <wchar.h> /* Illustrates how to use wcsnrtombs API */ size_t example_wcsnrtombs(wchar_t *wcs, char *s, size_t n, szie_t nmwc) { size_t len; mstate_t mbs; /* converting multibyte string to a wide-char string */ len = wcsrtombs(s, &wcs, nwc, n, &mbs); /* returning no of bytes that make up the multibyte sequence */ return (len;); }
[EILSEQ] | |
An invalid wide character was encountered. | |
[EINVAL] | |
The conversion state is invalid. | |
The wcsrtombs function conforms to -isoC-99.
The wcsnrtombs function is an extension to the standard.
© 2005-2007 Nokia |