Piotr Caban : msvcrt: Added mbstowcs and wcstombs tests.
Alexandre Julliard
julliard at winehq.org
Thu May 6 11:13:23 CDT 2010
Module: wine
Branch: master
Commit: 2eb4b694a7256c4a5c418363501ef1b8122b84a4
URL: http://source.winehq.org/git/wine.git/?a=commit;h=2eb4b694a7256c4a5c418363501ef1b8122b84a4
Author: Piotr Caban <piotr at codeweavers.com>
Date: Thu May 6 14:28:08 2010 +0200
msvcrt: Added mbstowcs and wcstombs tests.
---
dlls/msvcrt/tests/string.c | 78 ++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 78 insertions(+), 0 deletions(-)
diff --git a/dlls/msvcrt/tests/string.c b/dlls/msvcrt/tests/string.c
index 5d61687..f6c0e2c 100644
--- a/dlls/msvcrt/tests/string.c
+++ b/dlls/msvcrt/tests/string.c
@@ -56,6 +56,8 @@ static int (__cdecl *p_wcsupr_s)(wchar_t *str, size_t size);
static size_t (__cdecl *p_strnlen)(const char *, size_t);
static __int64 (__cdecl *p_strtoi64)(const char *, char **, int);
static unsigned __int64 (__cdecl *p_strtoui64)(const char *, char **, int);
+static int (__cdecl *pwcstombs_s)(size_t*,char*,size_t,const wchar_t*,size_t);
+static int (__cdecl *pmbstowcs_s)(size_t*,wchar_t*,size_t,const char*,size_t);
static int *p__mb_cur_max;
static unsigned char *p_mbctype;
@@ -1161,6 +1163,79 @@ static void test__strtod(void)
ok(errno == ERANGE, "errno = %x\n", errno);
}
+static void test_mbstowcs(void)
+{
+ static const wchar_t wSimple[] = { 't','e','x','t',0 };
+ static const wchar_t wHiragana[] = { 0x3042,0x3043,0 };
+ static const char mSimple[] = "text";
+ static const char mHiragana[] = { 0x82,0xa0,0x82,0xa1,0 };
+
+ wchar_t wOut[6];
+ char mOut[6];
+ size_t ret;
+ int err;
+
+ wOut[4] = '!'; wOut[5] = '\0';
+ mOut[4] = '!'; mOut[5] = '\0';
+
+ ret = mbstowcs(NULL, mSimple, 0);
+ ok(ret == 4, "ret = %d\n", ret);
+
+ ret = mbstowcs(wOut, mSimple, 4);
+ ok(ret == 4, "ret = %d\n", ret);
+ ok(!memcmp(wOut, wSimple, 4*sizeof(wchar_t)), "wOut = %s\n", wine_dbgstr_w(wOut));
+ ok(wOut[4] == '!', "wOut[4] != \'!\'\n");
+
+ ret = wcstombs(NULL, wSimple, 0);
+ ok(ret == 4, "ret = %d\n", ret);
+
+ ret = wcstombs(mOut, wSimple, 6);
+ ok(ret == 4, "ret = %d\n", ret);
+ ok(!memcmp(mOut, mSimple, 5*sizeof(char)), "mOut = %s\n", mOut);
+
+ ret = wcstombs(mOut, wSimple, 2);
+ ok(ret == 2, "ret = %d\n", ret);
+ ok(!memcmp(mOut, mSimple, 5*sizeof(char)), "mOut = %s\n", mOut);
+
+ if(!setlocale(LC_ALL, "Japanese_Japan.932")) {
+ win_skip("Japanese_Japan.932 locale not available\n");
+ return;
+ }
+
+ ret = mbstowcs(wOut, mHiragana, 6);
+ ok(ret == 2, "ret = %d\n", ret);
+ ok(!memcmp(wOut, wHiragana, sizeof(wHiragana)), "wOut = %s\n", wine_dbgstr_w(wOut));
+
+ ret = wcstombs(mOut, wHiragana, 6);
+ ok(ret == 4, "ret = %d\n", ret);
+ ok(!memcmp(mOut, mHiragana, sizeof(mHiragana)), "mOut = %s\n", mOut);
+
+ if(!pmbstowcs_s || !pwcstombs_s) {
+ win_skip("mbstowcs_s or wcstombs_s not available\n");
+ return;
+ }
+
+ err = pmbstowcs_s(&ret, wOut, 6, mSimple, -1/*_TRUNCATE*/);
+ ok(err == 0, "err = %d\n", err);
+ ok(ret == 5, "ret = %d\n", (int)ret);
+ ok(!memcmp(wOut, wSimple, sizeof(wSimple)), "wOut = %s\n", wine_dbgstr_w(wOut));
+
+ err = pmbstowcs_s(&ret, wOut, 6, mHiragana, -1/*_TRUNCATE*/);
+ ok(err == 0, "err = %d\n", err);
+ ok(ret == 3, "ret = %d\n", (int)ret);
+ ok(!memcmp(wOut, wHiragana, sizeof(wHiragana)), "wOut = %s\n", wine_dbgstr_w(wOut));
+
+ err = pwcstombs_s(&ret, mOut, 6, wSimple, -1/*_TRUNCATE*/);
+ ok(err == 0, "err = %d\n", err);
+ ok(ret == 5, "ret = %d\n", (int)ret);
+ ok(!memcmp(mOut, mSimple, sizeof(mSimple)), "mOut = %s\n", mOut);
+
+ err = pwcstombs_s(&ret, mOut, 6, wHiragana, -1/*_TRUNCATE*/);
+ ok(err == 0, "err = %d\n", err);
+ ok(ret == 5, "ret = %d\n", (int)ret);
+ ok(!memcmp(mOut, mHiragana, sizeof(mHiragana)), "mOut = %s\n", mOut);
+}
+
START_TEST(string)
{
char mem[100];
@@ -1183,6 +1258,8 @@ START_TEST(string)
p_strnlen = (void *)GetProcAddress( hMsvcrt,"strnlen" );
p_strtoi64 = (void *) GetProcAddress(hMsvcrt, "_strtoi64");
p_strtoui64 = (void *) GetProcAddress(hMsvcrt, "_strtoui64");
+ pmbstowcs_s = (void *) GetProcAddress(hMsvcrt, "mbstowcs_s");
+ pwcstombs_s = (void *) GetProcAddress(hMsvcrt, "wcstombs_s");
/* MSVCRT memcpy behaves like memmove for overlapping moves,
MFC42 CString::Insert seems to rely on that behaviour */
@@ -1215,4 +1292,5 @@ START_TEST(string)
test_strnlen();
test__strtoi64();
test__strtod();
+ test_mbstowcs();
}
More information about the wine-cvs
mailing list