summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMichael Kuron <mkuron@users.noreply.github.com>2017-03-25 20:27:52 +0100
committerAdam J. Stewart <ajstewart426@gmail.com>2017-03-25 14:27:52 -0500
commit55300d1181cb07f62f9dc7c6cf40bef38e9dffa7 (patch)
tree43b56c01fa14d717afdb94bcdb706293def93b44
parent3af971165a4e6a682fb40fcef0e9c68e5c905d8c (diff)
downloadspack-55300d1181cb07f62f9dc7c6cf40bef38e9dffa7.tar.gz
spack-55300d1181cb07f62f9dc7c6cf40bef38e9dffa7.tar.bz2
spack-55300d1181cb07f62f9dc7c6cf40bef38e9dffa7.tar.xz
spack-55300d1181cb07f62f9dc7c6cf40bef38e9dffa7.zip
pnfft: new package (#2646)
* pnfft: new package * Convert some packages with overridden install from AutotoolsPackage to Package * pnfft: fix URL * Switch FFTW-derived packages back to AutotoolsPackage * Disable unneeded build phases in FFTW and derived packages * Separate build phases for FFTW and derived packages * Fix broken merge * fftw: pfft_patches for 3.3.6 * fftw: address @adamjstewart’s review comments
-rw-r--r--var/spack/repos/builtin/packages/fftw/package.py91
-rw-r--r--var/spack/repos/builtin/packages/nfft/package.py57
-rw-r--r--var/spack/repos/builtin/packages/pfft/package.py54
-rw-r--r--var/spack/repos/builtin/packages/pnfft/package.py87
4 files changed, 231 insertions, 58 deletions
diff --git a/var/spack/repos/builtin/packages/fftw/package.py b/var/spack/repos/builtin/packages/fftw/package.py
index 90252a0d32..43892465db 100644
--- a/var/spack/repos/builtin/packages/fftw/package.py
+++ b/var/spack/repos/builtin/packages/fftw/package.py
@@ -25,7 +25,7 @@
from spack import *
-class Fftw(Package):
+class Fftw(AutotoolsPackage):
"""FFTW is a C subroutine library for computing the discrete Fourier
transform (DFT) in one or more dimensions, of arbitrary input
size, and of both real and complex data (as well as of even/odd
@@ -41,13 +41,16 @@ class Fftw(Package):
version('3.3.4', '2edab8c06b24feeb3b82bbb3ebf3e7b3')
version('2.1.5', '8d16a84f3ca02a785ef9eb36249ba433')
- patch('pfft-3.3.5.patch', when="@3.3.5+pfft_patches", level=0)
+ patch('pfft-3.3.5.patch', when="@3.3.5:+pfft_patches", level=0)
patch('pfft-3.3.4.patch', when="@3.3.4+pfft_patches", level=0)
variant(
'float', default=True,
description='Produces a single precision version of the library')
variant(
+ 'double', default=True,
+ description='Produces a double precision version of the library')
+ variant(
'long_double', default=True,
description='Produces a long double precision version of the library')
variant(
@@ -63,8 +66,14 @@ class Fftw(Package):
depends_on('mpi', when='+mpi')
depends_on('automake', type='build', when='+pfft_patches')
depends_on('autoconf', type='build', when='+pfft_patches')
+ depends_on('libtool', type='build', when='+pfft_patches')
- def install(self, spec, prefix):
+ def autoreconf(self, spec, prefix):
+ if '+pfft_patches' in spec:
+ autoreconf = which('autoreconf')
+ autoreconf('-ifv')
+
+ def configure(self, spec, prefix):
# Base options
options = [
'--prefix={0}'.format(prefix),
@@ -90,9 +99,6 @@ class Fftw(Package):
options.insert(0, 'CFLAGS=' + self.compiler.openmp_flag)
if '+mpi' in spec:
options.append('--enable-mpi')
- if '+pfft_patches' in spec:
- autoreconf = which('autoreconf')
- autoreconf('-ifv')
# SIMD support
# TODO: add support for more architectures
@@ -102,29 +108,60 @@ class Fftw(Package):
float_options.append('--enable-sse2')
double_options.append('--enable-sse2')
- # Build double precision
- configure(*(options + double_options))
- make()
- if self.run_tests:
- make("check")
- make("install")
+ configure = Executable('../configure')
- # Build float/long double/quad variants
+ # Build double/float/long double/quad variants
+ if '+double' in spec:
+ with working_dir('double', create=True):
+ configure(*(options + double_options))
if '+float' in spec:
- configure('--enable-float', *(options + float_options))
- make()
- if self.run_tests:
- make("check")
- make("install")
+ with working_dir('float', create=True):
+ configure('--enable-float', *(options + float_options))
if spec.satisfies('@3:+long_double'):
- configure('--enable-long-double', *options)
- make()
- if self.run_tests:
- make("check")
- make("install")
+ with working_dir('long-double', create=True):
+ configure('--enable-long-double', *options)
if spec.satisfies('@3:+quad'):
- configure('--enable-quad-precision', *options)
- make()
- if self.run_tests:
+ with working_dir('quad', create=True):
+ configure('--enable-quad-precision', *options)
+
+ def build(self, spec, prefix):
+ if '+double' in spec:
+ with working_dir('double'):
+ make()
+ if '+float' in spec:
+ with working_dir('float'):
+ make()
+ if '+long_double' in spec:
+ with working_dir('long-double'):
+ make()
+ if '+quad' in spec:
+ with working_dir('quad'):
+ make()
+
+ def check(self, spec, prefix):
+ if '+double' in spec:
+ with working_dir('double'):
+ make("check")
+ if '+float' in spec:
+ with working_dir('float'):
make("check")
- make("install")
+ if '+long_double' in spec:
+ with working_dir('long-double'):
+ make("check")
+ if '+quad' in spec:
+ with working_dir('quad'):
+ make("check")
+
+ def install(self, spec, prefix):
+ if '+double' in spec:
+ with working_dir('double'):
+ make("install")
+ if '+float' in spec:
+ with working_dir('float'):
+ make("install")
+ if '+long_double' in spec:
+ with working_dir('long-double'):
+ make("install")
+ if '+quad' in spec:
+ with working_dir('quad'):
+ make("install")
diff --git a/var/spack/repos/builtin/packages/nfft/package.py b/var/spack/repos/builtin/packages/nfft/package.py
index 522191d89a..a137dcf019 100644
--- a/var/spack/repos/builtin/packages/nfft/package.py
+++ b/var/spack/repos/builtin/packages/nfft/package.py
@@ -37,27 +37,50 @@ class Nfft(AutotoolsPackage):
depends_on('fftw')
- def install(self, spec, prefix):
+ def configure(self, spec, prefix):
options = ['--prefix={0}'.format(prefix)]
- make("distclean")
- configure(*options)
- make()
- if self.run_tests:
- make("check")
- make("install")
+ configure = Executable('../configure')
+
+ if '+double' in spec['fftw']:
+ with working_dir('double', create=True):
+ configure(*options)
+ if '+float' in spec['fftw']:
+ with working_dir('float', create=True):
+ configure('--enable-float', *options)
+ if '+long_double' in spec['fftw']:
+ with working_dir('long-double', create=True):
+ configure('--enable-long-double', *options)
+
+ def build(self, spec, prefix):
+ if '+double' in spec['fftw']:
+ with working_dir('double'):
+ make()
+ if '+float' in spec['fftw']:
+ with working_dir('float'):
+ make()
+ if '+long_double' in spec['fftw']:
+ with working_dir('long-double'):
+ make()
+ def check(self, spec, prefix):
+ if '+double' in spec['fftw']:
+ with working_dir('double'):
+ make("check")
if '+float' in spec['fftw']:
- make("distclean")
- configure('--enable-float', *options)
- make()
- if self.run_tests:
+ with working_dir('float'):
make("check")
- make("install")
if '+long_double' in spec['fftw']:
- make("distclean")
- configure('--enable-long-double', *options)
- make()
- if self.run_tests:
+ with working_dir('long-double'):
make("check")
- make("install")
+
+ def install(self, spec, prefix):
+ if '+double' in spec['fftw']:
+ with working_dir('double'):
+ make("install")
+ if '+float' in spec['fftw']:
+ with working_dir('float'):
+ make("install")
+ if '+long_double' in spec['fftw']:
+ with working_dir('long-double'):
+ make("install")
diff --git a/var/spack/repos/builtin/packages/pfft/package.py b/var/spack/repos/builtin/packages/pfft/package.py
index 575f0af3c5..f46526be37 100644
--- a/var/spack/repos/builtin/packages/pfft/package.py
+++ b/var/spack/repos/builtin/packages/pfft/package.py
@@ -39,26 +39,52 @@ class Pfft(AutotoolsPackage):
depends_on('fftw+mpi+pfft_patches')
depends_on('mpi')
- def install(self, spec, prefix):
+ def configure(self, spec, prefix):
options = ['--prefix={0}'.format(prefix)]
if not self.compiler.f77 or not self.compiler.fc:
options.append("--disable-fortran")
- configure(*options)
- make()
- if self.run_tests:
- make("check")
- make("install")
+ configure = Executable('../configure')
+
+ if '+double' in spec['fftw']:
+ with working_dir('double', create=True):
+ configure(*options)
+ if '+float' in spec['fftw']:
+ with working_dir('float', create=True):
+ configure('--enable-float', *options)
+ if '+long_double' in spec['fftw']:
+ with working_dir('long-double', create=True):
+ configure('--enable-long-double', *options)
+
+ def build(self, spec, prefix):
+ if '+double' in spec['fftw']:
+ with working_dir('double'):
+ make()
+ if '+float' in spec['fftw']:
+ with working_dir('float'):
+ make()
+ if '+long_double' in spec['fftw']:
+ with working_dir('long-double'):
+ make()
+ def check(self, spec, prefix):
+ if '+double' in spec['fftw']:
+ with working_dir('double'):
+ make("check")
if '+float' in spec['fftw']:
- configure('--enable-float', *options)
- make()
- if self.run_tests:
+ with working_dir('float'):
make("check")
- make("install")
if '+long_double' in spec['fftw']:
- configure('--enable-long-double', *options)
- make()
- if self.run_tests:
+ with working_dir('long-double'):
make("check")
- make("install")
+
+ def install(self, spec, prefix):
+ if '+double' in spec['fftw']:
+ with working_dir('double'):
+ make("install")
+ if '+float' in spec['fftw']:
+ with working_dir('float'):
+ make("install")
+ if '+long_double' in spec['fftw']:
+ with working_dir('long-double'):
+ make("install")
diff --git a/var/spack/repos/builtin/packages/pnfft/package.py b/var/spack/repos/builtin/packages/pnfft/package.py
new file mode 100644
index 0000000000..772bd8f195
--- /dev/null
+++ b/var/spack/repos/builtin/packages/pnfft/package.py
@@ -0,0 +1,87 @@
+##############################################################################
+# Copyright (c) 2013-2016, Lawrence Livermore National Security, LLC.
+# Produced at the Lawrence Livermore National Laboratory.
+#
+# This file is part of Spack.
+# Created by Todd Gamblin, tgamblin@llnl.gov, All rights reserved.
+# LLNL-CODE-647188
+#
+# For details, see https://github.com/llnl/spack
+# Please also see the LICENSE file for our notice and the LGPL.
+#
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU Lesser General Public License (as
+# published by the Free Software Foundation) version 2.1, February 1999.
+#
+# This program is distributed in the hope that it will be useful, but
+# WITHOUT ANY WARRANTY; without even the IMPLIED WARRANTY OF
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the terms and
+# conditions of the GNU Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this program; if not, write to the Free Software
+# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+##############################################################################
+from spack import *
+
+
+class Pnfft(AutotoolsPackage):
+ """PNFFT is a parallel software library for the calculation of
+ three-dimensional nonequispaced FFTs."""
+
+ homepage = "https://www-user.tu-chemnitz.de/~potts/workgroup/pippig/software.php.en"
+ url = "https://www-user.tu-chemnitz.de/~potts/workgroup/pippig/software/pnfft-1.0.7-alpha.tar.gz"
+
+ version('1.0.7-alpha', '5caa7f214eed99de2281043ca2367e9e')
+
+ depends_on('pfft')
+
+ def configure(self, spec, prefix):
+ options = ['--prefix={0}'.format(prefix)]
+ if not self.compiler.f77 or not self.compiler.fc:
+ options.append("--disable-fortran")
+
+ configure = Executable('../configure')
+
+ if '+double' in spec['fftw']:
+ with working_dir('double', create=True):
+ configure(*options)
+ if '+float' in spec['fftw']:
+ with working_dir('float', create=True):
+ configure('--enable-float', *options)
+ if '+long_double' in spec['fftw']:
+ with working_dir('long-double', create=True):
+ configure('--enable-long-double', *options)
+
+ def build(self, spec, prefix):
+ if '+double' in spec['fftw']:
+ with working_dir('double'):
+ make()
+ if '+float' in spec['fftw']:
+ with working_dir('float'):
+ make()
+ if '+long_double' in spec['fftw']:
+ with working_dir('long-double'):
+ make()
+
+ def check(self, spec, prefix):
+ if '+double' in spec['fftw']:
+ with working_dir('double'):
+ make("check")
+ if '+float' in spec['fftw']:
+ with working_dir('float'):
+ make("check")
+ if '+long_double' in spec['fftw']:
+ with working_dir('long-double'):
+ make("check")
+
+ def install(self, spec, prefix):
+ if '+double' in spec['fftw']:
+ with working_dir('double'):
+ make("install")
+ if '+float' in spec['fftw']:
+ with working_dir('float'):
+ make("install")
+ if '+long_double' in spec['fftw']:
+ with working_dir('long-double'):
+ make("install")