summaryrefslogtreecommitdiff
path: root/var/spack/repos/builtin/packages/ecp-data-vis-sdk/package.py
blob: 615cec4789e41b7e748def63749017e4a4f80a36 (plain) (blame)
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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
# Copyright 2013-2021 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 import *


class EcpDataVisSdk(BundlePackage):
    """ECP Data & Vis SDK"""

    homepage = "https://github.com/chuckatkins/ecp-data-viz-sdk"

    tags = ['ecp']
    maintainers = ['chuckatkins']

    version('1.0')

    ############################################################
    # Variants
    ############################################################

    # I/O
    variant('adios2', default=False, description="Enable ADIOS2")
    variant('darshan', default=False, description="Enable Darshan")
    variant('faodel', default=False, description="Enable FAODEL")
    variant('hdf5', default=False, description="Enable HDF5")
    variant('pnetcdf', default=False, description="Enable PNetCDF")
    variant('unifyfs', default=False, description="Enable UnifyFS")
    variant('veloc', default=False, description="Enable VeloC")

    # Vis
    variant('ascent', default=False, description="Enable Ascent")
    variant('paraview', default=False, description="Enable ParaView")
    variant('sz', default=False, description="Enable SZ")
    variant('vtkm', default=False, description="Enable VTK-m")
    variant('zfp', default=False, description="Enable ZFP")

    # Outstanding concretization issues
    variant('cinema', default=False, description="Enable Cinema")
    conflicts('+cinema')

    # Outstanding build issues
    variant('catalyst', default=False, description="Enable Catalyst")
    conflicts('+catalyst')
    variant('visit', default=False, description="Enable VisIt")
    conflicts('+visit')

    ############################################################
    # This is a messy workaround until the clingo concretizer can be required.
    # The intent is to map package variants to dependency variants:
    #   Package variants a, and b, mapping to dependency variants A and B
    #   produce the following set of dependencies:
    #     depends_on('foo+A+B', when='+a+b')
    #     depends_on('foo+A~B', when='+a~b')
    #     depends_on('foo~A+B', when='~a+b')
    #     depends_on('foo~A~B', when='~a~b')
    #   The clingo concretizer will allow that to be expressed much simpler by
    #   only considering defaults once everything else is resolved:
    #     depends_on('foo')
    #     depends_on('foo+A', when='+a')
    #     depends_on('foo+B', when='+b')
    ############################################################

    # Helper function to generate dependencies on the Cartesian product of
    # variants.  If a dictionary is passed then it provides a mapping of
    # package variant name to dependency variant name.  Otherwise assume they
    # are the same variant name in both the package and dependency
    def variants2deps(dep_spec, pkg_spec, variants):
        if not type(variants) is dict:
            variants = dict([(v, v) for v in variants])
        n = len(variants)
        for i in range(0, pow(2, n)):
            state = ['+' if d == '1' else '~' for d in format(i, '0' + str(n) + 'b')]
            [pkg_vars, dep_vars] = [''.join(v) for v in zip(
                *[(s + pv, s + dv) for s, (pv, dv) in zip(state, variants.items())])]
            dependency = ' '.join((dep_spec, dep_vars))
            predicate = ' '.join((pkg_spec, pkg_vars))
            depends_on(dependency, when=predicate)

    ############################################################
    # Dependencies
    ############################################################
    variants2deps('adios2+shared+mpi+fortran+python+blosc+sst+ssc+dataman',
                  '+adios2', ['hdf5', 'sz', 'zfp'])

    depends_on('darshan-runtime+mpi', when='+darshan')
    depends_on('darshan-util', when='+darshan')

    variants2deps('faodel+shared+mpi network=libfabric', '+faodel', ['hdf5'])

    depends_on('hdf5 +shared+mpi', when='+hdf5')
    # +fortran breaks the concretizer... Needs new concretizer
    # depends_on('hdf5 +shared+mpi+fortran', when='+hdf5')

    depends_on('parallel-netcdf+shared+fortran', when='+pnetcdf')

    variants2deps('unifyfs', '+unifyfs ', ['hdf5'])

    depends_on('veloc', when='+veloc')

    depends_on('ascent+shared+mpi+fortran+openmp+python+vtkh+dray', when='+ascent')
    depends_on('catalyst', when='+catalyst')

    depends_on('py-cinema-lib', when='+cinema')
    depends_on('py-cinemasci', when='+cinema')

    variants2deps('paraview+shared+mpi+python3+kits', '+paraview', ['hdf5'])
    # +adios2 is not yet enabled in the paraview package
    # depends_on('paraview+adios2', when='+paraview +adios2')

    depends_on('visit', when='+visit')

    depends_on('vtk-m+shared+mpi+openmp+rendering', when='+vtkm')

    # +python is currently broken in sz
    # variants2deps('sz+shared+fortran+python+random_access', '+sz', ['hdf5'])
    variants2deps('sz+shared+fortran+random_access', '+sz', ['hdf5'])

    depends_on('zfp', when='+zfp')