Skip to content
Snippets Groups Projects
Commit b3ba45af authored by Adam J. Stewart's avatar Adam J. Stewart Committed by Todd Gamblin
Browse files

Various improvements to H5hut (#2636)

parent c89de04f
No related branches found
No related tags found
No related merge requests found
...@@ -26,45 +26,50 @@ ...@@ -26,45 +26,50 @@
from spack import * from spack import *
class H5hut(Package): class H5hut(AutotoolsPackage):
"""H5hut (HDF5 Utility Toolkit) """H5hut (HDF5 Utility Toolkit).
High-Performance I/O Library for Particle-based Simulations High-Performance I/O Library for Particle-based Simulations."""
"""
homepage = "https://amas.psi.ch/H5hut/" homepage = "https://amas.psi.ch/H5hut/"
url = "https://amas.psi.ch/H5hut/raw-attachment/wiki/DownloadSources/H5hut-1.99.13.tar.gz" url = "https://amas.psi.ch/H5hut/raw-attachment/wiki/DownloadSources/H5hut-1.99.13.tar.gz"
version("1.99.13", "2a07a449afe50534de006ac6954a421a") version('1.99.13', '2a07a449afe50534de006ac6954a421a')
variant("fortran", default=True, description="Enable Fortran support") variant('fortran', default=True, description='Enable Fortran support')
variant("mpi", default=True, description="Enable MPI support") variant('mpi', default=True, description='Enable MPI support')
depends_on("autoconf @2.60:", type="build") depends_on('mpi', when='+mpi')
depends_on("automake", type="build")
depends_on("hdf5 +mpi", when="+mpi")
depends_on("hdf5 @1.8:")
# h5hut +mpi uses the obsolete function H5Pset_fapl_mpiposix: # h5hut +mpi uses the obsolete function H5Pset_fapl_mpiposix:
depends_on("hdf5 @:1.8.12", when="+mpi") depends_on('hdf5@1.8:1.8.12+mpi', when='+mpi')
depends_on("libtool", type="build") depends_on('hdf5@1.8:', when='~mpi')
depends_on("mpi", when="+mpi")
def install(self, spec, prefix): # If built in parallel, the following error message occurs:
autogen = Executable("./autogen.sh") # install: .libs/libH5hut.a: No such file or directory
autogen() parallel = False
configopts = ["--prefix={0}".format(prefix)]
if "+fortran" in spec:
if not self.compiler.fc:
raise RuntimeError(
"Cannot build Fortran variant without a Fortran compiler")
configopts.append("--enable-fortran")
if "+mpi" in spec:
configopts.extend([
"--enable-parallel",
"CC=%s" % spec["mpi"].mpicc,
"CXX=%s" % spec["mpi"].mpicxx])
if "+fortran" in spec:
configopts.append("FC=%s" % spec["mpi"].mpifc)
configure(*configopts)
make() @AutotoolsPackage.precondition('configure')
make("install") def validate(self):
"""Checks if Fortran compiler is available."""
if '+fortran' in self.spec and not self.compiler.fc:
raise RuntimeError(
'Cannot build Fortran variant without a Fortran compiler.')
def configure_args(self):
spec = self.spec
config_args = ['--enable-shared']
if '+fortran' in spec:
config_args.append('--enable-fortran')
if '+mpi' in spec:
config_args.extend([
'--enable-parallel',
'CC={0}'.format(spec['mpi'].mpicc),
'CXX={0}'.format(spec['mpi'].mpicxx)
])
if '+fortran' in spec:
config_args.append('FC={0}'.format(spec['mpi'].mpifc))
return config_args
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment