Piotr Caban : msvcp90/tests: Added basic_string<wchar_t> tests.
Alexandre Julliard
julliard at winehq.org
Mon Aug 30 13:00:46 CDT 2010
Module: wine
Branch: master
Commit: 39b98144c7e01a727fc1a27aaf4025012a347f19
URL: http://source.winehq.org/git/wine.git/?a=commit;h=39b98144c7e01a727fc1a27aaf4025012a347f19
Author: Piotr Caban <piotr at codeweavers.com>
Date: Mon Aug 30 16:36:07 2010 +0200
msvcp90/tests: Added basic_string<wchar_t> tests.
---
dlls/msvcp90/tests/string.c | 114 ++++++++++++++++++++++++++++++++++++++++++-
1 files changed, 113 insertions(+), 1 deletions(-)
diff --git a/dlls/msvcp90/tests/string.c b/dlls/msvcp90/tests/string.c
index 1eae95d..f780779 100644
--- a/dlls/msvcp90/tests/string.c
+++ b/dlls/msvcp90/tests/string.c
@@ -27,7 +27,7 @@
typedef struct _basic_string_char
{
void *allocator;
- union _data {
+ union {
char buf[BUF_SIZE_CHAR];
char *ptr;
} data;
@@ -35,6 +35,19 @@ typedef struct _basic_string_char
size_t res;
} basic_string_char;
+/* basic_string<wchar_t, char_traits<wchar_t>, allocator<wchar_t>> */
+#define BUF_SIZE_WCHAR 8
+typedef struct _basic_string_wchar
+{
+ void *allocator;
+ union {
+ wchar_t buf[BUF_SIZE_WCHAR];
+ wchar_t *ptr;
+ } data;
+ size_t size;
+ size_t res;
+} basic_string_wchar;
+
static void* (__cdecl *p_set_invalid_parameter_handler)(void*);
#ifdef __i386__
@@ -45,6 +58,14 @@ static void (WINAPI *p_basic_string_char_dtor)(void);
static basic_string_char* (WINAPI *p_basic_string_char_erase)(size_t, size_t);
static basic_string_char* (WINAPI *p_basic_string_char_assign_cstr_len)(const char*, size_t);
static const char* (WINAPI *p_basic_string_char_cstr)(void);
+
+static basic_string_wchar* (WINAPI *p_basic_string_wchar_ctor)(void);
+static basic_string_wchar* (WINAPI *p_basic_string_wchar_copy_ctor)(basic_string_wchar*);
+static basic_string_wchar* (WINAPI *p_basic_string_wchar_ctor_cstr)(const wchar_t*);
+static void (WINAPI *p_basic_string_wchar_dtor)(void);
+static basic_string_wchar* (WINAPI *p_basic_string_wchar_erase)(size_t, size_t);
+static basic_string_wchar* (WINAPI *p_basic_string_wchar_assign_cstr_len)(const wchar_t*, size_t);
+static const wchar_t* (WINAPI *p_basic_string_wchar_cstr)(void);
#else
static basic_string_char* (__cdecl *p_basic_string_char_ctor)(basic_string_char*);
static basic_string_char* (__cdecl *p_basic_string_char_copy_ctor)(basic_string_char*, basic_string_char*);
@@ -53,6 +74,14 @@ static void (__cdecl *p_basic_string_char_dtor)(basic_string_char*);
static basic_string_char* (__cdecl *p_basic_string_char_erase)(basic_string_char*, size_t, size_t);
static basic_string_char* (__cdecl *p_basic_string_char_assign_cstr_len)(basic_string_char*, const char*, size_t);
static const char* (__cdecl *p_basic_string_char_cstr)(basic_string_char*);
+
+static basic_string_wchar* (__cdecl *p_basic_string_wchar_ctor)(basic_string_wchar*);
+static basic_string_wchar* (__cdecl *p_basic_string_wchar_copy_ctor)(basic_string_wchar*, basic_string_wchar*);
+static basic_string_wchar* (__cdecl *p_basic_string_wchar_ctor_cstr)(basic_string_wchar*, const wchar_t*);
+static void (__cdecl *p_basic_string_wchar_dtor)(basic_string_wchar*);
+static basic_string_wchar* (__cdecl *p_basic_string_wchar_erase)(basic_string_wchar*, size_t, size_t);
+static basic_string_wchar* (__cdecl *p_basic_string_wchar_assign_cstr_len)(basic_string_wchar*, const wchar_t*, size_t);
+static const wchar_t* (__cdecl *p_basic_string_wchar_cstr)(basic_string_wchar*);
#endif
static int invalid_parameter = 0;
@@ -199,6 +228,21 @@ static BOOL init(void)
"?assign@?$basic_string at DU?$char_traits at D@std@@V?$allocator at D@2@@std@@QEAAAEAV12 at PEBD_K@Z");
p_basic_string_char_cstr = (void*)GetProcAddress(msvcp,
"?c_str@?$basic_string at DU?$char_traits at D@std@@V?$allocator at D@2@@std@@QEBAPEBDXZ");
+
+ p_basic_string_wchar_ctor = (void*)GetProcAddress(msvcp,
+ "??0?$basic_string at _WU?$char_traits at _W@std@@V?$allocator at _W@2@@std@@QEAA at XZ");
+ p_basic_string_wchar_copy_ctor = (void*)GetProcAddress(msvcp,
+ "??0?$basic_string at _WU?$char_traits at _W@std@@V?$allocator at _W@2@@std@@QEAA at AEBV01@@Z");
+ p_basic_string_wchar_ctor_cstr = (void*)GetProcAddress(msvcp,
+ "??0?$basic_string at _WU?$char_traits at _W@std@@V?$allocator at _W@2@@std@@QEAA at PEB_W@Z");
+ p_basic_string_wchar_dtor = (void*)GetProcAddress(msvcp,
+ "??1?$basic_string at _WU?$char_traits at _W@std@@V?$allocator at _W@2@@std@@QEAA at XZ");
+ p_basic_string_wchar_erase = (void*)GetProcAddress(msvcp,
+ "?erase@?$basic_string at _WU?$char_traits at _W@std@@V?$allocator at _W@2@@std@@QEAAAEAV12 at _K0@Z");
+ p_basic_string_wchar_assign_cstr_len = (void*)GetProcAddress(msvcp,
+ "?assign@?$basic_string at _WU?$char_traits at _W@std@@V?$allocator at _W@2@@std@@QEAAAEAV12 at PEB_W_K@Z");
+ p_basic_string_wchar_cstr = (void*)GetProcAddress(msvcp,
+ "?c_str@?$basic_string at _WU?$char_traits at _W@std@@V?$allocator at _W@2@@std@@QEBAPEB_WXZ");
} else {
p_basic_string_char_ctor = (void*)GetProcAddress(msvcp,
"??0?$basic_string at DU?$char_traits at D@std@@V?$allocator at D@2@@std@@QAE at XZ");
@@ -214,6 +258,21 @@ static BOOL init(void)
"?assign@?$basic_string at DU?$char_traits at D@std@@V?$allocator at D@2@@std@@QAEAAV12 at PBDI@Z");
p_basic_string_char_cstr = (void*)GetProcAddress(msvcp,
"?c_str@?$basic_string at DU?$char_traits at D@std@@V?$allocator at D@2@@std@@QBEPBDXZ");
+
+ p_basic_string_wchar_ctor = (void*)GetProcAddress(msvcp,
+ "??0?$basic_string at _WU?$char_traits at _W@std@@V?$allocator at _W@2@@std@@QAE at XZ");
+ p_basic_string_wchar_copy_ctor = (void*)GetProcAddress(msvcp,
+ "??0?$basic_string at _WU?$char_traits at _W@std@@V?$allocator at _W@2@@std@@QAE at ABV01@@Z");
+ p_basic_string_wchar_ctor_cstr = (void*)GetProcAddress(msvcp,
+ "??0?$basic_string at _WU?$char_traits at _W@std@@V?$allocator at _W@2@@std@@QAE at PB_W@Z");
+ p_basic_string_wchar_dtor = (void*)GetProcAddress(msvcp,
+ "??1?$basic_string at _WU?$char_traits at _W@std@@V?$allocator at _W@2@@std@@QAE at XZ");
+ p_basic_string_wchar_erase = (void*)GetProcAddress(msvcp,
+ "?erase@?$basic_string at _WU?$char_traits at _W@std@@V?$allocator at _W@2@@std@@QAEAAV12 at II@Z");
+ p_basic_string_wchar_assign_cstr_len = (void*)GetProcAddress(msvcp,
+ "?assign@?$basic_string at _WU?$char_traits at _W@std@@V?$allocator at _W@2@@std@@QAEAAV12 at PB_WI@Z");
+ p_basic_string_wchar_cstr = (void*)GetProcAddress(msvcp,
+ "?c_str@?$basic_string at _WU?$char_traits at _W@std@@V?$allocator at _W@2@@std@@QBEPB_WXZ");
}
return TRUE;
@@ -268,12 +327,65 @@ static void test_basic_string_char(void) {
call_func1(p_basic_string_char_dtor, &str2);
}
+static void test_basic_string_wchar(void) {
+ static const wchar_t test[] = { 't','e','s','t',0 };
+
+ basic_string_wchar str1, str2, *pstr;
+ const wchar_t *str;
+
+ if(!p_basic_string_wchar_ctor || !p_basic_string_wchar_copy_ctor
+ || !p_basic_string_wchar_ctor_cstr || !p_basic_string_wchar_dtor
+ || !p_basic_string_wchar_erase || !p_basic_string_wchar_assign_cstr_len
+ || !p_basic_string_wchar_cstr) {
+ win_skip("basic_string<wchar_t> unavailable\n");
+ return;
+ }
+
+ call_func1(p_basic_string_wchar_ctor, &str1);
+ str = NULL;
+ str = call_func1(p_basic_string_wchar_cstr, &str1);
+ ok(str != NULL, "str = NULL\n");
+ ok(*str == '\0', "*str = %c\n", *str);
+ call_func1(p_basic_string_wchar_dtor, &str1);
+
+ pstr = call_func2(p_basic_string_wchar_ctor_cstr, &str1, test);
+ ok(pstr == &str1, "pstr != &str1\n");
+ str = call_func1(p_basic_string_wchar_cstr, &str1);
+ ok(!memcmp(str, test, 5*sizeof(wchar_t)), "str = %s\n", wine_dbgstr_w(str));
+
+ memset(&str2, 0, sizeof(basic_string_wchar));
+ pstr = call_func2(p_basic_string_wchar_copy_ctor, &str2, &str1);
+ ok(pstr == &str2, "pstr != &str2\n");
+ str = call_func1(p_basic_string_wchar_cstr, &str2);
+ ok(!memcmp(str, test, 5*sizeof(wchar_t)), "str = %s\n", wine_dbgstr_w(str));
+
+ call_func3(p_basic_string_wchar_erase, &str2, 1, 2);
+ str = call_func1(p_basic_string_wchar_cstr, &str2);
+ ok(str[0]=='t' && str[1]=='t' && str[2]=='\0', "str = %s\n", wine_dbgstr_w(str));
+
+ call_func3(p_basic_string_wchar_erase, &str2, 1, 100);
+ str = call_func1(p_basic_string_wchar_cstr, &str2);
+ ok(str[0]=='t' && str[1]=='\0', "str = %s\n", wine_dbgstr_w(str));
+
+ call_func3(p_basic_string_wchar_assign_cstr_len, &str2, test, 4);
+ str = call_func1(p_basic_string_wchar_cstr, &str2);
+ ok(!memcmp(str, test, 5*sizeof(wchar_t)), "str = %s\n", wine_dbgstr_w(str));
+
+ call_func3(p_basic_string_wchar_assign_cstr_len, &str2, (str+1), 2);
+ str = call_func1(p_basic_string_wchar_cstr, &str2);
+ ok(str[0]=='e' && str[1]=='s' && str[2]=='\0', "str = %s\n", wine_dbgstr_w(str));
+
+ call_func1(p_basic_string_wchar_dtor, &str1);
+ call_func1(p_basic_string_wchar_dtor, &str2);
+}
+
START_TEST(string)
{
if(!init())
return;
test_basic_string_char();
+ test_basic_string_wchar();
ok(!invalid_parameter, "invalid_parameter_handler was invoked too many times\n");
}
More information about the wine-cvs
mailing list