aboutsummaryrefslogtreecommitdiffstats
path: root/mpm/cmake
diff options
context:
space:
mode:
authorJoerg Hofrichter <joerg.hofrichter@ni.com>2020-01-22 17:19:04 +0100
committerMartin Braun <martin.braun@ettus.com>2020-01-22 12:54:54 -0800
commit608c8a3ab33db629596c37fc8b00902a77900e20 (patch)
treeab6148290c351ebcced70fa6ed4299ba2bc10a9f /mpm/cmake
parent84bb89878ce6fb08ed512532a0e934d89ca4b7d3 (diff)
downloaduhd-608c8a3ab33db629596c37fc8b00902a77900e20.tar.gz
uhd-608c8a3ab33db629596c37fc8b00902a77900e20.tar.bz2
uhd-608c8a3ab33db629596c37fc8b00902a77900e20.zip
mpm: fixed cmake macro for enabling modules
The macro MPM_REGISTER_COMPONENT did not work as described: in case the default enable was set to ON and all dependencies were met, the module was still not enabled. Also made the status prints more helpful: - print the default value, - print the user override (if one was provided) - print the resulting VAR = VALUE - print the override hint only if the user did not already specify an override Example of old incorrect behavior: -- Configuring Mykonos support... -- Dependency ENABLE_LIBMPM = ON -- Disabling Mykonos support. -- Override with -DENABLE_MYKONOS=ON/OFF Example of new correct behavior (also with changed prints): -- Configuring Mykonos support... -- Default value ENABLE_MYKONOS = ON -- Dependency ENABLE_LIBMPM = ON -- Enabling Mykonos support (ENABLE_MYKONOS = ON) -- Override with -DENABLE_MYKONOS=ON/OFF
Diffstat (limited to 'mpm/cmake')
-rw-r--r--mpm/cmake/Modules/MPMComponent.cmake19
1 files changed, 12 insertions, 7 deletions
diff --git a/mpm/cmake/Modules/MPMComponent.cmake b/mpm/cmake/Modules/MPMComponent.cmake
index 461d95185..216e86f3d 100644
--- a/mpm/cmake/Modules/MPMComponent.cmake
+++ b/mpm/cmake/Modules/MPMComponent.cmake
@@ -24,9 +24,6 @@ set(_mpm_disabled_components "" CACHE INTERNAL "" FORCE)
macro(MPM_REGISTER_COMPONENT name var enb deps dis req)
message(STATUS "")
message(STATUS "Configuring ${name} support...")
- foreach(dep ${deps})
- message(STATUS " Dependency ${dep} = ${${dep}}")
- endforeach(dep)
# If user specified option, store here. Note: If the user doesn't specify
# this option on the cmake command line, both user_enabled and
@@ -44,11 +41,17 @@ macro(MPM_REGISTER_COMPONENT name var enb deps dis req)
# Override default if user set
if(user_enabled OR user_disabled)
+ message(STATUS " User forced ${var} = ${${var}}")
set(option "${${var}}")
else(user_enabled OR user_disabled)
- set(option ${req})
+ message(STATUS " Default value ${var} = ${enb}")
+ set(option ${enb})
endif()
+ foreach(dep ${deps})
+ message(STATUS " Dependency ${dep} = ${${dep}}")
+ endforeach(dep)
+
# setup the dependent option for this component
include(CMakeDependentOption)
CMAKE_DEPENDENT_OPTION(${var} "enable ${name} support" ${option} "${deps}" ${dis})
@@ -67,13 +70,15 @@ macro(MPM_REGISTER_COMPONENT name var enb deps dis req)
#append the component into one of the lists
if(${var})
- message(STATUS " Enabling ${name} support.")
+ message(STATUS " Enabling ${name} support (${var} = ${${var}})")
list(APPEND _mpm_enabled_components ${name})
else(${var})
- message(STATUS " Disabling ${name} support.")
+ message(STATUS " Disabling ${name} support (${var} = ${${var}})")
list(APPEND _mpm_disabled_components ${name})
endif(${var})
- message(STATUS " Override with -D${var}=ON/OFF")
+ if(NOT user_enabled AND NOT user_disabled)
+ message(STATUS " Override with -D${var}=ON/OFF")
+ endif(NOT user_enabled AND NOT user_disabled)
#make components lists into global variables
set(_mpm_enabled_components ${_uhd_enabled_components} CACHE INTERNAL "" FORCE)