Update for 'magics' and 'libemos'. (#6275)
This commit is contained in:
parent
b9be9519e8
commit
e77b11674f
@ -31,31 +31,37 @@ class Libemos(CMakePackage):
|
|||||||
|
|
||||||
homepage = "https://software.ecmwf.int/wiki/display/EMOS/Emoslib"
|
homepage = "https://software.ecmwf.int/wiki/display/EMOS/Emoslib"
|
||||||
url = "https://software.ecmwf.int/wiki/download/attachments/3473472/libemos-4.4.2-Source.tar.gz"
|
url = "https://software.ecmwf.int/wiki/download/attachments/3473472/libemos-4.4.2-Source.tar.gz"
|
||||||
|
list_url = "https://software.ecmwf.int/wiki/display/EMOS/Releases"
|
||||||
|
|
||||||
|
version('4.5.1', 'eec1ef4de841df3c68c08fa94d7939ff')
|
||||||
|
version('4.5.0', '0ad8962a73e3ca90a8094561adc81276')
|
||||||
|
version('4.4.9', '24d098cd062d443a544fe17727726285')
|
||||||
version('4.4.7', '395dcf21cf06872f772fb6b73d8e67b9')
|
version('4.4.7', '395dcf21cf06872f772fb6b73d8e67b9')
|
||||||
version('4.4.2', 'f15a9aff0f40861f3f046c9088197376')
|
version('4.4.2', 'f15a9aff0f40861f3f046c9088197376')
|
||||||
|
|
||||||
variant('eccodes', default=False,
|
variant('grib', default='eccodes', values=('eccodes', 'grib-api'),
|
||||||
description="Use eccodes instead of grib-api for GRIB decoding")
|
description='Specify GRIB backend')
|
||||||
variant('build_type', default='RelWithDebInfo',
|
variant('build_type', default='RelWithDebInfo',
|
||||||
description='The build type to build',
|
description='The build type to build',
|
||||||
values=('Debug', 'Release', 'RelWithDebInfo', 'Production'))
|
values=('Debug', 'Release', 'RelWithDebInfo', 'Production'))
|
||||||
|
|
||||||
depends_on('eccodes', when='+eccodes')
|
depends_on('eccodes', when='grib=eccodes')
|
||||||
depends_on('grib-api', when='~eccodes')
|
depends_on('grib-api', when='grib=grib-api')
|
||||||
depends_on('fftw+float+double')
|
depends_on('fftw+float+double')
|
||||||
depends_on('cmake@2.8.11:', type='build')
|
depends_on('cmake@2.8.11:', type='build')
|
||||||
|
depends_on('pkg-config', type='build')
|
||||||
|
|
||||||
|
conflicts('grib=eccodes', when='@:4.4.1',
|
||||||
|
msg='Eccodes is supported starting version 4.4.2')
|
||||||
|
|
||||||
def cmake_args(self):
|
def cmake_args(self):
|
||||||
spec = self.spec
|
|
||||||
args = []
|
args = []
|
||||||
|
|
||||||
if spec.satisfies('+eccodes'):
|
if self.spec.variants['grib'].value == 'eccodes':
|
||||||
args.append('-DENABLE_ECCODES=ON')
|
args.append('-DENABLE_ECCODES=ON')
|
||||||
args.append('-DECCODES_PATH=%s' % spec['eccodes'].prefix)
|
|
||||||
else:
|
else:
|
||||||
|
if self.spec.satisfies('@4.4.2:'):
|
||||||
args.append('-DENABLE_ECCODES=OFF')
|
args.append('-DENABLE_ECCODES=OFF')
|
||||||
args.append('-DGRIB_API_PATH=%s' % spec['grib-api'].prefix)
|
|
||||||
|
|
||||||
# To support long pathnames that spack generates
|
# To support long pathnames that spack generates
|
||||||
args.append('-DCMAKE_Fortran_FLAGS=-ffree-line-length-none')
|
args.append('-DCMAKE_Fortran_FLAGS=-ffree-line-length-none')
|
||||||
|
@ -33,48 +33,86 @@ class Magics(CMakePackage):
|
|||||||
|
|
||||||
homepage = "https://software.ecmwf.int/wiki/display/MAGP/Magics"
|
homepage = "https://software.ecmwf.int/wiki/display/MAGP/Magics"
|
||||||
url = "https://software.ecmwf.int/wiki/download/attachments/3473464/Magics-2.29.0-Source.tar.gz"
|
url = "https://software.ecmwf.int/wiki/download/attachments/3473464/Magics-2.29.0-Source.tar.gz"
|
||||||
|
list_url = "https://software.ecmwf.int/wiki/display/MAGP/Releases"
|
||||||
|
|
||||||
# Maintainers of Magics do not keep tarballs of minor releases. Once the
|
# The policy on which minor releases remain available and which get deleted
|
||||||
# next minor released is published the previous one becomes unavailable.
|
# after a newer version becomes available is unclear.
|
||||||
# That is why the preferred version is the latest stable one.
|
version('2.34.3', 'b4180bc4114ffd723b80728947f50c17')
|
||||||
|
version('2.34.1', '1ecc5cc20cb0c3f2f0b9171626f09d53')
|
||||||
|
version('2.33.0', '8d513fd2244f2974b3517a8b30dd51f6')
|
||||||
version('2.32.0', 'e17956fffce9ea826cf994f8d275e0f5')
|
version('2.32.0', 'e17956fffce9ea826cf994f8d275e0f5')
|
||||||
|
version('2.31.0', '3564dca9e1b4af096fd631906f5e6c89')
|
||||||
|
version('2.29.6', '56d2c31ca75162e5e86ef75d355e87f1')
|
||||||
version('2.29.4', '91c561f413316fb665b3bb563f3878d1')
|
version('2.29.4', '91c561f413316fb665b3bb563f3878d1')
|
||||||
version('2.29.0', 'db20a4d3c51a2da5657c31ae3de59709', preferred=True)
|
version('2.29.0', 'db20a4d3c51a2da5657c31ae3de59709')
|
||||||
|
|
||||||
# The patch reorders includes and adds namespaces where necessary to
|
# The patch reorders includes and adds namespaces where necessary to
|
||||||
# resolve ambiguity of invocations of isnan and isinf functions. The
|
# resolve ambiguity of invocations of isnan and isinf functions. The
|
||||||
# patch is not needed since the version 2.29.1
|
# patch is not needed since the version 2.29.1
|
||||||
patch('resolve_isnan_ambiguity.patch', when='@2.29.0')
|
patch('resolve_isnan_ambiguity.patch', when='@2.29.0')
|
||||||
|
|
||||||
variant('bufr', default=False, description='Enable BUFR support')
|
variant('grib', default='eccodes', values=('eccodes', 'grib-api'),
|
||||||
|
description='Specify GRIB backend')
|
||||||
variant('netcdf', default=False, description='Enable NetCDF support')
|
variant('netcdf', default=False, description='Enable NetCDF support')
|
||||||
variant('cairo', default=True, description='Enable cairo support[png/jpeg]')
|
variant('cairo', default=False,
|
||||||
|
description='Enable cairo support[png/jpeg]')
|
||||||
|
variant('python', default=False, description='Enable Python interface')
|
||||||
|
variant('fortran', default=False, description='Enable Fortran interface')
|
||||||
variant('metview', default=False, description='Enable metview support')
|
variant('metview', default=False, description='Enable metview support')
|
||||||
variant('qt', default=False, description='Enable metview support with qt')
|
variant('qt', default=False, description='Enable metview support with qt')
|
||||||
variant('eccodes', default=False, description='Use eccodes instead of grib-api')
|
variant('bufr', default=False, description='Enable BUFR support')
|
||||||
|
|
||||||
variant('build_type', default='RelWithDebInfo',
|
variant('build_type', default='RelWithDebInfo',
|
||||||
description='The build type to build',
|
description='The build type to build',
|
||||||
values=('Debug', 'Release', 'RelWithDebInfo', 'Production'))
|
values=('Debug', 'Release', 'RelWithDebInfo', 'Production'))
|
||||||
|
|
||||||
|
# Build dependencies
|
||||||
depends_on('cmake@2.8.11:', type='build')
|
depends_on('cmake@2.8.11:', type='build')
|
||||||
depends_on('pkg-config', type='build')
|
depends_on('pkg-config', type='build')
|
||||||
|
depends_on('python@:2', type='build')
|
||||||
# Currently python is only necessary to run
|
|
||||||
# building preprocessing scripts.
|
|
||||||
depends_on('python', type='build')
|
|
||||||
depends_on('perl', type='build')
|
depends_on('perl', type='build')
|
||||||
depends_on('perl-xml-parser', type='build')
|
depends_on('perl-xml-parser', type='build')
|
||||||
depends_on('eccodes', when='+eccodes')
|
|
||||||
depends_on('grib-api', when='~eccodes')
|
# Non-optional dependencies
|
||||||
depends_on('proj')
|
depends_on('proj')
|
||||||
depends_on('boost')
|
depends_on('boost')
|
||||||
depends_on('expat')
|
depends_on('expat')
|
||||||
depends_on('pango', when='+cairo')
|
|
||||||
|
# Magics (at least up to version 2.34.3) should directly and
|
||||||
|
# unconditionally depend on zlib, which is not reflected neither in the
|
||||||
|
# installation instructions nor explicitly stated in the cmake script:
|
||||||
|
# zlib is pulled as a dependency of png. The dependency on png is formally
|
||||||
|
# optional and depends on an unofficial flag ENABLE_PNG, which is
|
||||||
|
# redundant, because png is used only when ENABLE_CAIRO=ON. The problem is
|
||||||
|
# that files that make calls to png library get compiled and linked
|
||||||
|
# unconditionally, which makes png a non-optional dependency (and
|
||||||
|
# ENABLE_PNG always has to be set to ON).
|
||||||
|
depends_on('zlib')
|
||||||
|
depends_on('libpng')
|
||||||
|
|
||||||
|
# GRIB support is non-optional, regardless of what the instruction says.
|
||||||
|
depends_on('eccodes', when='grib=eccodes')
|
||||||
|
depends_on('grib-api', when='grib=grib-api')
|
||||||
|
|
||||||
|
# Optional dependencies
|
||||||
depends_on('netcdf-cxx', when='+netcdf')
|
depends_on('netcdf-cxx', when='+netcdf')
|
||||||
depends_on('libemos', when='+bufr')
|
depends_on('pango', when='+cairo')
|
||||||
|
depends_on('libemos grib=eccodes', when='+bufr grib=eccodes')
|
||||||
|
depends_on('libemos grib=grib-api', when='+bufr grib=grib-api')
|
||||||
depends_on('qt', when='+metview+qt')
|
depends_on('qt', when='+metview+qt')
|
||||||
|
|
||||||
conflicts('+eccodes', when='@:2.29.0')
|
extends('python', when='+python')
|
||||||
|
# Python 2 is required for running the building scripts. Since we can't
|
||||||
|
# have two different versions of Python at the same time, we haven't even
|
||||||
|
# tested if the Python interface supports Python 3.
|
||||||
|
depends_on('python', when='+python', type=('link', 'run'))
|
||||||
|
depends_on('py-numpy', when='+python', type=('build', 'run'))
|
||||||
|
depends_on('swig', when='+python', type='build')
|
||||||
|
|
||||||
|
conflicts('grib=eccodes', when='@:2.29.0',
|
||||||
|
msg='Eccodes is supported starting version 2.29.1')
|
||||||
|
conflicts('+python', when='@:2.28',
|
||||||
|
msg='Python interface is supported starting version 2.29.0')
|
||||||
|
|
||||||
# Replace system python and perl by spack versions:
|
# Replace system python and perl by spack versions:
|
||||||
def patch(self):
|
def patch(self):
|
||||||
@ -84,50 +122,51 @@ def patch(self):
|
|||||||
filter_file('#!/usr/bin/python', '#!/usr/bin/env python', pyfile)
|
filter_file('#!/usr/bin/python', '#!/usr/bin/env python', pyfile)
|
||||||
|
|
||||||
def cmake_args(self):
|
def cmake_args(self):
|
||||||
spec = self.spec
|
|
||||||
args = [
|
args = [
|
||||||
'-DENABLE_ODB=OFF',
|
'-DENABLE_ODB=OFF',
|
||||||
'-DENABLE_PYTHON=OFF',
|
'-DENABLE_SPOT=OFF'
|
||||||
'-DBOOST_ROOT=%s' % spec['boost'].prefix,
|
|
||||||
'-DPROJ4_PATH=%s' % spec['proj'].prefix,
|
|
||||||
'-DENABLE_TESTS=OFF',
|
|
||||||
]
|
]
|
||||||
|
|
||||||
if '+bufr' in spec:
|
if self.spec.variants['grib'].value == 'eccodes':
|
||||||
args.append('-DENABLE_BUFR=ON')
|
args.append('-DENABLE_ECCODES=ON')
|
||||||
args.append('-DLIBEMOS_PATH=%s' % spec['libemos'].prefix)
|
|
||||||
else:
|
else:
|
||||||
args.append('-DENABLE_BUFR=OFF')
|
if self.spec.satisfies('@2.29.1:'):
|
||||||
|
args.append('-DENABLE_ECCODES=OFF')
|
||||||
|
|
||||||
if '+netcdf' in spec:
|
if '+netcdf' in self.spec:
|
||||||
args.append('-DENABLE_NETCDF=ON')
|
args.append('-DENABLE_NETCDF=ON')
|
||||||
args.append('-DNETCDF_PATH=%s' % spec['netcdf-cxx'].prefix)
|
|
||||||
else:
|
else:
|
||||||
args.append('-DENABLE_NETCDF=OFF')
|
args.append('-DENABLE_NETCDF=OFF')
|
||||||
|
|
||||||
if '+cairo' in spec:
|
if '+cairo' in self.spec:
|
||||||
args.append('-DENABLE_CAIRO=ON')
|
args.append('-DENABLE_CAIRO=ON')
|
||||||
else:
|
else:
|
||||||
args.append('-DENABLE_CAIRO=OFF')
|
args.append('-DENABLE_CAIRO=OFF')
|
||||||
|
|
||||||
if '+metview' in spec:
|
if '+python' in self.spec:
|
||||||
if '+qt' in spec:
|
args.append('-DENABLE_PYTHON=ON')
|
||||||
|
else:
|
||||||
|
if self.spec.satisfies('@2.29.0:'):
|
||||||
|
args.append('-DENABLE_PYTHON=OFF')
|
||||||
|
|
||||||
|
if '+fortran' in self.spec:
|
||||||
|
args.append('-DENABLE_FORTRAN=ON')
|
||||||
|
else:
|
||||||
|
args.append('-DENABLE_FORTRAN=OFF')
|
||||||
|
|
||||||
|
if '+bufr' in self.spec:
|
||||||
|
args.append('-DENABLE_BUFR=ON')
|
||||||
|
else:
|
||||||
|
args.append('-DENABLE_BUFR=OFF')
|
||||||
|
|
||||||
|
if '+metview' in self.spec:
|
||||||
|
if '+qt' in self.spec:
|
||||||
args.append('-DENABLE_METVIEW=ON')
|
args.append('-DENABLE_METVIEW=ON')
|
||||||
if spec['qt'].version[0] == 5:
|
if self.spec['qt'].satisfies('@5:'):
|
||||||
args.append('-DENABLE_QT5=ON')
|
args.append('-DENABLE_QT5=ON')
|
||||||
else:
|
else:
|
||||||
args.append('-DENABLE_METVIEW_NO_QT=ON')
|
args.append('-DENABLE_METVIEW_NO_QT=ON')
|
||||||
else:
|
else:
|
||||||
args.append('-DENABLE_METVIEW=OFF')
|
args.append('-DENABLE_METVIEW=OFF')
|
||||||
|
|
||||||
if '+eccodes' in spec:
|
|
||||||
args.append('-DENABLE_ECCODES=ON')
|
|
||||||
args.append('-DECCODES_PATH=%s' % spec['eccodes'].prefix)
|
|
||||||
else:
|
|
||||||
args.append('-DENABLE_ECCODES=OFF')
|
|
||||||
args.append('-DGRIB_API_PATH=%s' % spec['grib-api'].prefix)
|
|
||||||
|
|
||||||
if (self.compiler.f77 is None) or (self.compiler.fc is None):
|
|
||||||
args.append('-DENABLE_FORTRAN=OFF')
|
|
||||||
|
|
||||||
return args
|
return args
|
||||||
|
Loading…
Reference in New Issue
Block a user