Commit 51b9f4cd authored by Ted Lyngmo's avatar Ted Lyngmo Committed by Alexandre Julliard

ucrtbase: Add support for x mode in fopen.

parent bb637469
...@@ -1586,6 +1586,13 @@ static int msvcrt_get_flags(const wchar_t* mode, int *open_flags, int* stream_fl ...@@ -1586,6 +1586,13 @@ static int msvcrt_get_flags(const wchar_t* mode, int *open_flags, int* stream_fl
*open_flags |= _O_TEXT; *open_flags |= _O_TEXT;
*open_flags &= ~_O_BINARY; *open_flags &= ~_O_BINARY;
break; break;
#if _MSVCR_VER>=140
case 'x':
if(!MSVCRT_CHECK_PMT((*open_flags & (_O_CREAT | _O_APPEND)) == _O_CREAT))
return -1;
*open_flags |= _O_EXCL;
break;
#endif
case 'D': case 'D':
*open_flags |= _O_TEMPORARY; *open_flags |= _O_TEMPORARY;
break; break;
......
...@@ -1539,6 +1539,54 @@ static void test_fenv(void) ...@@ -1539,6 +1539,54 @@ static void test_fenv(void)
ok(!except, "expected 0, got %lx\n", except); ok(!except, "expected 0, got %lx\n", except);
} }
static void test_fopen_exclusive( void )
{
char path[MAX_PATH*2];
DWORD len;
FILE *fp;
if (!GetProcAddress(GetModuleHandleA("ucrtbase.dll"), "__std_terminate"))
{
win_skip("skipping fopen x mode tests.\n");
return;
}
len = GetTempPathA(MAX_PATH, path);
ok(len, "GetTempPathA failed\n");
strcat(path, "\\fileexcl.tst");
fp = fopen(path, "wx");
ok(fp != NULL, "creating file with mode wx failed\n");
fclose(fp);
fp = fopen(path, "wx");
ok(!fp, "overwrote existing file with mode wx\n");
unlink(path);
fp = fopen(path, "w+x");
ok(fp != NULL, "creating file with mode w+x failed\n");
fclose(fp);
fp = fopen(path, "w+x");
ok(!fp, "overwrote existing file with mode w+x\n");
SET_EXPECT(global_invalid_parameter_handler);
fp = fopen(path, "rx");
CHECK_CALLED(global_invalid_parameter_handler);
ok(!fp, "opening file with mode rx succeeded\n");
unlink(path);
SET_EXPECT(global_invalid_parameter_handler);
fp = fopen(path, "xw");
CHECK_CALLED(global_invalid_parameter_handler);
ok(!fp, "creating file with mode xw succeeded\n");
fp = fopen(path, "wbx");
ok(fp != NULL, "creating file with mode wx failed\n");
fclose(fp);
unlink(path);
}
START_TEST(misc) START_TEST(misc)
{ {
int arg_c; int arg_c;
...@@ -1580,4 +1628,5 @@ START_TEST(misc) ...@@ -1580,4 +1628,5 @@ START_TEST(misc)
test_clock(); test_clock();
test_thread_storage(); test_thread_storage();
test_fenv(); test_fenv();
test_fopen_exclusive();
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment