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