mirror of
https://github.com/microsoft/vcpkg.git
synced 2025-06-07 16:52:53 +08:00
[libflac] using #ifdef for patches instead
This commit is contained in:
parent
cb30c3fd00
commit
38ae2f69b7
@ -7,16 +7,12 @@ vcpkg_download_distfile(ARCHIVE
|
|||||||
|
|
||||||
vcpkg_extract_source_archive(${ARCHIVE})
|
vcpkg_extract_source_archive(${ARCHIVE})
|
||||||
|
|
||||||
if (VCPKG_CMAKE_SYSTEM_NAME STREQUAL WindowsStore)
|
vcpkg_apply_patches(
|
||||||
vcpkg_apply_patches(
|
SOURCE_PATH ${CURRENT_BUILDTREES_DIR}/src/flac-1.3.2
|
||||||
SOURCE_PATH ${CURRENT_BUILDTREES_DIR}/src/flac-1.3.2
|
PATCHES
|
||||||
PATCHES
|
"${CMAKE_CURRENT_LIST_DIR}/uwp-library-console.patch"
|
||||||
"${CMAKE_CURRENT_LIST_DIR}/uwp-consolewidth.patch"
|
"${CMAKE_CURRENT_LIST_DIR}/uwp-createfile2.patch"
|
||||||
"${CMAKE_CURRENT_LIST_DIR}/uwp-loadlibrary.patch"
|
)
|
||||||
"${CMAKE_CURRENT_LIST_DIR}/uwp-createfile.patch"
|
|
||||||
"${CMAKE_CURRENT_LIST_DIR}/uwp-writeconsole.patch"
|
|
||||||
)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(VCPKG_TARGET_ARCHITECTURE STREQUAL x86)
|
if(VCPKG_TARGET_ARCHITECTURE STREQUAL x86)
|
||||||
vcpkg_find_acquire_program(NASM)
|
vcpkg_find_acquire_program(NASM)
|
||||||
|
@ -1,16 +0,0 @@
|
|||||||
diff --git a/src/share/win_utf8_io/win_utf8_io.c b/src/share/win_utf8_io/win_utf8_io.c
|
|
||||||
index c61d27f..5b0e8f0 100644
|
|
||||||
--- a/src/share/win_utf8_io/win_utf8_io.c
|
|
||||||
+++ b/src/share/win_utf8_io/win_utf8_io.c
|
|
||||||
@@ -164,11 +164,6 @@ size_t strlen_utf8(const char *str)
|
|
||||||
int win_get_console_width(void)
|
|
||||||
{
|
|
||||||
int width = 80;
|
|
||||||
- CONSOLE_SCREEN_BUFFER_INFO csbi;
|
|
||||||
- HANDLE hOut = GetStdHandle(STD_OUTPUT_HANDLE);
|
|
||||||
- if(hOut != INVALID_HANDLE_VALUE && hOut != NULL)
|
|
||||||
- if (GetConsoleScreenBufferInfo(hOut, &csbi) != 0)
|
|
||||||
- width = csbi.dwSize.X;
|
|
||||||
return width;
|
|
||||||
}
|
|
||||||
|
|
@ -1,25 +1,16 @@
|
|||||||
diff --git a/src/libFLAC/windows_unicode_filenames.c b/src/libFLAC/windows_unicode_filenames.c
|
diff --git a/src/libFLAC/windows_unicode_filenames.c b/src/libFLAC/windows_unicode_filenames.c
|
||||||
index 2404e31..6d8bc74 100644
|
index 2404e31..d320bf5 100644
|
||||||
--- a/src/libFLAC/windows_unicode_filenames.c
|
--- a/src/libFLAC/windows_unicode_filenames.c
|
||||||
+++ b/src/libFLAC/windows_unicode_filenames.c
|
+++ b/src/libFLAC/windows_unicode_filenames.c
|
||||||
@@ -185,17 +185,23 @@ int flac_internal_rename_utf8(const char *oldname, const char *newname)
|
@@ -185,6 +185,27 @@ int flac_internal_rename_utf8(const char *oldname, const char *newname)
|
||||||
|
|
||||||
HANDLE WINAPI flac_internal_CreateFile_utf8(const char *lpFileName, DWORD dwDesiredAccess, DWORD dwShareMode, LPSECURITY_ATTRIBUTES lpSecurityAttributes, DWORD dwCreationDisposition, DWORD dwFlagsAndAttributes, HANDLE hTemplateFile)
|
HANDLE WINAPI flac_internal_CreateFile_utf8(const char *lpFileName, DWORD dwDesiredAccess, DWORD dwShareMode, LPSECURITY_ATTRIBUTES lpSecurityAttributes, DWORD dwCreationDisposition, DWORD dwFlagsAndAttributes, HANDLE hTemplateFile)
|
||||||
{
|
{
|
||||||
- if (!utf8_filenames) {
|
+#if defined (WINAPI_FAMILY_PARTITION) && !WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP | WINAPI_PARTITION_SYSTEM)
|
||||||
- return CreateFileA(lpFileName, dwDesiredAccess, dwShareMode, lpSecurityAttributes, dwCreationDisposition, dwFlagsAndAttributes, hTemplateFile);
|
|
||||||
- } else {
|
|
||||||
- wchar_t *wname;
|
|
||||||
- HANDLE handle = INVALID_HANDLE_VALUE;
|
|
||||||
-
|
|
||||||
- if ((wname = wchar_from_utf8(lpFileName)) != NULL) {
|
|
||||||
- handle = CreateFileW(wname, dwDesiredAccess, dwShareMode, lpSecurityAttributes, dwCreationDisposition, dwFlagsAndAttributes, hTemplateFile);
|
|
||||||
- free(wname);
|
|
||||||
- }
|
|
||||||
+ HANDLE handle = INVALID_HANDLE_VALUE;
|
+ HANDLE handle = INVALID_HANDLE_VALUE;
|
||||||
|
+
|
||||||
+ if (!utf8_filenames)
|
+ if (!utf8_filenames)
|
||||||
return handle;
|
+ return handle;
|
||||||
+
|
+
|
||||||
+ wchar_t *wname;
|
+ wchar_t *wname;
|
||||||
+
|
+
|
||||||
@ -32,7 +23,16 @@ index 2404e31..6d8bc74 100644
|
|||||||
+ cfParams.hTemplateFile = hTemplateFile;
|
+ cfParams.hTemplateFile = hTemplateFile;
|
||||||
+ handle = CreateFile2(wname, dwDesiredAccess, dwShareMode, dwCreationDisposition, &cfParams);
|
+ handle = CreateFile2(wname, dwDesiredAccess, dwShareMode, dwCreationDisposition, &cfParams);
|
||||||
+ free(wname);
|
+ free(wname);
|
||||||
}
|
+ }
|
||||||
+
|
+
|
||||||
+ return handle;
|
+ return handle;
|
||||||
|
+#else
|
||||||
|
if (!utf8_filenames) {
|
||||||
|
return CreateFileA(lpFileName, dwDesiredAccess, dwShareMode, lpSecurityAttributes, dwCreationDisposition, dwFlagsAndAttributes, hTemplateFile);
|
||||||
|
} else {
|
||||||
|
@@ -198,4 +219,5 @@ HANDLE WINAPI flac_internal_CreateFile_utf8(const char *lpFileName, DWORD dwDesi
|
||||||
|
|
||||||
|
return handle;
|
||||||
|
}
|
||||||
|
+#endif
|
||||||
}
|
}
|
53
ports/libflac/uwp-library-console.patch
Normal file
53
ports/libflac/uwp-library-console.patch
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
diff --git a/src/share/win_utf8_io/win_utf8_io.c b/src/share/win_utf8_io/win_utf8_io.c
|
||||||
|
index c61d27f..0870054 100644
|
||||||
|
--- a/src/share/win_utf8_io/win_utf8_io.c
|
||||||
|
+++ b/src/share/win_utf8_io/win_utf8_io.c
|
||||||
|
@@ -110,7 +110,11 @@ int get_utf8_argv(int *argc, char ***argv)
|
||||||
|
char **utf8argv;
|
||||||
|
int ret, i;
|
||||||
|
|
||||||
|
+#if defined (WINAPI_FAMILY_PARTITION) && !WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP | WINAPI_PARTITION_SYSTEM)
|
||||||
|
+ if ((handle = LoadPackagedLibrary("msvcrt.dll", 0)) == NULL) return 1;
|
||||||
|
+#else
|
||||||
|
if ((handle = LoadLibrary("msvcrt.dll")) == NULL) return 1;
|
||||||
|
+#endif
|
||||||
|
if ((wgetmainargs = (wgetmainargs_t)GetProcAddress(handle, "__wgetmainargs")) == NULL) {
|
||||||
|
FreeLibrary(handle);
|
||||||
|
return 1;
|
||||||
|
@@ -163,6 +167,9 @@ size_t strlen_utf8(const char *str)
|
||||||
|
/* get the console width in characters */
|
||||||
|
int win_get_console_width(void)
|
||||||
|
{
|
||||||
|
+#if defined (WINAPI_FAMILY_PARTITION) && !WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP | WINAPI_PARTITION_SYSTEM)
|
||||||
|
+ return 80;
|
||||||
|
+#else
|
||||||
|
int width = 80;
|
||||||
|
CONSOLE_SCREEN_BUFFER_INFO csbi;
|
||||||
|
HANDLE hOut = GetStdHandle(STD_OUTPUT_HANDLE);
|
||||||
|
@@ -170,6 +177,7 @@ int win_get_console_width(void)
|
||||||
|
if (GetConsoleScreenBufferInfo(hOut, &csbi) != 0)
|
||||||
|
width = csbi.dwSize.X;
|
||||||
|
return width;
|
||||||
|
+#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
/* print functions */
|
||||||
|
@@ -179,6 +187,10 @@ static int wprint_console(FILE *stream, const wchar_t *text, size_t len)
|
||||||
|
DWORD out;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
+#if defined (WINAPI_FAMILY_PARTITION) && !WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP | WINAPI_PARTITION_SYSTEM)
|
||||||
|
+ // disabled for UWP as there's no alternative:
|
||||||
|
+ // https://docs.microsoft.com/en-us/uwp/win32-and-com/alternatives-to-windows-apis-uwp
|
||||||
|
+#else
|
||||||
|
do {
|
||||||
|
if (stream == stdout) {
|
||||||
|
HANDLE hOut = GetStdHandle(STD_OUTPUT_HANDLE);
|
||||||
|
@@ -197,6 +209,7 @@ static int wprint_console(FILE *stream, const wchar_t *text, size_t len)
|
||||||
|
return out;
|
||||||
|
}
|
||||||
|
} while(0);
|
||||||
|
+#endif
|
||||||
|
|
||||||
|
ret = fputws(text, stream);
|
||||||
|
if (ret < 0)
|
@ -1,13 +0,0 @@
|
|||||||
diff --git a/src/share/win_utf8_io/win_utf8_io.c b/src/share/win_utf8_io/win_utf8_io.c
|
|
||||||
index 5b0e8f0..15a76d4 100644
|
|
||||||
--- a/src/share/win_utf8_io/win_utf8_io.c
|
|
||||||
+++ b/src/share/win_utf8_io/win_utf8_io.c
|
|
||||||
@@ -110,7 +110,7 @@ int get_utf8_argv(int *argc, char ***argv)
|
|
||||||
char **utf8argv;
|
|
||||||
int ret, i;
|
|
||||||
|
|
||||||
- if ((handle = LoadLibrary("msvcrt.dll")) == NULL) return 1;
|
|
||||||
+ if ((handle = LoadPackagedLibrary("msvcrt.dll", 0)) == NULL) return 1;
|
|
||||||
if ((wgetmainargs = (wgetmainargs_t)GetProcAddress(handle, "__wgetmainargs")) == NULL) {
|
|
||||||
FreeLibrary(handle);
|
|
||||||
return 1;
|
|
@ -1,39 +0,0 @@
|
|||||||
diff --git a/src/share/win_utf8_io/win_utf8_io.c b/src/share/win_utf8_io/win_utf8_io.c
|
|
||||||
index 15a76d4..bfcc9db 100644
|
|
||||||
--- a/src/share/win_utf8_io/win_utf8_io.c
|
|
||||||
+++ b/src/share/win_utf8_io/win_utf8_io.c
|
|
||||||
@@ -171,31 +171,13 @@ int win_get_console_width(void)
|
|
||||||
|
|
||||||
static int wprint_console(FILE *stream, const wchar_t *text, size_t len)
|
|
||||||
{
|
|
||||||
- DWORD out;
|
|
||||||
- int ret;
|
|
||||||
+ // disabled for UWP (https://docs.microsoft.com/en-us/uwp/win32-and-com/alternatives-to-windows-apis-uwp)
|
|
||||||
|
|
||||||
- do {
|
|
||||||
- if (stream == stdout) {
|
|
||||||
- HANDLE hOut = GetStdHandle(STD_OUTPUT_HANDLE);
|
|
||||||
- if (hOut == INVALID_HANDLE_VALUE || hOut == NULL || GetFileType(hOut) != FILE_TYPE_CHAR)
|
|
||||||
- break;
|
|
||||||
- if (WriteConsoleW(hOut, text, len, &out, NULL) == 0)
|
|
||||||
- return -1;
|
|
||||||
- return out;
|
|
||||||
- }
|
|
||||||
- if (stream == stderr) {
|
|
||||||
- HANDLE hErr = GetStdHandle(STD_ERROR_HANDLE);
|
|
||||||
- if (hErr == INVALID_HANDLE_VALUE || hErr == NULL || GetFileType(hErr) != FILE_TYPE_CHAR)
|
|
||||||
- break;
|
|
||||||
- if (WriteConsoleW(hErr, text, len, &out, NULL) == 0)
|
|
||||||
- return -1;
|
|
||||||
- return out;
|
|
||||||
- }
|
|
||||||
- } while(0);
|
|
||||||
+ int ret = fputws(text, stream);
|
|
||||||
|
|
||||||
- ret = fputws(text, stream);
|
|
||||||
if (ret < 0)
|
|
||||||
return ret;
|
|
||||||
+
|
|
||||||
return len;
|
|
||||||
}
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user