You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Unfortunately, the change in #135 causes a bunch of CMake variables we (or our users) set for our project to be unset when not using the corresponding SUNDIALS features, for example: PETSC_DIR, PETSC_INCLUDES, CMAKE_CUDA_ARCHITECTURES.
This then breaks our downstream users because in our built CMake config file PETSC_DIR is no longer set and so find_dependency(PETSC) won't find PETSc.
There is a warning:
CMake Warning at build/_deps/sundials-src/cmake/macros/SundialsCMakeMacros.cmake:65 (message):
------------------------------------------------------------------------
WARNING: The variable PETSC_DIR was set to my/path/to/petsc but not all of
its dependencies (ENABLE_PETSC,) evaluate to TRUE.
Unsetting PETSC_DIR
------------------------------------------------------------------------
Call Stack (most recent call first):
build/_deps/sundials-src/cmake/macros/SundialsOption.cmake:85 (print_warning)
build/_deps/sundials-src/cmake/SundialsTPLOptions.cmake:195 (sundials_option)
build/_deps/sundials-src/CMakeLists.txt:168 (include)
but these variables should really be left alone entirely.
Expected Behavior:
Un-namespaced and non-SUNDIALS-specific CMake variables are left alone, especially paths for third-party libraries.
I think this is maybe just as simple as removing the DEPENDS_ON option from most sundials_option calls in cmake/SundialsTPLOptions.cmake?
Steps To Reproduce:
Here's a minimal example:
cmake_minimum_required(VERSION 3.12)
project(mvce LANGUAGES C)
set(SUNDIALS_VERSION "v7.0.0"CACHESTRING"SUNDIALS tag")
include(FetchContent)
FetchContent_Declare(
sundials
GIT_REPOSITORY https://github.com/LLNL/sundials
GIT_TAG ${SUNDIALS_VERSION}
)
set(EXAMPLES_ENABLE_C OFFCACHEBOOL"" FORCE)
set(EXAMPLES_INSTALL OFFCACHEBOOL"" FORCE)
FetchContent_MakeAvailable(sundials)
message(STATUS"***** Value of PETSC_DIR: ${PETSC_DIR}")
And observe the value of PETSC_DIR in the output between:
FixesLLNL#538
Non-`SUNDIALS` namespaced variables may be used by other
projects so don't `unset` them
Signed-off-by: Peter Hill <peter.hill@york.ac.uk>
Non-`SUNDIALS` namespaced variables may be used by other projects so
don't `unset` them. Fixes#538
---------
Signed-off-by: Peter Hill <peter.hill@york.ac.uk>
Co-authored-by: Cody Balos <balos1@llnl.gov>
Current Behavior:
We (optionally) build SUNDIALS as part of our project, with something like:
Unfortunately, the change in #135 causes a bunch of CMake variables we (or our users) set for our project to be unset when not using the corresponding SUNDIALS features, for example:
PETSC_DIR
,PETSC_INCLUDES
,CMAKE_CUDA_ARCHITECTURES
.This then breaks our downstream users because in our built CMake config file
PETSC_DIR
is no longer set and sofind_dependency(PETSC)
won't find PETSc.There is a warning:
but these variables should really be left alone entirely.
Expected Behavior:
Un-namespaced and non-SUNDIALS-specific CMake variables are left alone, especially paths for third-party libraries.
I think this is maybe just as simple as removing the
DEPENDS_ON
option from mostsundials_option
calls incmake/SundialsTPLOptions.cmake
?Steps To Reproduce:
Here's a minimal example:
And observe the value of
PETSC_DIR
in the output between:Environment:
SUNDIALS 7.0+
Anything else:
The text was updated successfully, but these errors were encountered: