From 5d8abfd0ba60aff006e75f1d9881e3b1df05360a Mon Sep 17 00:00:00 2001 From: Geoff Evans Date: Tue, 8 Jun 2021 12:00:29 -0700 Subject: [PATCH] Make filemanager aware of UWP Win32 API --- src/filemanager.cpp | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) diff --git a/src/filemanager.cpp b/src/filemanager.cpp index aa1db6e5fb..c0f58ca4f6 100644 --- a/src/filemanager.cpp +++ b/src/filemanager.cpp @@ -48,6 +48,12 @@ #include "proj_config.h" +#if defined(WINAPI_FAMILY) && (WINAPI_FAMILY == WINAPI_FAMILY_APP) +#define UWP 1 +#else +#define UWP 0 +#endif + #ifdef _WIN32 #include #include @@ -692,10 +698,21 @@ std::unique_ptr FileWin32::open(PJ_CONTEXT *ctx, const char *filename, ? FILE_ATTRIBUTE_READONLY : FILE_ATTRIBUTE_NORMAL; try { +#if UWP + CREATEFILE2_EXTENDED_PARAMETERS extendedParameters; + ZeroMemory(&extendedParameters, sizeof(extendedParameters)); + extendedParameters.dwSize = sizeof(extendedParameters); + extendedParameters.dwFileAttributes = dwFlagsAndAttributes; + HANDLE hFile = CreateFile2( + UTF8ToWString(std::string(filename)).c_str(), dwDesiredAccess, + FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE, + dwCreationDisposition, &extendedParameters); +#else // UWP HANDLE hFile = CreateFileW( UTF8ToWString(std::string(filename)).c_str(), dwDesiredAccess, FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE, nullptr, dwCreationDisposition, dwFlagsAndAttributes, nullptr); +#endif // UWP return std::unique_ptr(hFile != INVALID_HANDLE_VALUE ? new FileWin32(filename, ctx, hFile) : nullptr); @@ -1136,6 +1153,9 @@ const char *proj_context_get_user_writable_directory(PJ_CONTEXT *ctx, wPath.resize(wcslen(wPath.data())); path = NS_PROJ::WStringToUTF8(wPath); #else +#if UWP + if (false) { +#else // UWP wchar_t *wPath; if (SHGetKnownFolderPath(FOLDERID_LocalAppData, 0, nullptr, &wPath) == S_OK) { @@ -1143,6 +1163,7 @@ const char *proj_context_get_user_writable_directory(PJ_CONTEXT *ctx, std::string str = NS_PROJ::WStringToUTF8(ws); path = str; CoTaskMemFree(wPath); +#endif // UWP #endif } else { const char *local_app_data = getenv("LOCALAPPDATA"); @@ -1236,11 +1257,13 @@ static std::string pj_get_relative_share_proj_internal_no_check() { #if defined(_WIN32) || defined(HAVE_LIBDL) #ifdef _WIN32 HMODULE hm = NULL; +#if !UWP if (GetModuleHandleEx(GET_MODULE_HANDLE_EX_FLAG_FROM_ADDRESS | GET_MODULE_HANDLE_EX_FLAG_UNCHANGED_REFCOUNT, (LPCSTR)&pj_get_relative_share_proj, &hm) == 0) { return std::string(); } +#endif // UWP DWORD path_size = 1024;