summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlex Richert <82525672+AlexanderRichert-NOAA@users.noreply.github.com>2023-09-13 18:41:45 -0400
committerGitHub <noreply@github.com>2023-09-13 15:41:45 -0700
commit372bbb43a8e5371cd491985863573b173c9106d2 (patch)
tree70b075e248f8aa5049d3e22f15bd61fd14d34c16
parent7b763faa1ceb843d8278d319b8d92c44e4884e4f (diff)
downloadspack-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.py38
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")