diff options
Diffstat (limited to 'var/spack/repos/builtin/packages/adios2/package.py')
-rw-r--r-- | var/spack/repos/builtin/packages/adios2/package.py | 100 |
1 files changed, 51 insertions, 49 deletions
diff --git a/var/spack/repos/builtin/packages/adios2/package.py b/var/spack/repos/builtin/packages/adios2/package.py index a222477c2d..a7ba1eec0b 100644 --- a/var/spack/repos/builtin/packages/adios2/package.py +++ b/var/spack/repos/builtin/packages/adios2/package.py @@ -1,27 +1,8 @@ -############################################################################## -# Copyright (c) 2013-2017, Lawrence Livermore National Security, LLC. -# Produced at the Lawrence Livermore National Laboratory. +# Copyright 2013-2018 Lawrence Livermore National Security, LLC and other +# Spack Project Developers. See the top-level COPYRIGHT file for details. # -# 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/spack/spack -# Please also see the NOTICE and LICENSE files 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 -############################################################################## +# SPDX-License-Identifier: (Apache-2.0 OR MIT) + from spack import * @@ -30,21 +11,27 @@ class Adios2(CMakePackage): homepage = "https://www.olcf.ornl.gov/center-projects/adios/" url = "https://github.com/ornladios/ADIOS2/archive/v2.0.0.tar.gz" + git = "https://github.com/ornladios/ADIOS2.git" - version('develop', branch='master', - git='https://github.com/ornladios/ADIOS2.git') + maintainers = ['ax3l'] + version('develop', branch='master') + version('2.2.0', sha256='77058ea2ff7224dc02ea519733de42d89112cf21ffe7474fb2fa3c5696152948') + version('2.1.0', '431fa5b015349f1838b96b8f5a1cc8f8') version('2.0.0', 'da39655b51745d2c5f3f1e46c5abc4d7') variant('shared', default=True, description='Also build shared libraries') variant('mpi', default=True, description='Enable MPI') - # transforms (not yet implemented) - # variant('bzip2', default=True, - # description='Enable BZip2 compression') - # variant('zfp', default=True, - # description='Enable ZFP compression') + # transforms + variant('bzip2', default=True, + description='Enable BZip2 compression') + variant('zfp', default=True, + description='Enable ZFP compression') + # sz is broken in 2.2.0: https://github.com/ornladios/ADIOS2/issues/705 + # variant('sz', default=True, + # description='Enable SZ compression') # transport engines variant('dataman', default=True, description='Enable the DataMan engine for WAN transports') @@ -58,6 +45,8 @@ class Adios2(CMakePackage): # language bindings variant('python', default=True, description='Enable the Python >= 2.7 bindings') + variant('fortran', default=True, + description='Enable the Fortran bindings') # requires mature C++11 implementations conflicts('%gcc@:4.7') @@ -68,12 +57,17 @@ class Adios2(CMakePackage): conflicts('+dataman', when='~shared') depends_on('cmake@3.5.0:', type='build') + depends_on('pkgconfig', type='build', when='@2.2.0:') + # The included ffs requires bison and flex but using them makes + # the build fail due to an undefined reference. + # depends_on('bison', type='build', when='@2.2.0:') + # depends_on('flex', when='@2.2.0:') # contained in thirdparty/ # depends_on('googletest') # depends_on('pugixml') # depends_on('kwsys') - # depends_on('nlohmannjson') + # depends_on('nlohmann-json') # depends_on('pybind11@2.1.1:', when='+python') depends_on('mpi', when='+mpi') @@ -86,6 +80,7 @@ class Adios2(CMakePackage): depends_on('bzip2', when='+bzip2') depends_on('zfp', when='+zfp') + # depends_on('sz@:1.4.12', when='+sz') extends('python', when='+python') depends_on('python@2.7:', type=('build', 'run'), when='+python') @@ -96,24 +91,31 @@ class Adios2(CMakePackage): spec = self.spec args = [ - '-DADIOS2_BUILD_SHARED_LIBS:BOOL={0}'.format(( - 'ON' if '+shared' in spec else 'OFF')), + '-DADIOS2_BUILD_SHARED_LIBS:BOOL={0}'.format( + 'ON' if '+shared' in spec else 'OFF'), '-DADIOS2_BUILD_TESTING=OFF', - '-DADIOS2_USE_MPI={0}'.format(( - 'ON' if '+mpi' in spec else 'OFF')), - '-DADIOS2_USE_BZip2={0}'.format(( - 'ON' if '+bzip2' in spec else 'OFF')), - '-DADIOS2_USE_ZFP={0}'.format(( - 'ON' if '+zfp' in spec else 'OFF')), - '-DADIOS2_USE_DataMan={0}'.format(( - 'ON' if '+dataman' in spec else 'OFF')), - '-DADIOS2_USE_ZeroMQ={0}'.format(( - 'ON' if '+dataman' in spec else 'OFF')), - '-DADIOS2_USE_HDF5={0}'.format(( - 'ON' if '+hdf5' in spec else 'OFF')), - '-DADIOS2_USE_ADIOS1={0}'.format(( - 'ON' if '+adios1' in spec else 'OFF')), - '-DADIOS2_USE_Python={0}'.format(( - 'ON' if '+python' in spec else 'OFF')) + '-DADIOS2_USE_MPI={0}'.format( + 'ON' if '+mpi' in spec else 'OFF'), + '-DADIOS2_USE_BZip2={0}'.format( + 'ON' if '+bzip2' in spec else 'OFF'), + '-DADIOS2_USE_ZFP={0}'.format( + 'ON' if '+zfp' in spec else 'OFF'), + '-DADIOS2_USE_SZ={0}'.format( + 'ON' if '+sz' in spec else 'OFF'), + '-DADIOS2_USE_DataMan={0}'.format( + 'ON' if '+dataman' in spec else 'OFF'), + '-DADIOS2_USE_ZeroMQ={0}'.format( + 'ON' if '+dataman' in spec else 'OFF'), + '-DADIOS2_USE_HDF5={0}'.format( + 'ON' if '+hdf5' in spec else 'OFF'), + '-DADIOS2_USE_ADIOS1={0}'.format( + 'ON' if '+adios1' in spec else 'OFF'), + '-DADIOS2_USE_Python={0}'.format( + 'ON' if '+python' in spec else 'OFF'), + '-DADIOS2_USE_Fortran={0}'.format( + 'ON' if '+fortran' in spec else 'OFF') ] + if spec.satisfies('+python'): + args.append('-DPYTHON_EXECUTABLE:FILEPATH=%s' + % self.spec['python'].command.path) return args |