Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-winehq
Commits
7b170df2
Commit
7b170df2
authored
Oct 22, 2006
by
Mikołaj Zalewski
Committed by
Alexandre Julliard
Oct 23, 2006
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
shlwapi: Test and fix StrRStrI[AW].
parent
ef8151b3
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
60 additions
and
18 deletions
+60
-18
string.c
dlls/shlwapi/string.c
+20
-18
string.c
dlls/shlwapi/tests/string.c
+40
-0
No files found.
dlls/shlwapi/string.c
View file @
7b170df2
...
@@ -639,7 +639,6 @@ LPWSTR WINAPI StrStrW(LPCWSTR lpszStr, LPCWSTR lpszSearch)
...
@@ -639,7 +639,6 @@ LPWSTR WINAPI StrStrW(LPCWSTR lpszStr, LPCWSTR lpszSearch)
*/
*/
LPSTR
WINAPI
StrRStrIA
(
LPCSTR
lpszStr
,
LPCSTR
lpszEnd
,
LPCSTR
lpszSearch
)
LPSTR
WINAPI
StrRStrIA
(
LPCSTR
lpszStr
,
LPCSTR
lpszEnd
,
LPCSTR
lpszSearch
)
{
{
LPSTR
lpszRet
=
NULL
;
WORD
ch1
,
ch2
;
WORD
ch1
,
ch2
;
INT
iLen
;
INT
iLen
;
...
@@ -650,24 +649,26 @@ LPSTR WINAPI StrRStrIA(LPCSTR lpszStr, LPCSTR lpszEnd, LPCSTR lpszSearch)
...
@@ -650,24 +649,26 @@ LPSTR WINAPI StrRStrIA(LPCSTR lpszStr, LPCSTR lpszEnd, LPCSTR lpszSearch)
if
(
!
lpszEnd
)
if
(
!
lpszEnd
)
lpszEnd
=
lpszStr
+
lstrlenA
(
lpszStr
);
lpszEnd
=
lpszStr
+
lstrlenA
(
lpszStr
);
if
(
lpszEnd
==
lpszStr
)
return
NULL
;
if
(
IsDBCSLeadByte
(
*
lpszSearch
))
if
(
IsDBCSLeadByte
(
*
lpszSearch
))
ch1
=
*
lpszSearch
<<
8
|
lpszSearch
[
1
];
ch1
=
*
lpszSearch
<<
8
|
(
UCHAR
)
lpszSearch
[
1
];
else
else
ch1
=
*
lpszSearch
;
ch1
=
*
lpszSearch
;
iLen
=
lstrlenA
(
lpszSearch
);
iLen
=
lstrlenA
(
lpszSearch
);
while
(
lpszStr
<=
lpszEnd
&&
*
lpszStr
)
do
{
{
ch2
=
IsDBCSLeadByte
(
*
lpszStr
)
?
*
lpszStr
<<
8
|
lpszStr
[
1
]
:
*
lpszStr
;
lpszEnd
=
CharPrevA
(
lpszStr
,
lpszEnd
);
ch2
=
IsDBCSLeadByte
(
*
lpszEnd
)
?
*
lpszEnd
<<
8
|
(
UCHAR
)
lpszEnd
[
1
]
:
*
lpszEnd
;
if
(
!
ChrCmpIA
(
ch1
,
ch2
))
if
(
!
ChrCmpIA
(
ch1
,
ch2
))
{
{
if
(
!
StrCmpNIA
(
lpsz
Str
,
lpszSearch
,
iLen
))
if
(
!
StrCmpNIA
(
lpsz
End
,
lpszSearch
,
iLen
))
lpszRet
=
(
LPSTR
)
lpszStr
;
return
(
LPSTR
)
lpszEnd
;
}
}
lpszStr
=
CharNextA
(
lpszStr
);
}
while
(
lpszEnd
>
lpszStr
);
}
return
NULL
;
return
lpszRet
;
}
}
/*************************************************************************
/*************************************************************************
...
@@ -677,7 +678,6 @@ LPSTR WINAPI StrRStrIA(LPCSTR lpszStr, LPCSTR lpszEnd, LPCSTR lpszSearch)
...
@@ -677,7 +678,6 @@ LPSTR WINAPI StrRStrIA(LPCSTR lpszStr, LPCSTR lpszEnd, LPCSTR lpszSearch)
*/
*/
LPWSTR
WINAPI
StrRStrIW
(
LPCWSTR
lpszStr
,
LPCWSTR
lpszEnd
,
LPCWSTR
lpszSearch
)
LPWSTR
WINAPI
StrRStrIW
(
LPCWSTR
lpszStr
,
LPCWSTR
lpszEnd
,
LPCWSTR
lpszSearch
)
{
{
LPWSTR
lpszRet
=
NULL
;
INT
iLen
;
INT
iLen
;
TRACE
(
"(%s,%s)
\n
"
,
debugstr_w
(
lpszStr
),
debugstr_w
(
lpszSearch
));
TRACE
(
"(%s,%s)
\n
"
,
debugstr_w
(
lpszStr
),
debugstr_w
(
lpszSearch
));
...
@@ -687,19 +687,21 @@ LPWSTR WINAPI StrRStrIW(LPCWSTR lpszStr, LPCWSTR lpszEnd, LPCWSTR lpszSearch)
...
@@ -687,19 +687,21 @@ LPWSTR WINAPI StrRStrIW(LPCWSTR lpszStr, LPCWSTR lpszEnd, LPCWSTR lpszSearch)
if
(
!
lpszEnd
)
if
(
!
lpszEnd
)
lpszEnd
=
lpszStr
+
strlenW
(
lpszStr
);
lpszEnd
=
lpszStr
+
strlenW
(
lpszStr
);
if
(
lpszEnd
==
lpszStr
)
return
NULL
;
iLen
=
strlenW
(
lpszSearch
);
iLen
=
strlenW
(
lpszSearch
);
while
(
lpszStr
<=
lpszEnd
&&
*
lpszStr
)
do
{
{
if
(
!
ChrCmpIW
(
*
lpszSearch
,
*
lpszStr
))
lpszEnd
=
CharPrevW
(
lpszStr
,
lpszEnd
);
if
(
!
ChrCmpIW
(
*
lpszSearch
,
*
lpszEnd
))
{
{
if
(
!
StrCmpNIW
(
lpsz
Str
,
lpszSearch
,
iLen
))
if
(
!
StrCmpNIW
(
lpsz
End
,
lpszSearch
,
iLen
))
lpszRet
=
(
LPWSTR
)
lpszStr
;
return
(
LPWSTR
)
lpszEnd
;
}
}
lpszStr
=
CharNextW
(
lpszStr
);
}
while
(
lpszEnd
>
lpszStr
);
}
return
NULL
;
return
lpszRet
;
}
}
/*************************************************************************
/*************************************************************************
...
...
dlls/shlwapi/tests/string.c
View file @
7b170df2
...
@@ -683,6 +683,45 @@ static void test_StrCpyNXW(void)
...
@@ -683,6 +683,45 @@ static void test_StrCpyNXW(void)
dest
+
5
,
lpszRes
,
dest
[
0
],
dest
[
1
],
dest
[
2
],
dest
[
3
],
dest
[
4
],
dest
[
5
],
dest
[
6
],
dest
[
7
]);
dest
+
5
,
lpszRes
,
dest
[
0
],
dest
[
1
],
dest
[
2
],
dest
[
3
],
dest
[
4
],
dest
[
5
],
dest
[
6
],
dest
[
7
]);
}
}
#define check_strrstri(type, str, pos, needle, exp) \
ret##type = StrRStrI##type(str, str+pos, needle); \
ok(ret##type == (exp), "Type " #type ", expected %p but got %p (string base %p)\n", \
(exp), ret##type, str);
static
void
test_StrRStrI
()
{
static
const
CHAR
szTest
[]
=
"yAxxxxAy"
;
static
const
CHAR
szTest2
[]
=
"ABABABAB"
;
static
const
WCHAR
wszTest
[]
=
{
'y'
,
'A'
,
'x'
,
'x'
,
'x'
,
'x'
,
'A'
,
'y'
,
0
};
static
const
WCHAR
wszTest2
[]
=
{
'A'
,
'B'
,
'A'
,
'B'
,
'A'
,
'B'
,
'A'
,
'B'
,
0
};
static
const
WCHAR
wszPattern1
[]
=
{
'A'
,
0
};
static
const
WCHAR
wszPattern2
[]
=
{
'a'
,
'X'
,
0
};
static
const
WCHAR
wszPattern3
[]
=
{
'A'
,
'y'
,
0
};
static
const
WCHAR
wszPattern4
[]
=
{
'a'
,
'b'
,
0
};
LPWSTR
retW
;
LPSTR
retA
;
check_strrstri
(
A
,
szTest
,
4
,
"A"
,
szTest
+
1
);
check_strrstri
(
A
,
szTest
,
4
,
"aX"
,
szTest
+
1
);
check_strrstri
(
A
,
szTest
,
4
,
"Ay"
,
NULL
);
check_strrstri
(
W
,
wszTest
,
4
,
wszPattern1
,
wszTest
+
1
);
check_strrstri
(
W
,
wszTest
,
4
,
wszPattern2
,
wszTest
+
1
);
check_strrstri
(
W
,
wszTest
,
4
,
wszPattern3
,
NULL
);
check_strrstri
(
A
,
szTest2
,
4
,
"ab"
,
szTest2
+
2
);
check_strrstri
(
A
,
szTest2
,
3
,
"ab"
,
szTest2
+
2
);
check_strrstri
(
A
,
szTest2
,
2
,
"ab"
,
szTest2
);
check_strrstri
(
A
,
szTest2
,
1
,
"ab"
,
szTest2
);
check_strrstri
(
A
,
szTest2
,
0
,
"ab"
,
NULL
);
check_strrstri
(
W
,
wszTest2
,
4
,
wszPattern4
,
wszTest2
+
2
);
check_strrstri
(
W
,
wszTest2
,
3
,
wszPattern4
,
wszTest2
+
2
);
check_strrstri
(
W
,
wszTest2
,
2
,
wszPattern4
,
wszTest2
);
check_strrstri
(
W
,
wszTest2
,
1
,
wszPattern4
,
wszTest2
);
check_strrstri
(
W
,
wszTest2
,
0
,
wszPattern4
,
NULL
);
}
static
void
test_SHAnsiToAnsi
(
void
)
static
void
test_SHAnsiToAnsi
(
void
)
{
{
char
dest
[
8
];
char
dest
[
8
];
...
@@ -760,6 +799,7 @@ START_TEST(string)
...
@@ -760,6 +799,7 @@ START_TEST(string)
test_StrRetToBSTR
();
test_StrRetToBSTR
();
test_StrCpyNXA
();
test_StrCpyNXA
();
test_StrCpyNXW
();
test_StrCpyNXW
();
test_StrRStrI
();
test_SHAnsiToAnsi
();
test_SHAnsiToAnsi
();
test_SHUnicodeToUnicode
();
test_SHUnicodeToUnicode
();
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment