142 lines
2.2 KiB
C
142 lines
2.2 KiB
C
/* $NetBSD: multibyte.c,v 1.5 2013/04/19 18:45:03 joerg 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 <stdlib.h>
|
|
#include <wchar.h>
|
|
|
|
size_t
|
|
mbrtowc(wchar_t *wc, const char *str, size_t max_sz, mbstate_t *ps)
|
|
{
|
|
return str == NULL || (*wc = (unsigned char)*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;
|
|
}
|