msvcrt: Fix char to int promotion that breaks pattern lookup.

Signed-off-by: Nikolay Sivov <nsivov@codeweavers.com>
Signed-off-by: Piotr Caban <piotr@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
Nikolay Sivov 2015-12-23 01:14:28 +03:00 committed by Alexandre Julliard
parent b0d4502c29
commit d99727bcb3
2 changed files with 15 additions and 0 deletions

View File

@ -68,7 +68,11 @@
#undef _EOF_ #undef _EOF_
#define _EOF_ 0 #define _EOF_ 0
#ifdef STRING_LEN #ifdef STRING_LEN
#ifdef WIDE_CHAR
#define _GETC_(file) (consumed==length ? '\0' : (consumed++, *file++)) #define _GETC_(file) (consumed==length ? '\0' : (consumed++, *file++))
#else /* WIDE_CHAR */
#define _GETC_(file) (consumed==length ? '\0' : (consumed++, (unsigned char)*file++))
#endif /* WIDE_CHAR */
#define _UNGETC_(nch, file) do { file--; consumed--; } while(0) #define _UNGETC_(nch, file) do { file--; consumed--; } while(0)
#define _LOCK_FILE_(file) do {} while(0) #define _LOCK_FILE_(file) do {} while(0)
#define _UNLOCK_FILE_(file) do {} while(0) #define _UNLOCK_FILE_(file) do {} while(0)
@ -86,7 +90,11 @@
#endif /* SECURE */ #endif /* SECURE */
#endif /* WIDE_SCANF */ #endif /* WIDE_SCANF */
#else /* STRING_LEN */ #else /* STRING_LEN */
#ifdef WIDE_CHAR
#define _GETC_(file) (consumed++, *file++) #define _GETC_(file) (consumed++, *file++)
#else /* WIDE_CHAR */
#define _GETC_(file) (consumed++, (unsigned char)*file++)
#endif /* WIDE_CHAR */
#define _UNGETC_(nch, file) do { file--; consumed--; } while(0) #define _UNGETC_(nch, file) do { file--; consumed--; } while(0)
#define _LOCK_FILE_(file) do {} while(0) #define _LOCK_FILE_(file) do {} while(0)
#define _UNLOCK_FILE_(file) do {} while(0) #define _UNLOCK_FILE_(file) do {} while(0)

View File

@ -244,6 +244,13 @@ static void test_sscanf( void )
ret = sscanf(buffer, "%d:%d%n", &hour, &min, &number_so_far); ret = sscanf(buffer, "%d:%d%n", &hour, &min, &number_so_far);
ok(ret == 2, "Wrong number of arguments read: %d\n", ret); ok(ret == 2, "Wrong number of arguments read: %d\n", ret);
ok(number_so_far == 4, "%%n yielded wrong result: %d\n", number_so_far); ok(number_so_far == 4, "%%n yielded wrong result: %d\n", number_so_far);
buffer[0] = 0;
buffer1[0] = 0;
ret = sscanf("test=value\xda", "%[^=] = %[^;]", buffer, buffer1);
ok(ret == 2, "got %d\n", ret);
ok(!strcmp(buffer, "test"), "buf %s\n", buffer);
ok(!strcmp(buffer1, "value\xda"), "buf %s\n", buffer1);
} }
static void test_sscanf_s(void) static void test_sscanf_s(void)