cp2k: update to 4.1 + update of dependencies (#3561)

* libint: updated version, ported to AutotoolsPackage

* elpa: updated version, ported to AutotoolsPackage

* wannier90: updated version, ported to MakefilePackage

* pexsi: updated version, ported to MakefilePackage

* cp2k: updated version, removed wannier 90 from dependencies if cp2k@4.1

* plumed: updated version

Modifications:

* modules has been turned into a single variant, as different versions
  have different modules available
* added dictionaries for patches

* netlib-scalapack: ported to CMakePackage
This commit is contained in:
Massimiliano Culpo
2017-03-30 16:46:05 +02:00
committed by Adam J. Stewart
parent 73f78cb8c4
commit f9c0348891
8 changed files with 160 additions and 122 deletions

View File

@@ -29,7 +29,7 @@
from spack import *
class Wannier90(Package):
class Wannier90(MakefilePackage):
"""Wannier90 calculates maximally-localised Wannier functions (MLWFs).
Wannier90 is released under the GNU General Public License.
@@ -37,6 +37,7 @@ class Wannier90(Package):
homepage = 'http://wannier.org'
url = 'http://wannier.org/code/wannier90-2.0.1.tar.gz'
version('2.1.0', '07a81c002b41d6d0f97857e55c57d769')
version('2.0.1', '4edd742506eaba93317249d33261fb22')
depends_on('mpi')
@@ -45,7 +46,23 @@ class Wannier90(Package):
parallel = False
def install(self, spec, prefix):
build_targets = [
'wannier', 'post', 'lib', 'w90chk2chk', 'w90vdw', 'w90pov'
]
@property
def makefile_name(self):
# Older versions use 'make.sys'
filename = 'make.sys'
# While newer search for 'make.inc'
if self.spec.satisfies('@2.1.0:'):
filename = 'make.inc'
abspath = join_path(self.stage.source_path, filename)
return abspath
def edit(self, spec, prefix):
lapack = self.spec['lapack'].libs
blas = self.spec['blas'].libs
@@ -54,57 +71,46 @@ def install(self, spec, prefix):
'@MPIF90': self.spec['mpi'].mpifc,
'@LIBS': (lapack + blas).joined()
}
#######
# TODO : this part is replicated in PEXSI
# TODO : and may be a common pattern for Editable Makefiles
# TODO : see #1186
template = join_path(
os.path.dirname(inspect.getmodule(self).__file__),
'make.sys'
)
makefile = join_path(
self.stage.source_path,
'make.sys'
)
shutil.copy(template, makefile)
shutil.copy(template, self.makefile_name)
for key, value in substitutions.items():
filter_file(key, value, makefile)
######
filter_file(key, value, self.makefile_name)
def install(self, spec, prefix):
make('wannier')
mkdirp(self.prefix.bin)
mkdirp(self.prefix.lib)
install(
join_path(self.stage.source_path, 'wannier90.x'),
join_path(self.prefix.bin, 'wannier90.x')
)
make('post')
install(
join_path(self.stage.source_path, 'postw90.x'),
join_path(self.prefix.bin, 'postw90.x')
)
make('lib')
mkdirp(self.prefix.lib)
install(
join_path(self.stage.source_path, 'libwannier.a'),
join_path(self.prefix.lib, 'libwannier.a')
)
make('w90chk2chk')
install(
join_path(self.stage.source_path, 'w90chk2chk.x'),
join_path(self.prefix.bin, 'w90chk2chk.x')
)
make('w90vdw')
install(
join_path(self.stage.source_path, 'utility', 'w90vdw', 'w90vdw.x'),
join_path(self.prefix.bin, 'w90vdw.x')
)
make('w90pov')
install(
join_path(self.stage.source_path, 'utility', 'w90pov', 'w90pov'),
join_path(self.prefix.bin, 'w90pov')