Skip to content

Commit

Permalink
Merge pull request #743 from Devsh-Graphics-Programming/tad_remove_fe…
Browse files Browse the repository at this point in the history
…tch_openexr

remove fetch from OpenEXR
  • Loading branch information
AnastaZIuk committed Sep 17, 2024
2 parents 8701867 + 89b3ed0 commit 337d13a
Show file tree
Hide file tree
Showing 5 changed files with 45 additions and 40 deletions.
6 changes: 6 additions & 0 deletions .gitmodules
Original file line number Diff line number Diff line change
Expand Up @@ -105,3 +105,9 @@
[submodule "3rdparty/git-version-tracking"]
path = 3rdparty/git-version-tracking
url = [email protected]:Devsh-Graphics-Programming/cmake-git-version-tracking.git
[submodule "3rdparty/imath"]
path = 3rdparty/imath
url = [email protected]:AcademySoftwareFoundation/Imath.git
[submodule "3rdparty/libdeflate"]
path = 3rdparty/libdeflate
url = [email protected]:Devsh-Graphics-Programming/libdeflate.git
75 changes: 36 additions & 39 deletions 3rdparty/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -197,44 +197,45 @@ add_dependencies(png_static zlibstatic)
# OpenEXR
option(_NBL_COMPILE_WITH_OPEN_EXR_ "Build with OpenEXR library" ON)

# Note we are adding it anyway regardless _NBL_COMPILE_WITH_OPEN_EXR_, its because we need Half dependecy
# it generates on fly in its build directory which doesnt have to be linked (class with inline methods),
# here is where _NBL_COMPILE_WITH_OPEN_EXR_ plays a role - when disabled OpenEXR won't be built and linked
# but it's core
# Imath
add_subdirectory(imath EXCLUDE_FROM_ALL)

if(_NBL_COMPILE_WITH_OPEN_EXR_)
# Deflate
option(LIBDEFLATE_BUILD_SHARED_LIB "" OFF)
option(LIBDEFLATE_BUILD_STATIC_LIB "" ON)
option(LIBDEFLATE_GZIP_SUPPORT "" OFF)
option(LIBDEFLATE_BUILD_GZIP "" OFF)
add_subdirectory(libdeflate EXCLUDE_FROM_ALL)
set(libdeflate_DIR "${CMAKE_CURRENT_BINARY_DIR}/libdeflate")

# OpenEXR
set(_OLD_BUILD_SHARED_LIBS ${BUILD_SHARED_LIBS})
set(_OLD_BUILD_STATIC_LIBS ${BUILD_STATIC_LIBS})
set(_OLD_BUILD_TESTING ${BUILD_TESTING})
set(BUILD_SHARED_LIBS OFF)
set(BUILD_STATIC_LIBS OFF)
set(BUILD_TESTING OFF)
set(PYILMBASE_ENABLE OFF CACHE STRING "" FORCE)
set(OPENEXR_BUILD_UTILS OFF CACHE STRING "" FORCE)
set(OPENEXR_FORCE_INTERNAL_IMATH OFF CACHE STRING "" FORCE)
set(OPENEXR_FORCE_INTERNAL_DEFLATE OFF CACHE STRING "" FORCE)
set(OPENEXR_BUILD_TOOLS OFF CACHE STRING "" FORCE)
set(OPENEXR_INSTALL OFF CACHE STRING "" FORCE)
set(OPENEXR_INSTALL_DOCS OFF CACHE STRING "" FORCE)
set(OPENEXR_INSTALL_EXAMPLES OFF CACHE STRING "" FORCE)
set(OPENEXR_INSTALL_PKG_CONFIG OFF CACHE STRING "" FORCE)
set(OPENEXR_INSTALL_TOOLS OFF CACHE STRING "" FORCE)

add_subdirectory(openexr EXCLUDE_FROM_ALL)

# for new build system it doesn't matter since we no more fetch content stuff, temporary to fix current master CMake clones
set(BUILD_SHARED_LIBS ${_OLD_BUILD_SHARED_LIBS})
set(BUILD_STATIC_LIBS ${_OLD_BUILD_STATIC_LIBS})
set(BUILD_TESTING ${_OLD_BUILD_TESTING})
endif()

option(NBL_OPENEXR_FORCE_SSH "" ON)

if(NBL_OPENEXR_FORCE_SSH)
set(OPENEXR_DEFLATE_REPO "[email protected]:ebiggers/libdeflate.git" CACHE STRING "Repo path for libdeflate source" FORCE)
set(OPENEXR_IMATH_REPO "[email protected]:AcademySoftwareFoundation/Imath.git" CACHE STRING "Repo for auto-build of Imath" FORCE)
else()
set(OPENEXR_DEFLATE_REPO "https://github.com/ebiggers/libdeflate.git" CACHE STRING "Repo path for libdeflate source" FORCE)
set(OPENEXR_IMATH_REPO "https://github.com/AcademySoftwareFoundation/Imath.git" CACHE STRING "Repo for auto-build of Imath" FORCE)
endif()

set(_OLD_BUILD_SHARED_LIBS ${BUILD_SHARED_LIBS})
set(_OLD_BUILD_STATIC_LIBS ${BUILD_STATIC_LIBS})
set(_OLD_BUILD_TESTING ${BUILD_TESTING})
set(BUILD_SHARED_LIBS OFF)
set(BUILD_STATIC_LIBS OFF)
set(BUILD_TESTING OFF)
set(PYILMBASE_ENABLE OFF CACHE STRING "" FORCE)
set(OPENEXR_BUILD_UTILS OFF CACHE STRING "" FORCE)
set(OPENEXR_FORCE_INTERNAL_IMATH ON CACHE STRING "" FORCE) # TODO: make it a submodule and force using it maybe instead of letting OpenEXR download it from it's github repository [FIXED in newBuildSystem branch]
set(OPENEXR_FORCE_INTERNAL_DEFLATE ON CACHE STRING "" FORCE) # TODO: make it a submodule and force using it maybe instead of letting OpenEXR download it from it's github repository [FIXED in newBuildSystem branch]
set(OPENEXR_BUILD_TOOLS OFF CACHE STRING "" FORCE)
set(OPENEXR_INSTALL OFF CACHE STRING "" FORCE)
set(OPENEXR_INSTALL_DOCS OFF CACHE STRING "" FORCE)
set(OPENEXR_INSTALL_EXAMPLES OFF CACHE STRING "" FORCE)
set(OPENEXR_INSTALL_PKG_CONFIG OFF CACHE STRING "" FORCE)
set(OPENEXR_INSTALL_TOOLS OFF CACHE STRING "" FORCE)

add_subdirectory(openexr openexr EXCLUDE_FROM_ALL)
set(BUILD_SHARED_LIBS ${_OLD_BUILD_SHARED_LIBS})
set(BUILD_STATIC_LIBS ${_OLD_BUILD_STATIC_LIBS})
set(BUILD_TESTING ${_OLD_BUILD_TESTING})

#gli
option(_NBL_COMPILE_WITH_GLI_ "Build with GLI library" ON)
Expand Down Expand Up @@ -410,10 +411,6 @@ set(NBL_3RDPARTY_TARGETS
SPIRV
SPIRV-Tools-static # SPIRV-Tools-shared in case of SHARED lib
SPIRV-Tools-opt
OpenEXRUtil
OpenEXRCore
Iex
IlmThread
Imath
freetype
${NBL_MSDFGEN_TARGETS}
Expand All @@ -422,7 +419,7 @@ set(NBL_3RDPARTY_TARGETS
)
if (_NBL_COMPILE_WITH_OPEN_EXR_)
list(APPEND NBL_3RDPARTY_TARGETS
OpenEXR
OpenEXR libdeflate_static OpenEXRUtil OpenEXRCore Iex IlmThread
)
endif()

Expand Down
1 change: 1 addition & 0 deletions 3rdparty/imath
Submodule imath added at 8c1d11
1 change: 1 addition & 0 deletions 3rdparty/libdeflate
Submodule libdeflate added at 0967de
2 changes: 1 addition & 1 deletion 3rdparty/openexr
Submodule openexr updated 432 files

0 comments on commit 337d13a

Please sign in to comment.