mirror of
https://github.com/microsoft/vcpkg.git
synced 2025-01-19 02:13:03 +08:00
[libsndfile] patches applied with #ifdef instead
This commit is contained in:
parent
295bb9f454
commit
72fdd294b0
@ -19,14 +19,11 @@ 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/libsndfile-6830c421899e32f8d413a903a21a9b6cf384d369
|
||||||
SOURCE_PATH ${CURRENT_BUILDTREES_DIR}/src/libsndfile-6830c421899e32f8d413a903a21a9b6cf384d369
|
PATCHES
|
||||||
PATCHES
|
"${CMAKE_CURRENT_LIST_DIR}/uwp-createfile-getfilesize.patch"
|
||||||
"${CMAKE_CURRENT_LIST_DIR}/uwp-createfile.patch"
|
)
|
||||||
"${CMAKE_CURRENT_LIST_DIR}/uwp-getfilesize.patch"
|
|
||||||
)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if (VCPKG_CRT_LINKAGE STREQUAL "dynamic")
|
if (VCPKG_CRT_LINKAGE STREQUAL "dynamic")
|
||||||
set(CRT_LIB_STATIC 0)
|
set(CRT_LIB_STATIC 0)
|
||||||
|
58
ports/libsndfile/uwp-createfile-getfilesize.patch
Normal file
58
ports/libsndfile/uwp-createfile-getfilesize.patch
Normal file
@ -0,0 +1,58 @@
|
|||||||
|
diff --git a/src/file_io.c b/src/file_io.c
|
||||||
|
index 7cf8f0c..47351bc 100644
|
||||||
|
--- a/src/file_io.c
|
||||||
|
+++ b/src/file_io.c
|
||||||
|
@@ -787,6 +787,19 @@ psf_open_handle (PSF_FILE * pfile)
|
||||||
|
return NULL ;
|
||||||
|
} ;
|
||||||
|
|
||||||
|
+#if defined (WINAPI_FAMILY_PARTITION) && !WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP | WINAPI_PARTITION_SYSTEM)
|
||||||
|
+ if (!pfile->use_wchar)
|
||||||
|
+ return NULL;
|
||||||
|
+
|
||||||
|
+ CREATEFILE2_EXTENDED_PARAMETERS cfParams = {0};
|
||||||
|
+ cfParams.dwSize = sizeof(CREATEFILE2_EXTENDED_PARAMETERS);
|
||||||
|
+ cfParams.dwFileAttributes = FILE_ATTRIBUTE_NORMAL;
|
||||||
|
+
|
||||||
|
+ handle = CreateFile2(pfile->path.wc, dwDesiredAccess, dwShareMode, dwCreationDistribution, &cfParams);
|
||||||
|
+
|
||||||
|
+ if (handle == INVALID_HANDLE_VALUE)
|
||||||
|
+ return NULL;
|
||||||
|
+#else
|
||||||
|
if (pfile->use_wchar)
|
||||||
|
handle = CreateFileW (
|
||||||
|
pfile->path.wc, /* pointer to name of the file */
|
||||||
|
@@ -812,6 +825,7 @@ psf_open_handle (PSF_FILE * pfile)
|
||||||
|
return NULL ;
|
||||||
|
|
||||||
|
return handle ;
|
||||||
|
+#endif
|
||||||
|
} /* psf_open_handle */
|
||||||
|
|
||||||
|
/* USE_WINDOWS_API */ static void
|
||||||
|
@@ -1104,7 +1118,16 @@ psf_is_pipe (SF_PRIVATE *psf)
|
||||||
|
|
||||||
|
/* USE_WINDOWS_API */ sf_count_t
|
||||||
|
psf_get_filelen_handle (HANDLE handle)
|
||||||
|
-{ sf_count_t filelen ;
|
||||||
|
+{
|
||||||
|
+#if defined (WINAPI_FAMILY_PARTITION) && !WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP | WINAPI_PARTITION_SYSTEM)
|
||||||
|
+ LARGE_INTEGER size;
|
||||||
|
+
|
||||||
|
+ if (!GetFileSizeEx(handle, &size) && GetLastError() != NO_ERROR)
|
||||||
|
+ return (sf_count_t) -1 ;
|
||||||
|
+
|
||||||
|
+ return size.QuadPart;
|
||||||
|
+#else
|
||||||
|
+ sf_count_t filelen ;
|
||||||
|
DWORD dwFileSizeLow, dwFileSizeHigh, dwError = NO_ERROR ;
|
||||||
|
|
||||||
|
dwFileSizeLow = GetFileSize (handle, &dwFileSizeHigh) ;
|
||||||
|
@@ -1118,6 +1141,7 @@ psf_get_filelen_handle (HANDLE handle)
|
||||||
|
filelen = dwFileSizeLow + ((__int64) dwFileSizeHigh << 32) ;
|
||||||
|
|
||||||
|
return filelen ;
|
||||||
|
+#endif
|
||||||
|
} /* psf_get_filelen_handle */
|
||||||
|
|
||||||
|
/* USE_WINDOWS_API */ void
|
@ -1,39 +0,0 @@
|
|||||||
diff --git a/src/file_io.c b/src/file_io.c
|
|
||||||
index 7cf8f0c..a47ce6b 100644
|
|
||||||
--- a/src/file_io.c
|
|
||||||
+++ b/src/file_io.c
|
|
||||||
@@ -787,26 +787,14 @@ psf_open_handle (PSF_FILE * pfile)
|
|
||||||
return NULL ;
|
|
||||||
} ;
|
|
||||||
|
|
||||||
- if (pfile->use_wchar)
|
|
||||||
- handle = CreateFileW (
|
|
||||||
- pfile->path.wc, /* pointer to name of the file */
|
|
||||||
- dwDesiredAccess, /* access (read-write) mode */
|
|
||||||
- dwShareMode, /* share mode */
|
|
||||||
- 0, /* pointer to security attributes */
|
|
||||||
- dwCreationDistribution, /* how to create */
|
|
||||||
- FILE_ATTRIBUTE_NORMAL, /* file attributes (could use FILE_FLAG_SEQUENTIAL_SCAN) */
|
|
||||||
- NULL /* handle to file with attributes to copy */
|
|
||||||
- ) ;
|
|
||||||
- else
|
|
||||||
- handle = CreateFile (
|
|
||||||
- pfile->path.c, /* pointer to name of the file */
|
|
||||||
- dwDesiredAccess, /* access (read-write) mode */
|
|
||||||
- dwShareMode, /* share mode */
|
|
||||||
- 0, /* pointer to security attributes */
|
|
||||||
- dwCreationDistribution, /* how to create */
|
|
||||||
- FILE_ATTRIBUTE_NORMAL, /* file attributes (could use FILE_FLAG_SEQUENTIAL_SCAN) */
|
|
||||||
- NULL /* handle to file with attributes to copy */
|
|
||||||
- ) ;
|
|
||||||
+ if (!pfile->use_wchar)
|
|
||||||
+ return NULL;
|
|
||||||
+
|
|
||||||
+ CREATEFILE2_EXTENDED_PARAMETERS cfParams = {0};
|
|
||||||
+ cfParams.dwSize = sizeof(CREATEFILE2_EXTENDED_PARAMETERS);
|
|
||||||
+ cfParams.dwFileAttributes = FILE_ATTRIBUTE_NORMAL;
|
|
||||||
+
|
|
||||||
+ handle = CreateFile2(pfile->path.wc, dwDesiredAccess, dwShareMode, dwCreationDistribution, &cfParams);
|
|
||||||
|
|
||||||
if (handle == INVALID_HANDLE_VALUE)
|
|
||||||
return NULL ;
|
|
@ -1,29 +0,0 @@
|
|||||||
diff --git a/src/file_io.c b/src/file_io.c
|
|
||||||
index a47ce6b..4b38455 100644
|
|
||||||
--- a/src/file_io.c
|
|
||||||
+++ b/src/file_io.c
|
|
||||||
@@ -1093,19 +1093,16 @@ psf_is_pipe (SF_PRIVATE *psf)
|
|
||||||
/* USE_WINDOWS_API */ sf_count_t
|
|
||||||
psf_get_filelen_handle (HANDLE handle)
|
|
||||||
{ sf_count_t filelen ;
|
|
||||||
- DWORD dwFileSizeLow, dwFileSizeHigh, dwError = NO_ERROR ;
|
|
||||||
+ DWORD dwError = NO_ERROR ;
|
|
||||||
+ LARGE_INTEGER size;
|
|
||||||
|
|
||||||
- dwFileSizeLow = GetFileSize (handle, &dwFileSizeHigh) ;
|
|
||||||
-
|
|
||||||
- if (dwFileSizeLow == 0xFFFFFFFF)
|
|
||||||
- dwError = GetLastError () ;
|
|
||||||
+ if (!GetFileSizeEx(handle, &size))
|
|
||||||
+ dwError = GetLastError();
|
|
||||||
|
|
||||||
if (dwError != NO_ERROR)
|
|
||||||
return (sf_count_t) -1 ;
|
|
||||||
|
|
||||||
- filelen = dwFileSizeLow + ((__int64) dwFileSizeHigh << 32) ;
|
|
||||||
-
|
|
||||||
- return filelen ;
|
|
||||||
+ return size.QuadPart;
|
|
||||||
} /* psf_get_filelen_handle */
|
|
||||||
|
|
||||||
/* USE_WINDOWS_API */ void
|
|
Loading…
Reference in New Issue
Block a user