Mac Developer Library Developer


This manual page is part of Xcode Tools version 5.0

To obtain these tools:

If you are running a version of Xcode Tools other than 5.0, view the documentation locally:

  • In Xcode

  • In Terminal, using the man(1) command

Reading manual pages

Manual pages are intended as a quick reference for people who already understand a technology.

  • To learn how the manual is organized or to learn about command syntax, read the manual page for manpages(5).

  • For more information about this technology, look for other documentation in the Apple Developer Library.

  • For general information about writing shell scripts, read Shell Scripting Primer.

MBSRTOWCS(3)             BSD Library Functions Manual             MBSRTOWCS(3)

     mbsnrtowcs, mbsnrtowcs_l, mbsrtowcs, mbsrtowcs_l -- convert a character string to a wide-character
     string (restartable)

     Standard C Library (libc, -lc)

     #include <wchar.h>

     mbsnrtowcs(wchar_t *restrict dst, const char **restrict src, size_t nms, size_t len,
         mbstate_t *restrict ps);

     mbsrtowcs(wchar_t *restrict dst, const char **restrict src, size_t len, mbstate_t *restrict ps);

     #include <wchar.h>
     #include <xlocale.h>

     mbsrtowcs_l(wchar_t *restrict dst, const char **restrict src, size_t len, mbstate_t *restrict ps,
         locale_t loc);

     mbsnrtowcs_l(wchar_t *restrict dst, const char **restrict src, size_t nms, size_t len,
         mbstate_t *restrict ps, locale_t loc);

     The mbsrtowcs() function converts a sequence of multibyte characters, pointed to indirectly by src,
     into a sequence of corresponding wide characters. It stores at most len of them in the wchar_t array
     pointed to by dst, until it encounters a terminating null character ('\0').

     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, mbsrtowcs() uses
     an internal, static mbstate_t object, which is initialized to the initial conversion state at program

     The mbsnrtowcs() function behaves identically to mbsrtowcs(), except that conversion stops after read-ing reading
     ing at most nms bytes from the buffer pointed to by src.

     While the mbsrtowcs() and mbsnrtowcs() functions use the current locale, the mbsrtowcs_l() and
     mbsnrtowcs_l() functions may be passed locales directly. See xlocale(3) for more information.

     The mbsrtowcs() and mbsnrtowcs() functions return the number of wide characters stored in the array
     pointed to by dst if successful, otherwise it returns (size_t)-1.

     The mbsrtowcs() and mbsnrtowcs() functions will fail if:

     [EILSEQ]           An invalid multibyte character sequence was encountered.

     [EINVAL]           The conversion state is invalid.

     mbrtowc(3), mbstowcs(3), multibyte(3), wcsrtombs(3), xlocale(3)

     The mbsrtowcs() function conforms to ISO/IEC 9899:1999 (``ISO C99'').

     The mbsnrtowcs() function is an extension to the standard.

BSD                              July 21, 2004                             BSD

Reporting Problems

The way to report a problem with this manual page depends on the type of problem:

Content errors
Report errors in the content of this documentation with the feedback links below.
Bug reports
Report bugs in the functionality of the described tool or API through Bug Reporter.
Formatting problems
Report formatting mistakes in the online version of these pages with the feedback links below.