1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
|
# Copyright 2013-2022 Lawrence Livermore National Security, LLC and other
# Spack Project Developers. See the top-level COPYRIGHT file for details.
#
# SPDX-License-Identifier: (Apache-2.0 OR MIT)
from spack.package import *
class Shuffile(CMakePackage):
"""Shuffle files between MPI ranks"""
homepage = "https://github.com/ecp-veloc/shuffile"
url = "https://github.com/ecp-veloc/shuffile/archive/v0.0.4.tar.gz"
git = "https://github.com/ecp-veloc/shuffile.git"
tags = ['ecp']
maintainers = ['CamStan', 'gonsie']
version('main', branch='main')
version('0.1.0', sha256='9e730cc8b7937517a9cffb08c031d9f5772306341c49d17b87b7f349d55a6d5e')
version('0.0.4', sha256='f0249ab31fc6123103ad67b1eaf799277c72adcf0dfcddf8c3a18bad2d45031d')
version('0.0.3', sha256='a3f685526a1146a5ad8dbacdc5f9c2e1152d9761a1a179c1db34f55afc8372f6')
depends_on('mpi')
depends_on('kvtree+mpi')
depends_on('zlib', type='link')
variant('shared', default=True, description='Build with shared libraries')
depends_on('kvtree+shared', when='@0.1: +shared')
depends_on('kvtree~shared', when='@0.1: ~shared')
def cmake_args(self):
spec = self.spec
args = []
args.append(self.define('MPI_C_COMPILER', spec['mpi'].mpicc))
args.append(self.define('WITH_KVTREE_PREFIX', spec['kvtree'].prefix))
if spec.satisfies('@0.1.0:'):
args.append(self.define_from_variant('BUILD_SHARED_LIBS', 'shared'))
else:
if spec.satisfies('platform=cray'):
args.append(self.define('SHUFFILE_LINK_STATIC', True))
return args
|