summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSeth R. Johnson <johnsonsr@ornl.gov>2021-05-19 06:59:06 -0400
committerGitHub <noreply@github.com>2021-05-19 06:59:06 -0400
commit3d2cd480486648cd60c2400b9771df34e7aca684 (patch)
treec4cda21621fba37732020be3a10eb1b0df84c9eb
parent33df3990de3dc89fcdbefd1cb4b8bfe0b316f43a (diff)
downloadspack-3d2cd480486648cd60c2400b9771df34e7aca684.tar.gz
spack-3d2cd480486648cd60c2400b9771df34e7aca684.tar.bz2
spack-3d2cd480486648cd60c2400b9771df34e7aca684.tar.xz
spack-3d2cd480486648cd60c2400b9771df34e7aca684.zip
Use define_from_variant in numerous CMakePackages (#23655)
Example replacement: ``` '-D(\w+)(:BOOL)?=\{0\}'\.\s*format\s*\(\s*'(ON|YES|true|TRUE)' if '\+(\w+)' in (self\.)?spec else '(OFF|NO|false|FALSE)'\) ``` with ``` self.define_from_variant('\1', '\4') ``` This will cause failures if any variants were misspelled: I have already caught two packages with nonexistent variants.
-rw-r--r--var/spack/repos/builtin/packages/adios2/package.py52
-rw-r--r--var/spack/repos/builtin/packages/albany/package.py45
-rw-r--r--var/spack/repos/builtin/packages/alquimia/package.py3
-rw-r--r--var/spack/repos/builtin/packages/aocl-sparse/package.py6
-rw-r--r--var/spack/repos/builtin/packages/arborx/package.py2
-rw-r--r--var/spack/repos/builtin/packages/arrayfire/package.py9
-rw-r--r--var/spack/repos/builtin/packages/asagi/package.py16
-rw-r--r--var/spack/repos/builtin/packages/aspect/package.py3
-rw-r--r--var/spack/repos/builtin/packages/assimp/package.py3
-rw-r--r--var/spack/repos/builtin/packages/babelflow/package.py5
-rw-r--r--var/spack/repos/builtin/packages/bml/package.py3
-rw-r--r--var/spack/repos/builtin/packages/butterflypack/package.py5
-rw-r--r--var/spack/repos/builtin/packages/c-blosc2/package.py9
-rw-r--r--var/spack/repos/builtin/packages/camp/package.py3
-rw-r--r--var/spack/repos/builtin/packages/care/package.py52
-rw-r--r--var/spack/repos/builtin/packages/catch2/package.py3
-rw-r--r--var/spack/repos/builtin/packages/cgns/package.py30
-rw-r--r--var/spack/repos/builtin/packages/chai/package.py9
-rw-r--r--var/spack/repos/builtin/packages/clfft/package.py8
-rw-r--r--var/spack/repos/builtin/packages/cminpack/package.py3
-rw-r--r--var/spack/repos/builtin/packages/dakota/package.py3
-rw-r--r--var/spack/repos/builtin/packages/datatransferkit/package.py7
-rw-r--r--var/spack/repos/builtin/packages/dmlc-core/package.py3
-rw-r--r--var/spack/repos/builtin/packages/draco/package.py2
-rw-r--r--var/spack/repos/builtin/packages/ethminer/package.py8
-rw-r--r--var/spack/repos/builtin/packages/everytrace/package.py7
-rw-r--r--var/spack/repos/builtin/packages/fairlogger/package.py3
-rw-r--r--var/spack/repos/builtin/packages/faodel/package.py21
-rw-r--r--var/spack/repos/builtin/packages/flatbuffers/package.py3
-rw-r--r--var/spack/repos/builtin/packages/flcl/package.py3
-rw-r--r--var/spack/repos/builtin/packages/ghost/package.py15
-rw-r--r--var/spack/repos/builtin/packages/ginkgo/package.py19
-rw-r--r--var/spack/repos/builtin/packages/gl2ps/package.py4
-rw-r--r--var/spack/repos/builtin/packages/googletest/package.py3
-rw-r--r--var/spack/repos/builtin/packages/gotcha/package.py3
-rw-r--r--var/spack/repos/builtin/packages/gunrock/package.py28
-rw-r--r--var/spack/repos/builtin/packages/helics/package.py34
-rw-r--r--var/spack/repos/builtin/packages/ibmisc/package.py16
-rw-r--r--var/spack/repos/builtin/packages/jansson/package.py3
-rw-r--r--var/spack/repos/builtin/packages/lammps/package.py21
-rw-r--r--var/spack/repos/builtin/packages/libgit2/package.py2
-rw-r--r--var/spack/repos/builtin/packages/libnetworkit/package.py3
-rw-r--r--var/spack/repos/builtin/packages/libsplash/package.py6
-rw-r--r--var/spack/repos/builtin/packages/libssh/package.py3
-rw-r--r--var/spack/repos/builtin/packages/libssh2/package.py4
-rw-r--r--var/spack/repos/builtin/packages/modern-wheel/package.py7
-rw-r--r--var/spack/repos/builtin/packages/mofem-cephas/package.py6
-rw-r--r--var/spack/repos/builtin/packages/mofem-fracture-module/package.py22
-rw-r--r--var/spack/repos/builtin/packages/mofem-minimal-surface-equation/package.py7
-rw-r--r--var/spack/repos/builtin/packages/mofem-users-modules/package.py7
-rw-r--r--var/spack/repos/builtin/packages/mpilander/package.py6
-rw-r--r--var/spack/repos/builtin/packages/msgpack-c/package.py3
-rw-r--r--var/spack/repos/builtin/packages/nalu/package.py3
-rw-r--r--var/spack/repos/builtin/packages/nnvm/package.py2
-rw-r--r--var/spack/repos/builtin/packages/openfast/package.py15
-rw-r--r--var/spack/repos/builtin/packages/opennurbs/package.py3
-rw-r--r--var/spack/repos/builtin/packages/pagmo/package.py24
-rw-r--r--var/spack/repos/builtin/packages/paradiseo/package.py17
-rw-r--r--var/spack/repos/builtin/packages/perfstubs/package.py5
-rw-r--r--var/spack/repos/builtin/packages/pfunit/package.py8
-rw-r--r--var/spack/repos/builtin/packages/phist/package.py18
-rw-r--r--var/spack/repos/builtin/packages/piranha/package.py2
-rw-r--r--var/spack/repos/builtin/packages/pism/package.py33
-rw-r--r--var/spack/repos/builtin/packages/pumi/package.py7
-rw-r--r--var/spack/repos/builtin/packages/py-pybind11/package.py3
-rw-r--r--var/spack/repos/builtin/packages/qgis/package.py9
-rw-r--r--var/spack/repos/builtin/packages/raja/package.py15
-rw-r--r--var/spack/repos/builtin/packages/rmlab/package.py5
-rw-r--r--var/spack/repos/builtin/packages/seacas/package.py73
-rw-r--r--var/spack/repos/builtin/packages/snappy/package.py15
-rw-r--r--var/spack/repos/builtin/packages/spdlog/package.py11
-rw-r--r--var/spack/repos/builtin/packages/strumpack/package.py29
-rw-r--r--var/spack/repos/builtin/packages/sundials/package.py26
-rw-r--r--var/spack/repos/builtin/packages/symengine/package.py18
-rw-r--r--var/spack/repos/builtin/packages/tasmanian/package.py24
-rw-r--r--var/spack/repos/builtin/packages/tinyxml/package.py4
-rw-r--r--var/spack/repos/builtin/packages/umap/package.py5
-rw-r--r--var/spack/repos/builtin/packages/warpx/package.py33
-rw-r--r--var/spack/repos/builtin/packages/wt/package.py20
-rw-r--r--var/spack/repos/builtin/packages/xeus/package.py3
-rw-r--r--var/spack/repos/builtin/packages/xsdktrilinos/package.py9
-rw-r--r--var/spack/repos/builtin/packages/xsimd/package.py3
-rw-r--r--var/spack/repos/builtin/packages/xtensor/package.py11
83 files changed, 364 insertions, 640 deletions
diff --git a/var/spack/repos/builtin/packages/adios2/package.py b/var/spack/repos/builtin/packages/adios2/package.py
index 9bcc8e336f..389d5c7c4a 100644
--- a/var/spack/repos/builtin/packages/adios2/package.py
+++ b/var/spack/repos/builtin/packages/adios2/package.py
@@ -139,47 +139,32 @@ class Adios2(CMakePackage):
def cmake_args(self):
spec = self.spec
+ from_variant = self.define_from_variant
args = [
- '-DBUILD_SHARED_LIBS:BOOL={0}'.format(
- 'ON' if '+shared' in spec else 'OFF'),
+ from_variant('BUILD_SHARED_LIBS', 'shared'),
'-DADIOS2_BUILD_EXAMPLES=OFF',
- '-DADIOS2_USE_MPI={0}'.format(
- 'ON' if '+mpi' in spec else 'OFF'),
+ from_variant('ADIOS2_USE_MPI', 'mpi'),
'-DADIOS2_USE_MGARD=OFF',
- '-DADIOS2_USE_ZFP={0}'.format(
- 'ON' if '+zfp' in spec else 'OFF'),
- '-DADIOS2_USE_SZ={0}'.format(
- 'ON' if '+sz' in spec else 'OFF'),
- '-DADIOS2_USE_DataMan={0}'.format(
- 'ON' if '+dataman' in spec else 'OFF'),
- '-DADIOS2_USE_SST={0}'.format(
- 'ON' if '+sst' in spec else 'OFF'),
- '-DADIOS2_USE_HDF5={0}'.format(
- 'ON' if '+hdf5' in spec else 'OFF'),
- '-DADIOS2_USE_Python={0}'.format(
- 'ON' if '+python' in spec else 'OFF'),
- '-DADIOS2_USE_Fortran={0}'.format(
- 'ON' if '+fortran' in spec else 'OFF'),
- '-DADIOS2_USE_Endian_Reverse={0}'.format(
- 'ON' if '+endian_reverse' in spec else 'OFF'),
- '-DBUILD_TESTING:BOOL={0}'.format(
- 'ON' if self.run_tests else 'OFF'),
+ from_variant('ADIOS2_USE_ZFP', 'zfp'),
+ from_variant('ADIOS2_USE_SZ', 'sz'),
+ from_variant('ADIOS2_USE_DataMan', 'dataman'),
+ from_variant('ADIOS2_USE_SST', 'sst'),
+ from_variant('ADIOS2_USE_HDF5', 'hdf5'),
+ from_variant('ADIOS2_USE_Python', 'python'),
+ from_variant('ADIOS2_USE_Fortran', 'fortran'),
+ from_variant('ADIOS2_USE_Endian_Reverse', 'endian_reverse'),
+ self.define('BUILD_TESTING', self.run_tests),
]
if spec.version >= Version('2.4.0'):
- args.append('-DADIOS2_USE_Blosc={0}'.format(
- 'ON' if '+blosc' in spec else 'OFF'))
- args.append('-DADIOS2_USE_BZip2={0}'.format(
- 'ON' if '+bzip2' in spec else 'OFF'))
- args.append('-DADIOS2_USE_PNG={0}'.format(
- 'ON' if '+png' in spec else 'OFF'))
- args.append('-DADIOS2_USE_SSC={0}'.format(
- 'ON' if '+ssc' in spec else 'OFF'))
+ args.append(from_variant('ADIOS2_USE_Blosc', 'blosc'))
+ args.append(from_variant('ADIOS2_USE_BZip2', 'bzip2'))
+ args.append(from_variant('ADIOS2_USE_PNG', 'png'))
+ args.append(from_variant('ADIOS2_USE_SSC', 'ssc'))
if spec.version >= Version('2.5.0'):
- args.append('-DADIOS2_USE_DataSpaces={0}'.format(
- 'ON' if '+dataspaces' in spec else 'OFF'))
+ args.append(from_variant('ADIOS2_USE_DataSpaces', 'dataspaces'))
if spec.version >= Version('2.6.0'):
args.append('-DADIOS2_USE_IME=OFF')
@@ -197,8 +182,7 @@ class Adios2(CMakePackage):
])
if spec.satisfies('~shared'):
- args.append('-DCMAKE_POSITION_INDEPENDENT_CODE:BOOL={0}'.format(
- 'ON' if '+pic' in spec else 'OFF'))
+ args.append(from_variant('CMAKE_POSITION_INDEPENDENT_CODE', 'pic'))
if spec.satisfies('%fj'):
args.extend([
diff --git a/var/spack/repos/builtin/packages/albany/package.py b/var/spack/repos/builtin/packages/albany/package.py
index be643e7e86..3f2f9094ef 100644
--- a/var/spack/repos/builtin/packages/albany/package.py
+++ b/var/spack/repos/builtin/packages/albany/package.py
@@ -67,36 +67,21 @@ class Albany(CMakePackage):
])
options.extend([
- '-DENABLE_LCM:BOOL=%s' % (
- 'ON' if '+lcm' in spec else 'OFF'),
- '-DENABLE_AERAS:BOOL=%s' % (
- 'ON' if '+aeras' in spec else 'OFF'),
- '-DENABLE_QCAD:BOOL=%s' % (
- 'ON' if '+qcad' in spec else 'OFF'),
- '-DENABLE_HYDRIDE:BOOL=%s' % (
- 'ON' if '+hydride' in spec else 'OFF'),
- '-DENABLE_LCM_SPECULATIVE:BOOL=%s' % (
- 'ON' if '+lcm_spec' in spec else 'OFF'),
- '-DENABLE_LAME:BOOL=%s' % (
- 'ON' if '+lame' in spec else 'OFF'),
- '-DENABLE_DEBUGGING:BOOL=%s' % (
- 'ON' if '+debug' in spec else 'OFF'),
- '-DENABLE_CHECK_FPE:BOOL=%s' % (
- 'ON' if '+fpe' in spec else 'OFF'),
- '-DENABLE_SCOREC:BOOL=%s' % (
- 'ON' if '+scorec' in spec else 'OFF'),
- '-DENABLE_FELIX:BOOL=%s' % (
- 'ON' if '+felix' in spec else 'OFF'),
- '-DENABLE_MOR:BOOL=%s' % (
- 'ON' if '+mor' in spec else 'OFF'),
- '-DENABLE_ALBANY_CI:BOOL=%s' % (
- 'ON' if '+ci' in spec else 'OFF'),
- '-DENABLE_ASCR:BOOL=%s' % (
- 'ON' if '+ascr' in spec else 'OFF'),
- '-DENABLE_PERFORMANCE_TESTS:BOOL=%s' % (
- 'ON' if '+perf' in spec else 'OFF'),
- '-DENABLE_64BIT_INT:BOOL=%s' % (
- 'ON' if '+64bit' in spec else 'OFF')
+ self.define_from_variant('ENABLE_LCM', 'lcm'),
+ self.define_from_variant('ENABLE_AERAS', 'aeras'),
+ self.define_from_variant('ENABLE_QCAD', 'qcad'),
+ self.define_from_variant('ENABLE_HYDRIDE', 'hydride'),
+ self.define_from_variant('ENABLE_LCM_SPECULATIVE', 'lcm_spec'),
+ self.define_from_variant('ENABLE_LAME', 'lame'),
+ self.define_from_variant('ENABLE_DEBUGGING', 'debug'),
+ self.define_from_variant('ENABLE_CHECK_FPE', 'fpe'),
+ self.define_from_variant('ENABLE_SCOREC', 'scorec'),
+ self.define_from_variant('ENABLE_FELIX', 'felix'),
+ self.define_from_variant('ENABLE_MOR', 'mor'),
+ self.define_from_variant('ENABLE_ALBANY_CI', 'ci'),
+ self.define_from_variant('ENABLE_ASCR', 'ascr'),
+ self.define_from_variant('ENABLE_PERFORMANCE_TESTS', 'perf'),
+ self.define_from_variant('ENABLE_64BIT_INT', '64bit')
])
return options
diff --git a/var/spack/repos/builtin/packages/alquimia/package.py b/var/spack/repos/builtin/packages/alquimia/package.py
index d5ad9e436d..eaa94afd09 100644
--- a/var/spack/repos/builtin/packages/alquimia/package.py
+++ b/var/spack/repos/builtin/packages/alquimia/package.py
@@ -44,8 +44,7 @@ class Alquimia(CMakePackage):
options = ['-DCMAKE_C_COMPILER=%s' % spec['mpi'].mpicc,
'-DCMAKE_Fortran_COMPILER=%s' % spec['mpi'].mpifc,
'-DUSE_XSDK_DEFAULTS=YES',
- '-DBUILD_SHARED_LIBS:BOOL=%s' % (
- 'ON' if '+shared' in spec else 'OFF'),
+ self.define_from_variant('BUILD_SHARED_LIBS', 'shared'),
'-DTPL_ENABLE_MPI:BOOL=ON',
'-DMPI_BASE_DIR:PATH=%s' % spec['mpi'].prefix,
'-DTPL_ENABLE_HDF5:BOOL=ON',
diff --git a/var/spack/repos/builtin/packages/aocl-sparse/package.py b/var/spack/repos/builtin/packages/aocl-sparse/package.py
index ddb2cc8bf3..0be34f7054 100644
--- a/var/spack/repos/builtin/packages/aocl-sparse/package.py
+++ b/var/spack/repos/builtin/packages/aocl-sparse/package.py
@@ -66,8 +66,7 @@ class AoclSparse(CMakePackage):
args.append("-DCMAKE_BUILD_TYPE=Release")
args.extend([
- "-DBUILD_SHARED_LIBS:BOOL=%s" % (
- 'ON' if '+shared' in spec else 'OFF'),
+ self.define_from_variant('BUILD_SHARED_LIBS', 'shared'),
"-DBUILD_CLIENTS_BENCHMARKS:BOOL=%s" % (
'ON' if self.run_tests else 'OFF')
@@ -75,8 +74,7 @@ class AoclSparse(CMakePackage):
if spec.satisfies('@3.0:'):
args.extend([
- "-DBUILD_ILP64:BOOL=%s" % (
- 'ON' if '+ilp64' in spec else 'OFF')
+ self.define_from_variant('BUILD_ILP64', 'ilp64')
])
return args
diff --git a/var/spack/repos/builtin/packages/arborx/package.py b/var/spack/repos/builtin/packages/arborx/package.py
index f7a5d843aa..8633994ec7 100644
--- a/var/spack/repos/builtin/packages/arborx/package.py
+++ b/var/spack/repos/builtin/packages/arborx/package.py
@@ -61,7 +61,7 @@ class Arborx(CMakePackage):
options = [
'-DKokkos_ROOT=%s' % (spec['kokkos'].prefix if '~trilinos' in spec
else spec['trilinos'].prefix),
- '-DARBORX_ENABLE_MPI=%s' % ('ON' if '+mpi' in spec else 'OFF')
+ self.define_from_variant('ARBORX_ENABLE_MPI', 'mpi')
]
if '+cuda' in spec:
diff --git a/var/spack/repos/builtin/packages/arrayfire/package.py b/var/spack/repos/builtin/packages/arrayfire/package.py
index 474519834e..0315dffadc 100644
--- a/var/spack/repos/builtin/packages/arrayfire/package.py
+++ b/var/spack/repos/builtin/packages/arrayfire/package.py
@@ -55,12 +55,9 @@ class Arrayfire(CMakePackage, CudaPackage):
def cmake_args(self):
args = []
args.extend([
- '-DAF_BUILD_CUDA={0}'.format(
- 'ON' if '+cuda' in self.spec else 'OFF'),
- '-DAF_BUILD_FORGE={0}'.format(
- 'ON' if '+forge' in self.spec else 'OFF'),
- '-DAF_BUILD_OPENCL={0}'.format(
- 'ON' if '+opencl' in self.spec else 'OFF'),
+ self.define_from_variant('AF_BUILD_CUDA', 'cuda'),
+ self.define_from_variant('AF_BUILD_FORGE', 'forge'),
+ self.define_from_variant('AF_BUILD_OPENCL', 'opencl'),
])
if '^mkl' in self.spec:
args.append('-DUSE_CPU_MKL=ON')
diff --git a/var/spack/repos/builtin/packages/asagi/package.py b/var/spack/repos/builtin/packages/asagi/package.py
index 6caedab8c5..150988d9da 100644
--- a/var/spack/repos/builtin/packages/asagi/package.py
+++ b/var/spack/repos/builtin/packages/asagi/package.py
@@ -59,15 +59,13 @@ class Asagi(CMakePackage):
args = ['-DMAX_DIMENSIONS=' + spec.variants['max_dimensions'].value,
'-DSHARED_LIB=' + ('ON' if 'shared' in link_type else 'OFF'),
'-DSTATIC_LIB=' + ('ON' if 'static' in link_type else 'OFF'),
- '-DFORTRAN_SUPPORT=' + ('ON' if '+fortran' in spec else 'OFF'),
- '-DTHREADSAFE=' + ('ON' if '+threadsafe' in spec else 'OFF'),
+ self.define_from_variant('FORTRAN_SUPPORT', 'fortran'),
+ self.define_from_variant('THREADSAFE', 'threadsafe'),
'-DNOMPI=' + ('ON' if '~mpi' in spec else 'OFF'),
- '-DMPI3=' + ('ON' if '+mpi3' in spec else 'OFF'),
+ self.define_from_variant('MPI3', 'mpi3'),
'-DNONUMA=' + ('ON' if '~numa' in spec else 'OFF'),
- '-DTESTS=' + ('ON' if '+tests' in spec else 'OFF'),
- '-DEXAMPLES=' + ('ON' if '+examples' in spec else 'OFF'),
- '-DTHREADSAFE_COUNTER='
- + ('ON' if '+threadsafe_counter' in spec else 'OFF'),
- '-DTHREADSAFE_MPI='
- + ('ON' if '+threadsafe_mpi' in spec else 'OFF'), ]
+ self.define_from_variant('TESTS', 'tests'),
+ self.define_from_variant('EXAMPLES', 'examples'),
+ self.define_from_variant('THREADSAFE_COUNTER', 'threadsafe_counter'),
+ self.define_from_variant('THREADSAFE_MPI', 'threadsafe_mpi'), ]
return args
diff --git a/var/spack/repos/builtin/packages/aspect/package.py b/var/spack/repos/builtin/packages/aspect/package.py
index f996313c98..efb17a0be6 100644
--- a/var/spack/repos/builtin/packages/aspect/package.py
+++ b/var/spack/repos/builtin/packages/aspect/package.py
@@ -35,8 +35,7 @@ class Aspect(CMakePackage):
def cmake_args(self):
return [
- '-DASPECT_USE_FP_EXCEPTIONS=%s' %
- ('ON' if '+fpe' in self.spec else 'OFF')
+ self.define_from_variant('ASPECT_USE_FP_EXCEPTIONS', 'fpe')
]
def setup_run_environment(self, env):
diff --git a/var/spack/repos/builtin/packages/assimp/package.py b/var/spack/repos/builtin/packages/assimp/package.py
index f2be52a4f2..5a0a1b7b51 100644
--- a/var/spack/repos/builtin/packages/assimp/package.py
+++ b/var/spack/repos/builtin/packages/assimp/package.py
@@ -26,8 +26,7 @@ class Assimp(CMakePackage):
def cmake_args(self):
args = [
'-DASSIMP_BUILD_TESTS=OFF',
- '-DBUILD_SHARED_LIBS:BOOL=%s' % (
- 'ON' if '+shared' in self.spec else 'OFF'),
+ self.define_from_variant('BUILD_SHARED_LIBS', 'shared'),
]
return args
diff --git a/var/spack/repos/builtin/packages/babelflow/package.py b/var/spack/repos/builtin/packages/babelflow/package.py
index d6d84c5625..8110f4d61f 100644
--- a/var/spack/repos/builtin/packages/babelflow/package.py
+++ b/var/spack/repos/builtin/packages/babelflow/package.py
@@ -25,8 +25,5 @@ class Babelflow(CMakePackage):
variant("shared", default=True, description="Build Babelflow as shared libs")
def cmake_args(self):
- spec = self.spec
- args = [
- '-DBUILD_SHARED_LIBS:BOOL={0}'.format(
- 'ON' if '+shared' in spec else 'OFF')]
+ args = [self.define_from_variant('BUILD_SHARED_LIBS', 'shared')]
return args
diff --git a/var/spack/repos/builtin/packages/bml/package.py b/var/spack/repos/builtin/packages/bml/package.py
index e535e1072d..b3c021315b 100644
--- a/var/spack/repos/builtin/packages/bml/package.py
+++ b/var/spack/repos/builtin/packages/bml/package.py
@@ -34,8 +34,7 @@ class Bml(CMakePackage):
def cmake_args(self):
args = [
- '-DBUILD_SHARED_LIBS={0}'.format(
- 'ON' if '+shared' in self.spec else 'OFF')
+ self.define_from_variant('BUILD_SHARED_LIBS', 'shared')
]
spec = self.spec
if '+mpi' in spec:
diff --git a/var/spack/repos/builtin/packages/butterflypack/package.py b/var/spack/repos/builtin/packages/butterflypack/package.py
index 8da61ed45b..aa145b28bf 100644
--- a/var/spack/repos/builtin/packages/butterflypack/package.py
+++ b/var/spack/repos/builtin/packages/butterflypack/package.py
@@ -48,9 +48,6 @@ class Butterflypack(CMakePackage):
def cmake_args(self):
spec = self.spec
- def on_off(varstr):
- return 'ON' if varstr in spec else 'OFF'
-
args = [
'-DCMAKE_C_COMPILER=%s' % spec['mpi'].mpicc,
'-DCMAKE_Fortran_COMPILER=%s' % spec['mpi'].mpifc,
@@ -60,7 +57,7 @@ class Butterflypack(CMakePackage):
'-DTPL_SCALAPACK_LIBRARIES=%s' % spec['scalapack'].
libs.joined(";"),
'-DTPL_ARPACK_LIBRARIES=%s' % spec['arpack-ng'].libs.joined(";"),
- '-DBUILD_SHARED_LIBS=%s' % on_off('+shared'),
+ self.define_from_variant('BUILD_SHARED_LIBS', 'shared'),
]
return args
diff --git a/var/spack/repos/builtin/packages/c-blosc2/package.py b/var/spack/repos/builtin/packages/c-blosc2/package.py
index 47f3138b2c..82206d28fe 100644
--- a/var/spack/repos/builtin/packages/c-blosc2/package.py
+++ b/var/spack/repos/builtin/packages/c-blosc2/package.py
@@ -60,12 +60,9 @@ class CBlosc2(CMakePackage):
'-DPREFER_EXTERNAL_ZSTD=ON',
'-DDEACTIVATE_AVX2={0}'.format(
'ON' if '~avx2' in spec else 'OFF'),
- '-DBUILD_TESTS={0}'.format(
- 'ON' if self.run_tests else 'OFF'),
- '-DBUILD_BENCHMARKS={0}'.format(
- 'ON' if self.run_tests else 'OFF'),
- '-DBUILD_EXAMPLES={0}'.format(
- 'ON' if self.run_tests else 'OFF')
+ self.define('BUILD_TESTS', self.run_tests),
+ self.define('BUILD_BENCHMARKS', self.run_tests),
+ self.define('BUILD_EXAMPLES', self.run_tests)
]
return args
diff --git a/var/spack/repos/builtin/packages/camp/package.py b/var/spack/repos/builtin/packages/camp/package.py
index 6584a1e7e7..66e1f245f2 100644
--- a/var/spack/repos/builtin/packages/camp/package.py
+++ b/var/spack/repos/builtin/packages/camp/package.py
@@ -56,7 +56,6 @@ class Camp(CMakePackage, CudaPackage, ROCmPackage):
else:
options.append('-DENABLE_HIP=OFF')
- options.append('-DENABLE_TESTS={0}'.format(
- 'ON' if '+tests' in spec else 'OFF'))
+ options.append(self.define_from_variant('ENABLE_TESTS', 'tests'))
return options
diff --git a/var/spack/repos/builtin/packages/care/package.py b/var/spack/repos/builtin/packages/care/package.py
index 83abcb11d2..0cd358c60a 100644
--- a/var/spack/repos/builtin/packages/care/package.py
+++ b/var/spack/repos/builtin/packages/care/package.py
@@ -63,6 +63,7 @@ class Care(CMakePackage, CudaPackage, ROCmPackage):
def cmake_args(self):
spec = self.spec
+ from_variant = self.define_from_variant
options = []
options.append('-DBLT_SOURCE_DIR={0}'.format(spec['blt'].prefix))
@@ -98,46 +99,33 @@ class Care(CMakePackage, CudaPackage, ROCmPackage):
else:
options.append('-DENABLE_HIP=OFF')
- options.append('-DCARE_ENABLE_IMPLICIT_CONVERSIONS={0}'.format(
- 'ON' if '+implicit_conversions' in spec else 'OFF'))
+ options.extend([
+ from_variant('CARE_ENABLE_IMPLICIT_CONVERSIONS',
+ 'implicit_conversions'),
+ from_variant('CARE_ENABLE_LOOP_FUSER', 'loop_fuser'),
+ self.define('CAMP_DIR', spec['camp'].prefix.share.camp.cmake),
+ self.define('UMPIRE_DIR', spec['umpire'].prefix.share.umpire.cmake),
+ self.define('RAJA_DIR', spec['raja'].prefix.share.raja.cmake),
+ self.define('CHAI_DIR', spec['chai'].prefix.share.chai.cmake),
+ from_variant('CARE_ENABLE_TESTS', 'tests'),
+ ])
- options.append('-DCARE_ENABLE_LOOP_FUSER={0}'.format(
- 'ON' if '+loop_fuser' in spec else 'OFF'))
-
- options.append('-DCAMP_DIR:PATH='
- + spec['camp'].prefix.share.camp.cmake)
- options.append('-DUMPIRE_DIR:PATH='
- + spec['umpire'].prefix.share.umpire.cmake)
- options.append('-DRAJA_DIR:PATH='
- + spec['raja'].prefix.share.raja.cmake)
- options.append('-DCHAI_DIR:PATH='
- + spec['chai'].prefix.share.chai.cmake)
-
- options.append('-DCARE_ENABLE_TESTS={0}'.format(
- 'ON' if '+tests' in spec else 'OFF'))
# For tests to work, we also need BLT_ENABLE_TESTS to be on.
# This will take care of the gtest dependency. CARE developers should
# consider consolidating these flags in the future.
- options.append('-DBLT_ENABLE_TESTS={0}'.format(
- 'ON' if '+tests' in spec else 'OFF'))
+ options.append(from_variant('BLT_ENABLE_TESTS', 'tests'))
# There are both CARE_ENABLE_* and ENABLE_* variables in here because
# one controls the BLT infrastructure and the other controls the CARE
# infrastructure. The goal is to just be able to use the CARE_ENABLE_*
# variables, but CARE isn't set up correctly for that yet.
- options.append('-DENABLE_BENCHMARKS={0}'.format(
- 'ON' if '+benchmarks' in spec else 'OFF'))
- options.append('-DCARE_ENABLE_BENCHMARKS={0}'.format(
- 'ON' if '+benchmarks' in spec else 'OFF'))
-
- options.append('-DENABLE_EXAMPLES={0}'.format(
- 'ON' if '+examples' in spec else 'OFF'))
- options.append('-DCARE_ENABLE_EXAMPLES={0}'.format(
- 'ON' if '+examples' in spec else 'OFF'))
-
- options.append('-DENABLE_DOCS={0}'.format(
- 'ON' if '+docs' in spec else 'OFF'))
- options.append('-DCARE_ENABLE_DOCS={0}'.format(
- 'ON' if '+docs' in spec else 'OFF'))
+ options.append(from_variant('ENABLE_BENCHMARKS', 'benchmarks'))
+ options.append(from_variant('CARE_ENABLE_BENCHMARKS', 'benchmarks'))
+
+ options.append(from_variant('ENABLE_EXAMPLES', 'examples'))
+ options.append(from_variant('CARE_ENABLE_EXAMPLES', 'examples'))
+
+ options.append(from_variant('ENABLE_DOCS', 'docs'))
+ options.append(from_variant('CARE_ENABLE_DOCS', 'docs'))
return options
diff --git a/var/spack/repos/builtin/packages/catch2/package.py b/var/spack/repos/builtin/packages/catch2/package.py
index 183f284de1..2b7e468073 100644
--- a/var/spack/repos/builtin/packages/catch2/package.py
+++ b/var/spack/repos/builtin/packages/catch2/package.py
@@ -93,8 +93,7 @@ class Catch2(CMakePackage):
args.append('-DNO_SELFTEST={0}'.format(
'OFF' if self.run_tests else 'ON'))
elif spec.satisfies('@2.1.1:'):
- args.append('-DBUILD_TESTING:BOOL={0}'.format(
- 'ON' if self.run_tests else 'OFF'))
+ args.append(self.define('BUILD_TESTING', self.run_tests))
return args
@when('@:1.6.99')
diff --git a/var/spack/repos/builtin/packages/cgns/package.py b/var/spack/repos/builtin/packages/cgns/package.py
index 6818bbc37a..799a817454 100644
--- a/var/spack/repos/builtin/packages/cgns/package.py
+++ b/var/spack/repos/builtin/packages/cgns/package.py
@@ -51,26 +51,17 @@ class Cgns(CMakePackage):
options = []
options.extend([
- '-DCGNS_ENABLE_FORTRAN:BOOL=%s' % (
- 'ON' if '+fortran' in spec else 'OFF'),
- '-DCGNS_ENABLE_SCOPING:BOOL=%s' % (
- 'ON' if '+scoping' in spec else 'OFF'),
- '-DCGNS_ENABLE_PARALLEL:BOOL=%s' % (
- 'ON' if '+mpi' in spec else 'OFF'),
+ self.define_from_variant('CGNS_ENABLE_FORTRAN', 'fortran'),
+ self.define_from_variant('CGNS_ENABLE_SCOPING', 'scoping'),
+ self.define_from_variant('CGNS_ENABLE_PARALLEL', 'mpi'),
'-DCGNS_ENABLE_TESTS:BOOL=OFF',
- '-DCGNS_BUILD_TESTING:BOOL=%s' % (
- 'ON' if '+testing' in spec else 'OFF'),
+ self.define_from_variant('CGNS_BUILD_TESTING', 'testing'),
'-DCGNS_BUILD_CGNSTOOLS:BOOL=OFF',
- '-DCGNS_BUILD_SHARED:BOOL=%s' % (
- 'ON' if '+shared' in spec else 'OFF'),
- '-DCGNS_BUILD_STATIC:BOOL=%s' % (
- 'ON' if '+static' in spec else 'OFF'),
- '-DCGNS_ENABLE_BASE_SCOPE:BOOL=%s' % (
- 'ON' if '+base_scope' in spec else 'OFF'),
- '-DCGNS_ENABLE_LEGACY:BOOL=%s' % (
- 'ON' if '+legacy' in spec else 'OFF'),
- '-DCGNS_ENABLE_MEM_DEBUG:BOOL=%s' % (
- 'ON' if '+mem_debug' in spec else 'OFF')
+ self.define_from_variant('CGNS_BUILD_SHARED', 'shared'),
+ self.define_from_variant('CGNS_BUILD_STATIC', 'static'),
+ self.define_from_variant('CGNS_ENABLE_BASE_SCOPE', 'base_scope'),
+ self.define_from_variant('CGNS_ENABLE_LEGACY', 'legacy'),
+ self.define_from_variant('CGNS_ENABLE_MEM_DEBUG', 'mem_debug')
])
if '+mpi' in spec:
@@ -81,8 +72,7 @@ class Cgns(CMakePackage):
])
options.append(
- '-DCGNS_ENABLE_64BIT:BOOL={0}'.format(
- 'ON' if '+int64' in spec else 'OFF'))
+ self.define_from_variant('CGNS_ENABLE_64BIT', 'int64'))
if '+hdf5' in spec:
options.extend([
diff --git a/var/spack/repos/builtin/packages/chai/package.py b/var/spack/repos/builtin/packages/chai/package.py
index edff6ed3b3..b284da358f 100644
--- a/var/spack/repos/builtin/packages/chai/package.py
+++ b/var/spack/repos/builtin/packages/chai/package.py
@@ -92,8 +92,7 @@ class Chai(CMakePackage, CudaPackage, ROCmPackage):
options.extend(['-DENABLE_RAJA_PLUGIN=ON',
'-DRAJA_DIR=' + spec['raja'].prefix])
- options.append('-DENABLE_PICK={0}'.format(
- 'ON' if '+enable_pick' in spec else 'OFF'))
+ options.append(self.define_from_variant('ENABLE_PICK', 'enable_pick'))
options.append('-Dumpire_DIR:PATH='
+ spec['umpire'].prefix.share.umpire.cmake)
@@ -101,10 +100,8 @@ class Chai(CMakePackage, CudaPackage, ROCmPackage):
options.append('-DENABLE_TESTS={0}'.format(
'ON' if '+tests' in spec else 'OFF'))
- options.append('-DENABLE_BENCHMARKS={0}'.format(
- 'ON' if '+benchmarks' in spec else 'OFF'))
+ options.append(self.define_from_variant('ENABLE_BENCHMARKS', 'benchmarks'))
- options.append('-DENABLE_EXAMPLES={0}'.format(
- 'ON' if '+examples' in spec else 'OFF'))
+ options.append(self.define_from_variant('ENABLE_EXAMPLES', 'examples'))
return options
diff --git a/var/spack/repos/builtin/packages/clfft/package.py b/var/spack/repos/builtin/packages/clfft/package.py
index e8f739e213..53c10bcb3e 100644
--- a/var/spack/repos/builtin/packages/clfft/package.py
+++ b/var/spack/repos/builtin/packages/clfft/package.py
@@ -26,12 +26,8 @@ class Clfft(CMakePackage):
root_cmakelists_dir = 'src'
def cmake_args(self):
- spec = self.spec
-
args = [
- '-DBUILD_CLIENT:BOOL={0}'.format((
- 'ON' if '+client' in spec else 'OFF')),
- '-DBUILD_CALLBACK_CLIENT:BOOL={0}'.format((
- 'ON' if '+client' in spec else 'OFF'))
+ self.define_from_variant('BUILD_CLIENT', 'client'),
+ self.define_from_variant('BUILD_CALLBACK_CLIENT', 'client')
]
return args
diff --git a/var/spack/repos/builtin/packages/cminpack/package.py b/var/spack/repos/builtin/packages/cminpack/package.py
index f828e63ffa..a553de9a7b 100644
--- a/var/spack/repos/builtin/packages/cminpack/package.py
+++ b/var/spack/repos/builtin/packages/cminpack/package.py
@@ -30,8 +30,7 @@ class Cminpack(CMakePackage):
def cmake_args(self):
args = [
- '-DBUILD_SHARED_LIBS=%s' % (
- 'ON' if '+shared' in self.spec else 'OFF'),
+ self.define_from_variant('BUILD_SHARED_LIBS', 'shared'),
'-DUSE_BLAS=%s' % (
'ON' if 'blas' in self.spec else 'OFF')
]
diff --git a/var/spack/repos/builtin/packages/dakota/package.py b/var/spack/repos/builtin/packages/dakota/package.py
index 6cb35bcf8a..656adfc460 100644
--- a/var/spack/repos/builtin/packages/dakota/package.py
+++ b/var/spack/repos/builtin/packages/dakota/package.py
@@ -52,8 +52,7 @@ class Dakota(CMakePackage):
spec = self.spec
args = [
- '-DBUILD_SHARED_LIBS:BOOL=%s' % (
- 'ON' if '+shared' in spec else 'OFF'),
+ self.define_from_variant('BUILD_SHARED_LIBS', 'shared'),
]
if '+mpi' in spec:
diff --git a/var/spack/repos/builtin/packages/datatransferkit/package.py b/var/spack/repos/builtin/packages/datatransferkit/package.py
index 6cb90de775..8cc72a2da5 100644
--- a/var/spack/repos/builtin/packages/datatransferkit/package.py
+++ b/var/spack/repos/builtin/packages/datatransferkit/package.py
@@ -35,13 +35,12 @@ class Datatransferkit(CMakePackage):
def cmake_args(self):
spec = self.spec
+ from_variant = self.define_from_variant
options = [
- '-DBUILD_SHARED_LIBS:BOOL=%s' % (
- 'ON' if '+shared' in spec else 'OFF'),
+ from_variant('BUILD_SHARED_LIBS', 'shared'),
'-DDataTransferKit_ENABLE_DataTransferKit=ON',
- '-DDataTransferKit_ENABLE_ArborX_TPL=%s' % (
- 'ON' if '+external-arborx' in spec else 'OFF'),
+ from_variant('DataTransferKit_ENABLE_ArborX_TPL', 'external-arborx'),
'-DDataTransferKit_ENABLE_TESTS=OFF',
'-DDataTransferKit_ENABLE_EXAMPLES=OFF',
'-DCMAKE_CXX_EXTENSIONS=OFF',
diff --git a/var/spack/repos/builtin/packages/dmlc-core/package.py b/var/spack/repos/builtin/packages/dmlc-core/package.py
index 6663c81010..3dab3aec02 100644
--- a/var/spack/repos/builtin/packages/dmlc-core/package.py
+++ b/var/spack/repos/builtin/packages/dmlc-core/package.py
@@ -31,7 +31,6 @@ class DmlcCore(CMakePackage):
'make/config.mk')
def cmake_args(self):
- spec = self.spec
return [
- '-DUSE_OPENMP=%s' % ('ON' if '+openmp' in spec else 'OFF'),
+ self.define_from_variant('USE_OPENMP', 'openmp'),
]
diff --git a/var/spack/repos/builtin/packages/draco/package.py b/var/spack/repos/builtin/packages/draco/package.py
index 84ef0bd216..242c7bcad6 100644
--- a/var/spack/repos/builtin/packages/draco/package.py
+++ b/var/spack/repos/builtin/packages/draco/package.py
@@ -92,7 +92,7 @@ class Draco(CMakePackage):
options = []
options.extend([
'-Wno-dev',
- '-DBUILD_TESTING={0}'.format('ON' if self.run_tests else 'OFF'),
+ self.define('BUILD_TESTING', self.run_tests),
'-DUSE_CUDA={0}'.format('ON' if '+cuda' in self.spec else 'OFF'),
'-DUSE_QT={0}'.format('ON' if '+qt' in self.spec else 'OFF')
])
diff --git a/var/spack/repos/builtin/packages/ethminer/package.py b/var/spack/repos/builtin/packages/ethminer/package.py
index bd5f045c18..1d33f32520 100644
--- a/var/spack/repos/builtin/packages/ethminer/package.py
+++ b/var/spack/repos/builtin/packages/ethminer/package.py
@@ -28,8 +28,8 @@ class Ethminer(CMakePackage):
depends_on('mesa', when='+opencl')
def cmake_args(self):
- spec = self.spec
return [
- '-DETHASHCL=%s' % ('YES' if '+opencl' in spec else 'NO'),
- '-DETHASHCUDA=%s' % ('YES' if '+cuda' in spec else 'NO'),
- '-DETHSTRATUM=%s' % ('YES' if '+stratum' in spec else 'NO')]
+ self.define_from_variant('ETHASHCL', 'opencl'),
+ self.define_from_variant('ETHASHCUDA', 'cuda'),
+ self.define_from_variant('ETHSTRATUM', 'stratum')
+ ]
diff --git a/var/spack/repos/builtin/packages/everytrace/package.py b/var/spack/repos/builtin/packages/everytrace/package.py
index e808fa9dae..9e0a3a3a1a 100644
--- a/var/spack/repos/builtin/packages/everytrace/package.py
+++ b/var/spack/repos/builtin/packages/everytrace/package.py
@@ -26,8 +26,7 @@ class Everytrace(CMakePackage):
depends_on('mpi', when='+mpi')
def cmake_args(self):
- spec = self.spec
return [
- '-DUSE_MPI=%s' % ('YES' if '+mpi' in spec else 'NO'),
- '-DUSE_FORTRAN=%s' % ('YES' if '+fortran' in spec else 'NO'),
- '-DUSE_CXX=%s' % ('YES' if '+cxx' in spec else 'NO')]
+ self.define_from_variant('USE_MPI', 'mpi'),
+ self.define_from_variant('USE_FORTRAN', 'fortran'),
+ self.define_from_variant('USE_CXX', 'cxx')]
diff --git a/var/spack/repos/builtin/packages/fairlogger/package.py b/var/spack/repos/builtin/packages/fairlogger/package.py
index 16a58949b6..e2112215e2 100644
--- a/var/spack/repos/builtin/packages/fairlogger/package.py
+++ b/var/spack/repos/builtin/packages/fairlogger/package.py
@@ -68,8 +68,7 @@ class Fairlogger(CMakePackage):
if cxxstd != 'default':
args.append('-DCMAKE_CXX_STANDARD=%s' % cxxstd)
if self.spec.satisfies('@1.4:'):
- args.append('-DUSE_BOOST_PRETTY_FUNCTION=%s' %
- ('ON' if '+pretty' in self.spec else 'OFF'))
+ args.append(self.define_from_variant('USE_BOOST_PRETTY_FUNCTION', 'pretty'))
if self.spec.satisfies('@1.6:'):
args.append('-DUSE_EXTERNAL_FMT=ON')
if self.spec.satisfies('^boost@:1.69.99'):
diff --git a/var/spack/repos/builtin/packages/faodel/package.py b/var/spack/repos/builtin/packages/faodel/package.py
index 45d8bdcfd8..56e1495141 100644
--- a/var/spack/repos/builtin/packages/faodel/package.py
+++ b/var/spack/repos/builtin/packages/faodel/package.py
@@ -63,26 +63,19 @@ class Faodel(CMakePackage):
spec = self.spec
args = [
- '-DBUILD_SHARED_LIBS:BOOL={0}'.format(
- 'ON' if '+shared' in spec else 'OFF'),
- '-DBUILD_TESTS:BOOL={0}'.format(
- 'ON' if '+mpi' in spec else 'OFF'),
+ self.define_from_variant('BUILD_SHARED_LIBS', 'shared'),
+ self.define_from_variant('BUILD_TESTS', 'mpi'),
'-DBOOST_ROOT:PATH={0}'.format(spec['boost'].prefix),
'-DGTEST_ROOT:PATH={0}'.format(spec['googletest'].prefix),
'-DBUILD_DOCS:BOOL=OFF',
- '-DFaodel_ENABLE_IOM_HDF5:BOOL={0}'.format(
- 'ON' if '+hdf5' in spec else 'OFF'),
- '-DFaodel_ENABLE_IOM_LEVELDB:BOOL={0}'.format(
- 'ON' if '+leveldb' in spec else 'OFF'),
- '-DFaodel_ENABLE_MPI_SUPPORT:BOOL={0}'.format(
- 'ON' if '+mpi' in spec else 'OFF'),
- '-DFaodel_ENABLE_TCMALLOC:BOOL={0}'.format(
- 'ON' if '+tcmalloc' in spec else 'OFF'),
+ self.define_from_variant('Faodel_ENABLE_IOM_HDF5', 'hdf5'),
+ # self.define_from_variant('Faodel_ENABLE_IOM_LEVELDB', 'leveldb'),
+ self.define_from_variant('Faodel_ENABLE_MPI_SUPPORT', 'mpi'),
+ self.define_from_variant('Faodel_ENABLE_TCMALLOC', 'tcmalloc'),
'-DFaodel_LOGGING_METHOD:STRING={0}'.format(
spec.variants['logging'].value),
'-DFaodel_NETWORK_LIBRARY:STRING={0}'.format(
spec.variants['network'].value),
- '-DFaodel_ENABLE_CEREAL:BOOL={0}'.format(
- 'ON' if '+cereal' in spec else 'OFF')
+ self.define_from_variant('Faodel_ENABLE_CEREAL', 'cereal')
]
return args
diff --git a/var/spack/repos/builtin/packages/flatbuffers/package.py b/var/spack/repos/builtin/packages/flatbuffers/package.py
index 69041f54d1..35a36b35b9 100644
--- a/var/spack/repos/builtin/packages/flatbuffers/package.py
+++ b/var/spack/repos/builtin/packages/flatbuffers/package.py
@@ -54,8 +54,7 @@ class Flatbuffers(CMakePackage):
def cmake_args(self):
args = []
- args.append('-DFLATBUFFERS_BUILD_SHAREDLIB={0}'.format(
- 'ON' if '+shared' in self.spec else 'OFF'))
+ args.append(self.define_from_variant('FLATBUFFERS_BUILD_SHAREDLIB', 'shared'))
args.append('-DFLATBUFFERS_BUILD_FLATLIB={0}'.format(
'ON' if '+shared' not in self.spec else 'OFF'))
if 'darwin' in self.spec.architecture:
diff --git a/var/spack/repos/builtin/packages/flcl/package.py b/var/spack/repos/builtin/packages/flcl/package.py
index 73e5cd4cef..a3a6ba9c98 100644
--- a/var/spack/repos/builtin/packages/flcl/package.py
+++ b/var/spack/repos/builtin/packages/flcl/package.py
@@ -23,7 +23,6 @@ class Flcl(CMakePackage):
def cmake_args(self):
args = []
- args.append('-DBUILD_TESTING:BOOL={0}'.format(
- 'ON' if self.run_tests else 'OFF'))
+ args.append(self.define('BUILD_TESTING', self.run_tests))
return args
diff --git a/var/spack/repos/builtin/packages/ghost/package.py b/var/spack/repos/builtin/packages/ghost/package.py
index e7d550a7e7..3011d70583 100644
--- a/var/spack/repos/builtin/packages/ghost/package.py
+++ b/var/spack/repos/builtin/packages/ghost/package.py
@@ -44,16 +44,11 @@ class Ghost(CMakePackage, CudaPackage):
# note: we require the cblas_include_dir property from the blas
# provider, this is implemented at least for intel-mkl and
# netlib-lapack
- args = ['-DGHOST_ENABLE_MPI:BOOL=%s'
- % ('ON' if '+mpi' in spec else 'OFF'),
- '-DGHOST_USE_CUDA:BOOL=%s'
- % ('ON' if '+cuda' in spec else 'OFF'),
- '-DGHOST_USE_SCOTCH:BOOL=%s'
- % ('ON' if '+scotch' in spec else 'OFF'),
- '-DGHOST_USE_ZOLTAN:BOOL=%s'
- % ('ON' if '+zoltan' in spec else 'OFF'),
- '-DBUILD_SHARED_LIBS:BOOL=%s'
- % ('ON' if '+shared' in spec else 'OFF'),
+ args = [self.define_from_variant('GHOST_ENABLE_MPI', 'mpi'),
+ self.define_from_variant('GHOST_USE_CUDA', 'cuda'),
+ self.define_from_variant('GHOST_USE_SCOTCH', 'scotch'),
+ self.define_from_variant('GHOST_USE_ZOLTAN', 'zoltan'),
+ self.define_from_variant('BUILD_SHARED_LIBS', 'shared'),
'-DCBLAS_INCLUDE_DIR:STRING=%s'
% format(spec['blas'].headers.directories[0]),
'-DBLAS_LIBRARIES=%s'
diff --git a/var/spack/repos/builtin/packages/ginkgo/package.py b/var/spack/repos/builtin/packages/ginkgo/package.py
index a5af280996..8cdbca4ff8 100644
--- a/var/spack/repos/builtin/packages/ginkgo/package.py
+++ b/var/spack/repos/builtin/packages/ginkgo/package.py
@@ -73,22 +73,21 @@ class Ginkgo(CMakePackage, CudaPackage, ROCmPackage):
InstallError('Ginkgo requires a C++14-compliant C++ compiler')
spec = self.spec
+ from_variant = self.define_from_variant
args = [
- '-DGINKGO_BUILD_CUDA=%s' % ('ON' if '+cuda' in spec else 'OFF'),
- '-DGINKGO_BUILD_HIP=%s' % ('ON' if '+rocm' in spec else 'OFF'),
- '-DGINKGO_BUILD_OMP=%s' % ('ON' if '+openmp' in spec else 'OFF'),
- '-DBUILD_SHARED_LIBS=%s' % ('ON' if '+shared' in spec else 'OFF'),
- '-DGINKGO_JACOBI_FULL_OPTIMIZATIONS=%s' % (
- 'ON' if '+full_optimizations' in spec else 'OFF'),
- '-DGINKGO_BUILD_HWLOC=%s' % ('ON' if '+hwloc' in spec else 'OFF'),
- '-DGINKGO_DEVEL_TOOLS=%s' % (
- 'ON' if '+develtools' in spec else 'OFF'),
+ from_variant('GINKGO_BUILD_CUDA', 'cuda'),
+ from_variant('GINKGO_BUILD_HIP', 'rocm'),
+ from_variant('GINKGO_BUILD_OMP', 'openmp'),
+ from_variant('BUILD_SHARED_LIBS', 'shared'),
+ from_variant('GINKGO_JACOBI_FULL_OPTIMIZATIONS', 'full_optimizations'),
+ from_variant('GINKGO_BUILD_HWLOC', 'hwloc'),
+ from_variant('GINKGO_DEVEL_TOOLS', 'develtools'),
# As we are not exposing benchmarks, examples, tests nor doc
# as part of the installation, disable building them altogether.
'-DGINKGO_BUILD_BENCHMARKS=OFF',
'-DGINKGO_BUILD_DOC=OFF',
'-DGINKGO_BUILD_EXAMPLES=OFF',
- '-DGINKGO_BUILD_TESTS=%s' % ('ON' if self.run_tests else 'OFF'),
+ self.define('GINKGO_BUILD_TESTS', self.run_tests),
# Let spack handle the RPATH
'-DGINKGO_INSTALL_RPATH=OFF'
]
diff --git a/var/spack/repos/builtin/packages/gl2ps/package.py b/var/spack/repos/builtin/packages/gl2ps/package.py
index 6597cb3a85..b6267af616 100644
--- a/var/spack/repos/builtin/packages/gl2ps/package.py
+++ b/var/spack/repos/builtin/packages/gl2ps/package.py
@@ -50,8 +50,8 @@ class Gl2ps(CMakePackage):
def cmake_args(self):
options = [
- '-DENABLE_PNG={0}'.format(self.variant_to_bool('+png')),
- '-DENABLE_ZLIB={0}'.format(self.variant_to_bool('+zlib')),
+ self.define_from_variant('ENABLE_PNG', 'png'),
+ self.define_from_variant('ENABLE_ZLIB', 'zlib'),
]
if '~doc' in self.spec:
# Make sure we don't look.
diff --git a/var/spack/repos/builtin/packages/googletest/package.py b/var/spack/repos/builtin/packages/googletest/package.py
index 42c135aa64..7690ec0170 100644
--- a/var/spack/repos/builtin/packages/googletest/package.py
+++ b/var/spack/repos/builtin/packages/googletest/package.py
@@ -40,8 +40,7 @@ class Googletest(CMakePackage):
options.append('-Dgtest_disable_pthreads={0}'.format(
'OFF' if '+pthreads' in spec else 'ON'))
- options.append('-DBUILD_SHARED_LIBS={0}'.format(
- 'ON' if '+shared' in spec else 'OFF'))
+ options.append(self.define_from_variant('BUILD_SHARED_LIBS', 'shared'))
return options
@when('@:1.7.0')
diff --git a/var/spack/repos/builtin/packages/gotcha/package.py b/var/spack/repos/builtin/packages/gotcha/package.py
index 61ad3b5f8d..99ff2fa656 100644
--- a/var/spack/repos/builtin/packages/gotcha/package.py
+++ b/var/spack/repos/builtin/packages/gotcha/package.py
@@ -26,7 +26,6 @@ class Gotcha(CMakePackage):
when='@0.0.2:1.0.2')
def configure_args(self):
- spec = self.spec
return [
- '-DGOTCHA_ENABLE_TESTS=%s' % ('ON' if '+test' in spec else 'OFF')
+ self.define_from_variant('GOTCHA_ENABLE_TESTS', 'test')
]
diff --git a/var/spack/repos/builtin/packages/gunrock/package.py b/var/spack/repos/builtin/packages/gunrock/package.py
index 82fbaaa27b..81b237a78d 100644
--- a/var/spack/repos/builtin/packages/gunrock/package.py
+++ b/var/spack/repos/builtin/packages/gunrock/package.py
@@ -60,23 +60,17 @@ See "spack info gunrock"')
def cmake_args(self):
spec = self.spec
- args = []
- args.extend([
- '-DGUNROCK_BUILD_LIB={0}'.format(
- 'ON' if '+lib' in spec else 'OFF'),
- '-DGUNROCK_BUILD_SHARED_LIBS={0}'.format(
- 'ON' if '+shared_libs' in spec else 'OFF'),
- '-DGUNROCK_BUILD_TESTS={0}'.format(
- 'ON' if '+tests' in spec else 'OFF'),
- '-DGUNROCK_MGPU_TESTS={0}'.format(
- 'ON' if '+mgpu_tests' in spec else 'OFF'),
- '-DCUDA_VERBOSE_PTXAS={0}'.format(
- 'ON' if '+cuda_verbose_ptxas' in spec else 'OFF'),
- '-DGUNROCK_GOOGLE_TESTS={0}'.format(
- 'ON' if '+google_tests' in spec else 'OFF'),
- '-DGUNROCK_CODE_COVERAGE={0}'.format(
- 'ON' if '+code_coverage' in spec else 'OFF'),
- ])
+ from_variant = self.define_from_variant
+
+ args = [
+ from_variant('GUNROCK_BUILD_LIB', 'lib'),
+ from_variant('GUNROCK_BUILD_SHARED_LIBS', 'shared_libs'),
+ from_variant('GUNROCK_BUILD_TESTS', 'tests'),
+ from_variant('GUNROCK_MGPU_TESTS', 'mgpu_tests'),
+ from_variant('CUDA_VERBOSE_PTXAS', 'cuda_verbose_ptxas'),
+ from_variant('GUNROCK_GOOGLE_TESTS', 'google_tests'),
+ from_variant('GUNROCK_CODE_COVERAGE', 'code_coverage'),
+ ]
# turn off auto detect, which undoes custom cuda arch options
args.append('-DCUDA_AUTODETECT_GENCODE=OFF')
diff --git a/var/spack/repos/builtin/packages/helics/package.py b/var/spack/repos/builtin/packages/helics/package.py
index fde24d9dce..4f564d1256 100644
--- a/var/spack/repos/builtin/packages/helics/package.py
+++ b/var/spack/repos/builtin/packages/helics/package.py
@@ -72,38 +72,30 @@ class Helics(CMakePackage):
def cmake_args(self):
spec = self.spec
+ from_variant = self.define_from_variant
args = [
'-DHELICS_BUILD_EXAMPLES=OFF',
'-DHELICS_BUILD_TESTS=OFF',
]
# HELICS core type CMake options
- args.append('-DENABLE_ZMQ_CORE={0}'.format(
- 'ON' if '+zmq' in spec else 'OFF'))
- args.append('-DENABLE_TCP_CORE={0}'.format(
- 'ON' if '+tcp' in spec else 'OFF'))
- args.append('-DENABLE_UDP_CORE={0}'.format(
- 'ON' if '+udp' in spec else 'OFF'))
- args.append('-DENABLE_IPC_CORE={0}'.format(
- 'ON' if '+ipc' in spec else 'OFF'))
- args.append('-DENABLE_INPROC_CORE={0}'.format(
- 'ON' if '+inproc' in spec else 'OFF'))
- args.append('-DENABLE_MPI_CORE={0}'.format(
- 'ON' if '+mpi' in spec else 'OFF'))
+ args.append(from_variant('ENABLE_ZMQ_CORE', 'zmq'))
+ args.append(from_variant('ENABLE_TCP_CORE', 'tcp'))
+ args.append(from_variant('ENABLE_UDP_CORE', 'udp'))
+ args.append(from_variant('ENABLE_IPC_CORE', 'ipc'))
+ args.append(from_variant('ENABLE_INPROC_CORE', 'inproc'))
+ args.append(from_variant('ENABLE_MPI_CORE', 'mpi'))
# HELICS shared library options
args.append('-DHELICS_DISABLE_C_SHARED_LIB={0}'.format(
'OFF' if '+c_shared' in spec else 'ON'))
- args.append('-DHELICS_BUILD_CXX_SHARED_LIB={0}'.format(
- 'ON' if '+cxx_shared' in spec else 'OFF'))
+ args.append(from_variant('HELICS_BUILD_CXX_SHARED_LIB', 'cxx_shared'))
# HELICS executable app options
- args.append('-DHELICS_BUILD_APP_EXECUTABLES={0}'.format(
- 'ON' if '+apps' in spec else 'OFF'))
+ args.append(from_variant('HELICS_BUILD_APP_EXECUTABLES', 'apps'))
args.append('-DHELICS_DISABLE_WEBSERVER={0}'.format(
'OFF' if '+webserver' in spec else 'ON'))
- args.append('-DHELICS_BUILD_BENCHMARKS={0}'.format(
- 'ON' if '+benchmarks' in spec else 'OFF'))
+ args.append(from_variant('HELICS_BUILD_BENCHMARKS', 'benchmarks'))
# Extra HELICS library dependencies
args.append('-DHELICS_DISABLE_BOOST={0}'.format(
@@ -112,12 +104,10 @@ class Helics(CMakePackage):
'OFF' if '+asio' in spec else 'ON'))
# SWIG
- args.append('-DHELICS_ENABLE_SWIG={0}'.format(
- 'ON' if '+swig' in spec else 'OFF'))
+ args.append(from_variant('HELICS_ENABLE_SWIG', 'swig'))
# Python
- args.append('-DBUILD_PYTHON_INTERFACE={0}'.format(
- 'ON' if '+python' in spec else 'OFF'))
+ args.append(from_variant('BUILD_PYTHON_INTERFACE', 'python'))
return args
diff --git a/var/spack/repos/builtin/packages/ibmisc/package.py b/var/spack/repos/builtin/packages/ibmisc/package.py
index de77372c14..7fe8019a57 100644
--- a/var/spack/repos/builtin/packages/ibmisc/package.py
+++ b/var/spack/repos/builtin/packages/ibmisc/package.py
@@ -50,12 +50,12 @@ class Ibmisc(CMakePackage):
depends_on('doxygen', type='build')
def cmake_args(self):
- spec = self.spec
return [
- '-DUSE_EVERYTRACE=%s' % ('YES' if '+everytrace' in spec else 'NO'),
- '-DUSE_PROJ4=%s' % ('YES' if '+proj' in spec else 'NO'),
- '-DUSE_BLITZ=%s' % ('YES' if '+blitz' in spec else 'NO'),
- '-DUSE_NETCDF=%s' % ('YES' if '+netcdf' in spec else 'NO'),
- '-DUSE_BOOST=%s' % ('YES' if '+boost' in spec else 'NO'),
- '-DUSE_UDUNITS2=%s' % ('YES' if '+udunits2' in spec else 'NO'),
- '-DUSE_GTEST=%s' % ('YES' if '+googletest' in spec else 'NO')]
+ self.define_from_variant('USE_EVERYTRACE', 'everytrace'),
+ self.define_from_variant('USE_PROJ4', 'proj'),
+ self.define_from_variant('USE_BLITZ', 'blitz'),
+ self.define_from_variant('USE_NETCDF', 'netcdf'),
+ self.define_from_variant('USE_BOOST', 'boost'),
+ self.define_from_variant('USE_UDUNITS2', 'udunits2'),
+ self.define_from_variant('USE_GTEST', 'googletest'),
+ ]
diff --git a/var/spack/repos/builtin/packages/jansson/package.py b/var/spack/repos/builtin/packages/jansson/package.py
index b2e8b69971..b781d68dbe 100644
--- a/var/spack/repos/builtin/packages/jansson/package.py
+++ b/var/spack/repos/builtin/packages/jansson/package.py
@@ -26,6 +26,5 @@ class Jansson(CMakePackage):
def cmake_args(self):
return [
- '-DJANSSON_BUILD_SHARED_LIBS:BOOL=%s' % (
- 'ON' if '+shared' in self.spec else 'OFF'),
+ self.define_from_variant('JANSSON_BUILD_SHARED_LIBS', 'shared'),
]
diff --git a/var/spack/repos/builtin/packages/lammps/package.py b/var/spack/repos/builtin/packages/lammps/package.py
index 455e54b86c..3aeb584bf6 100644
--- a/var/spack/repos/builtin/packages/lammps/package.py
+++ b/var/spack/repos/builtin/packages/lammps/package.py
@@ -172,15 +172,12 @@ class Lammps(CMakePackage, CudaPackage):
pkg_prefix = 'PKG'
args = [
- '-DBUILD_SHARED_LIBS={0}'.format(
- 'ON' if '+lib' in spec else 'OFF'),
- '-DLAMMPS_EXCEPTIONS={0}'.format(
- 'ON' if '+exceptions' in spec else 'OFF'),
+ self.define_from_variant('BUILD_SHARED_LIBS', 'lib'),
+ self.define_from_variant('LAMMPS_EXCEPTIONS', 'exceptions'),
'-D{0}_MPI={1}'.format(
mpi_prefix,
'ON' if '+mpi' in spec else 'OFF'),
- '-DBUILD_OMP={0}'.format(
- 'ON' if '+openmp' in spec else 'OFF'),
+ self.define_from_variant('BUILD_OMP', 'openmp'),
]
if spec.satisfies('+cuda'):
args.append('-DPKG_GPU=ON')
@@ -188,8 +185,7 @@ class Lammps(CMakePackage, CudaPackage):
cuda_arch = spec.variants['cuda_arch'].value
if cuda_arch != 'none':
args.append('-DGPU_ARCH=sm_{0}'.format(cuda_arch[0]))
- args.append('-DCUDA_MPS_SUPPORT={0}'.format(
- 'ON' if '+cuda_mps' in spec else 'OFF'))
+ args.append(self.define_from_variant('CUDA_MPS_SUPPORT', 'cuda_mps'))
elif spec.satisfies('+opencl'):
args.append('-DPKG_GPU=ON')
args.append('-DGPU_API=opencl')
@@ -199,12 +195,9 @@ class Lammps(CMakePackage, CudaPackage):
if spec.satisfies('@20180629:+lib'):
args.append('-DBUILD_LIB=ON')
- args.append('-DWITH_JPEG={0}'.format(
- 'ON' if '+jpeg' in spec else 'OFF'))
- args.append('-DWITH_PNG={0}'.format(
- 'ON' if '+png' in spec else 'OFF'))
- args.append('-DWITH_FFMPEG={0}'.format(
- 'ON' if '+ffmpeg' in spec else 'OFF'))
+ args.append(self.define_from_variant('WITH_JPEG', 'jpeg'))
+ args.append(self.define_from_variant('WITH_PNG', 'png'))
+ args.append(self.define_from_variant('WITH_FFMPEG', 'ffmpeg'))
for pkg in self.supported_packages:
opt = '-D{0}_{1}'.format(pkg_prefix, pkg.upper())
diff --git a/var/spack/repos/builtin/packages/libgit2/package.py b/var/spack/repos/builtin/packages/libgit2/package.py
index 257bd01de5..ab25b74f80 100644
--- a/var/spack/repos/builtin/packages/libgit2/package.py
+++ b/var/spack/repos/builtin/packages/libgit2/package.py
@@ -96,6 +96,6 @@ class Libgit2(CMakePackage):
# Control tests
args.append(
- '-DBUILD_CLAR={0}'.format('ON' if self.run_tests else 'OFF'))
+ self.define('BUILD_CLAR', self.run_tests))
return args
diff --git a/var/spack/repos/builtin/packages/libnetworkit/package.py b/var/spack/repos/builtin/packages/libnetworkit/package.py
index 461b3ffc3d..1b9d3c1f40 100644
--- a/var/spack/repos/builtin/packages/libnetworkit/package.py
+++ b/var/spack/repos/builtin/packages/libnetworkit/package.py
@@ -42,7 +42,6 @@ class Libnetworkit(CMakePackage):
tlx_libs = spec['libtlx'].prefix
args = ['-DNETWORKIT_EXT_TLX=%s' % tlx_libs,
- '-DNETWORKIT_STATIC=%s' %
- ('ON' if '+static' in spec else 'OFF')]
+ self.define_from_variant('NETWORKIT_STATIC', 'static')]
return args
diff --git a/var/spack/repos/builtin/packages/libsplash/package.py b/var/spack/repos/builtin/packages/libsplash/package.py
index 0b385ae987..1d7026a664 100644
--- a/var/spack/repos/builtin/packages/libsplash/package.py
+++ b/var/spack/repos/builtin/packages/libsplash/package.py
@@ -45,10 +45,8 @@ class Libsplash(CMakePackage):
if spec.satisfies('@1.7.0:'):
args += [
- '-DSplash_USE_MPI:BOOL={0}'.format(
- 'ON' if '+mpi' in spec else 'OFF'),
- '-DSplash_USE_PARALLEL:BOOL={0}'.format(
- 'ON' if '+mpi' in spec else 'OFF')
+ self.define_from_variant('Splash_USE_MPI', 'mpi'),
+ self.define_from_variant('Splash_USE_PARALLEL', 'mpi')
]
return args
diff --git a/var/spack/repos/builtin/packages/libssh/package.py b/var/spack/repos/builtin/packages/libssh/package.py
index 81e4fd1925..02bad9790e 100644
--- a/var/spack/repos/builtin/packages/libssh/package.py
+++ b/var/spack/repos/builtin/packages/libssh/package.py
@@ -26,6 +26,5 @@ class Libssh(CMakePackage):
return url.format(version.up_to(2), version)
def cmake_args(self):
- args = ['-DWITH_GSSAPI=%s' %
- ('ON' if '+gssapi' in self.spec else 'OFF')]
+ args = [self.define_from_variant('WITH_GSSAPI', 'gssapi')]
return args
diff --git a/var/spack/repos/builtin/packages/libssh2/package.py b/var/spack/repos/builtin/packages/libssh2/package.py
index 2458525611..7b9beb7b14 100644
--- a/var/spack/repos/builtin/packages/libssh2/package.py
+++ b/var/spack/repos/builtin/packages/libssh2/package.py
@@ -25,9 +25,7 @@ class Libssh2(CMakePackage):
depends_on('xz')
def cmake_args(self):
- spec = self.spec
- return [
- '-DBUILD_SHARED_LIBS=%s' % ('YES' if '+shared' in spec else 'NO')]
+ return [self.define_from_variant('BUILD_SHARED_LIBS', 'shared')]
@run_after('install')
def darwin_fix(self):
diff --git a/var/spack/repos/builtin/packages/modern-wheel/package.py b/var/spack/repos/builtin/packages/modern-wheel/package.py
index b63dcab8ec..d56f0d9b24 100644
--- a/var/spack/repos/builtin/packages/modern-wheel/package.py
+++ b/var/spack/repos/builtin/packages/modern-wheel/package.py
@@ -40,10 +40,7 @@ class ModernWheel(CMakePackage):
patch('add_virtual_destructor.patch')
def cmake_args(self):
- spec = self.spec
return [
- '-DBUILD_UNIT_TEST:BOOL={0}'.format(
- 'ON' if '+test' in spec else 'OFF'),
- '-DBUILD_SHARED_LIBS:BOOL={0}'.format(
- 'ON' if '+shared' in spec else 'OFF'),
+ self.define_from_variant('BUILD_UNIT_TEST', 'test'),
+ self.define_from_variant('BUILD_SHARED_LIBS', 'shared'),
]
diff --git a/var/spack/repos/builtin/packages/mofem-cephas/package.py b/var/spack/repos/builtin/packages/mofem-cephas/package.py
index 15530f5df8..be19e838a2 100644
--- a/var/spack/repos/builtin/packages/mofem-cephas/package.py
+++ b/var/spack/repos/builtin/packages/mofem-cephas/package.py
@@ -69,8 +69,7 @@ class MofemCephas(CMakePackage):
'-DBOOST_DIR=%s' % spec['boost'].prefix])
# build tests
- options.append('-DMOFEM_BUILD_TESTS={0}'.format(
- 'ON' if self.run_tests else 'OFF'))
+ options.append(self.define('MOFEM_BUILD_TESTS', self.run_tests))
# variant packages
if '+adol-c' in spec:
@@ -87,6 +86,5 @@ class MofemCephas(CMakePackage):
# copy users modules, i.e. stand alone vs linked users modules
options.append(
- '-DSTAND_ALLONE_USERS_MODULES=%s' %
- ('YES' if '+copy_user_modules' in spec else 'NO'))
+ self.define_from_variant('STAND_ALLONE_USERS_MODULES', 'copy_user_modules'))
return options
diff --git a/var/spack/repos/builtin/packages/mofem-fracture-module/package.py b/var/spack/repos/builtin/packages/mofem-fracture-module/package.py
index 1abce3b805..5c77a31f4e 100644
--- a/var/spack/repos/builtin/packages/mofem-fracture-module/package.py
+++ b/var/spack/repos/builtin/packages/mofem-fracture-module/package.py
@@ -54,18 +54,17 @@ class MofemFractureModule(CMakePackage):
def cmake_args(self):
spec = self.spec
- source = self.stage.source_path
-
- options = []
# obligatory options
- options.extend([
- '-DWITH_SPACK=YES',
- '-DEXTERNAL_MODULES_BUILD=YES',
- '-DUM_INSTALL_BREFIX=%s' % spec['mofem-users-modules'].prefix,
- '-DEXTERNAL_MODULE_SOURCE_DIRS=%s' % source,
- '-DSTAND_ALLONE_USERS_MODULES=%s' %
- ('YES' if '+copy_user_modules' in spec else 'NO')])
+ options = [
+ self.define('WITH_SPACK', True),
+ self.define('EXTERNAL_MODULES_BUILD', True),
+ self.define('UM_INSTALL_BREFIX',
+ spec['mofem-users-modules'].prefix),
+ self.define('EXTERNAL_MODULE_SOURCE_DIRS', self.stage.source_path),
+ self.define_from_variant('STAND_ALLONE_USERS_MODULES',
+ 'copy_user_modules')
+ ]
# Set module version
if self.spec.version == Version('develop'):
@@ -80,8 +79,7 @@ class MofemFractureModule(CMakePackage):
'-DFM_VERSION_BUILD=%s' % self.spec.version[2]])
# build tests
- options.append('-DMOFEM_UM_BUILD_TESTS={0}'.format(
- 'ON' if self.run_tests else 'OFF'))
+ options.append(self.define('MOFEM_UM_BUILD_TESTS', self.run_tests))
return options
diff --git a/var/spack/repos/builtin/packages/mofem-minimal-surface-equation/package.py b/var/spack/repos/builtin/packages/mofem-minimal-surface-equation/package.py
index 93bbdfdb23..659f1134da 100644
--- a/var/spack/repos/builtin/packages/mofem-minimal-surface-equation/package.py
+++ b/var/spack/repos/builtin/packages/mofem-minimal-surface-equation/package.py
@@ -45,6 +45,7 @@ class MofemMinimalSurfaceEquation(CMakePackage):
def cmake_args(self):
spec = self.spec
+ from_variant = self.define_from_variant
source = self.stage.source_path
options = []
@@ -55,12 +56,10 @@ class MofemMinimalSurfaceEquation(CMakePackage):
'-DEXTERNAL_MODULES_BUILD=YES',
'-DUM_INSTALL_BREFIX=%s' % spec['mofem-users-modules'].prefix,
'-DEXTERNAL_MODULE_SOURCE_DIRS=%s' % source,
- '-DSTAND_ALLONE_USERS_MODULES=%s' %
- ('YES' if '+copy_user_modules' in spec else 'NO')])
+ from_variant('STAND_ALLONE_USERS_MODULES', 'copy_user_modules')])
# build tests
- options.append('-DMOFEM_UM_BUILD_TESTS={0}'.format(
- 'ON' if self.run_tests else 'OFF'))
+ options.append(self.define('MOFEM_UM_BUILD_TESTS', self.run_tests))
return options
diff --git a/var/spack/repos/builtin/packages/mofem-users-modules/package.py b/var/spack/repos/builtin/packages/mofem-users-modules/package.py
index 3373a60a88..b65299b50c 100644
--- a/var/spack/repos/builtin/packages/mofem-users-modules/package.py
+++ b/var/spack/repos/builtin/packages/mofem-users-modules/package.py
@@ -46,6 +46,7 @@ class MofemUsersModules(CMakePackage):
def cmake_args(self):
spec = self.spec
+ from_variant = self.define_from_variant
options = []
@@ -53,12 +54,10 @@ class MofemUsersModules(CMakePackage):
options.extend([
'-DMOFEM_DIR=%s' % spec['mofem-cephas'].prefix.users_module,
'-DWITH_SPACK=YES',
- '-DSTAND_ALLONE_USERS_MODULES=%s' %
- ('YES' if '+copy_user_modules' in spec else 'NO')])
+ from_variant('STAND_ALLONE_USERS_MODULES', 'copy_user_modules')])
# build tests
- options.append('-DMOFEM_UM_BUILD_TESTS={0}'.format(
- 'ON' if self.run_tests else 'OFF'))
+ options.append(self.define('MOFEM_UM_BUILD_TESTS', self.run_tests))
return options
diff --git a/var/spack/repos/builtin/packages/mpilander/package.py b/var/spack/repos/builtin/packages/mpilander/package.py
index 3db8e6c3f3..ce154f1251 100644
--- a/var/spack/repos/builtin/packages/mpilander/package.py
+++ b/var/spack/repos/builtin/packages/mpilander/package.py
@@ -37,10 +37,8 @@ class Mpilander(CMakePackage):
def cmake_args(self):
args = [
# tests and examples
- '-DBUILD_TESTING:BOOL={0}'.format(
- 'ON' if self.run_tests else 'OFF'),
- '-DBUILD_EXAMPLES:BOOL={0}'.format(
- 'ON' if self.run_tests else 'OFF'),
+ self.define('BUILD_TESTING', self.run_tests),
+ self.define('BUILD_EXAMPLES', self.run_tests),
]
return args
diff --git a/var/spack/repos/builtin/packages/msgpack-c/package.py b/var/spack/repos/builtin/packages/msgpack-c/package.py
index e81e6c8cf5..ca90981c40 100644
--- a/var/spack/repos/builtin/packages/msgpack-c/package.py
+++ b/var/spack/repos/builtin/packages/msgpack-c/package.py
@@ -22,7 +22,6 @@ class MsgpackC(CMakePackage):
args = [
"-DCMAKE_CXX_FLAGS=-Wno-implicit-fallthrough",
"-DCMAKE_C_FLAGS=-Wno-implicit-fallthrough",
- '-DMSGPACK_BUILD_TESTS:BOOL={0}'.format(
- 'ON' if self.run_tests else 'OFF')
+ self.define('MSGPACK_BUILD_TESTS', self.run_tests)
]
return args
diff --git a/var/spack/repos/builtin/packages/nalu/package.py b/var/spack/repos/builtin/packages/nalu/package.py
index cebf38488f..5f443554e6 100644
--- a/var/spack/repos/builtin/packages/nalu/package.py
+++ b/var/spack/repos/builtin/packages/nalu/package.py
@@ -53,8 +53,7 @@ class Nalu(CMakePackage):
'-DMPI_C_COMPILER=%s' % spec['mpi'].mpicc,
'-DMPI_CXX_COMPILER=%s' % spec['mpi'].mpicxx,
'-DMPI_Fortran_COMPILER=%s' % spec['mpi'].mpifc,
- '-DCMAKE_POSITION_INDEPENDENT_CODE:BOOL=%s' % (
- 'ON' if '+pic' in spec else 'OFF'),
+ self.define_from_variant('CMAKE_POSITION_INDEPENDENT_CODE', 'pic'),
])
if '+tioga' in spec:
diff --git a/var/spack/repos/builtin/packages/nnvm/package.py b/var/spack/repos/builtin/packages/nnvm/package.py
index 40db801133..ae82139089 100644
--- a/var/spack/repos/builtin/packages/nnvm/package.py
+++ b/var/spack/repos/builtin/packages/nnvm/package.py
@@ -26,6 +26,6 @@ class Nnvm(CMakePackage):
def cmake_args(self):
spec = self.spec
return [
- '-DUSE_SHARED_NNVM=%s' % ('ON' if '+shared' in spec else 'OFF'),
+ self.define_from_variant('USE_SHARED_NNVM', 'shared'),
'-DUSE_STATIC_NNVM=%s' % ('ON' if '~shared' in spec else 'OFF'),
]
diff --git a/var/spack/repos/builtin/packages/openfast/package.py b/var/spack/repos/builtin/packages/openfast/package.py
index 0e106da1bc..b368168aa2 100644
--- a/var/spack/repos/builtin/packages/openfast/package.py
+++ b/var/spack/repos/builtin/packages/openfast/package.py
@@ -47,16 +47,11 @@ class Openfast(CMakePackage):
options.extend([
'-DBUILD_DOCUMENTATION:BOOL=OFF',
'-DBUILD_TESTING:BOOL=OFF',
- '-DBUILD_SHARED_LIBS:BOOL=%s' % (
- 'ON' if '+shared' in spec else 'OFF'),
- '-DDOUBLE_PRECISION:BOOL=%s' % (
- 'ON' if '+double-precision' in spec else 'OFF'),
- '-DUSE_DLL_INTERFACE:BOOL=%s' % (
- 'ON' if '+dll-interface' in spec else 'OFF'),
- '-DBUILD_OPENFAST_CPP_API:BOOL=%s' % (
- 'ON' if '+cxx' in spec else 'OFF'),
- '-DCMAKE_POSITION_INDEPENDENT_CODE:BOOL=%s' % (
- 'ON' if '+pic' in spec else 'OFF'),
+ self.define_from_variant('BUILD_SHARED_LIBS', 'shared'),
+ self.define_from_variant('DOUBLE_PRECISION', 'double-precision'),
+ self.define_from_variant('USE_DLL_INTERFACE', 'dll-interface'),
+ self.define_from_variant('BUILD_OPENFAST_CPP_API', 'cxx'),
+ self.define_from_variant('CMAKE_POSITION_INDEPENDENT_CODE', 'pic'),
])
# Make sure we use Spack's blas/lapack:
diff --git a/var/spack/repos/builtin/packages/opennurbs/package.py b/var/spack/repos/builtin/packages/opennurbs/package.py
index ece24e66ef..bfe4c2316e 100644
--- a/var/spack/repos/builtin/packages/opennurbs/package.py
+++ b/var/spack/repos/builtin/packages/opennurbs/package.py
@@ -25,8 +25,7 @@ class Opennurbs(Package):
# CMake installation method
def install(self, spec, prefix):
cmake_args = [
- '-DBUILD_SHARED_LIBS:BOOL=%s' % (
- 'ON' if '+shared' in spec else 'OFF')
+ self.define_from_variant('BUILD_SHARED_LIBS', 'shared')
]
cmake_args.extend(std_cmake_args)
diff --git a/var/spack/repos/builtin/packages/pagmo/package.py b/var/spack/repos/builtin/packages/pagmo/package.py
index 43da2bb969..6ca785d7c5 100644
--- a/var/spack/repos/builtin/packages/pagmo/package.py
+++ b/var/spack/repos/builtin/packages/pagmo/package.py
@@ -74,18 +74,18 @@ class Pagmo(CMakePackage):
spec = self.spec
args = [
- '-DBUILD_EXAMPLES={0}'.format(self.variant_to_bool('+examples')),
- '-DBUILD_MAIN={0}'.format(self.variant_to_bool('+cxx')),
- '-DBUILD_PYGMO={0}'.format(self.variant_to_bool('+python')),
- '-DENABLE_GSL={0}'.format(self.variant_to_bool('+gsl')),
- '-DENABLE_GTOP_DATABASE={0}'.format(self.variant_to_bool('+gtop')),
- '-DENABLE_IPOPT={0}'.format(self.variant_to_bool('+ipopt')),
- '-DENABLE_MPI={0}'.format(self.variant_to_bool('+mpi')),
- '-DENABLE_NLOPT={0}'.format(self.variant_to_bool('+nlopt')),
- '-DENABLE_SNOPT={0}'.format(self.variant_to_bool('+snopt')),
- '-DENABLE_WORHP={0}'.format(self.variant_to_bool('+worhp')),
- '-DINSTALL_HEADERS={0}'.format(self.variant_to_bool('+headers')),
- '-DENABLE_TESTS={0}'.format('ON' if self.run_tests else 'OFF'),
+ self.define_from_variant('BUILD_EXAMPLES', 'examples'),
+ self.define_from_variant('BUILD_MAIN', 'cxx'),
+ self.define_from_variant('BUILD_PYGMO', 'python'),
+ self.define_from_variant('ENABLE_GSL', 'gsl'),
+ self.define_from_variant('ENABLE_GTOP_DATABASE', 'gtop'),
+ self.define_from_variant('ENABLE_IPOPT', 'ipopt'),
+ self.define_from_variant('ENABLE_MPI', 'mpi'),
+ self.define_from_variant('ENABLE_NLOPT', 'nlopt'),
+ self.define_from_variant('ENABLE_SNOPT', 'snopt'),
+ self.define_from_variant('ENABLE_WORHP', 'worhp'),
+ self.define_from_variant('INSTALL_HEADERS', 'headers'),
+ self.define('ENABLE_TESTS', self.run_tests),
]
if '+python' in spec:
diff --git a/var/spack/repos/builtin/packages/paradiseo/package.py b/var/spack/repos/builtin/packages/paradiseo/package.py
index 1b6ff11b20..778799fc6e 100644
--- a/var/spack/repos/builtin/packages/paradiseo/package.py
+++ b/var/spack/repos/builtin/packages/paradiseo/package.py
@@ -53,18 +53,13 @@ class Paradiseo(CMakePackage):
patch('fix_tutorials.patch')
def cmake_args(self):
- spec = self.spec
-
return [
'-DINSTALL_TYPE:STRING=MIN',
- '-DMPI:BOOL=%s' % ('TRUE' if '+mpi' in spec else 'FALSE'),
+ self.define_from_variant('MPI', 'mpi'),
# Note: This requires a C++11 compatible compiler
- '-DSMP:BOOL=%s' % ('TRUE' if '+smp' in spec else 'FALSE'),
- '-DEDO:BOOL=%s' % ('TRUE' if '+edo' in spec else 'FALSE'),
- '-DENABLE_CMAKE_TESTING:BOOL=%s' % (
- 'TRUE' if self.run_tests else 'FALSE'),
- '-DENABLE_OPENMP:BOOL=%s' % (
- 'TRUE' if '+openmp' in spec else 'FALSE'),
- '-DENABLE_GNUPLOT:BOOL=%s' % (
- 'TRUE' if '+gnuplot' in spec else 'FALSE')
+ self.define_from_variant('SMP', 'smp'),
+ self.define_from_variant('EDO', 'edo'),
+ self.define('ENABLE_CMAKE_TESTING', self.run_tests),
+ self.define_from_variant('ENABLE_OPENMP', 'openmp'),
+ self.define_from_variant('ENABLE_GNUPLOT', 'gnuplot')
]
diff --git a/var/spack/repos/builtin/packages/perfstubs/package.py b/var/spack/repos/builtin/packages/perfstubs/package.py
index 2882d0c348..32f51fa978 100644
--- a/var/spack/repos/builtin/packages/perfstubs/package.py
+++ b/var/spack/repos/builtin/packages/perfstubs/package.py
@@ -25,10 +25,7 @@ class Perfstubs(CMakePackage):
variant('static', default=False, description='Build static executable support')
def cmake_args(self):
- spec = self.spec
-
args = [
- '-DPERFSTUBS_USE_STATIC:BOOL={0}'.format(
- 'ON' if '+static' in spec else 'OFF')
+ self.define_from_variant('PERFSTUBS_USE_STATIC', 'static')
]
return args
diff --git a/var/spack/repos/builtin/packages/pfunit/package.py b/var/spack/repos/builtin/packages/pfunit/package.py
index 2c8524b09d..7aea55a1eb 100644
--- a/var/spack/repos/builtin/packages/pfunit/package.py
+++ b/var/spack/repos/builtin/packages/pfunit/package.py
@@ -72,16 +72,16 @@ class Pfunit(CMakePackage):
spec = self.spec
args = [
'-DPYTHON_EXECUTABLE=%s' % spec['python'].command,
- '-DBUILD_SHARED=%s' % ('YES' if '+shared' in spec else 'NO'),
+ self.define_from_variant('BUILD_SHARED', 'shared'),
'-DCMAKE_Fortran_MODULE_DIRECTORY=%s' % spec.prefix.include,
- '-DBUILD_DOCS=%s' % ('YES' if '+docs' in spec else 'NO'),
- '-DOPENMP=%s' % ('YES' if '+openmp' in spec else 'NO'),
+ self.define_from_variant('BUILD_DOCS', 'docs'),
+ self.define_from_variant('OPENMP', 'openmp'),
'-DMAX_RANK=%s' % spec.variants['max_array_rank'].value]
if spec.satisfies('@4.0.0:'):
args.append('-DSKIP_MPI=%s' % ('YES' if '~mpi' in spec else 'NO'))
else:
- args.append('-DMPI=%s' % ('YES' if '+mpi' in spec else 'NO'))
+ args.append(self.define_from_variant('MPI', 'mpi'))
if spec.satisfies('+mpi'):
args.extend(['-DMPI_USE_MPIEXEC=YES',
diff --git a/var/spack/repos/builtin/packages/phist/package.py b/var/spack/repos/builtin/packages/phist/package.py
index 83efd9df7f..e276bcf800 100644
--- a/var/spack/repos/builtin/packages/phist/package.py
+++ b/var/spack/repos/builtin/packages/phist/package.py
@@ -154,26 +154,20 @@ class Phist(CMakePackage):
'-DPHIST_OUTLEV=%s' % outlev,
'-DTPL_LAPACKE_LIBRARIES=%s' % lapacke_libs,
'-DTPL_LAPACKE_INCLUDE_DIRS=%s' % lapacke_include_dir,
- '-DPHIST_ENABLE_MPI:BOOL=%s'
- % ('ON' if '+mpi' in spec else 'OFF'),
- '-DPHIST_ENABLE_OPENMP=%s'
- % ('ON' if '+openmp' in spec else 'OFF'),
- '-DBUILD_SHARED_LIBS:BOOL=%s'
- % ('ON' if '+shared' in spec else 'OFF'),
- '-DPHIST_ENABLE_SCAMAC:BOOL=%s'
- % ('ON' if '+scamac' in spec else 'OFF'),
+ self.define_from_variant('PHIST_ENABLE_MPI', 'mpi'),
+ self.define_from_variant('PHIST_ENABLE_OPENMP', 'openmp'),
+ self.define_from_variant('BUILD_SHARED_LIBS', 'shared'),
+ self.define_from_variant('PHIST_ENABLE_SCAMAC', 'scamac'),
'-DPHIST_USE_TRILINOS_TPLS:BOOL=%s'
% ('ON' if '^trilinos' in spec else 'OFF'),
'-DPHIST_USE_SOLVER_TPLS:BOOL=%s'
% ('ON' if '^trilinos+belos+anasazi' in spec else 'OFF'),
'-DPHIST_USE_PRECON_TPLS:BOOL=%s'
% ('ON' if '^trilinos' in spec else 'OFF'),
- '-DXSDK_ENABLE_Fortran:BOOL=%s'
- % ('ON' if '+fortran' in spec else 'OFF'),
+ self.define_from_variant('XSDK_ENABLE_Fortran', 'fortran'),
'-DXSDK_INDEX_SIZE=%s'
% ('64' if '+int64' in spec else '32'),
- '-DPHIST_HOST_OPTIMIZE:BOOL=%s'
- % ('ON' if '+host' in spec else 'OFF'),
+ self.define_from_variant('PHIST_HOST_OPTIMIZE', 'host'),
]
return args
diff --git a/var/spack/repos/builtin/packages/piranha/package.py b/var/spack/repos/builtin/packages/piranha/package.py
index 5e92f608db..a5a5346eeb 100644
--- a/var/spack/repos/builtin/packages/piranha/package.py
+++ b/var/spack/repos/builtin/packages/piranha/package.py
@@ -37,6 +37,6 @@ class Piranha(CMakePackage):
def cmake_args(self):
return [
- '-DBUILD_PYRANHA=%s' % ('ON' if '+python' in self.spec else 'OFF'),
+ self.define_from_variant('BUILD_PYRANHA', 'python'),
'-DBUILD_TESTS:BOOL=ON',
]
diff --git a/var/spack/repos/builtin/packages/pism/package.py b/var/spack/repos/builtin/packages/pism/package.py
index 5b672718e5..4a8b300f14 100644
--- a/var/spack/repos/builtin/packages/pism/package.py
+++ b/var/spack/repos/builtin/packages/pism/package.py
@@ -93,28 +93,17 @@ class Pism(CMakePackage):
'-DCMAKE_CXX_COMPILER=%s' % spec['mpi'].mpicxx,
# Fortran not needed for PISM...
# '-DCMAKE_Fortran_COMPILER=%s' % spec['mpi'].mpifc,
- '-DPism_BUILD_EXTRA_EXECS=%s' %
- ('YES' if '+extra' in spec else 'NO'),
- '-DBUILD_SHARED_LIBS=%s' %
- ('YES' if '+shared' in spec else 'NO'),
- '-DPism_BUILD_PYTHON_BINDINGS=%s' %
- ('YES' if '+python' in spec else 'NO'),
- '-DPism_BUILD_ICEBIN=%s' %
- ('YES' if '+icebin' in spec else 'NO'),
- '-DPism_USE_PROJ4=%s' %
- ('YES' if '+proj' in spec else 'NO'),
- '-DPism_USE_PARALLEL_NETCDF4=%s' %
- ('YES' if '+parallel-netcdf4' in spec else 'NO'),
- '-DPism_USE_PNETCDF=%s' %
- ('YES' if '+parallel-netcdf3' in spec else 'NO'),
- '-DPism_USE_PARALLEL_HDF5=%s' %
- ('YES' if '+parallel-hdf5' in spec else 'NO'),
- '-DPism_BUILD_PDFS=%s' %
- ('YES' if '+doc' in spec else 'NO'),
- '-DPism_INSTALL_EXAMPLES=%s' %
- ('YES' if '+examples' in spec else 'NO'),
- '-DPism_USE_EVERYTRACE=%s' %
- ('YES' if '+everytrace' in spec else 'NO')]
+ self.define_from_variant('Pism_BUILD_EXTRA_EXECS', 'extra'),
+ self.define_from_variant('BUILD_SHARED_LIBS', 'shared'),
+ self.define_from_variant('Pism_BUILD_PYTHON_BINDINGS', 'python'),
+ self.define_from_variant('Pism_BUILD_ICEBIN', 'icebin'),
+ self.define_from_variant('Pism_USE_PROJ4', 'proj'),
+ self.define_from_variant('Pism_USE_PARALLEL_NETCDF4', 'parallel-netcdf4'),
+ self.define_from_variant('Pism_USE_PNETCDF', 'parallel-netcdf3'),
+ self.define_from_variant('Pism_USE_PARALLEL_HDF5', 'parallel-hdf5'),
+ self.define_from_variant('Pism_BUILD_PDFS', 'doc'),
+ self.define_from_variant('Pism_INSTALL_EXAMPLES', 'examples'),
+ self.define_from_variant('Pism_USE_EVERYTRACE', 'everytrace')]
def setup_run_environment(self, env):
env.set('PISM_PREFIX', self.prefix)
diff --git a/var/spack/repos/builtin/packages/pumi/package.py b/var/spack/repos/builtin/packages/pumi/package.py
index 1dbfad44b3..08930cd70d 100644
--- a/var/spack/repos/builtin/packages/pumi/package.py
+++ b/var/spack/repos/builtin/packages/pumi/package.py
@@ -67,13 +67,12 @@ class Pumi(CMakePackage):
args = [
'-DSCOREC_CXX_WARNINGS=OFF',
- '-DENABLE_ZOLTAN=%s' % ('ON' if '+zoltan' in spec else 'OFF'),
+ self.define_from_variant('ENABLE_ZOLTAN', 'zoltan'),
'-DCMAKE_C_COMPILER=%s' % spec['mpi'].mpicc,
'-DCMAKE_CXX_COMPILER=%s' % spec['mpi'].mpicxx,
- '-DBUILD_SHARED_LIBS=%s' % ('ON' if '+shared' in spec else 'OFF'),
+ self.define_from_variant('BUILD_SHARED_LIBS', 'shared'),
'-DCMAKE_Fortran_COMPILER=%s' % spec['mpi'].mpifc,
- '-DPUMI_FORTRAN_INTERFACE=%s' %
- ('ON' if '+fortran' in spec else 'OFF'),
+ self.define_from_variant('PUMI_FORTRAN_INTERFACE', 'fortran'),
'-DMDS_ID_TYPE=%s' % ('long' if '+int64' in spec else 'int'),
'-DSKIP_SIMMETRIX_VERSION_CHECK=%s' %
('ON' if '~simmodsuite_version_check' in spec else 'OFF'),
diff --git a/var/spack/repos/builtin/packages/py-pybind11/package.py b/var/spack/repos/builtin/packages/py-pybind11/package.py
index 07f3350815..7913e5a5cb 100644
--- a/var/spack/repos/builtin/packages/py-pybind11/package.py
+++ b/var/spack/repos/builtin/packages/py-pybind11/package.py
@@ -51,8 +51,7 @@ class PyPybind11(CMakePackage):
args.append('-DPYTHON_EXECUTABLE:FILEPATH=%s'
% self.spec['python'].command.path)
args += [
- '-DPYBIND11_TEST:BOOL={0}'.format(
- 'ON' if self.run_tests else 'OFF')
+ self.define('PYBIND11_TEST', self.run_tests)
]
return args
diff --git a/var/spack/repos/builtin/packages/qgis/package.py b/var/spack/repos/builtin/packages/qgis/package.py
index 1b111370ff..95a45656cf 100644
--- a/var/spack/repos/builtin/packages/qgis/package.py
+++ b/var/spack/repos/builtin/packages/qgis/package.py
@@ -191,8 +191,7 @@ class Qgis(CMakePackage):
'TRUE' if '+gui' in spec else 'FALSE'),
'-DWITH_INTERNAL_MDAL={0}'.format(
'TRUE' if '+internal_mdal' in spec else 'FALSE'),
- '-DWITH_INTERNAL_O2={0}'.format(
- 'ON' if '+internal_o2' in spec else 'OFF'),
+ self.define_from_variant('WITH_INTERNAL_O2', 'internal_o2'),
'-DWITH_OAUTH2_PLUGIN={0}'.format(
'TRUE' if '+oauth2_plugin' in spec else 'FALSE'),
'-DWITH_ORACLE={0}'.format(
@@ -203,14 +202,12 @@ class Qgis(CMakePackage):
'TRUE' if '+py_compile' in spec else 'FALSE'),
'-DWITH_QSCIAPI={0}'.format(
'TRUE' if '+qsciapi' in spec else 'FALSE'),
- '-DWITH_QSPATIALITE={0}'.format(
- 'ON' if '+qspatialite' in spec else 'OFF'),
+ self.define_from_variant('WITH_QSPATIALITE', 'qspatialite'),
'-DWITH_QT5SERIALPORT={0}'.format(
'TRUE' if '+qt5serialport' in spec else 'FALSE'),
'-DWITH_QTMOBILITY={0}'.format(
'TRUE' if '+qtmobility' in spec else 'FALSE'),
- '-DWITH_QTWEBKIT={0}'.format(
- 'ON' if '+qtwebkit' in spec else 'OFF'),
+ self.define_from_variant('WITH_QTWEBKIT', 'qtwebkit'),
'-DWITH_QUICK={0}'.format(
'TRUE' if '+quick' in spec else 'FALSE'),
'-DWITH_QWTPOLAR={0}'.format(
diff --git a/var/spack/repos/builtin/packages/raja/package.py b/var/spack/repos/builtin/packages/raja/package.py
index 49ba6996b7..3603d4ad4c 100644
--- a/var/spack/repos/builtin/packages/raja/package.py
+++ b/var/spack/repos/builtin/packages/raja/package.py
@@ -58,8 +58,7 @@ class Raja(CMakePackage, CudaPackage, ROCmPackage):
options.append('-DBLT_SOURCE_DIR={0}'.format(spec['blt'].prefix))
- options.append('-DENABLE_OPENMP={0}'.format(
- 'ON' if '+openmp' in spec else 'OFF'))
+ options.append(self.define_from_variant('ENABLE_OPENMP', 'openmp'))
if '+cuda' in spec:
options.extend([
@@ -85,14 +84,11 @@ class Raja(CMakePackage, CudaPackage, ROCmPackage):
else:
options.append('-DENABLE_HIP=OFF')
- options.append('-DBUILD_SHARED_LIBS={0}'.format(
- 'ON' if '+shared' in spec else 'OFF'))
+ options.append(self.define_from_variant('BUILD_SHARED_LIBS', 'shared'))
- options.append('-DENABLE_EXAMPLES={0}'.format(
- 'ON' if '+examples' in spec else 'OFF'))
+ options.append(self.define_from_variant('ENABLE_EXAMPLES', 'examples'))
- options.append('-DENABLE_EXERCISES={0}'.format(
- 'ON' if '+exercises' in spec else 'OFF'))
+ options.append(self.define_from_variant('ENABLE_EXERCISES', 'exercises'))
# Work around spack adding -march=ppc64le to SPACK_TARGET_ARGS which
# is used by the spack compiler wrapper. This can go away when BLT
@@ -100,8 +96,7 @@ class Raja(CMakePackage, CudaPackage, ROCmPackage):
if self.spec.satisfies('%clang target=ppc64le:') or not self.run_tests:
options.append('-DENABLE_TESTS=OFF')
else:
- options.append('-DENABLE_TESTS={0}'.format(
- 'ON' if '+tests' in spec else 'OFF'))
+ options.append(self.define_from_variant('ENABLE_TESTS', 'tests'))
return options
diff --git a/var/spack/repos/builtin/packages/rmlab/package.py b/var/spack/repos/builtin/packages/rmlab/package.py
index 2c711a6e0b..58ed4f4a3f 100644
--- a/var/spack/repos/builtin/packages/rmlab/package.py
+++ b/var/spack/repos/builtin/packages/rmlab/package.py
@@ -29,10 +29,7 @@ class Rmlab(CMakePackage):
depends_on('pngwriter@0.6.0:', when='+png')
def cmake_args(self):
- spec = self.spec
-
args = [
- '-DRmlab_USE_PNG={0}'.format(
- 'ON' if '+png' in spec else 'OFF')
+ self.define_from_variant('Rmlab_USE_PNG', 'png')
]
return args
diff --git a/var/spack/repos/builtin/packages/seacas/package.py b/var/spack/repos/builtin/packages/seacas/package.py
index 860ebb15e7..b5e2f55ba7 100644
--- a/var/spack/repos/builtin/packages/seacas/package.py
+++ b/var/spack/repos/builtin/packages/seacas/package.py
@@ -99,6 +99,7 @@ class Seacas(CMakePackage):
def cmake_args(self):
spec = self.spec
+ from_variant = self.define_from_variant
options = []
@@ -116,20 +117,14 @@ class Seacas(CMakePackage):
options.extend([
'-DSEACASProj_ENABLE_TESTS:BOOL=ON',
'-DSEACASProj_ENABLE_CXX11:BOOL=ON',
- '-DCMAKE_INSTALL_RPATH_USE_LINK_PATH:BOOL=%s' % (
- 'ON' if '+shared' in spec else 'OFF'),
- '-DBUILD_SHARED_LIBS:BOOL=%s' % (
- 'ON' if '+shared' in spec else 'OFF'),
+ from_variant('CMAKE_INSTALL_RPATH_USE_LINK_PATH', 'shared'),
+ from_variant('BUILD_SHARED_LIBS', 'shared'),
'-DSEACASProj_ENABLE_Kokkos:BOOL=OFF',
'-DSEACASProj_HIDE_DEPRECATED_CODE:BOOL=OFF',
- '-DSEACASExodus_ENABLE_THREADSAFE:BOOL=%s' % (
- 'ON' if '+thread_safe' in spec else 'OFF'),
- '-DSEACASIoss_ENABLE_THREADSAFE:BOOL=%s' % (
- 'ON' if '+thread_safe' in spec else 'OFF'),
- '-DSEACASProj_ENABLE_Fortran:BOOL=%s' % (
- 'ON' if '+fortran' in spec else 'OFF'),
- '-DTPL_ENABLE_X11:BOOL=%s' % (
- 'ON' if '+x11' in spec else 'OFF'),
+ from_variant('SEACASExodus_ENABLE_THREADSAFE', 'thread_safe'),
+ from_variant('SEACASIoss_ENABLE_THREADSAFE', 'thread_safe'),
+ from_variant('SEACASProj_ENABLE_Fortran', 'fortran'),
+ from_variant('TPL_ENABLE_X11', 'x11'),
])
# ########## What applications should be built #############
@@ -148,10 +143,8 @@ class Seacas(CMakePackage):
'-DSEACASProj_ENABLE_SECONDARY_TESTED_CODE:BOOL=OFF',
'-DSEACASProj_ENABLE_SEACASIoss:BOOL=ON',
'-DSEACASProj_ENABLE_SEACASExodus:BOOL=ON',
- '-DSEACASProj_ENABLE_SEACASExodus_for:BOOL=%s' % (
- 'ON' if '+fortran' in spec else 'OFF'),
- '-DSEACASProj_ENABLE_SEACASExoIIv2for32:BOOL=%s' % (
- 'ON' if '+fortran' in spec else 'OFF'),
+ from_variant('SEACASProj_ENABLE_SEACASExodus_for', 'fortran'),
+ from_variant('SEACASProj_ENABLE_SEACASExoIIv2for32', 'fortran'),
])
if '+applications' in spec:
@@ -164,10 +157,8 @@ class Seacas(CMakePackage):
'-DSEACASProj_ENABLE_SEACASExo2mat:BOOL=ON',
'-DSEACASProj_ENABLE_SEACASExo_format:BOOL=ON',
'-DSEACASProj_ENABLE_SEACASExodiff:BOOL=ON',
- '-DSEACASProj_ENABLE_SEACASExplore:BOOL=%s' % (
- 'ON' if '+fortran' in spec else 'OFF'),
- '-DSEACASProj_ENABLE_SEACASGrepos:BOOL=%s' % (
- 'ON' if '+fortran' in spec else 'OFF'),
+ from_variant('SEACASProj_ENABLE_SEACASExplore', 'fortran'),
+ from_variant('SEACASProj_ENABLE_SEACASGrepos', 'fortran'),
'-DSEACASProj_ENABLE_SEACASMat2exo:BOOL=ON',
'-DSEACASProj_ENABLE_SEACASNas2exo:BOOL=ON',
'-DSEACASProj_ENABLE_SEACASNemslice:BOOL=ON',
@@ -177,37 +168,23 @@ class Seacas(CMakePackage):
if '+legacy' in spec:
options.extend([
- '-DSEACASProj_ENABLE_SEACASAlgebra:BOOL=%s' % (
- 'ON' if '+fortran' in spec else 'OFF'),
- '-DSEACASProj_ENABLE_SEACASBlot:BOOL=%s' % (
- 'ON' if '+fortran' in spec else 'OFF'),
- '-DSEACASProj_ENABLE_SEACASEx1ex2v2:BOOL=%s' % (
- 'ON' if '+fortran' in spec else 'OFF'),
- '-DSEACASProj_ENABLE_SEACASEx2ex1v2:BOOL=%s' % (
- 'ON' if '+fortran' in spec else 'OFF'),
- '-DSEACASProj_ENABLE_SEACASExomatlab:BOOL=%s' % (
- 'ON' if '+fortran' in spec else 'OFF'),
- '-DSEACASProj_ENABLE_SEACASExotec2:BOOL=%s' % (
- 'ON' if '+fortran' in spec else 'OFF'),
- '-DSEACASProj_ENABLE_SEACASExotxt:BOOL=%s' % (
- 'ON' if '+fortran' in spec else 'OFF'),
- '-DSEACASProj_ENABLE_SEACASFastq:BOOL=%s' % (
- 'ON' if '+fortran' in spec else 'OFF'),
- '-DSEACASProj_ENABLE_SEACASGen3D:BOOL=%s' % (
- 'ON' if '+fortran' in spec else 'OFF'),
- '-DSEACASProj_ENABLE_SEACASGenshell:BOOL=%s' % (
- 'ON' if '+fortran' in spec else 'OFF'),
- '-DSEACASProj_ENABLE_SEACASGjoin:BOOL=%s' % (
- 'ON' if '+fortran' in spec else 'OFF'),
- '-DSEACASProj_ENABLE_SEACASMapvar:BOOL=%s' % (
- 'ON' if '+fortran' in spec else 'OFF'),
+ from_variant('SEACASProj_ENABLE_SEACASAlgebra', 'fortran'),
+ from_variant('SEACASProj_ENABLE_SEACASBlot', 'fortran'),
+ from_variant('SEACASProj_ENABLE_SEACASEx1ex2v2', 'fortran'),
+ from_variant('SEACASProj_ENABLE_SEACASEx2ex1v2', 'fortran'),
+ from_variant('SEACASProj_ENABLE_SEACASExomatlab', 'fortran'),
+ from_variant('SEACASProj_ENABLE_SEACASExotec2', 'fortran'),
+ from_variant('SEACASProj_ENABLE_SEACASExotxt', 'fortran'),
+ from_variant('SEACASProj_ENABLE_SEACASFastq', 'fortran'),
+ from_variant('SEACASProj_ENABLE_SEACASGen3D', 'fortran'),
+ from_variant('SEACASProj_ENABLE_SEACASGenshell', 'fortran'),
+ from_variant('SEACASProj_ENABLE_SEACASGjoin', 'fortran'),
+ from_variant('SEACASProj_ENABLE_SEACASMapvar', 'fortran'),
'-DSEACASProj_ENABLE_SEACASMapvar-kd:BOOL=%s' % (
'ON' if '+fortran' in spec else 'OFF'),
'-DSEACASProj_ENABLE_SEACASNemesis:BOOL=ON',
- '-DSEACASProj_ENABLE_SEACASNumbers:BOOL=%s' % (
- 'ON' if '+fortran' in spec else 'OFF'),
- '-DSEACASProj_ENABLE_SEACASTxtexo:BOOL=%s' % (
- 'ON' if '+fortran' in spec else 'OFF'),
+ from_variant('SEACASProj_ENABLE_SEACASNumbers', 'fortran'),
+ from_variant('SEACASProj_ENABLE_SEACASTxtexo', 'fortran'),
])
# ##################### Dependencies ##########################
diff --git a/var/spack/repos/builtin/packages/snappy/package.py b/var/spack/repos/builtin/packages/snappy/package.py
index 053aa4a9be..3929f4caaf 100644
--- a/var/spack/repos/builtin/packages/snappy/package.py
+++ b/var/spack/repos/builtin/packages/snappy/package.py
@@ -23,19 +23,12 @@ class Snappy(CMakePackage):
patch('link_gtest.patch')
def cmake_args(self):
- spec = self.spec
-
- args = [
- '-DCMAKE_INSTALL_LIBDIR:PATH={0}'.format(
- self.prefix.lib),
- '-DBUILD_SHARED_LIBS:BOOL={0}'.format(
- 'ON' if '+shared' in spec else 'OFF'),
- '-DSNAPPY_BUILD_TESTS:BOOL={0}'.format(
- 'ON' if self.run_tests else 'OFF')
+ return [
+ self.define('CMAKE_INSTALL_LIBDIR', self.prefix.lib),
+ self.define_from_variant('BUILD_SHARED_LIBS', 'shared'),
+ self.define('SNAPPY_BUILD_TESTS', self.run_tests),
]
- return args
-
def flag_handler(self, name, flags):
flags = list(flags)
if '+pic' in self.spec:
diff --git a/var/spack/repos/builtin/packages/spdlog/package.py b/var/spack/repos/builtin/packages/spdlog/package.py
index a52096bd99..c6832c547d 100644
--- a/var/spack/repos/builtin/packages/spdlog/package.py
+++ b/var/spack/repos/builtin/packages/spdlog/package.py
@@ -42,19 +42,14 @@ class Spdlog(CMakePackage):
depends_on('cmake@3.2:', type='build')
def cmake_args(self):
- spec = self.spec
-
args = []
if self.spec.version >= Version('1.4.0'):
args.extend([
- '-DSPDLOG_BUILD_SHARED:BOOL={0}'.format(
- 'ON' if '+shared' in spec else 'OFF'),
+ self.define_from_variant('SPDLOG_BUILD_SHARED', 'shared'),
# tests and examples
- '-DSPDLOG_BUILD_TESTS:BOOL={0}'.format(
- 'ON' if self.run_tests else 'OFF'),
- '-DSPDLOG_BUILD_EXAMPLE:BOOL={0}'.format(
- 'ON' if self.run_tests else 'OFF')
+ self.define('SPDLOG_BUILD_TESTS', self.run_tests),
+ self.define('SPDLOG_BUILD_EXAMPLE', self.run_tests)
])
return args
diff --git a/var/spack/repos/builtin/packages/strumpack/package.py b/var/spack/repos/builtin/packages/strumpack/package.py
index d6ffad3d3c..b8cf21116b 100644
--- a/var/spack/repos/builtin/packages/strumpack/package.py
+++ b/var/spack/repos/builtin/packages/strumpack/package.py
@@ -97,24 +97,21 @@ class Strumpack(CMakePackage, CudaPackage, ROCmPackage):
def cmake_args(self):
spec = self.spec
- def on_off(varstr):
- return 'ON' if varstr in spec else 'OFF'
-
args = [
- '-DSTRUMPACK_USE_MPI=%s' % on_off('+mpi'),
- '-DSTRUMPACK_USE_OPENMP=%s' % on_off('+openmp'),
- '-DSTRUMPACK_USE_CUDA=%s' % on_off('+cuda'),
- '-DSTRUMPACK_USE_HIP=%s' % on_off('+rocm'),
- '-DTPL_ENABLE_PARMETIS=%s' % on_off('+parmetis'),
- '-DTPL_ENABLE_SCOTCH=%s' % on_off('+scotch'),
- '-DTPL_ENABLE_BPACK=%s' % on_off('+butterflypack'),
- '-DSTRUMPACK_COUNT_FLOPS=%s' % on_off('+count_flops'),
- '-DSTRUMPACK_TASK_TIMERS=%s' % on_off('+task_timers'),
- '-DSTRUMPACK_DEV_TESTING=%s' % on_off('+build_dev_tests'),
- '-DSTRUMPACK_BUILD_TESTS=%s' % on_off('+build_tests'),
+ self.define_from_variant('STRUMPACK_USE_MPI', 'mpi'),
+ self.define_from_variant('STRUMPACK_USE_OPENMP', 'openmp'),
+ self.define_from_variant('STRUMPACK_USE_CUDA', 'cuda'),
+ self.define_from_variant('STRUMPACK_USE_HIP', 'rocm'),
+ self.define_from_variant('TPL_ENABLE_PARMETIS', 'parmetis'),
+ self.define_from_variant('TPL_ENABLE_SCOTCH', 'scotch'),
+ self.define_from_variant('TPL_ENABLE_BPACK', 'butterflypack'),
+ self.define_from_variant('STRUMPACK_COUNT_FLOPS', 'count_flops'),
+ self.define_from_variant('STRUMPACK_TASK_TIMERS', 'task_timers'),
+ self.define_from_variant('STRUMPACK_DEV_TESTING', 'build_dev_tests'),
+ self.define_from_variant('STRUMPACK_BUILD_TESTS', 'build_tests'),
'-DTPL_BLAS_LIBRARIES=%s' % spec['blas'].libs.joined(";"),
'-DTPL_LAPACK_LIBRARIES=%s' % spec['lapack'].libs.joined(";"),
- '-DBUILD_SHARED_LIBS=%s' % on_off('+shared')
+ self.define_from_variant('BUILD_SHARED_LIBS', 'shared')
]
if '+mpi' in spec:
@@ -130,7 +127,7 @@ class Strumpack(CMakePackage, CudaPackage, ROCmPackage):
'-DCMAKE_Fortran_COMPILER=%s' % spec['mpi'].mpifc
])
args.extend([
- '-DSTRUMPACK_C_INTERFACE=%s' % on_off('+c_interface'),
+ self.define_from_variant('STRUMPACK_C_INTERFACE', 'c_interface'),
])
if '+cuda' in spec:
diff --git a/var/spack/repos/builtin/packages/sundials/package.py b/var/spack/repos/builtin/packages/sundials/package.py
index 715824475a..498d4390fc 100644
--- a/var/spack/repos/builtin/packages/sundials/package.py
+++ b/var/spack/repos/builtin/packages/sundials/package.py
@@ -226,7 +226,7 @@ class Sundials(CMakePackage, CudaPackage, ROCmPackage):
# SUNDIALS solvers
for pkg in self.sun_solvers:
- args.extend(['-DBUILD_%s=%s' % (pkg, on_off('+' + pkg))])
+ args.append(self.define_from_variant('BUILD_' + pkg, pkg))
# precision
args.extend([
@@ -243,13 +243,13 @@ class Sundials(CMakePackage, CudaPackage, ROCmPackage):
args.extend(['-DSUNDIALS_INDEX_TYPE=int32_t'])
# Fortran interface
- args.extend(['-DF77_INTERFACE_ENABLE=%s' % on_off('+fcmix')])
- args.extend(['-DF2003_INTERFACE_ENABLE=%s' % on_off('+f2003')])
+ args.extend([self.define_from_variant('F77_INTERFACE_ENABLE', 'fcmix')])
+ args.extend([self.define_from_variant('F2003_INTERFACE_ENABLE', 'f2003')])
# library type
args.extend([
- '-DBUILD_SHARED_LIBS=%s' % on_off('+shared'),
- '-DBUILD_STATIC_LIBS=%s' % on_off('+static')
+ self.define_from_variant('BUILD_SHARED_LIBS', 'shared'),
+ self.define_from_variant('BUILD_STATIC_LIBS', 'static')
])
# generic (std-c) math libraries
@@ -259,14 +259,14 @@ class Sundials(CMakePackage, CudaPackage, ROCmPackage):
# Monitoring
args.extend([
- '-DSUNDIALS_BUILD_WITH_MONITORING=%s' % on_off('+monitoring')
+ self.define_from_variant('SUNDIALS_BUILD_WITH_MONITORING', 'monitoring')
])
# parallelism
args.extend([
- '-DMPI_ENABLE=%s' % on_off('+mpi'),
- '-DOPENMP_ENABLE=%s' % on_off('+openmp'),
- '-DPTHREAD_ENABLE=%s' % on_off('+pthread')
+ self.define_from_variant('MPI_ENABLE', 'mpi'),
+ self.define_from_variant('OPENMP_ENABLE', 'openmp'),
+ self.define_from_variant('PTHREAD_ENABLE', 'pthread')
])
if '+cuda' in spec:
@@ -423,8 +423,8 @@ class Sundials(CMakePackage, CudaPackage, ROCmPackage):
# Examples
if spec.satisfies('@3.0.0:'):
args.extend([
- '-DEXAMPLES_ENABLE_C=%s' % on_off('+examples'),
- '-DEXAMPLES_ENABLE_CXX=%s' % on_off('+examples'),
+ self.define_from_variant('EXAMPLES_ENABLE_C', 'examples'),
+ self.define_from_variant('EXAMPLES_ENABLE_CXX', 'examples'),
'-DEXAMPLES_ENABLE_CUDA=%s' % on_off('+examples+cuda'),
'-DEXAMPLES_ENABLE_F77=%s' % on_off('+examples+fcmix'),
'-DEXAMPLES_ENABLE_F90=%s' % on_off('+examples+fcmix'),
@@ -432,8 +432,8 @@ class Sundials(CMakePackage, CudaPackage, ROCmPackage):
])
else:
args.extend([
- '-DEXAMPLES_ENABLE=%s' % on_off('+examples'),
- '-DCXX_ENABLE=%s' % on_off('+examples'),
+ self.define_from_variant('EXAMPLES_ENABLE', 'examples'),
+ self.define_from_variant('CXX_ENABLE', 'examples'),
'-DF90_ENABLE=%s' % on_off('+examples+fcmix')
])
diff --git a/var/spack/repos/builtin/packages/symengine/package.py b/var/spack/repos/builtin/packages/symengine/package.py
index c99e85ce7f..ac13bfd0fc 100644
--- a/var/spack/repos/builtin/packages/symengine/package.py
+++ b/var/spack/repos/builtin/packages/symengine/package.py
@@ -66,15 +66,11 @@ class Symengine(CMakePackage):
'-DWITH_SYMENGINE_RCP:BOOL=ON',
'-DWITH_SYMENGINE_THREAD_SAFE:BOOL=%s' % (
'ON' if ('+thread_safe' or '+openmp') in spec else 'OFF'),
- '-DBUILD_TESTS:BOOL=%s' % (
- 'ON' if self.run_tests else 'OFF'),
+ self.define('BUILD_TESTS', self.run_tests),
'-DBUILD_BENCHMARKS:BOOL=ON',
- '-DWITH_LLVM:BOOL=%s' % (
- 'ON' if '+llvm' in spec else 'OFF'),
- '-DWITH_OPENMP:BOOL=%s' % (
- 'ON' if '+openmp' in spec else 'OFF'),
- '-DBUILD_SHARED_LIBS:BOOL=%s' % (
- 'ON' if '+shared' in spec else 'OFF'),
+ self.define_from_variant('WITH_LLVM', 'llvm'),
+ self.define_from_variant('WITH_OPENMP', 'openmp'),
+ self.define_from_variant('BUILD_SHARED_LIBS', 'shared'),
])
if sys.platform == 'darwin':
@@ -91,10 +87,8 @@ class Symengine(CMakePackage):
])
else:
options.extend([
- '-DWITH_MPC:BOOL=%s' % (
- 'ON' if '+mpc' in spec else 'OFF'),
- '-DWITH_MPFR:BOOL=%s' % (
- 'ON' if '+mpfr' in spec else 'OFF'),
+ self.define_from_variant('WITH_MPC', 'mpc'),
+ self.define_from_variant('WITH_MPFR', 'mpfr'),
])
if '+flint' in spec:
options.extend([
diff --git a/var/spack/repos/builtin/packages/tasmanian/package.py b/var/spack/repos/builtin/packages/tasmanian/package.py
index fca84f74ba..d11a973a06 100644
--- a/var/spack/repos/builtin/packages/tasmanian/package.py
+++ b/var/spack/repos/builtin/packages/tasmanian/package.py
@@ -111,20 +111,13 @@ class Tasmanian(CMakePackage, CudaPackage, ROCmPackage):
if '+xsdkflags' in spec and spec.satisfies('@:7.1'):
args = [
'-DUSE_XSDK_DEFAULTS:BOOL=ON',
- '-DXSDK_ENABLE_PYTHON:BOOL={0}'.format(
- 'ON' if '+python' in spec else 'OFF'),
- '-DTPL_ENABLE_MPI:BOOL={0}'.format(
- 'ON' if '+mpi' in spec else 'OFF'),
- '-DXSDK_ENABLE_OPENMP:BOOL={0}'.format(
- 'ON' if '+openmp' in spec else 'OFF'),
- '-DTPL_ENABLE_BLAS:BOOL={0}'.format(
- 'ON' if '+blas' in spec else 'OFF'),
- '-DXSDK_ENABLE_CUDA:BOOL={0}'.format(
- 'ON' if '+cuda' in spec else 'OFF'),
- '-DTPL_ENABLE_MAGMA:BOOL={0}'.format(
- 'ON' if '+magma' in spec else 'OFF'),
- '-DXSDK_ENABLE_FORTRAN:BOOL={0}'.format(
- 'ON' if '+fortran' in spec else 'OFF'), ]
+ self.define_from_variant('XSDK_ENABLE_PYTHON', 'python'),
+ self.define_from_variant('TPL_ENABLE_MPI', 'mpi'),
+ self.define_from_variant('XSDK_ENABLE_OPENMP', 'openmp'),
+ self.define_from_variant('TPL_ENABLE_BLAS', 'blas'),
+ self.define_from_variant('XSDK_ENABLE_CUDA', 'cuda'),
+ self.define_from_variant('TPL_ENABLE_MAGMA', 'magma'),
+ self.define_from_variant('XSDK_ENABLE_FORTRAN', 'fortran'), ]
else:
args = [
self.define_from_variant('Tasmanian_ENABLE_OPENMP', 'openmp'),
@@ -150,7 +143,6 @@ class Tasmanian(CMakePackage, CudaPackage, ROCmPackage):
# _CUBLAS and _CUDA were separate options prior to 6.0
# skipping _CUBLAS leads to peformance regression
if spec.satisfies('@:5.1'):
- args.append('-DTasmanian_ENABLE_CUBLAS={0}'.format(
- 'ON' if '+cuda' in spec else 'OFF'))
+ args.append(self.define_from_variant('Tasmanian_ENABLE_CUBLAS', 'cuda'))
return args
diff --git a/var/spack/repos/builtin/packages/tinyxml/package.py b/var/spack/repos/builtin/packages/tinyxml/package.py
index 4ce541c250..5cb26b4cb8 100644
--- a/var/spack/repos/builtin/packages/tinyxml/package.py
+++ b/var/spack/repos/builtin/packages/tinyxml/package.py
@@ -26,6 +26,4 @@ class Tinyxml(CMakePackage):
"CMakeLists.txt"), "CMakeLists.txt")
def cmake_args(self):
- spec = self.spec
- return [
- '-DBUILD_SHARED_LIBS=%s' % ('YES' if '+shared' in spec else 'NO')]
+ return [self.define_from_variant('BUILD_SHARED_LIBS', 'shared')]
diff --git a/var/spack/repos/builtin/packages/umap/package.py b/var/spack/repos/builtin/packages/umap/package.py
index c2a8f7e778..4d4fe5ed51 100644
--- a/var/spack/repos/builtin/packages/umap/package.py
+++ b/var/spack/repos/builtin/packages/umap/package.py
@@ -28,9 +28,8 @@ class Umap(CMakePackage):
variant('tests', default=False, description='Build test programs.')
def cmake_args(self):
- spec = self.spec
args = [
- "-DENABLE_LOGGING=%s" % ('On' if '+logging' in spec else 'Off'),
- "-DENABLE_TESTS=%s" % ('On' if '+tests' in spec else 'Off'),
+ self.define_from_variant('ENABLE_LOGGING', 'logging'),
+ self.define_from_variant('ENABLE_TESTS', 'tests'),
]
return args
diff --git a/var/spack/repos/builtin/packages/warpx/package.py b/var/spack/repos/builtin/packages/warpx/package.py
index 1e4179d453..45baa90143 100644
--- a/var/spack/repos/builtin/packages/warpx/package.py
+++ b/var/spack/repos/builtin/packages/warpx/package.py
@@ -99,36 +99,25 @@ class Warpx(CMakePackage):
spec = self.spec
args = [
- '-DBUILD_SHARED_LIBS:BOOL={0}'.format(
- 'ON' if '+shared' in spec else 'OFF'),
+ self.define_from_variant('BUILD_SHARED_LIBS', 'shared'),
'-DCMAKE_INSTALL_LIBDIR=lib',
# variants
- '-DWarpX_APP:BOOL={0}'.format(
- 'ON' if '+app' in spec else 'OFF'),
- '-DWarpX_ASCENT:BOOL={0}'.format(
- 'ON' if '+ascent' in spec else 'OFF'),
+ self.define_from_variant('WarpX_APP', 'app'),
+ self.define_from_variant('WarpX_ASCENT', 'ascent'),
'-DWarpX_COMPUTE={0}'.format(
spec.variants['compute'].value.upper()),
'-DWarpX_DIMS={0}'.format(
spec.variants['dims'].value.upper()),
- '-DWarpX_EB:BOOL={0}'.format(
- 'ON' if '+eb' in spec else 'OFF'),
- '-DWarpX_LIB:BOOL={0}'.format(
- 'ON' if '+lib' in spec else 'OFF'),
- '-DWarpX_MPI:BOOL={0}'.format(
- 'ON' if '+mpi' in spec else 'OFF'),
- '-DWarpX_MPI_THREAD_MULTIPLE:BOOL={0}'.format(
- 'ON' if '+mpithreadmultiple' in spec else 'OFF'),
- '-DWarpX_OPENPMD:BOOL={0}'.format(
- 'ON' if '+openpmd' in spec else 'OFF'),
+ self.define_from_variant('WarpX_EB', 'eb'),
+ self.define_from_variant('WarpX_LIB', 'lib'),
+ self.define_from_variant('WarpX_MPI', 'mpi'),
+ self.define_from_variant('WarpX_MPI_THREAD_MULTIPLE', 'mpithreadmultiple'),
+ self.define_from_variant('WarpX_OPENPMD', 'openpmd'),
'-DWarpX_PRECISION={0}'.format(
spec.variants['precision'].value.upper()),
- '-DWarpX_PSATD:BOOL={0}'.format(
- 'ON' if '+psatd' in spec else 'OFF'),
- '-DWarpX_QED:BOOL={0}'.format(
- 'ON' if '+qed' in spec else 'OFF'),
- '-DWarpX_QED_TABLE_GEN:BOOL={0}'.format(
- 'ON' if '+qedtablegen' in spec else 'OFF'),
+ self.define_from_variant('WarpX_PSATD', 'psatd'),
+ self.define_from_variant('WarpX_QED', 'qed'),
+ self.define_from_variant('WarpX_QED_TABLE_GEN', 'qedtablegen'),
]
return args
diff --git a/var/spack/repos/builtin/packages/wt/package.py b/var/spack/repos/builtin/packages/wt/package.py
index 9f3cd73d1e..ddf329455e 100644
--- a/var/spack/repos/builtin/packages/wt/package.py
+++ b/var/spack/repos/builtin/packages/wt/package.py
@@ -52,8 +52,6 @@ class Wt(CMakePackage):
depends_on('zlib', when='+zlib')
def cmake_args(self):
- spec = self.spec
-
cmake_args = [
'-DBUILD_EXAMPLES:BOOL=OFF',
'-DCONNECTOR_FCGI:BOOL=OFF',
@@ -61,17 +59,11 @@ class Wt(CMakePackage):
'-DENABLE_QT4:BOOL=OFF'
]
cmake_args.extend([
- '-DENABLE_SSL:BOOL={0}'.format((
- 'ON' if '+openssl' in spec else 'OFF')),
- '-DENABLE_HARU:BOOL={0}'.format((
- 'ON' if '+libharu' in spec else 'OFF')),
- '-DENABLE_PANGO:BOOL={0}'.format((
- 'ON' if '+pango' in spec else 'OFF')),
- '-DENABLE_SQLITE:BOOL={0}'.format((
- 'ON' if '+sqlite' in spec else 'OFF')),
- '-DENABLE_MYSQL:BOOL={0}'.format((
- 'ON' if '+mariadb' in spec else 'OFF')),
- '-DENABLE_POSTGRES:BOOL={0}'.format((
- 'ON' if '+postgres' in spec else 'OFF'))
+ self.define_from_variant('ENABLE_SSL', 'openssl'),
+ self.define_from_variant('ENABLE_HARU', 'libharu'),
+ self.define_from_variant('ENABLE_PANGO', 'pango'),
+ self.define_from_variant('ENABLE_SQLITE', 'sqlite'),
+ self.define_from_variant('ENABLE_MYSQL', 'mariadb'),
+ self.define_from_variant('ENABLE_POSTGRES', 'postgresql')
])
return cmake_args
diff --git a/var/spack/repos/builtin/packages/xeus/package.py b/var/spack/repos/builtin/packages/xeus/package.py
index 43ae7d598b..b4601508f5 100644
--- a/var/spack/repos/builtin/packages/xeus/package.py
+++ b/var/spack/repos/builtin/packages/xeus/package.py
@@ -37,8 +37,7 @@ class Xeus(CMakePackage):
def cmake_args(self):
args = [
- '-DBUILD_EXAMPLES:BOOL=%s' % (
- 'ON' if '+examples' in self.spec else 'OFF')
+ self.define_from_variant('BUILD_EXAMPLES', 'examples')
]
return args
diff --git a/var/spack/repos/builtin/packages/xsdktrilinos/package.py b/var/spack/repos/builtin/packages/xsdktrilinos/package.py
index 75b570d213..3d76808890 100644
--- a/var/spack/repos/builtin/packages/xsdktrilinos/package.py
+++ b/var/spack/repos/builtin/packages/xsdktrilinos/package.py
@@ -52,15 +52,12 @@ class Xsdktrilinos(CMakePackage):
'-DxSDKTrilinos_ENABLE_TESTS:BOOL=ON',
'-DxSDKTrilinos_ENABLE_EXAMPLES:BOOL=ON',
'-DTrilinos_INSTALL_DIR=%s' % spec['trilinos'].prefix,
- '-DBUILD_SHARED_LIBS:BOOL=%s' % (
- 'ON' if '+shared' in spec else 'OFF'),
+ self.define_from_variant('BUILD_SHARED_LIBS', 'shared'),
'-DTPL_ENABLE_MPI:BOOL=ON',
'-DMPI_BASE_DIR:PATH=%s' % spec['mpi'].prefix,
'-DxSDKTrilinos_ENABLE_CXX11:BOOL=ON',
- '-DTPL_ENABLE_HYPRE:BOOL=%s' % (
- 'ON' if '+hypre' in spec else 'OFF'),
- '-DTPL_ENABLE_PETSC:BOOL=%s' % (
- 'ON' if '+petsc' in spec else 'OFF'),
+ self.define_from_variant('TPL_ENABLE_HYPRE', 'hypre'),
+ self.define_from_variant('TPL_ENABLE_PETSC', 'petsc'),
'-DCMAKE_INSTALL_NAME_DIR:PATH=%s/lib' % self.prefix
])
diff --git a/var/spack/repos/builtin/packages/xsimd/package.py b/var/spack/repos/builtin/packages/xsimd/package.py
index cc760fcedf..8f61d23581 100644
--- a/var/spack/repos/builtin/packages/xsimd/package.py
+++ b/var/spack/repos/builtin/packages/xsimd/package.py
@@ -32,8 +32,7 @@ class Xsimd(CMakePackage):
def cmake_args(self):
args = [
- '-DBUILD_TESTS:BOOL={0}'.format(
- 'ON' if self.run_tests else 'OFF')
+ self.define('BUILD_TESTS', self.run_tests)
]
return args
diff --git a/var/spack/repos/builtin/packages/xtensor/package.py b/var/spack/repos/builtin/packages/xtensor/package.py
index ccead51428..835e1080ca 100644
--- a/var/spack/repos/builtin/packages/xtensor/package.py
+++ b/var/spack/repos/builtin/packages/xtensor/package.py
@@ -47,15 +47,10 @@ class Xtensor(CMakePackage):
# untested: conflicts('%pgi@:14')
def cmake_args(self):
- spec = self.spec
-
args = [
- '-DBUILD_TESTS:BOOL={0}'.format(
- 'ON' if self.run_tests else 'OFF'),
- '-DXTENSOR_USE_XSIMD:BOOL={0}'.format(
- 'ON' if '+xsimd' in spec else 'OFF'),
- '-DXTENSOR_USE_TBB:BOOL={0}'.format(
- 'ON' if '+tbb' in spec else 'OFF')
+ self.define('BUILD_TESTS', self.run_tests),
+ self.define_from_variant('XTENSOR_USE_XSIMD', 'xsimd'),
+ self.define_from_variant('XTENSOR_USE_TBB', 'tbb')
]
return args