From 1270ae1526722de44a0d5c50cb0cc49657f5388b Mon Sep 17 00:00:00 2001 From: Loïc Pottier <48072795+lpottier@users.noreply.github.com> Date: Tue, 29 Nov 2022 04:44:50 -0800 Subject: hiredis: updated package definition to use CMake (#33949) --- .../repos/builtin/packages/hiredis/package.py | 59 +++++++++++++++++----- 1 file changed, 45 insertions(+), 14 deletions(-) (limited to 'var') 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 -- cgit v1.2.3-70-g09d2