# Copyright 2013-2023 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.package 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") license("GPL-3.0-only") 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", when="@1.1:") 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) patch("pism-petsc-3.18.diff", when="@1.1.4 ^petsc@3.18:") # 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="+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 |