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
0f81fcb0
Commit
0f81fcb0
authored
Jan 13, 2014
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
msvcp90: Call the appropriate secure function instead of duplicating the checks.
parent
b88630a4
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
22 additions
and
51 deletions
+22
-51
string.c
dlls/msvcp90/string.c
+12
-44
misc.c
dlls/msvcp90/tests/misc.c
+10
-7
No files found.
dlls/msvcp90/string.c
View file @
0f81fcb0
...
@@ -109,14 +109,8 @@ MSVCP_size_t CDECL MSVCP_char_traits_char_length(const char *str)
...
@@ -109,14 +109,8 @@ MSVCP_size_t CDECL MSVCP_char_traits_char_length(const char *str)
char
*
CDECL
MSVCP_char_traits_char__Copy_s
(
char
*
dest
,
char
*
CDECL
MSVCP_char_traits_char__Copy_s
(
char
*
dest
,
MSVCP_size_t
size
,
const
char
*
src
,
MSVCP_size_t
count
)
MSVCP_size_t
size
,
const
char
*
src
,
MSVCP_size_t
count
)
{
{
if
(
!
dest
||
!
src
||
size
<
count
)
{
memcpy_s
(
dest
,
size
,
src
,
count
);
if
(
dest
&&
size
)
return
dest
;
dest
[
0
]
=
'\0'
;
_invalid_parameter
(
NULL
,
NULL
,
NULL
,
0
,
0
);
return
dest
;
}
return
memcpy
(
dest
,
src
,
count
);
}
}
/* ?copy@?$char_traits@D@std@@SAPADPADPBDI@Z */
/* ?copy@?$char_traits@D@std@@SAPADPADPBDI@Z */
...
@@ -140,14 +134,8 @@ const char * CDECL MSVCP_char_traits_char_find(
...
@@ -140,14 +134,8 @@ const char * CDECL MSVCP_char_traits_char_find(
char
*
CDECL
MSVCP_char_traits_char__Move_s
(
char
*
dest
,
char
*
CDECL
MSVCP_char_traits_char__Move_s
(
char
*
dest
,
MSVCP_size_t
size
,
const
char
*
src
,
MSVCP_size_t
count
)
MSVCP_size_t
size
,
const
char
*
src
,
MSVCP_size_t
count
)
{
{
if
(
!
dest
||
!
src
||
size
<
count
)
{
memmove_s
(
dest
,
size
,
src
,
count
);
if
(
dest
&&
size
)
return
dest
;
dest
[
0
]
=
'\0'
;
_invalid_parameter
(
NULL
,
NULL
,
NULL
,
0
,
0
);
return
dest
;
}
return
memmove
(
dest
,
src
,
count
);
}
}
/* ?move@?$char_traits@D@std@@SAPADPADPBDI@Z */
/* ?move@?$char_traits@D@std@@SAPADPADPBDI@Z */
...
@@ -245,14 +233,8 @@ MSVCP_size_t CDECL MSVCP_char_traits_wchar_length(const wchar_t *str)
...
@@ -245,14 +233,8 @@ MSVCP_size_t CDECL MSVCP_char_traits_wchar_length(const wchar_t *str)
wchar_t
*
CDECL
MSVCP_char_traits_wchar__Copy_s
(
wchar_t
*
dest
,
wchar_t
*
CDECL
MSVCP_char_traits_wchar__Copy_s
(
wchar_t
*
dest
,
MSVCP_size_t
size
,
const
wchar_t
*
src
,
MSVCP_size_t
count
)
MSVCP_size_t
size
,
const
wchar_t
*
src
,
MSVCP_size_t
count
)
{
{
if
(
!
dest
||
!
src
||
size
<
count
)
{
memcpy_s
(
dest
,
size
*
sizeof
(
wchar_t
),
src
,
count
*
sizeof
(
wchar_t
));
if
(
dest
&&
size
)
return
dest
;
dest
[
0
]
=
'\0'
;
_invalid_parameter
(
NULL
,
NULL
,
NULL
,
0
,
0
);
return
dest
;
}
return
memcpy
(
dest
,
src
,
count
*
sizeof
(
wchar_t
));
}
}
/* ?copy@?$char_traits@_W@std@@SAPA_WPA_WPB_WI@Z */
/* ?copy@?$char_traits@_W@std@@SAPA_WPA_WPB_WI@Z */
...
@@ -282,14 +264,8 @@ const wchar_t* CDECL MSVCP_char_traits_wchar_find(
...
@@ -282,14 +264,8 @@ const wchar_t* CDECL MSVCP_char_traits_wchar_find(
wchar_t
*
CDECL
MSVCP_char_traits_wchar__Move_s
(
wchar_t
*
dest
,
wchar_t
*
CDECL
MSVCP_char_traits_wchar__Move_s
(
wchar_t
*
dest
,
MSVCP_size_t
size
,
const
wchar_t
*
src
,
MSVCP_size_t
count
)
MSVCP_size_t
size
,
const
wchar_t
*
src
,
MSVCP_size_t
count
)
{
{
if
(
!
dest
||
!
src
||
size
<
count
)
{
memmove_s
(
dest
,
size
*
sizeof
(
wchar_t
),
src
,
count
*
sizeof
(
wchar_t
));
if
(
dest
&&
size
)
return
dest
;
dest
[
0
]
=
'\0'
;
_invalid_parameter
(
NULL
,
NULL
,
NULL
,
0
,
0
);
return
dest
;
}
return
memmove
(
dest
,
src
,
count
*
sizeof
(
WCHAR
));
}
}
/* ?move@?$char_traits@_W@std@@SAPA_WPA_WPB_WI@Z */
/* ?move@?$char_traits@_W@std@@SAPA_WPA_WPB_WI@Z */
...
@@ -404,12 +380,8 @@ MSVCP_size_t CDECL MSVCP_char_traits_short_length(const unsigned short *str)
...
@@ -404,12 +380,8 @@ MSVCP_size_t CDECL MSVCP_char_traits_short_length(const unsigned short *str)
unsigned
short
*
CDECL
MSVCP_char_traits_short__Copy_s
(
unsigned
short
*
dest
,
unsigned
short
*
CDECL
MSVCP_char_traits_short__Copy_s
(
unsigned
short
*
dest
,
MSVCP_size_t
size
,
const
unsigned
short
*
src
,
MSVCP_size_t
count
)
MSVCP_size_t
size
,
const
unsigned
short
*
src
,
MSVCP_size_t
count
)
{
{
if
(
size
<
count
)
{
memcpy_s
(
dest
,
size
*
sizeof
(
unsigned
short
),
src
,
count
*
sizeof
(
unsigned
short
));
_invalid_parameter
(
NULL
,
NULL
,
NULL
,
0
,
0
);
return
dest
;
return
dest
;
}
return
memcpy
(
dest
,
src
,
count
*
sizeof
(
unsigned
short
));
}
}
/* ?copy@?$char_traits@G@std@@SAPAGPAGPBGI@Z */
/* ?copy@?$char_traits@G@std@@SAPAGPAGPBGI@Z */
...
@@ -439,12 +411,8 @@ const unsigned short* CDECL MSVCP_char_traits_short_find(
...
@@ -439,12 +411,8 @@ const unsigned short* CDECL MSVCP_char_traits_short_find(
unsigned
short
*
CDECL
MSVCP_char_traits_short__Move_s
(
unsigned
short
*
dest
,
unsigned
short
*
CDECL
MSVCP_char_traits_short__Move_s
(
unsigned
short
*
dest
,
MSVCP_size_t
size
,
const
unsigned
short
*
src
,
MSVCP_size_t
count
)
MSVCP_size_t
size
,
const
unsigned
short
*
src
,
MSVCP_size_t
count
)
{
{
if
(
size
<
count
)
{
memmove_s
(
dest
,
size
*
sizeof
(
unsigned
short
),
src
,
count
*
sizeof
(
unsigned
short
));
_invalid_parameter
(
NULL
,
NULL
,
NULL
,
0
,
0
);
return
dest
;
return
dest
;
}
return
memmove
(
dest
,
src
,
count
*
sizeof
(
unsigned
short
));
}
}
/* ?move@?$char_traits@G@std@@SAPAGPAGPBGI@Z */
/* ?move@?$char_traits@G@std@@SAPAGPAGPBGI@Z */
...
...
dlls/msvcp90/tests/misc.c
View file @
0f81fcb0
...
@@ -20,6 +20,7 @@
...
@@ -20,6 +20,7 @@
#include <locale.h>
#include <locale.h>
#include <wctype.h>
#include <wctype.h>
#include <float.h>
#include <float.h>
#include <errno.h>
#include <windef.h>
#include <windef.h>
#include <winbase.h>
#include <winbase.h>
...
@@ -60,6 +61,7 @@ static void* (__cdecl *p_set_invalid_parameter_handler)(void*);
...
@@ -60,6 +61,7 @@ static void* (__cdecl *p_set_invalid_parameter_handler)(void*);
static
_locale_t
(
__cdecl
*
p__get_current_locale
)(
void
);
static
_locale_t
(
__cdecl
*
p__get_current_locale
)(
void
);
static
void
(
__cdecl
*
p__free_locale
)(
_locale_t
);
static
void
(
__cdecl
*
p__free_locale
)(
_locale_t
);
static
void
(
__cdecl
*
p_free
)(
void
*
);
static
void
(
__cdecl
*
p_free
)(
void
*
);
static
int
*
(
__cdecl
*
p_errno
)(
void
);
static
void
(
__cdecl
*
p_char_assign
)(
void
*
,
const
void
*
);
static
void
(
__cdecl
*
p_char_assign
)(
void
*
,
const
void
*
);
static
void
(
__cdecl
*
p_wchar_assign
)(
void
*
,
const
void
*
);
static
void
(
__cdecl
*
p_wchar_assign
)(
void
*
,
const
void
*
);
...
@@ -196,7 +198,8 @@ static BOOL init(void)
...
@@ -196,7 +198,8 @@ static BOOL init(void)
p__get_current_locale
=
(
void
*
)
GetProcAddress
(
msvcr
,
"_get_current_locale"
);
p__get_current_locale
=
(
void
*
)
GetProcAddress
(
msvcr
,
"_get_current_locale"
);
p__free_locale
=
(
void
*
)
GetProcAddress
(
msvcr
,
"_free_locale"
);
p__free_locale
=
(
void
*
)
GetProcAddress
(
msvcr
,
"_free_locale"
);
p_free
=
(
void
*
)
GetProcAddress
(
msvcr
,
"free"
);
p_free
=
(
void
*
)
GetProcAddress
(
msvcr
,
"free"
);
if
(
!
p_set_invalid_parameter_handler
||
!
p__get_current_locale
||
!
p__free_locale
||
!
p_free
)
{
p_errno
=
(
void
*
)
GetProcAddress
(
msvcr
,
"_errno"
);
if
(
!
p_set_invalid_parameter_handler
||
!
p__get_current_locale
||
!
p__free_locale
||
!
p_free
||
!
p_errno
)
{
win_skip
(
"Error setting tests environment
\n
"
);
win_skip
(
"Error setting tests environment
\n
"
);
return
FALSE
;
return
FALSE
;
}
}
...
@@ -449,7 +452,7 @@ static void test_Copy_s(void)
...
@@ -449,7 +452,7 @@ static void test_Copy_s(void)
ok
(
dest
[
4
]
==
'#'
,
"dest[4] != '#'
\n
"
);
ok
(
dest
[
4
]
==
'#'
,
"dest[4] != '#'
\n
"
);
ok
(
!
memcmp
(
dest
,
src
,
sizeof
(
char
[
4
])),
"dest = %s
\n
"
,
dest
);
ok
(
!
memcmp
(
dest
,
src
,
sizeof
(
char
[
4
])),
"dest = %s
\n
"
,
dest
);
errno
=
0xdeadbeef
;
*
p_errno
()
=
0xdeadbeef
;
dest
[
0
]
=
'#'
;
dest
[
0
]
=
'#'
;
ret
=
p_Copy_s
(
dest
,
3
,
src
,
4
);
ret
=
p_Copy_s
(
dest
,
3
,
src
,
4
);
ok
(
ret
==
dest
,
"ret != dest
\n
"
);
ok
(
ret
==
dest
,
"ret != dest
\n
"
);
...
@@ -457,21 +460,21 @@ static void test_Copy_s(void)
...
@@ -457,21 +460,21 @@ static void test_Copy_s(void)
ok
(
invalid_parameter
==
1
,
"invalid_parameter = %d
\n
"
,
ok
(
invalid_parameter
==
1
,
"invalid_parameter = %d
\n
"
,
invalid_parameter
);
invalid_parameter
);
invalid_parameter
=
0
;
invalid_parameter
=
0
;
ok
(
errno
==
0xdeadbeef
,
"errno = %d
\n
"
,
errno
);
ok
(
*
p_errno
()
==
ERANGE
,
"errno = %d
\n
"
,
*
p_errno
()
);
errno
=
0xdeadbeef
;
*
p_errno
()
=
0xdeadbeef
;
p_Copy_s
(
NULL
,
32
,
src
,
4
);
p_Copy_s
(
NULL
,
32
,
src
,
4
);
ok
(
invalid_parameter
==
1
,
"invalid_parameter = %d
\n
"
,
ok
(
invalid_parameter
==
1
,
"invalid_parameter = %d
\n
"
,
invalid_parameter
);
invalid_parameter
);
invalid_parameter
=
0
;
invalid_parameter
=
0
;
ok
(
errno
==
0xdeadbeef
,
"errno = %d
\n
"
,
errno
);
ok
(
*
p_errno
()
==
EINVAL
,
"errno = %d
\n
"
,
*
p_errno
()
);
errno
=
0xdeadbeef
;
*
p_errno
()
=
0xdeadbeef
;
p_Copy_s
(
dest
,
32
,
NULL
,
4
);
p_Copy_s
(
dest
,
32
,
NULL
,
4
);
ok
(
invalid_parameter
==
1
,
"invalid_parameter = %d
\n
"
,
ok
(
invalid_parameter
==
1
,
"invalid_parameter = %d
\n
"
,
invalid_parameter
);
invalid_parameter
);
invalid_parameter
=
0
;
invalid_parameter
=
0
;
ok
(
errno
==
0xdeadbeef
,
"errno = %d
\n
"
,
errno
);
ok
(
*
p_errno
()
==
EINVAL
,
"errno = %d
\n
"
,
*
p_errno
()
);
}
}
static
void
test_wctype
(
void
)
static
void
test_wctype
(
void
)
...
...
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