diff --git a/src/share/win_utf8_io/win_utf8_io.c b/src/share/win_utf8_io/win_utf8_io.c index af6d0f4..6a6de15 100644 --- a/src/share/win_utf8_io/win_utf8_io.c +++ b/src/share/win_utf8_io/win_utf8_io.c @@ -160,6 +160,27 @@ int get_utf8_argv(int *argc, char ***argv) /* similar to CreateFileW but accepts UTF-8 encoded lpFileName */ HANDLE WINAPI CreateFile_utf8(const char *lpFileName, DWORD dwDesiredAccess, DWORD dwShareMode, LPSECURITY_ATTRIBUTES lpSecurityAttributes, DWORD dwCreationDisposition, DWORD dwFlagsAndAttributes, HANDLE hTemplateFile) { +#if defined (WINAPI_FAMILY_PARTITION) && !WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP | WINAPI_PARTITION_SYSTEM) + HANDLE handle = INVALID_HANDLE_VALUE; + + if (!flac_internal_get_utf8_filenames()) + return handle; + + wchar_t *wname; + + if ((wname = wchar_from_utf8(lpFileName)) != NULL) + { + CREATEFILE2_EXTENDED_PARAMETERS cfParams = {0}; + cfParams.dwSize = sizeof(CREATEFILE2_EXTENDED_PARAMETERS); + cfParams.dwFileAttributes = dwFlagsAndAttributes & FILE_ATTRIBUTE_NORMAL; + cfParams.lpSecurityAttributes = lpSecurityAttributes; + cfParams.hTemplateFile = hTemplateFile; + handle = CreateFile2(wname, dwDesiredAccess, dwShareMode, dwCreationDisposition, &cfParams); + free(wname); + } + + return handle; +#else wchar_t *wname; HANDLE handle = INVALID_HANDLE_VALUE; @@ -180,6 +201,7 @@ HANDLE WINAPI CreateFile_utf8(const char *lpFileName, DWORD dwDesiredAccess, DWO } return handle; +#endif } /* return number of characters in the UTF-8 string */