libceed: remove custom phases, slight refactor of variants (#29970)
This commit is contained in:

committed by
GitHub

parent
8deb50fea5
commit
271f0c024a
@@ -6,11 +6,11 @@
|
|||||||
from spack import *
|
from spack import *
|
||||||
|
|
||||||
|
|
||||||
class Libceed(Package, CudaPackage, ROCmPackage):
|
class Libceed(MakefilePackage, CudaPackage, ROCmPackage):
|
||||||
"""The CEED API Library: Code for Efficient Extensible Discretizations."""
|
"""The CEED API Library: Code for Efficient Extensible Discretizations."""
|
||||||
|
|
||||||
homepage = "https://github.com/CEED/libCEED"
|
homepage = "https://github.com/CEED/libCEED"
|
||||||
git = "https://github.com/CEED/libCEED.git"
|
git = "https://github.com/CEED/libCEED.git"
|
||||||
|
|
||||||
maintainers = ['jedbrown', 'v-dobrev', 'tzanio']
|
maintainers = ['jedbrown', 'v-dobrev', 'tzanio']
|
||||||
|
|
||||||
@@ -25,24 +25,23 @@ class Libceed(Package, CudaPackage, ROCmPackage):
|
|||||||
|
|
||||||
variant('occa', default=False, description='Enable OCCA backends')
|
variant('occa', default=False, description='Enable OCCA backends')
|
||||||
variant('debug', default=False, description='Enable debug build')
|
variant('debug', default=False, description='Enable debug build')
|
||||||
variant('libxsmm', default=False, description='Enable LIBXSMM backend')
|
variant('libxsmm', default=False, description='Enable LIBXSMM backend', when='@0.3:')
|
||||||
variant('magma', default=False, description='Enable MAGMA backend')
|
variant('magma', default=False, description='Enable MAGMA backend', when='@0.6:')
|
||||||
|
|
||||||
conflicts('+libxsmm', when='@:0.2')
|
|
||||||
conflicts('+magma', when='@:0.5')
|
|
||||||
conflicts('+rocm', when='@:0.6')
|
conflicts('+rocm', when='@:0.6')
|
||||||
|
|
||||||
depends_on('cuda', when='+cuda')
|
with when('+rocm'):
|
||||||
depends_on('hip@3.8.0', when='@0.7:0.7.99+rocm')
|
depends_on('hip@3.8.0', when='@0.7:0.7.99')
|
||||||
depends_on('hip@3.8.0:', when='@0.8:+rocm')
|
depends_on('hip@3.8.0:', when='@0.8:')
|
||||||
depends_on('hipblas@3.8.0:', when='@0.8:+rocm')
|
depends_on('hipblas@3.8.0:', when='@0.8:')
|
||||||
|
|
||||||
depends_on('occa@develop', when='@develop+occa')
|
with when('+occa'):
|
||||||
depends_on('occa@1.1.0', when='@0.7:+occa')
|
depends_on('occa@develop', when='@develop')
|
||||||
depends_on('occa@1.0.8:', when='@0.4+occa')
|
depends_on('occa@1.1.0', when='@0.7:')
|
||||||
depends_on('occa@1.0.0-alpha.5,develop', when='@:0.2+occa')
|
depends_on('occa@1.0.8:', when='@0.4')
|
||||||
depends_on('occa+cuda', when='+occa+cuda')
|
depends_on('occa@1.0.0-alpha.5,develop', when='@:0.2')
|
||||||
depends_on('occa~cuda', when='+occa~cuda')
|
depends_on('occa+cuda', when='+cuda')
|
||||||
|
depends_on('occa~cuda', when='~cuda')
|
||||||
|
|
||||||
depends_on('libxsmm', when='+libxsmm')
|
depends_on('libxsmm', when='+libxsmm')
|
||||||
|
|
||||||
@@ -56,8 +55,6 @@ class Libceed(Package, CudaPackage, ROCmPackage):
|
|||||||
# bug in Occa.
|
# bug in Occa.
|
||||||
patch('occaFree-0.2.diff', when='@0.2')
|
patch('occaFree-0.2.diff', when='@0.2')
|
||||||
|
|
||||||
phases = ['build', 'install']
|
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def common_make_opts(self):
|
def common_make_opts(self):
|
||||||
spec = self.spec
|
spec = self.spec
|
||||||
@@ -129,18 +126,19 @@ def common_make_opts(self):
|
|||||||
|
|
||||||
return makeopts
|
return makeopts
|
||||||
|
|
||||||
def build(self, spec, prefix):
|
def edit(self, spec, prefix):
|
||||||
makeopts = self.common_make_opts
|
make('info', *self.common_make_opts)
|
||||||
make('info', *makeopts)
|
|
||||||
make(*makeopts)
|
|
||||||
|
|
||||||
if self.run_tests:
|
@property
|
||||||
make('prove', *makeopts, parallel=False)
|
def build_targets(self):
|
||||||
|
return self.common_make_opts
|
||||||
|
|
||||||
def install(self, spec, prefix):
|
@property
|
||||||
installopts = ['prefix=%s' % prefix]
|
def install_targets(self):
|
||||||
installopts += self.common_make_opts
|
return ['prefix={0}'.format(self.prefix)] + self.common_make_opts
|
||||||
make('install', *installopts, parallel=False)
|
|
||||||
|
def check(self):
|
||||||
|
make('prove', *self.common_make_opts, parallel=False)
|
||||||
|
|
||||||
@when('@0.1')
|
@when('@0.1')
|
||||||
def install(self, spec, prefix):
|
def install(self, spec, prefix):
|
||||||
|
Reference in New Issue
Block a user