/* $NetBSD: multibyte.c,v 1.7 2014/11/15 19:15:51 htodd Exp $ */ /* * Ignore all multibyte sequences, removes all the citrus code. * Probably only used by vfprintf() when parsing the format string. * And possibly from libcurses if compiled with HAVE_WCHAR. */ #include #include size_t mbrtowc(wchar_t *wc, const char *str, size_t max_sz, mbstate_t *ps) { if (str == NULL) return 0; if (wc != NULL) *wc = (unsigned char)*str; return *str == '\0' ? 0 : 1; } size_t mbrtowc_l(wchar_t *wc, const char *str, size_t max_sz, mbstate_t *ps, locale_t loc) { return mbrtowc(wc, str, max_sz, ps); } size_t wcrtomb(char *str, wchar_t wc, mbstate_t *ps) { *str = wc & 0xFF; return 1; } size_t wcrtomb_l(char *str, wchar_t wc, mbstate_t *ps, locale_t loc) { return wcrtomb(str, wc, ps); } int wctob(wint_t x) { return x; } int wctob_l(wint_t x, locale_t loc) { return x; } wint_t btowc(int x) { return x; } wint_t btowc_l(int x, locale_t loc) { return x; } size_t mbrlen(const char * __restrict p, size_t l, mbstate_t * __restrict v) { size_t i; for (i = 0; i < l; i++) if (p[i] == '\0') return i; return l; } size_t mbrlen_l(const char * __restrict p, size_t l, mbstate_t * __restrict v, locale_t loc) { return mbrlen(p, l, v); } int mbsinit(const mbstate_t *s) { return 0; } size_t mbsrtowcs(wchar_t * __restrict pwcs, const char ** __restrict s, size_t n, mbstate_t * __restrict ps) { const char *p; wchar_t *d; size_t count; for (p = *s, d = pwcs, count = 0; count <= n; count++, d++, p++) { if (mbrtowc(d, p, 1, ps) == 0) break; } return count; } size_t mbsrtowcs_l(wchar_t * __restrict pwcs, const char ** __restrict s, size_t n, mbstate_t * __restrict ps, locale_t loc) { return mbsrtowcs(pwcs, s, n, ps); } size_t wcsrtombs(char * __restrict s, const wchar_t ** __restrict pwcs, size_t n, mbstate_t * __restrict ps) { char *d; const wchar_t *p; size_t count; for (p = *pwcs, d = s, count = 0; count <= n && *p != 0; count++, d++, p++) { wcrtomb(d, *p, ps); } *d = 0; return count; } size_t wcsrtombs_l(char * __restrict s, const wchar_t ** __restrict pwcs, size_t n, mbstate_t * __restrict ps, locale_t loc) { return wcsrtombs(s, pwcs, n, ps); } size_t _mb_cur_max_l(locale_t loc) { return MB_CUR_MAX; }