mirror of
https://github.com/microsoft/vcpkg.git
synced 2025-01-13 05:37:57 +08:00
17b23eeb3b
* [directxtex] Use CMake build system and add OpenEXR support Use the provided CMake file instead of the VS solutions to build the library, as recommended in the vcpkg maintainer guide. Also add the openexr feature to enable OpenEXR in the library and its tools. https://github.com/Microsoft/DirectXTex/wiki/Adding-OpenEXR * [directxtex] Fix build failure on ARM and UWP * [directxtex] Use vcpkg_copy_tools * [directxtex] Add win7 feature DirectXTex can be build without DirectX12 to support Windows 7 Service Pack 1 or later platforms, so I added this as a feature. * [directxtex] Replace win7 with dx12 feature * [directxrex] Shorten patch file * [directxtex] Fix wrong port version * [directxtex] Use ninja
108 lines
4.1 KiB
Diff
108 lines
4.1 KiB
Diff
diff --git a/CMakeLists.txt b/CMakeLists.txt
|
|
index 53b41a3..84867f3 100644
|
|
--- a/CMakeLists.txt
|
|
+++ b/CMakeLists.txt
|
|
@@ -20,6 +20,9 @@ option(BC_USE_OPENMP "Build with OpenMP support" ON)
|
|
|
|
option(ENABLE_CODE_ANALYSIS "Use Static Code Analysis on build" OFF)
|
|
|
|
+# Includes the functions for loading/saving OpenEXR files at runtime
|
|
+option(ENABLE_OPENEXR_SUPPORT "Build with OpenEXR support" OFF)
|
|
+
|
|
set(CMAKE_CXX_STANDARD 14)
|
|
set(CMAKE_CXX_STANDARD_REQUIRED ON)
|
|
set(CMAKE_CXX_EXTENSIONS OFF)
|
|
@@ -67,6 +70,12 @@ endif()
|
|
if(BUILD_DX12)
|
|
set(LIBRARY_SOURCES ${LIBRARY_SOURCES} DirectXTex/DirectXTexD3D12.cpp)
|
|
endif()
|
|
+if(ENABLE_OPENEXR_SUPPORT)
|
|
+ set(LIBRARY_SOURCES
|
|
+ ${LIBRARY_SOURCES}
|
|
+ DirectXTex/DirectXTexEXR.h
|
|
+ DirectXTex/DirectXTexEXR.cpp)
|
|
+endif()
|
|
|
|
add_library(${PROJECT_NAME} STATIC ${LIBRARY_SOURCES} DirectXTex/Shaders/Compiled/BC6HEncode_EncodeBlockCS.inc)
|
|
|
|
@@ -82,6 +91,10 @@ add_custom_command(
|
|
source_group(${PROJECT_NAME} REGULAR_EXPRESSION DirectXTex/*.*)
|
|
|
|
target_include_directories(${PROJECT_NAME} PUBLIC DirectXTex)
|
|
+if(ENABLE_OPENEXR_SUPPORT)
|
|
+ find_package(openexr REQUIRED)
|
|
+ target_include_directories(${PROJECT_NAME} PRIVATE ${OPENEXR_INCLUDE_DIRS}/OpenEXR)
|
|
+endif()
|
|
|
|
if (${CMAKE_VERSION} VERSION_GREATER_EQUAL "3.16")
|
|
target_precompile_headers(${PROJECT_NAME} PRIVATE DirectXTex/DirectXTexP.h)
|
|
@@ -116,6 +129,13 @@ add_executable(texdiag Texdiag/texdiag.cpp)
|
|
target_link_libraries(texdiag ${PROJECT_NAME} version.lib)
|
|
source_group(texdiag REGULAR_EXPRESSION Texdiag/*.*)
|
|
|
|
+if(ENABLE_OPENEXR_SUPPORT)
|
|
+ target_link_libraries(${PROJECT_NAME} ${OPENEXR_ILMIMF_LIBRARY})
|
|
+ target_link_libraries(texassemble ${OPENEXR_ILMIMF_LIBRARY})
|
|
+ target_link_libraries(texconv ${OPENEXR_ILMIMF_LIBRARY})
|
|
+ target_link_libraries(texdiag ${OPENEXR_ILMIMF_LIBRARY})
|
|
+endif()
|
|
+
|
|
if(MSVC)
|
|
target_compile_options(${PROJECT_NAME} PRIVATE /fp:fast)
|
|
target_compile_options(texassemble PRIVATE /fp:fast)
|
|
@@ -140,6 +160,12 @@ if ( CMAKE_CXX_COMPILER_ID MATCHES "Clang" )
|
|
target_compile_options(texassemble PRIVATE ${WarningsEXE})
|
|
target_compile_options(texconv PRIVATE ${WarningsEXE})
|
|
target_compile_options(texdiag PRIVATE ${WarningsEXE} "-Wno-double-promotion" )
|
|
+
|
|
+ if(ENABLE_OPENEXR_SUPPORT)
|
|
+ target_compile_options(texassemble PRIVATE -DUSE_OPENEXR)
|
|
+ target_compile_options(texconv PRIVATE -DUSE_OPENEXR)
|
|
+ target_compile_options(texdiag PRIVATE -DUSE_OPENEXR)
|
|
+ endif()
|
|
endif()
|
|
if ( CMAKE_CXX_COMPILER_ID MATCHES "MSVC" )
|
|
target_compile_options(${PROJECT_NAME} PRIVATE /permissive- /JMC- /Zc:__cplusplus)
|
|
@@ -167,6 +193,12 @@ if ( CMAKE_CXX_COMPILER_ID MATCHES "MSVC" )
|
|
target_compile_options(texconv PRIVATE /openmp /Zc:twoPhase-)
|
|
endif()
|
|
|
|
+ if(ENABLE_OPENEXR_SUPPORT)
|
|
+ target_compile_options(texassemble PRIVATE /D "USE_OPENEXR")
|
|
+ target_compile_options(texconv PRIVATE /D "USE_OPENEXR")
|
|
+ target_compile_options(texdiag PRIVATE /D "USE_OPENEXR")
|
|
+ endif()
|
|
+
|
|
set(WarningsEXE "/wd4061" "/wd4062" "/wd4365" "/wd4668" "/wd4710" "/wd4820" "/wd5039" "/wd5045" "/wd5219")
|
|
target_compile_options(texassemble PRIVATE ${WarningsEXE})
|
|
target_compile_options(texconv PRIVATE ${WarningsEXE})
|
|
diff --git a/DirectXTex/DirectXTexEXR.cpp b/DirectXTex/DirectXTexEXR.cpp
|
|
index 0cfd4db..7a6e70c 100644
|
|
--- a/DirectXTex/DirectXTexEXR.cpp
|
|
+++ b/DirectXTex/DirectXTexEXR.cpp
|
|
@@ -8,7 +8,7 @@
|
|
//--------------------------------------------------------------------------------------
|
|
|
|
//Uncomment if you add DirectXTexEXR to your copy of the DirectXTex library
|
|
-//#include "DirectXTexP.h"
|
|
+#include "DirectXTexP.h"
|
|
|
|
#include "DirectXTexEXR.h"
|
|
|
|
@@ -38,6 +38,7 @@
|
|
using PackedVector::XMHALF4;
|
|
|
|
// Comment out this first anonymous namespace if you add the include of DirectXTexP.h above
|
|
+#if 0
|
|
namespace
|
|
{
|
|
struct handle_closer { void operator()(HANDLE h) { assert(h != INVALID_HANDLE_VALUE); if (h) CloseHandle(h); } };
|
|
@@ -70,6 +76,7 @@
|
|
HANDLE m_handle;
|
|
};
|
|
}
|
|
+#endif
|
|
|
|
namespace
|
|
{
|