diff options
author | Adam J. Stewart <ajstewart426@gmail.com> | 2016-12-19 19:06:14 -0600 |
---|---|---|
committer | Todd Gamblin <tgamblin@llnl.gov> | 2016-12-19 17:06:14 -0800 |
commit | b3ba45afa96c12bce96a8084d697cc68bc92f7c8 (patch) | |
tree | 4fdc3a4d2b0e608007089d615d3672402328a1bc | |
parent | c89de04f40aa19c33a5f0279793918ac6fe217fd (diff) | |
download | spack-b3ba45afa96c12bce96a8084d697cc68bc92f7c8.tar.gz spack-b3ba45afa96c12bce96a8084d697cc68bc92f7c8.tar.bz2 spack-b3ba45afa96c12bce96a8084d697cc68bc92f7c8.tar.xz spack-b3ba45afa96c12bce96a8084d697cc68bc92f7c8.zip |
Various improvements to H5hut (#2636)
-rw-r--r-- | var/spack/repos/builtin/packages/h5hut/package.py | 71 |
1 files changed, 38 insertions, 33 deletions
diff --git a/var/spack/repos/builtin/packages/h5hut/package.py b/var/spack/repos/builtin/packages/h5hut/package.py index a80a9e1082..22146372dc 100644 --- a/var/spack/repos/builtin/packages/h5hut/package.py +++ b/var/spack/repos/builtin/packages/h5hut/package.py @@ -26,45 +26,50 @@ from spack import * -class H5hut(Package): - """H5hut (HDF5 Utility Toolkit) - High-Performance I/O Library for Particle-based Simulations - """ +class H5hut(AutotoolsPackage): + """H5hut (HDF5 Utility Toolkit). + High-Performance I/O Library for Particle-based Simulations.""" homepage = "https://amas.psi.ch/H5hut/" 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("mpi", default=True, description="Enable MPI support") + variant('fortran', default=True, description='Enable Fortran support') + variant('mpi', default=True, description='Enable MPI support') - depends_on("autoconf @2.60:", type="build") - depends_on("automake", type="build") - depends_on("hdf5 +mpi", when="+mpi") - depends_on("hdf5 @1.8:") + depends_on('mpi', when='+mpi') # h5hut +mpi uses the obsolete function H5Pset_fapl_mpiposix: - depends_on("hdf5 @:1.8.12", when="+mpi") - depends_on("libtool", type="build") - depends_on("mpi", when="+mpi") + depends_on('hdf5@1.8:1.8.12+mpi', when='+mpi') + depends_on('hdf5@1.8:', when='~mpi') - def install(self, spec, prefix): - autogen = Executable("./autogen.sh") - autogen() - 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) + # If built in parallel, the following error message occurs: + # install: .libs/libH5hut.a: No such file or directory + parallel = False - make() - make("install") + @AutotoolsPackage.precondition('configure') + 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 |