A set of tools used in climate modeling and numerical weather prediction. (#1317)

* Update grib-api: switched to cmake building system.

* Update harfbuzz: added pkg-config dependency.

* Update pango: added pkg-config dependency.

* Add libemos package.

* Add Magics (from ECMWF) package.

* Revert "Variant for building cdo without mpi (#1638)":
CDO does not use MPI.

This reverts commit 079d063c6d.

* Update CDO package: full featured implementation.

* Update magics: added python as build dependency.

* Update cdo: added disabling configuration options.
This commit is contained in:
Sergey Kosukhin
2016-10-04 17:29:22 +01:00
committed by Todd Gamblin
parent 36c79e9df6
commit 1d981ebd50
8 changed files with 366 additions and 18 deletions

View File

@@ -34,13 +34,84 @@ class Cdo(Package):
version('1.7.2', 'f08e4ce8739a4f2b63fc81a24db3ee31', url='https://code.zmaw.de/attachments/download/12760/cdo-1.7.2.tar.gz')
version('1.6.9', 'bf0997bf20e812f35e10188a930e24e2', url='https://code.zmaw.de/attachments/download/10198/cdo-1.6.9.tar.gz')
variant('mpi', default=True)
variant('szip', default=True, description='Enable szip compression for GRIB1')
variant('hdf5', default=False, description='Enable HDF5 support')
variant('netcdf', default=True, description='Enable NetCDF support')
variant('udunits2', default=True, description='Enable UDUNITS2 support')
variant('grib', default=True, description='Enable GRIB_API support')
variant('libxml2', default=True, description='Enable libxml2 support')
variant('proj', default=True, description='Enable PROJ library for cartographic projections')
variant('curl', default=True, description='Enable curl support')
variant('fftw', default=True, description='Enable support for fftw3')
variant('magics', default=True, description='Enable Magics library support')
depends_on('netcdf')
depends_on('netcdf+mpi', when='+mpi')
depends_on('netcdf~mpi', when='~mpi')
depends_on('szip', when='+szip')
depends_on('netcdf', when='+netcdf')
depends_on('hdf5+threadsafe', when='+hdf5')
depends_on('udunits2', when='+udunits2')
depends_on('grib-api', when='+grib')
depends_on('libxml2', when='+libxml2')
depends_on('proj', when='+proj')
depends_on('curl', when='+curl')
depends_on('fftw', when='+fftw')
depends_on('magics', when='+magics')
def install(self, spec, prefix):
configure('--prefix={0}'.format(prefix))
config_args = ["--prefix=" + prefix,
"--enable-shared",
"--enable-static"]
if '+szip' in spec:
config_args.append('--with-szlib=' + spec['szip'].prefix)
else:
config_args.append('--without-szlib')
if '+hdf5' in spec:
config_args.append('--with-hdf5=' + spec['hdf5'].prefix)
else:
config_args.append('--without-hdf5')
if '+netcdf' in spec:
config_args.append('--with-netcdf=' + spec['netcdf'].prefix)
else:
config_args.append('--without-netcdf')
if '+udunits2' in spec:
config_args.append('--with-udunits2=' + spec['udunits2'].prefix)
else:
config_args.append('--without-udunits2')
if '+grib' in spec:
config_args.append('--with-grib_api=' + spec['grib-api'].prefix)
else:
config_args.append('--without-grib_api')
if '+libxml2' in spec:
config_args.append('--with-libxml2=' + spec['libxml2'].prefix)
else:
config_args.append('--without-libxml2')
if '+proj' in spec:
config_args.append('--with-proj=' + spec['proj'].prefix)
else:
config_args.append('--without-proj')
if '+curl' in spec:
config_args.append('--with-curl=' + spec['curl'].prefix)
else:
config_args.append('--without-curl')
if '+fftw' in spec:
config_args.append('--with-fftw3')
else:
config_args.append('--without-fftw3')
if '+magics' in spec:
config_args.append('--with-magics=' + spec['magics'].prefix)
else:
config_args.append('--without-magics')
configure(*config_args)
make()
make('install')