summaryrefslogtreecommitdiff
path: root/var/spack/repos/builtin/packages/symengine/package.py
diff options
context:
space:
mode:
Diffstat (limited to 'var/spack/repos/builtin/packages/symengine/package.py')
-rw-r--r--var/spack/repos/builtin/packages/symengine/package.py160
1 files changed, 75 insertions, 85 deletions
diff --git a/var/spack/repos/builtin/packages/symengine/package.py b/var/spack/repos/builtin/packages/symengine/package.py
index 28ecc89bce..ae927c88ba 100644
--- a/var/spack/repos/builtin/packages/symengine/package.py
+++ b/var/spack/repos/builtin/packages/symengine/package.py
@@ -13,58 +13,54 @@ class Symengine(CMakePackage):
"""SymEngine is a fast symbolic manipulation library, written in C++."""
homepage = "https://symengine.org"
- url = "https://github.com/symengine/symengine/archive/v0.2.0.tar.gz"
- git = "https://github.com/symengine/symengine.git"
- maintainers = ['HaoZeke', 'jppelteret']
+ url = "https://github.com/symengine/symengine/archive/v0.2.0.tar.gz"
+ git = "https://github.com/symengine/symengine.git"
+ maintainers = ["HaoZeke", "jppelteret"]
- version('master', branch='master')
- version('0.9.0', sha256='dcf174ac708ed2acea46691f6e78b9eb946d8a2ba62f75e87cf3bf4f0d651724')
- version('0.8.1', sha256='41eb6ae6901c09e53d7f61f0758f9201e81fc534bfeecd4b2bd4b4e6f6768693')
- version('0.7.0', sha256='8b865bb72b71539d9cd2488a0468c6c3ea90cc606062a7880c3ff5af6abd74b1')
- version('0.6.0', sha256='4d2caa86c03eaaa8ed004084d02f87b5c51b6229f8ba70d161227e22d6302f0a')
- version('0.5.0', sha256='5d02002f00d16a0928d1056e6ecb8f34fd59f3bfd8ed0009a55700334dbae29b')
- version('0.4.0', sha256='dd755901a9e2a49e53ba3bbe3f565f94265af05299e57a7b592186dd35916a1b')
- version('0.3.0', sha256='591463cb9e741d59f6dfd39a7943e3865d3afe9eac47d1a9cbf5ca74b9c49476')
- version('0.2.0', sha256='64d050b0b9decd12bf4ea3b7d18d3904dd7cb8baaae9fbac1b8068e3c59709be')
- version('0.1.0', sha256='daba3ba0ae91983a772f66bf755b1953c354fe6dc353588b23705d9a79b011fc')
+ version("master", branch="master")
+ version("0.9.0", sha256="dcf174ac708ed2acea46691f6e78b9eb946d8a2ba62f75e87cf3bf4f0d651724")
+ version("0.8.1", sha256="41eb6ae6901c09e53d7f61f0758f9201e81fc534bfeecd4b2bd4b4e6f6768693")
+ version("0.7.0", sha256="8b865bb72b71539d9cd2488a0468c6c3ea90cc606062a7880c3ff5af6abd74b1")
+ version("0.6.0", sha256="4d2caa86c03eaaa8ed004084d02f87b5c51b6229f8ba70d161227e22d6302f0a")
+ version("0.5.0", sha256="5d02002f00d16a0928d1056e6ecb8f34fd59f3bfd8ed0009a55700334dbae29b")
+ version("0.4.0", sha256="dd755901a9e2a49e53ba3bbe3f565f94265af05299e57a7b592186dd35916a1b")
+ version("0.3.0", sha256="591463cb9e741d59f6dfd39a7943e3865d3afe9eac47d1a9cbf5ca74b9c49476")
+ version("0.2.0", sha256="64d050b0b9decd12bf4ea3b7d18d3904dd7cb8baaae9fbac1b8068e3c59709be")
+ version("0.1.0", sha256="daba3ba0ae91983a772f66bf755b1953c354fe6dc353588b23705d9a79b011fc")
- variant('boostmp', default=False,
- description='Compile with Boost multi-precision integer library')
- variant('flint', default=False,
- description='Compile with Flint integer library')
- variant('llvm', default=False,
- description='Compile with LLVM JIT compiler support')
- variant('mpc', default=True,
- description='Compile with MPC library')
- variant('mpfr', default=True,
- description='Compile with MPFR library')
- variant('openmp', default=False,
- description='Enable OpenMP support')
- variant('piranha', default=False,
- description='Compile with Piranha integer library')
- variant('thread_safe', default=True,
- description='Enable thread safety option')
- variant('shared', default=True,
- description='Enables the build of shared libraries')
- variant('build_type', default='Release',
- description='The build type to build',
- values=('Debug', 'Release'))
+ variant(
+ "boostmp", default=False, description="Compile with Boost multi-precision integer library"
+ )
+ variant("flint", default=False, description="Compile with Flint integer library")
+ variant("llvm", default=False, description="Compile with LLVM JIT compiler support")
+ variant("mpc", default=True, description="Compile with MPC library")
+ variant("mpfr", default=True, description="Compile with MPFR library")
+ variant("openmp", default=False, description="Enable OpenMP support")
+ variant("piranha", default=False, description="Compile with Piranha integer library")
+ variant("thread_safe", default=True, description="Enable thread safety option")
+ variant("shared", default=True, description="Enables the build of shared libraries")
+ variant(
+ "build_type",
+ default="Release",
+ description="The build type to build",
+ values=("Debug", "Release"),
+ )
# NOTE: mpir is a drop-in replacement for gmp
# NOTE: [mpc,mpfr,flint,piranha] could also be built against mpir
- depends_on('boost', when='+boostmp')
+ depends_on("boost", when="+boostmp")
# TODO: replace this with an explicit list of components of Boost,
# for instance depends_on('boost +filesystem')
# See https://github.com/spack/spack/pull/22303 for reference
- depends_on(Boost.with_default_variants, when='+boostmp')
- depends_on('cereal', when='@0.9:')
- depends_on('gmp', when='~boostmp')
- depends_on('llvm', when='+llvm')
- depends_on('mpc', when='+mpc~boostmp')
- depends_on('mpfr', when='+mpfr~boostmp')
- depends_on('flint', when='+flint~boostmp')
- depends_on('piranha', when='+piranha~flint~boostmp')
+ depends_on(Boost.with_default_variants, when="+boostmp")
+ depends_on("cereal", when="@0.9:")
+ depends_on("gmp", when="~boostmp")
+ depends_on("llvm", when="+llvm")
+ depends_on("mpc", when="+mpc~boostmp")
+ depends_on("mpfr", when="+mpfr~boostmp")
+ depends_on("flint", when="+flint~boostmp")
+ depends_on("piranha", when="+piranha~flint~boostmp")
def cmake_args(self):
spec = self.spec
@@ -72,53 +68,47 @@ class Symengine(CMakePackage):
# See https://github.com/symengine/symengine/blob/master/README.md
# for build options
- options.extend([
- '-DWITH_SYMENGINE_RCP:BOOL=ON',
- '-DWITH_SYMENGINE_THREAD_SAFE:BOOL=%s' % (
- 'ON' if ('+thread_safe' or '+openmp') in spec else 'OFF'),
- self.define('BUILD_TESTS', self.run_tests),
- '-DBUILD_BENCHMARKS:BOOL=ON',
- self.define_from_variant('WITH_LLVM', 'llvm'),
- self.define_from_variant('WITH_OPENMP', 'openmp'),
- self.define_from_variant('BUILD_SHARED_LIBS', 'shared'),
- ])
+ options.extend(
+ [
+ "-DWITH_SYMENGINE_RCP:BOOL=ON",
+ "-DWITH_SYMENGINE_THREAD_SAFE:BOOL=%s"
+ % ("ON" if ("+thread_safe" or "+openmp") in spec else "OFF"),
+ self.define("BUILD_TESTS", self.run_tests),
+ "-DBUILD_BENCHMARKS:BOOL=ON",
+ self.define_from_variant("WITH_LLVM", "llvm"),
+ self.define_from_variant("WITH_OPENMP", "openmp"),
+ self.define_from_variant("BUILD_SHARED_LIBS", "shared"),
+ ]
+ )
- if sys.platform == 'darwin':
- options.extend([
- '-DCMAKE_INSTALL_RPATH_USE_LINK_PATH:BOOL=on'
- ])
+ if sys.platform == "darwin":
+ options.extend(["-DCMAKE_INSTALL_RPATH_USE_LINK_PATH:BOOL=on"])
# The use of the Cereal serialization library is a hard dependency
- if spec.satisfies('@0.9:'):
- options.extend([
- '-DWITH_SYSTEM_CEREAL:BOOL=on'
- ])
+ if spec.satisfies("@0.9:"):
+ options.extend(["-DWITH_SYSTEM_CEREAL:BOOL=on"])
- if '+boostmp' in spec:
- options.extend([
- '-DINTEGER_CLASS:STRING=boostmp',
- '-DBoost_INCLUDE_DIR=%s' % spec['boost'].prefix.include,
- '-DWITH_MPC:BOOL=OFF',
- '-DWITH_MPFR:BOOL=OFF',
- ])
+ if "+boostmp" in spec:
+ options.extend(
+ [
+ "-DINTEGER_CLASS:STRING=boostmp",
+ "-DBoost_INCLUDE_DIR=%s" % spec["boost"].prefix.include,
+ "-DWITH_MPC:BOOL=OFF",
+ "-DWITH_MPFR:BOOL=OFF",
+ ]
+ )
else:
- options.extend([
- self.define_from_variant('WITH_MPC', 'mpc'),
- self.define_from_variant('WITH_MPFR', 'mpfr'),
- ])
- if '+flint' in spec:
- options.extend([
- '-DWITH_FLINT:BOOL=ON',
- '-DINTEGER_CLASS:STRING=flint'
- ])
- elif '+piranha' in spec:
- options.extend([
- '-DWITH_PIRANHA:BOOL=ON',
- '-DINTEGER_CLASS:STRING=piranha'
- ])
+ options.extend(
+ [
+ self.define_from_variant("WITH_MPC", "mpc"),
+ self.define_from_variant("WITH_MPFR", "mpfr"),
+ ]
+ )
+ if "+flint" in spec:
+ options.extend(["-DWITH_FLINT:BOOL=ON", "-DINTEGER_CLASS:STRING=flint"])
+ elif "+piranha" in spec:
+ options.extend(["-DWITH_PIRANHA:BOOL=ON", "-DINTEGER_CLASS:STRING=piranha"])
else:
- options.extend([
- '-DINTEGER_CLASS:STRING=gmp'
- ])
+ options.extend(["-DINTEGER_CLASS:STRING=gmp"])
return options