diff options
author | Alex Richert <82525672+AlexanderRichert-NOAA@users.noreply.github.com> | 2023-09-13 18:41:45 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-09-13 15:41:45 -0700 |
commit | 372bbb43a8e5371cd491985863573b173c9106d2 (patch) | |
tree | 70b075e248f8aa5049d3e22f15bd61fd14d34c16 | |
parent | 7b763faa1ceb843d8278d319b8d92c44e4884e4f (diff) | |
download | spack-372bbb43a8e5371cd491985863573b173c9106d2.tar.gz spack-372bbb43a8e5371cd491985863573b173c9106d2.tar.bz2 spack-372bbb43a8e5371cd491985863573b173c9106d2.tar.xz spack-372bbb43a8e5371cd491985863573b173c9106d2.zip |
ip recipe updates (#39997)
-rw-r--r-- | var/spack/repos/builtin/packages/ip/package.py | 38 |
1 files changed, 29 insertions, 9 deletions
diff --git a/var/spack/repos/builtin/packages/ip/package.py b/var/spack/repos/builtin/packages/ip/package.py index d34dc2abd8..8854ecc135 100644 --- a/var/spack/repos/builtin/packages/ip/package.py +++ b/var/spack/repos/builtin/packages/ip/package.py @@ -13,9 +13,12 @@ class Ip(CMakePackage): homepage = "https://noaa-emc.github.io/NCEPLIBS-ip" url = "https://github.com/NOAA-EMC/NCEPLIBS-ip/archive/refs/tags/v3.3.3.tar.gz" + git = "https://github.com/NOAA-EMC/NCEPLIBS-ip" - maintainers("t-brown", "AlexanderRichert-NOAA", "edwardhartnett", "Hang-Lei-NOAA") + maintainers("AlexanderRichert-NOAA", "edwardhartnett", "Hang-Lei-NOAA") + version("develop", branch="develop") + version("4.2.0", sha256="9b9f47106822044ff224c6dfd9f140c146dffc833904f2a0c5db7b5d8932e39e") version("4.1.0", sha256="b83ca037d9a5ad3eb0fb1acfe665c38b51e01f6bd73ce9fb8bb2a14f5f63cdbe") version("4.0.0", sha256="a2ef0cc4e4012f9cb0389fab6097407f4c623eb49772d96eb80c44f804aa86b8") version( @@ -29,15 +32,28 @@ class Ip(CMakePackage): variant("shared", default=False, description="Build shared library", when="@4.1:") variant( "precision", - default=["4", "d"], - values=["4", "d"], + default=("4", "d"), + values=("4", "d"), multi=True, description="Set precision (_4/_d library versions)", - when="@4.1:", + when="@4.1", ) + variant( + "precision", + default=("4", "d"), + values=("4", "d", "8"), + multi=True, + description="Set precision (_4/_d/_8 library versions)", + when="@4.2:", + ) + + conflicts("+shared ~pic") depends_on("sp") depends_on("sp@:2.3.3", when="@:4.0") + depends_on("sp precision=4", when="precision=4") + depends_on("sp precision=d", when="precision=d") + depends_on("sp precision=8", when="precision=8") def cmake_args(self): args = [ @@ -46,15 +62,15 @@ class Ip(CMakePackage): ] if self.spec.satisfies("@4:"): - args.append(self.define("BUILD_TESTING", "NO")) + args.append(self.define("BUILD_TESTING", self.run_tests)) else: args.append(self.define("ENABLE_TESTS", "NO")) if self.spec.satisfies("@4.1:"): args.append(self.define_from_variant("BUILD_SHARED_LIBS", "shared")) - for prec in ["4", "d"]: - if not self.spec.satisfies("precision=" + prec): - args += ["-DBUILD_%s:BOOL=OFF" % prec.upper()] + args.append(self.define("BUILD_4", self.spec.satisfies("precision=4"))) + args.append(self.define("BUILD_D", self.spec.satisfies("precision=d"))) + args.append(self.define("BUILD_8", self.spec.satisfies("precision=8"))) return args @@ -62,7 +78,7 @@ class Ip(CMakePackage): suffixes = ( self.spec.variants["precision"].value if self.spec.satisfies("@4.1:") - else ["4", "8", "d"] + else ("4", "8", "d") ) shared = False if self.spec.satisfies("@:4.0") else self.spec.satisfies("+shared") for suffix in suffixes: @@ -71,3 +87,7 @@ class Ip(CMakePackage): ) env.set("IP_LIB" + suffix, lib[0]) env.set("IP_INC" + suffix, join_path(self.prefix, "include_" + suffix)) + + def check(self): + with working_dir(self.builder.build_directory): + make("test") |