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:

committed by
Todd Gamblin

parent
36c79e9df6
commit
1d981ebd50
@@ -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')
|
||||
|
Reference in New Issue
Block a user