# Copyright 2013-2021 Lawrence Livermore National Security, LLC and other
# Spack Project Developers. See the top-level COPYRIGHT file for details.
#
# SPDX-License-Identifier: (Apache-2.0 OR MIT)
from spack import *
class Pism(CMakePackage):
"""Parallel Ice Sheet Model"""
homepage = "http://pism-docs.org/wiki/doku.php:="
url = "https://github.com/pism/pism/archive/v1.1.4.tar.gz"
git = "https://github.com/pism/pism.git"
maintainers = ['citibeth']
version('develop', branch='dev')
version('1.1.4', sha256='8ccb867af3b37e8d103351dadc1d7e77512e64379519fe8a2592668deb27bc44')
version('0.7.x', branch='stable0.7')
version('icebin', branch='efischer/dev')
variant('extra', default=False,
description='Build extra executables (testing/verification)')
variant('shared', default=True,
description='Build shared Pism libraries')
variant('python', default=False,
description='Build python bindings')
variant('icebin', default=False,
description='Build classes needed by IceBin')
variant('proj', default=True,
description='Use Proj.4 to compute cell areas, '
'longitudes, and latitudes.')
variant('parallel-netcdf4', default=False,
description='Enables parallel NetCDF-4 I/O.')
variant('parallel-netcdf3', default=False,
description='Enables parallel NetCDF-3 I/O using PnetCDF.')
variant('parallel-hdf5', default=False,
description='Enables parallel HDF5 I/O.')
# variant('tao', default=False,
# description='Use TAO in inverse solvers.')
description = 'Build PISM documentation (requires LaTeX and Doxygen)'
variant('doc', default=False, description=description)
variant('examples', default=False,
description='Install examples directory')
description = 'Report errors through Everytrace (requires Everytrace)'
variant('everytrace', default=False, description=description)
# CMake build options not transferred to Spack variants
# (except from CMakeLists.txt)
#
# option (Pism_TEST_USING_VALGRIND "Add extra regression tests
# using valgrind" OFF)
# mark_as_advanced (Pism_TEST_USING_VALGRIND)
#
# option (Pism_ADD_FPIC "Add -fPIC to C++ compiler flags
# (CMAKE_CXX_FLAGS). Try turning it off if it does not work." ON)
# option (Pism_LINK_STATICALLY
# "Set CMake flags to try to ensure that everything is
# linked statically")
# option (Pism_LOOK_FOR_LIBRARIES
# "Specifies whether PISM should look for libraries. (Disable
# this on Crays.)" ON)
# option (Pism_USE_TR1
# "Use the std::tr1 namespace to access shared pointer
# definitions. Disable to get shared pointers from the std
# namespace (might be needed with some compilers)." ON)
# option (Pism_USE_TAO "Use TAO in inverse solvers." OFF)
depends_on('fftw')
depends_on('gsl')
depends_on('mpi')
depends_on('netcdf-c') # Only the C interface is used, no netcdf-cxx4
depends_on('petsc')
depends_on('udunits')
depends_on('proj@:4')
depends_on('everytrace', when='+everytrace')
extends('python', when='+python')
depends_on('python@2.7:2.8,3.3:', when='@1.1: +python')
depends_on('python@2.7:2.8', when='@:1.0 +python')
depends_on('py-matplotlib', when='+python')
depends_on('py-numpy', when='+python')
def cmake_args(self):
spec = self.spec
return [
'-DCMAKE_C_COMPILER=%s' % spec['mpi'].mpicc,
'-DCMAKE_CXX_COMPILER=%s' % spec['mpi'].mpicxx,
# Fortran not needed for PISM...
# '-DCMAKE_Fortran_COMPILER=%s' % spec['mpi'].mpifc,
self.define_from_variant('Pism_BUILD_EXTRA_EXECS', 'extra'),
self.define_from_variant('BUILD_SHARED_LIBS', 'shared'),
self.define_from_variant('Pism_BUILD_PYTHON_BINDINGS', 'python'),
self.define_from_variant('Pism_BUILD_ICEBIN', 'icebin'),
self.define_from_variant('Pism_USE_PROJ4', 'proj'),
self.define_from_variant('Pism_USE_PARALLEL_NETCDF4', 'parallel-netcdf4'),
self.define_from_variant('Pism_USE_PNETCDF', 'parallel-netcdf3'),
self.define_from_variant('Pism_USE_PARALLEL_HDF5', 'parallel-hdf5'),
self.define_from_variant('Pism_BUILD_PDFS', 'doc'),
self.define_from_variant('Pism_INSTALL_EXAMPLES', 'examples'),
self.define_from_variant('Pism_USE_EVERYTRACE', 'everytrace')]
def setup_run_environment(self, env):
env.set('PISM_PREFIX', self.prefix)
env.set('PISM_BIN', self.prefix.bin)
# From email correspondence with Constantine Khroulev:
#
# > Do you have handy a table of which versions of PETSc are required
# > for which versions of PISM?
#
# We don't. The installation manual [1] specifies the minimum PETSc
# version for the latest "stable" release (currently PETSc 3.3). The
# stable PISM version should support all PETSc versions starting from the
# one specified in the manual and up to the latest PETSc release.
#
# The current development PISM version should be built with the latest
# PETSc release at the time (the "maint" branch of PETSc).
#
# Thanks to Git it is relatively easy to find this info, though:
#
# | PISM version | PETSc version |
# |--------------+---------------|
# | 0.7 | 3.3 and later |
# | 0.6 | 3.3 |
# | new_bc | 3.4.4 |
# | 0.5 | 3.2 |
# | 0.4 | 3.1 |
# | 0.3 | 2.3.3 to 3.1 |
# | 0.2 | 2.3.3 to 3.0 |
# | 0.1 | 2.3.3-p2 |