ucrtbase: Add tests and fix more zero length __stdio_common_vs[w]printf cases.

Signed-off-by: Martin Storsjo <martin@martin.st>
Signed-off-by: Piotr Caban <piotr@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
Martin Storsjo 2020-05-18 15:15:34 +03:00 committed by Alexandre Julliard
parent 17355c0566
commit 2819fea352
2 changed files with 31 additions and 2 deletions

View File

@ -744,7 +744,9 @@ int CDECL __stdio_common_vsprintf( unsigned __int64 options, char *str, MSVCRT_s
return ret>len ? -1 : ret; return ret>len ? -1 : ret;
if(ret>=len) { if(ret>=len) {
if(len) str[len-1] = 0; if(len) str[len-1] = 0;
return (options & UCRTBASE_PRINTF_STANDARD_SNPRINTF_BEHAVIOUR) ? ret : -2; if(options & UCRTBASE_PRINTF_STANDARD_SNPRINTF_BEHAVIOUR)
return ret;
return len > 0 ? -2 : -1;
} }
return ret; return ret;
} }
@ -1284,7 +1286,9 @@ int CDECL MSVCRT__stdio_common_vswprintf( unsigned __int64 options,
return ret>len ? -1 : ret; return ret>len ? -1 : ret;
if(ret>=len) { if(ret>=len) {
if(len) str[len-1] = 0; if(len) str[len-1] = 0;
return (options & UCRTBASE_PRINTF_STANDARD_SNPRINTF_BEHAVIOUR) ? ret : -2; if(options & UCRTBASE_PRINTF_STANDARD_SNPRINTF_BEHAVIOUR)
return ret;
return len > 0 ? -2 : -1;
} }
return ret; return ret;
} }

View File

@ -144,6 +144,18 @@ static void test_snprintf (void)
"Failure to snprintf to NULL\n"); "Failure to snprintf to NULL\n");
ok (vsprintf_wrapper (0, NULL, 0, "abcd") == 4, ok (vsprintf_wrapper (0, NULL, 0, "abcd") == 4,
"Failure to snprintf to NULL\n"); "Failure to snprintf to NULL\n");
ok (vsprintf_wrapper (_CRT_INTERNAL_PRINTF_STANDARD_SNPRINTF_BEHAVIOR, buffer, 0, "abcd") == 4,
"Failure to snprintf to zero length buffer\n");
ok (vsprintf_wrapper (_CRT_INTERNAL_PRINTF_LEGACY_VSPRINTF_NULL_TERMINATION, buffer, 0, "abcd") == -1,
"Failure to snprintf to zero length buffer\n");
ok (vsprintf_wrapper (0, buffer, 0, "abcd") == -1,
"Failure to snprintf to zero length buffer\n");
ok (vsprintf_wrapper (_CRT_INTERNAL_PRINTF_STANDARD_SNPRINTF_BEHAVIOR, buffer, 0, "") == 0,
"Failure to snprintf a zero length string to a zero length buffer\n");
ok (vsprintf_wrapper (_CRT_INTERNAL_PRINTF_LEGACY_VSPRINTF_NULL_TERMINATION, buffer, 0, "") == 0,
"Failure to snprintf a zero length string to a zero length buffer\n");
ok (vsprintf_wrapper (0, buffer, 0, "") == -1,
"Failure to snprintf a zero length string to a zero length buffer\n");
} }
static int WINAPIV vswprintf_wrapper(unsigned __int64 options, wchar_t *str, static int WINAPIV vswprintf_wrapper(unsigned __int64 options, wchar_t *str,
@ -163,6 +175,7 @@ static void test_swprintf (void)
const wchar_t str_justfit[] = {'j','u','s','t','f','i','t',0}; const wchar_t str_justfit[] = {'j','u','s','t','f','i','t',0};
const wchar_t str_justfits[] = {'j','u','s','t','f','i','t','s',0}; const wchar_t str_justfits[] = {'j','u','s','t','f','i','t','s',0};
const wchar_t str_muchlonger[] = {'m','u','c','h','l','o','n','g','e','r',0}; const wchar_t str_muchlonger[] = {'m','u','c','h','l','o','n','g','e','r',0};
const wchar_t str_empty[] = {0};
const wchar_t *tests[] = {str_short, str_justfit, str_justfits, str_muchlonger}; const wchar_t *tests[] = {str_short, str_justfit, str_justfits, str_muchlonger};
wchar_t buffer[8]; wchar_t buffer[8];
@ -225,6 +238,18 @@ static void test_swprintf (void)
"Failure to swprintf to NULL\n"); "Failure to swprintf to NULL\n");
ok (vswprintf_wrapper (0, NULL, 0, str_short) == 5, ok (vswprintf_wrapper (0, NULL, 0, str_short) == 5,
"Failure to swprintf to NULL\n"); "Failure to swprintf to NULL\n");
ok (vswprintf_wrapper (_CRT_INTERNAL_PRINTF_STANDARD_SNPRINTF_BEHAVIOR, buffer, 0, str_short) == 5,
"Failure to swprintf to a zero length buffer\n");
ok (vswprintf_wrapper (_CRT_INTERNAL_PRINTF_LEGACY_VSPRINTF_NULL_TERMINATION, buffer, 0, str_short) == -1,
"Failure to swprintf to a zero length buffer\n");
ok (vswprintf_wrapper (0, buffer, 0, str_short) == -1,
"Failure to swprintf to a zero length buffer\n");
ok (vswprintf_wrapper (_CRT_INTERNAL_PRINTF_STANDARD_SNPRINTF_BEHAVIOR, buffer, 0, str_empty) == 0,
"Failure to swprintf a zero length string to a zero length buffer\n");
ok (vswprintf_wrapper (_CRT_INTERNAL_PRINTF_LEGACY_VSPRINTF_NULL_TERMINATION, buffer, 0, str_empty) == 0,
"Failure to swprintf a zero length string to a zero length buffer\n");
ok (vswprintf_wrapper (0, buffer, 0, str_empty) == -1,
"Failure to swprintf a zero length string to a zero length buffer\n");
} }
static int WINAPIV vfprintf_wrapper(FILE *file, static int WINAPIV vfprintf_wrapper(FILE *file,