spack/var/spack/repos/builtin/packages/cdo/package.py
2018-03-24 12:13:52 -07:00

150 lines
6.4 KiB
Python

##############################################################################
# Copyright (c) 2013-2018, 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/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
##############################################################################
from spack import *
class Cdo(AutotoolsPackage):
"""CDO is a collection of command line Operators to manipulate and analyse
Climate and NWP model Data.
"""
homepage = 'https://code.mpimet.mpg.de/projects/cdo'
url = 'https://code.mpimet.mpg.de/attachments/download/12760/cdo-1.7.2.tar.gz'
list_url = 'https://code.mpimet.mpg.de/projects/cdo/files'
maintainers = ['skosukhin']
version('1.9.3', '13ae222164413dbd53532b03b072def5')
version('1.9.2', '38e68d34f0b5b44a52c3241be6831423')
version('1.9.1', 'e60a89f268ba24cee5c461f2c217829e')
version('1.9.0', '2d88561b3b4a880df0422a62e5027e40')
version('1.8.2', '6a2e2f99b7c67ee9a512c40a8d4a7121')
version('1.7.2', 'f08e4ce8739a4f2b63fc81a24db3ee31')
variant('netcdf', default=True, description='Enable NetCDF support')
variant('grib2', default='eccodes', values=('eccodes', 'grib-api', 'none'),
description='Specify GRIB2 backend')
variant('external-grib1', default=False,
description='Ignore the built-in support and use the external '
'GRIB2 backend for GRIB1 files')
variant('szip', default=True,
description='Enable szip compression for GRIB1')
variant('hdf5', default=True, description='Enable HDF5 support')
variant('udunits2', default=True, description='Enable UDUNITS2 support')
variant('libxml2', default=True, description='Enable libxml2 support')
variant('proj', default=True,
description='Enable PROJ library for cartographic projections')
variant('curl', default=False, description='Enable curl support')
variant('fftw3', default=True, description='Enable support for fftw3')
variant('magics', default=False,
description='Enable Magics library support')
variant('openmp', default=True, description='Enable OpenMP support')
depends_on('netcdf', when='+netcdf')
# In this case CDO does not depend on hdf5 directly but we need the backend
# of netcdf to be thread safe.
depends_on('hdf5+threadsafe', when='+netcdf')
depends_on('grib-api', when='grib2=grib-api')
depends_on('eccodes', when='grib2=eccodes')
depends_on('szip', when='+szip')
depends_on('hdf5+threadsafe', when='+hdf5')
depends_on('udunits2', when='+udunits2')
depends_on('libxml2', when='+libxml2')
depends_on('proj', when='+proj')
depends_on('curl', when='+curl')
depends_on('fftw@3:', when='+fftw3')
depends_on('magics', when='+magics')
depends_on('libuuid')
conflicts('grib2=eccodes', when='@:1.8',
msg='Eccodes is supported starting version 1.9.0')
conflicts('+szip', when='+external-grib1 grib2=none',
msg='The configuration does not support GRIB1')
def configure_args(self):
config_args = self.with_or_without('netcdf', activation_value='prefix')
if self.spec.variants['grib2'].value == 'eccodes':
config_args.append('--with-eccodes=' +
self.spec['eccodes'].prefix)
config_args.append('--without-grib_api')
elif self.spec.variants['grib2'].value == 'grib-api':
config_args.append('--with-grib_api=' +
self.spec['grib-api'].prefix)
if self.spec.satisfies('@1.9:'):
config_args.append('--without-eccodes')
else:
config_args.append('--without-grib_api')
if self.spec.satisfies('@1.9:'):
config_args.append('--without-eccodes')
if '+external-grib1' in self.spec:
config_args.append('--disable-cgribex')
else:
config_args.append('--enable-cgribex')
if '+szip' in self.spec:
config_args.append('--with-szlib=' + self.spec['szip'].prefix)
else:
config_args.append('--without-szlib')
config_args += self.with_or_without('hdf5',
activation_value='prefix')
config_args += self.with_or_without('udunits2',
activation_value='prefix')
config_args += self.with_or_without('libxml2',
activation_value='prefix')
config_args += self.with_or_without('proj',
activation_value='prefix')
config_args += self.with_or_without('curl',
activation_value='prefix')
config_args += self.with_or_without('magics',
activation_value='prefix')
config_args += self.with_or_without('fftw3')
config_args += self.enable_or_disable('openmp')
# Starting version 1.9.0 CDO is a C++ program but it uses the C
# interface of HDF5 without the parallel features. To avoid
# unnecessary dependencies on mpi's cxx library, we need to set the
# following flags. This works for OpenMPI, MPICH, MVAPICH, Intel MPI,
# IBM Spectrum MPI, bullx MPI, and Cray MPI.
if self.spec.satisfies('@1.9:+hdf5^hdf5+mpi'):
config_args.append(
'CPPFLAGS=-DOMPI_SKIP_MPICXX -DMPICH_SKIP_MPICXX')
return config_args