/* * Copyright (C) 2008 The Android Open Source Project * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in * the documentation and/or other materials provided with the * distribution. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. */ #include #include #include #include #include /* stubs for wide-char functions */ wint_t btowc(int c) { return (c == EOF) ? WEOF : c; } int fwprintf(FILE* stream, const wchar_t* format, ...) { va_list args; va_start(args, format); int result = vfwprintf(stream, format, args); va_end(args); return result; } int wprintf(const wchar_t* format, ...) { va_list args; va_start(args, format); int result = vwprintf(format, args); va_end(args); return result; } int swprintf(wchar_t* s, size_t n, const wchar_t* format, ...) { va_list args; va_start(args, format); int result = vswprintf(s, n, format, args); va_end(args); return result; } int vwprintf(const wchar_t* format, va_list arg) { return vfwprintf(stdout, format, arg); } int vfwprintf(FILE* /*stream*/, const wchar_t* /*format*/, va_list /*arg*/) { errno = ENOTSUP; return -1; } int vswprintf(wchar_t* /*s*/, size_t /*n*/, const wchar_t* /*format*/, va_list /*arg*/) { errno = ENOTSUP; return -1; } int fwscanf(FILE* /*stream*/, const wchar_t* /*format*/, ... ) { errno = ENOTSUP; return -1; } int wscanf(const wchar_t* format, ... ) { va_list args; va_start (args, format); int result = fwscanf(stdout, format, args ); va_end (args); return result; } int swscanf(const wchar_t* /*s*/, const wchar_t* /*format*/, ... ) { errno = ENOTSUP; return -1; } int iswalnum(wint_t wc) { return isalnum(wc); } int iswalpha(wint_t wc) { return isalpha(wc); } int iswcntrl(wint_t wc) { return iscntrl(wc); } int iswdigit(wint_t wc) { return isdigit(wc); } int iswgraph(wint_t wc) { return isgraph(wc); } int iswlower(wint_t wc) { return islower(wc); } int iswprint(wint_t wc) { return isprint(wc); } int iswpunct(wint_t wc) { return ispunct(wc); } int iswspace(wint_t wc) { return isspace(wc); } int iswupper(wint_t wc) { return isupper(wc); } int iswxdigit(wint_t wc) { return isxdigit(wc); } int iswctype(wint_t wc, wctype_t char_class) { switch (char_class) { case WC_TYPE_ALNUM: return isalnum(wc); case WC_TYPE_ALPHA: return isalpha(wc); case WC_TYPE_BLANK: return isblank(wc); case WC_TYPE_CNTRL: return iscntrl(wc); case WC_TYPE_DIGIT: return isdigit(wc); case WC_TYPE_GRAPH: return isgraph(wc); case WC_TYPE_LOWER: return islower(wc); case WC_TYPE_PRINT: return isprint(wc); case WC_TYPE_PUNCT: return ispunct(wc); case WC_TYPE_SPACE: return isspace(wc); case WC_TYPE_UPPER: return isupper(wc); case WC_TYPE_XDIGIT: return isxdigit(wc); default: return 0; } } wint_t fgetwc(FILE* stream) { return static_cast(fgetc(stream)); } wchar_t* fgetws(wchar_t* ws, int n, FILE* stream) { return reinterpret_cast(fgets(reinterpret_cast(ws), n, stream)); } wint_t fputwc(wchar_t wc, FILE* stream) { return static_cast(fputc(static_cast(wc), stream)); } int fputws(const wchar_t* str, FILE* stream) { return fputs(reinterpret_cast(str), stream ); } int fwide(FILE* /*stream*/, int mode) { return mode; } wint_t getwc(FILE* stream) { return getc(stream); } wint_t getwchar() { return getchar(); } int mbsinit(const mbstate_t* /*ps*/) { return 1; } size_t mbrlen(const char* /*s*/, size_t n, mbstate_t* /*ps*/) { return (n != 0); } size_t mbrtowc(wchar_t* pwc, const char* s, size_t n, mbstate_t* /*ps*/) { if (s == NULL) { s = ""; pwc = NULL; } if (n == 0) { if (pwc) { *pwc = 0; return 0; } } if (pwc) { *pwc = *s; } return (*s != 0); } size_t mbsrtowcs(wchar_t* dst, const char** src, size_t len, mbstate_t* /*ps*/) { const char* s = *src; const char* s2 = reinterpret_cast(memchr(s, 0, len)); if (s2 != NULL) { len = (size_t)(s2 - s) + 1U; } if (dst) { memcpy(reinterpret_cast(dst), s, len ); } *src = s + len; return len; } size_t mbstowcs(wchar_t* dst, const char* src, size_t len) { return mbsrtowcs(dst, &src, len, NULL); } wint_t putwc(wchar_t wc, FILE* stream) { return fputc(static_cast(wc), stream); } wint_t putwchar(wchar_t wc) { return putchar(static_cast(wc)); } wint_t towlower(wint_t wc) { return tolower(wc); } wint_t towupper(wint_t wc) { return toupper(wc); } wint_t ungetwc(wint_t wc, FILE* stream) { return ungetc(static_cast(wc), stream); } size_t wcrtomb(char* s, wchar_t /*wc*/, mbstate_t* /*ps*/) { if (s != NULL) { *s = 1; } return 1; } size_t wcsftime(wchar_t* wcs, size_t maxsize, const wchar_t* format, const struct tm* timptr) { return strftime(reinterpret_cast(wcs), maxsize, reinterpret_cast(format), timptr); } size_t wcsrtombs(char* dst, const wchar_t** src, size_t len, mbstate_t* /*ps*/) { const char* s = reinterpret_cast(*src); const char* s2 = reinterpret_cast(memchr(s, 0, len)); if (s2 != NULL) { len = (s2 - s)+1; } if (dst != NULL) { memcpy( dst, s, len ); } *src = (wchar_t*)(s + len); return len; } size_t wcstombs(char* dst, const wchar_t* src, size_t len) { return wcsrtombs(dst, &src, len, NULL); } double wcstod(const wchar_t* nptr, wchar_t** endptr) { return strtod(reinterpret_cast(nptr), reinterpret_cast(endptr)); } long int wcstol(const wchar_t* nptr, wchar_t** endptr, int base) { return strtol(reinterpret_cast(nptr), reinterpret_cast(endptr), base); } unsigned long int wcstoul(const wchar_t* nptr, wchar_t** endptr, int base) { return strtoul(reinterpret_cast(nptr), reinterpret_cast(endptr), base); } wchar_t* wcswcs(const wchar_t* ws1, const wchar_t* ws2) { const char* s1 = reinterpret_cast(ws1); const char* s2 = reinterpret_cast(ws2); return reinterpret_cast(strstr(s1, s2)); } int wctob(wint_t c) { return c; } wctype_t wctype(const char* property) { static const char* const properties[WC_TYPE_MAX] = { "", "alnum", "alpha", "blank", "cntrl", "digit", "graph", "lower", "print", "punct", "space", "upper", "xdigit" }; for (size_t i = 0; i < WC_TYPE_MAX; ++i) { if (!strcmp(properties[i], property)) { return static_cast(i); } } return static_cast(0); } int wcwidth(wchar_t wc) { return (wc > 0); }