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.
This commit is contained in:
parent
f9617b2ad8
commit
a779e87442
1 changed files with 40 additions and 2 deletions
|
@ -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 @@ def cmake_args(self):
|
|||
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 @@ def cmake_args(self):
|
|||
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):
|
||||
|
|
Loading…
Reference in a new issue