summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJacob Merson <mersoj@rpi.edu>2021-05-14 03:45:04 -0400
committerGitHub <noreply@github.com>2021-05-14 07:45:04 +0000
commit117dfcae25b3d1d072a9a79302970918815a9372 (patch)
treeb367c3625563c4e1b7919b2b2215ca49fc9128e0
parent702f343fb1e85bca8a850e6a6a9c011d4bef353f (diff)
downloadspack-117dfcae25b3d1d072a9a79302970918815a9372.tar.gz
spack-117dfcae25b3d1d072a9a79302970918815a9372.tar.bz2
spack-117dfcae25b3d1d072a9a79302970918815a9372.tar.xz
spack-117dfcae25b3d1d072a9a79302970918815a9372.zip
model-traits: add new package (#23589)
-rw-r--r--var/spack/repos/builtin/packages/model-traits/package.py56
1 files changed, 56 insertions, 0 deletions
diff --git a/var/spack/repos/builtin/packages/model-traits/package.py b/var/spack/repos/builtin/packages/model-traits/package.py
new file mode 100644
index 0000000000..980d6f5b8d
--- /dev/null
+++ b/var/spack/repos/builtin/packages/model-traits/package.py
@@ -0,0 +1,56 @@
+# 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 ModelTraits(CMakePackage):
+ """ Model setup and querying in C++. """
+
+ homepage = "https://github.com/jacobmerson/model-traits/"
+ url = "https://github.com/jacobmerson/model-traits/archive/refs/tags/v0.1.0.tar.gz"
+ git = "https://github.com/jacobmerson/model-traits.git"
+
+ maintainers = ['jacobmerson']
+
+ version('0.1.1', sha256='75af53b4f576071570fdcfa7a4ce150b935cf21368da41d16d8377c5b3b93713')
+ version('0.1.0', sha256='ff7c1c5be6977f1d3dc592e8b6c5bff5a8b7ea80d0f059d85c02300bdb8faf2c')
+ version('main', branch='main')
+
+ variant('yaml', default=True, description='build the Yaml IO backend')
+ variant('simmetrix', default=False, description='build the Simmetrix backend')
+ variant('pumi', default=False, description='build the pumi examples')
+
+ depends_on('yaml-cpp@0.6.3:', when='+yaml')
+ depends_on('catch2@3.0.0-preview3:', type='test')
+ depends_on('pumi', when='+pumi')
+ depends_on('simmetrix-simmodsuite', when='+simmetrix')
+ depends_on('fmt@7.1.3')
+ depends_on('cmake@3.14.0:', type='build')
+ depends_on('mpi', when='+simmetrix')
+ depends_on('mpi', when='+pumi')
+
+ def cmake_args(self):
+ args = [self.define('BUILD_TESTING', self.run_tests)]
+ if self.spec.satisfies('@:0.1.1'):
+ args.extend([self.define('BUILD_EXTERNAL', False),
+ self.define_from_variant('ENABLE_SCOREC', 'pumi'),
+ self.define_from_variant('ENABLE_SIMMETRIX', 'simmetrix'),
+ self.define_from_variant('ENABLE_YAML', 'yaml')])
+ else:
+ args.extend([self.define('MODEL_TRAITS_BUILD_EXTERNAL', False),
+ self.define_from_variant('MODEL_TRAITS_ENABLE_SCOREC', 'pumi'),
+ self.define_from_variant('MODEL_TRAITS_ENABLE_SIMMETRIX',
+ 'simmetrix'),
+ self.define_from_variant('MODEL_TRAITS_ENABLE_YAML', 'yaml')])
+ if "+simmetrix" in self.spec:
+ args.append(self.define('SIM_MPI', self.spec['mpi'].name +
+ self.spec['mpi'].version.string))
+ args.append(self.define('SKIP_SIMMETRIX_VERSION_CHECK', True))
+ if '+pumi' in self.spec or "+simmetrix" in self.spec:
+ args.extend([self.define("CMAKE_CXX_COMPILER", self.spec['mpi'].mpicxx),
+ self.define("CMAKE_C_COMPILER", self.spec['mpi'].mpicc),
+ self.define("CMAKE_Fortran_COMPILER", self.spec['mpi'].mpif77)])
+ return args