Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
CMake: use EXCLUDE_FROM_ALL when declaring Fetch for deflate library
Commit af9ef0e made a change in the CMake setup to switch from using FetchContent_Populate() to FetchContent_MakeAvailable() to bring in libdeflate (and Imath) as dependencies. Using FetchContent_MakeAvailable() has the side effect that libdeflate is now being included as part of the build, causing libraries and headers to be built and installed. The intent with fetching the deflate source is solely to copy select files into OpenEXRCore, so this change adds the EXCLUDE_FROM_ALL option to the call to FetchContent_Declare() to prevent deflate from being included in the build. One wrinkle though is that prior to CMake 3.28, passing the EXCLUDE_FROM_ALL option to FetchContent_Declare() does *not* have the desired effect of excluding the fetched content from the build when FetchContent_MakeAvailable() is called. Ideally we could "manually" set the EXCLUDE_FROM_ALL property on the deflate SOURCE_DIR and BINARY_DIR, but a bug that was only fixed as of CMake 3.20.3 prevents that from properly excluding the directories: https://gitlab.kitware.com/cmake/cmake/-/issues/22234 To support the full range of CMake versions without overly complicating things with cumbersome workarounds, we continue to use Populate for CMake versions before 3.30, and switch to MakeAvailable for CMake 3.30 and later. Signed-off-by: Matt Johnson <[email protected]>
- Loading branch information