summaryrefslogtreecommitdiff
path: root/var
diff options
context:
space:
mode:
authorTristan Carel <tristan.carel@gmail.com>2018-09-05 20:01:45 +0200
committerTodd Gamblin <tgamblin@llnl.gov>2018-09-05 11:01:45 -0700
commita779e8744240c219e78ee5e8c468b68616451396 (patch)
tree238917fcbe0d5bf9f8e9b077f23654234dd359ff /var
parentf9617b2ad8bbb12bbd3bda0d2cd8d1856e2c7fa8 (diff)
downloadspack-a779e8744240c219e78ee5e8c468b68616451396.tar.gz
spack-a779e8744240c219e78ee5e8c468b68616451396.tar.bz2
spack-a779e8744240c219e78ee5e8c468b68616451396.tar.xz
spack-a779e8744240c219e78ee5e8c468b68616451396.zip
omega-h: add versions and variants (#9169)
* add 5 most recent versions and git master branch * add trilinos, gmodel, throw, examples, optimize, symbols, and warnings variants * disable XSDK so that Trilinos dependencies are found.
Diffstat (limited to 'var')
-rw-r--r--var/spack/repos/builtin/packages/omega-h/package.py42
1 files changed, 40 insertions, 2 deletions
diff --git a/var/spack/repos/builtin/packages/omega-h/package.py b/var/spack/repos/builtin/packages/omega-h/package.py
index 5eb7f47546..210b2befdf 100644
--- a/var/spack/repos/builtin/packages/omega-h/package.py
+++ b/var/spack/repos/builtin/packages/omega-h/package.py
@@ -34,18 +34,43 @@ class OmegaH(CMakePackage):
homepage = "https://github.com/ibaned/omega_h"
url = "https://github.com/ibaned/omega_h/archive/v9.13.4.tar.gz"
+ git = "https://github.com/ibaned/omega_h.git"
- version('9.13.4', '035f9986ec07ad97ae0aa1e171872307')
+ version('develop', branch='master')
+ version('9.15.0', sha256='342a506a0ff22f6cac759862efdcf34e360110f7901eb9b4c5de8afe38741522')
+ version('9.14.0', sha256='035d0f47142f965a57818d1cb6c5c00b5ae6b5a0178b67b0bc9177fa99ba083d')
+ version('9.13.14', sha256='f617dfd024c9cc323e56800ca23df3386bfa37e1b9bd378847d1f5d32d2b8e5d')
+ version('9.13.13', sha256='753702edf4bda9ae57ea21f09ca071e341604a468d8c86468c9aebba049f581c')
variant('shared', default=True, description='Build shared libraries')
variant('mpi', default=True, description='Activates MPI support')
variant('zlib', default=True, description='Activates ZLib support')
+ variant('trilinos', default=True, description='Use Teuchos and Kokkos')
+ variant('build_type', default='')
+ variant('gmodel', default=True, description='Gmsh model generation library')
+ variant('throw', default=False, description='Errors throw exceptions instead of abort')
+ variant('examples', default=False, description='Compile examples')
+ variant('optimize', default=True, description='Compile C++ with optimization')
+ variant('symbols', default=True, description='Compile C++ with debug symbols')
+ variant('warnings', default=True, description='Compile C++ with warnings')
+ depends_on('gmodel', when='+gmodel')
+ depends_on('gmsh', when='+examples', type='build')
depends_on('mpi', when='+mpi')
+ depends_on('trilinos +kokkos +teuchos', when='+trilinos')
depends_on('zlib', when='+zlib')
+ def _bob_options(self):
+ cmake_var_prefix = self.name.capitalize() + '_CXX_'
+ for variant in ['optimize', 'symbols', 'warnings']:
+ cmake_var = cmake_var_prefix + variant.upper()
+ if '+' + variant in self.spec:
+ yield '-D' + cmake_var + ':BOOL=ON'
+ else:
+ yield '-D' + cmake_var + ':BOOL=FALSE'
+
def cmake_args(self):
- args = ['-DUSE_XSDK_DEFAULTS:BOOL=ON']
+ args = ['-DUSE_XSDK_DEFAULTS:BOOL=OFF']
if '+shared' in self.spec:
args.append('-DBUILD_SHARED_LIBS:BOOL=ON')
else:
@@ -56,6 +81,10 @@ class OmegaH(CMakePackage):
self.spec['mpi'].mpicxx))
else:
args.append('-DOmega_h_USE_MPI:BOOL=OFF')
+ if '+trilinos' in self.spec:
+ args.append('-DOmega_h_USE_Trilinos:BOOL=ON')
+ if '+gmodel' in self.spec:
+ args.append('-DOmega_h_USE_Gmodel:BOOL=ON')
if '+zlib' in self.spec:
args.append('-DTPL_ENABLE_ZLIB:BOOL=ON')
args.append('-DTPL_ZLIB_INCLUDE_DIRS:STRING={0}'.format(
@@ -64,6 +93,15 @@ class OmegaH(CMakePackage):
self.spec['zlib'].libs))
else:
args.append('-DTPL_ENABLE_ZLIB:BOOL=OFF')
+ if '+examples' in self.spec:
+ args.append('-DOmega_h_EXAMPLES:BOOL=ON')
+ else:
+ args.append('-DOmega_h_EXAMPLES:BOOL=OFF')
+ if '+throw' in self.spec:
+ args.append('-DOmega_h_THROW:BOOL=ON')
+ else:
+ args.append('-DOmega_h_THROW:BOOL=OFF')
+ args += list(self._bob_options())
return args
def flag_handler(self, name, flags):