summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--var/spack/repos/builtin/packages/pism/package.py171
1 files changed, 171 insertions, 0 deletions
diff --git a/var/spack/repos/builtin/packages/pism/package.py b/var/spack/repos/builtin/packages/pism/package.py
new file mode 100644
index 0000000000..fd9f2a30fb
--- /dev/null
+++ b/var/spack/repos/builtin/packages/pism/package.py
@@ -0,0 +1,171 @@
+##############################################################################
+# 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 Pism(CMakePackage):
+ """Parallel Ice Sheet Model"""
+
+ homepage = "http://pism-docs.org/wiki/doku.php:="
+ url = "https://github.com/pism/pism/archive/v0.7.3.tar.gz"
+
+ maintainers = ['citibeth']
+
+ version('0.7.3', '7cfb034100d99d5c313c4ac06b7f17b6')
+
+ version('0.7.x', git='https://github.com/pism/pism.git',
+ branch='stable0.7')
+
+ version('icebin', git='https://github.com/pism/pism.git',
+ branch='efischer/dev')
+
+ version('develop', git='https://github.com/pism/pism.git',
+ branch='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') # Only the C interface is used, no netcdf-cxx4
+ depends_on('petsc')
+ depends_on('udunits2')
+ depends_on('proj')
+ depends_on('everytrace', when='+everytrace')
+
+ extends('python', when='+python')
+ depends_on('python@2.7:2.8', when='+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,
+ '-DPism_BUILD_EXTRA_EXECS=%s' %
+ ('YES' if '+extra' in spec else 'NO'),
+ '-DBUILD_SHARED_LIBS=%s' %
+ ('YES' if '+shared' in spec else 'NO'),
+ '-DPism_BUILD_PYTHON_BINDINGS=%s' %
+ ('YES' if '+python' in spec else 'NO'),
+ '-DPism_BUILD_ICEBIN=%s' %
+ ('YES' if '+icebin' in spec else 'NO'),
+ '-DPism_USE_PROJ4=%s' %
+ ('YES' if '+proj' in spec else 'NO'),
+ '-DPism_USE_PARALLEL_NETCDF4=%s' %
+ ('YES' if '+parallel-netcdf4' in spec else 'NO'),
+ '-DPism_USE_PNETCDF=%s' %
+ ('YES' if '+parallel-netcdf3' in spec else 'NO'),
+ '-DPism_USE_PARALLEL_HDF5=%s' %
+ ('YES' if '+parallel-hdf5' in spec else 'NO'),
+ '-DPism_BUILD_PDFS=%s' %
+ ('YES' if '+doc' in spec else 'NO'),
+ '-DPism_INSTALL_EXAMPLES=%s' %
+ ('YES' if '+examples' in spec else 'NO'),
+ '-DPism_USE_EVERYTRACE=%s' %
+ ('YES' if '+everytrace' in spec else 'NO')]
+
+ def setup_environment(self, spack_env, 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 |