summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLoïc Pottier <48072795+lpottier@users.noreply.github.com>2022-11-29 04:44:50 -0800
committerGitHub <noreply@github.com>2022-11-29 13:44:50 +0100
commit1270ae1526722de44a0d5c50cb0cc49657f5388b (patch)
tree7e30ca5ef5b269cd04efce7cede1e7e66f0dfe89
parentd15fead30ce0aff12650b11761c04b986d1e0093 (diff)
downloadspack-1270ae1526722de44a0d5c50cb0cc49657f5388b.tar.gz
spack-1270ae1526722de44a0d5c50cb0cc49657f5388b.tar.bz2
spack-1270ae1526722de44a0d5c50cb0cc49657f5388b.tar.xz
spack-1270ae1526722de44a0d5c50cb0cc49657f5388b.zip
hiredis: updated package definition to use CMake (#33949)
-rw-r--r--var/spack/repos/builtin/packages/hiredis/package.py59
1 files changed, 45 insertions, 14 deletions
diff --git a/var/spack/repos/builtin/packages/hiredis/package.py b/var/spack/repos/builtin/packages/hiredis/package.py
index 6cc3df3473..8469d330a0 100644
--- a/var/spack/repos/builtin/packages/hiredis/package.py
+++ b/var/spack/repos/builtin/packages/hiredis/package.py
@@ -6,21 +6,16 @@
from spack.package import *
-class Hiredis(CMakePackage, MakefilePackage):
+class Hiredis(MakefilePackage, CMakePackage):
"""Hiredis is a minimalistic C client library for the Redis database."""
homepage = "https://github.com/redis/hiredis"
- url = "https://github.com/redis/hiredis/archive/v0.14.1.tar.gz"
- git = "https://github.com/redis/hiredis"
+ url = "https://github.com/redis/hiredis/archive/refs/tags/v1.1.0.tar.gz"
+ git = "https://github.com/redis/hiredis.git"
- maintainers = ["rblake-llnl"]
-
- build_system(
- conditional("cmake", when="@1:"),
- conditional("makefile", when="@0"),
- default="cmake",
- )
+ maintainers = ["lpottier", "rblake-llnl"]
+ version("1.1.0", sha256="fe6d21741ec7f3fc9df409d921f47dfc73a4d8ff64f4ac6f1d95f951bf7f53d6")
version("1.0.2", sha256="e0ab696e2f07deb4252dda45b703d09854e53b9703c7d52182ce5a22616c3819")
version("1.0.1", sha256="a420df40775ac7b4b46550dd4df78ffe6620616333496a17c9c9fc556815ba4b")
version("1.0.0", sha256="2a0b5fe5119ec973a0c1966bfc4bd7ed39dbce1cb6d749064af9121fe971936f")
@@ -29,17 +24,53 @@ class Hiredis(CMakePackage, MakefilePackage):
version("0.13.3", sha256="717e6fc8dc2819bef522deaca516de9e51b9dfa68fe393b7db5c3b6079196f78")
version("0.13.2", sha256="b0cf73ebe039fe25ecaaa881acdda8bdc393ed997e049b04fc20865835953694")
+ build_system(
+ conditional("cmake", when="@1:"),
+ conditional("makefile", when="@:0"),
+ default="cmake",
+ )
+
+ variant("ssl", default=False, description="Builds with SSL enabled")
+ variant("test", default=False, description="Builds test suite")
+ variant("test_ssl", default=False, description="Builds test suite for SSL")
+ variant("test_async", default=False, description="Builds test suite for async primitives")
-def darwin_fix(builder):
- fix_darwin_install_name(builder.pkg.prefix.lib)
+ depends_on("cmake@3.18:", type="build", when="build_system=cmake")
+ depends_on("openssl@1.1:", type=("build", "link"), when="+ssl")
+ depends_on("openssl@1.1:", type=("build", "link"), when="+test_ssl")
class MakefileBuilder(spack.build_systems.makefile.MakefileBuilder):
+ @property
+ def build_targets(self):
+ use_ssl = 1 if "+ssl" in self.spec else 0
+ run_test_async = 1 if "+test_async" in self.spec else 0
+ return [
+ "USE_SSL={0}".format(use_ssl),
+ "TEST_ASYNC={0}".format(run_test_async),
+ ]
+
def install(self, pkg, spec, prefix):
make("PREFIX={0}".format(prefix), "install")
+ if "+test" in self.spec or "+test_async" in self.spec or "+test_ssl" in self.spec:
+ make("PREFIX={0}".format(prefix), "test")
- run_after("install", when="platform=darwin")(darwin_fix)
+ @run_after("install")
+ def darwin_fix(self):
+ if self.spec.satisfies("platform=darwin"):
+ fix_darwin_install_name(self.prefix.lib)
class CMakeBuilder(spack.build_systems.cmake.CMakeBuilder):
- run_after("install", when="platform=darwin")(darwin_fix)
+ def cmake_args(self):
+ build_test = not ("+test" in self.spec)
+ ssl_test = ("+test_ssl" in self.spec) and ("+test" in self.spec)
+ async_test = ("+test_async" in self.spec) and ("+test" in self.spec)
+
+ args = [
+ self.define_from_variant("ENABLE_SSL", "ssl"),
+ self.define("DISABLE_TESTS", build_test),
+ self.define("ENABLE_SSL_TESTS", ssl_test),
+ self.define("ENABLE_ASYNC_TESTS", async_test),
+ ]
+ return args