summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorHarmen Stoppels <harmenstoppels@gmail.com>2023-06-23 20:02:38 +0200
committerGitHub <noreply@github.com>2023-06-23 14:02:38 -0400
commite76b039997042b376f2c6d095bcfd91c69129269 (patch)
tree7bd0caae521a15decf8e6567602c1dfef1039807
parentb49d098e3f6711f562a335b8d7f18ab91bf361a2 (diff)
downloadspack-e76b039997042b376f2c6d095bcfd91c69129269.tar.gz
spack-e76b039997042b376f2c6d095bcfd91c69129269.tar.bz2
spack-e76b039997042b376f2c6d095bcfd91c69129269.tar.xz
spack-e76b039997042b376f2c6d095bcfd91c69129269.zip
zlib-ng: add latest, default to drop in replacement of zlib (#37370)
-rw-r--r--var/spack/repos/builtin/packages/zlib-ng/package.py31
1 files changed, 25 insertions, 6 deletions
diff --git a/var/spack/repos/builtin/packages/zlib-ng/package.py b/var/spack/repos/builtin/packages/zlib-ng/package.py
index 199347bbb1..a15dbdb086 100644
--- a/var/spack/repos/builtin/packages/zlib-ng/package.py
+++ b/var/spack/repos/builtin/packages/zlib-ng/package.py
@@ -3,26 +3,45 @@
#
# SPDX-License-Identifier: (Apache-2.0 OR MIT)
+from spack.build_systems import autotools, cmake
from spack.package import *
-class ZlibNg(CMakePackage):
+class ZlibNg(AutotoolsPackage, CMakePackage):
"""zlib replacement with optimizations for next generation systems."""
homepage = "https://github.com/zlib-ng/zlib-ng"
url = "https://github.com/zlib-ng/zlib-ng/archive/2.0.0.tar.gz"
+ version("2.1.2", sha256="383560d6b00697c04e8878e26c0187b480971a8bce90ffd26a5a7b0f7ecf1a33")
+ version("2.0.7", sha256="6c0853bb27738b811f2b4d4af095323c3d5ce36ceed6b50e5f773204fb8f7200")
version("2.0.0", sha256="86993903527d9b12fc543335c19c1d33a93797b3d4d37648b5addae83679ecd8")
- variant("compat", default=False, description="Enable compatibility API")
+ variant("compat", default=True, description="Enable compatibility API")
variant("opt", default=True, description="Enable optimizations")
- depends_on("cmake@3.5.1:", type="build")
+ # Default to autotools, since cmake would result in circular dependencies if it's not
+ # reused.
+ build_system("autotools", "cmake", default="autotools")
+ with when("build_system=cmake"):
+ depends_on("cmake@3.5.1:", type="build")
+ depends_on("cmake@3.14.0:", type="build", when="@2.1.0:")
+
+
+class AutotoolsBuilder(autotools.AutotoolsBuilder):
+ def configure_args(self):
+ args = []
+ if self.spec.satisfies("+compat"):
+ args.append("--zlib-compat")
+ if self.spec.satisfies("~opt"):
+ args.append("--without-optimizations")
+ return args
+
+
+class CMakeBuilder(cmake.CMakeBuilder):
def cmake_args(self):
- args = [
+ return [
self.define_from_variant("ZLIB_COMPAT", "compat"),
self.define_from_variant("WITH_OPTIM", "opt"),
]
-
- return args