Piotr Caban : msvcp90/tests: Added basic_string<char> find tests.
Alexandre Julliard
julliard at winehq.org
Fri Apr 29 11:09:15 CDT 2011
Module: wine
Branch: master
Commit: 02e46c8eaa2123631c1169ef83b8bf91f5332579
URL: http://source.winehq.org/git/wine.git/?a=commit;h=02e46c8eaa2123631c1169ef83b8bf91f5332579
Author: Piotr Caban <piotr at codeweavers.com>
Date: Fri Apr 29 11:15:29 2011 +0200
msvcp90/tests: Added basic_string<char> find tests.
---
dlls/msvcp90/tests/string.c | 31 ++++++++++++++++++++++++++++++-
1 files changed, 30 insertions(+), 1 deletions(-)
diff --git a/dlls/msvcp90/tests/string.c b/dlls/msvcp90/tests/string.c
index 4f84264..4ceb24c 100644
--- a/dlls/msvcp90/tests/string.c
+++ b/dlls/msvcp90/tests/string.c
@@ -68,6 +68,7 @@ static basic_string_char* (WINAPI *p_basic_string_char_append)(basic_string_char
static basic_string_char* (WINAPI *p_basic_string_char_append_substr)(basic_string_char*, size_t, size_t);
static int (WINAPI *p_basic_string_char_compare_substr_substr)(size_t, size_t, basic_string_char*, size_t, size_t);
static int (WINAPI *p_basic_string_char_compare_substr_cstr_len)(size_t, size_t, const char*, size_t);
+static size_t (WINAPI *p_basic_string_char_find_cstr_substr)(const char*, size_t, size_t);
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*);
@@ -96,6 +97,7 @@ static basic_string_char* (WINAPI *p_basic_string_char_append)(basic_string_char
static basic_string_char* (WINAPI *p_basic_string_char_append_substr)(basic_string_char*, basic_string_char*, size_t, size_t);
static int (WINAPI *p_basic_string_char_compare_substr_substr)(basic_string_char*, size_t, size_t, basic_string_char*, size_t, size_t);
static int (WINAPI *p_basic_string_char_compare_substr_cstr_len)(basic_string_char*, size_t, size_t, const char*, size_t);
+static size_t (WINAPI *p_basic_string_char_find_cstr_substr)(basic_string_char*, const char*, size_t, size_t);
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*);
@@ -381,6 +383,8 @@ static BOOL init(void)
"??$?HDU?$char_traits at D@std@@V?$allocator at D@1@@std@@YA?AV?$basic_string at DU?$char_traits at D@std@@V?$allocator at D@2@@0 at AEBV10@0 at Z");
p_basic_string_char_concatenate_cstr = (void*)GetProcAddress(msvcp,
"??$?HDU?$char_traits at D@std@@V?$allocator at D@1@@std@@YA?AV?$basic_string at DU?$char_traits at D@std@@V?$allocator at D@2@@0 at AEBV10@PEBD at Z");
+ p_basic_string_char_find_cstr_substr = (void*)GetProcAddress(msvcp,
+ "?find@?$basic_string at DU?$char_traits at D@std@@V?$allocator at D@2@@std@@QEBA_KPEBD_K1 at Z");
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");
@@ -439,6 +443,8 @@ static BOOL init(void)
"??$?HDU?$char_traits at D@std@@V?$allocator at D@1@@std@@YA?AV?$basic_string at DU?$char_traits at D@std@@V?$allocator at D@2@@0 at ABV10@0 at Z");
p_basic_string_char_concatenate_cstr = (void*)GetProcAddress(msvcp,
"??$?HDU?$char_traits at D@std@@V?$allocator at D@1@@std@@YA?AV?$basic_string at DU?$char_traits at D@std@@V?$allocator at D@2@@0 at ABV10@PBD at Z");
+ p_basic_string_char_find_cstr_substr = (void*)GetProcAddress(msvcp,
+ "?find@?$basic_string at DU?$char_traits at D@std@@V?$allocator at D@2@@std@@QBEIPBDII at Z");
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");
@@ -661,7 +667,7 @@ static void test_basic_string_char_concatenate(void) {
if(!p_basic_string_char_ctor_cstr || !p_basic_string_char_concatenate
|| !p_basic_string_char_concatenate_cstr || !p_basic_string_char_cstr
|| !p_basic_string_char_dtor) {
- win_skip("basic_string<wchar> unavailable\n");
+ win_skip("basic_string<char> unavailable\n");
return;
}
@@ -682,6 +688,28 @@ static void test_basic_string_char_concatenate(void) {
call_func1(p_basic_string_char_dtor, &str);
}
+static void test_basic_string_char_find(void) {
+ static const char tmp[] = {'a','a','a','\0','b','b','b',0};
+ basic_string_char str;
+ size_t ret;
+
+ if(!p_basic_string_char_ctor || !p_basic_string_char_assign_cstr_len
+ || !p_basic_string_char_dtor || !p_basic_string_char_find_cstr_substr) {
+ win_skip("basic_stringr> unavailable\n");
+ return;
+ }
+
+ call_func1(p_basic_string_char_ctor, &str);
+ call_func3(p_basic_string_char_assign_cstr_len, &str, tmp, 7);
+ ret = (size_t)call_func4(p_basic_string_char_find_cstr_substr, &str, "aaa", 0, 3);
+ ok(ret == 0, "ret = %lu\n", (unsigned long)ret);
+ ret = (size_t)call_func4(p_basic_string_char_find_cstr_substr, &str, "aaa", 1, 3);
+ ok(ret == -1, "ret = %lu\n", (unsigned long)ret);
+ ret = (size_t)call_func4(p_basic_string_char_find_cstr_substr, &str, "bbb", 0, 3);
+ ok(ret == 4, "ret = %lu\n", (unsigned long)ret);
+ call_func1(p_basic_string_char_dtor, &str);
+}
+
static void test_basic_string_wchar(void) {
static const wchar_t test[] = { 't','e','s','t',0 };
@@ -807,6 +835,7 @@ START_TEST(string)
test_basic_string_char_append();
test_basic_string_char_compare();
test_basic_string_char_concatenate();
+ test_basic_string_char_find();
test_basic_string_wchar();
test_basic_string_wchar_swap();
More information about the wine-cvs
mailing list