summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--var/spack/repos/builtin/packages/totalview/package.py201
1 files changed, 169 insertions, 32 deletions
diff --git a/var/spack/repos/builtin/packages/totalview/package.py b/var/spack/repos/builtin/packages/totalview/package.py
index 70c64de321..4b25e955ca 100644
--- a/var/spack/repos/builtin/packages/totalview/package.py
+++ b/var/spack/repos/builtin/packages/totalview/package.py
@@ -19,19 +19,22 @@ class Totalview(Package):
be used as the primary source and the architecture appropriate tarball will
be downloaded as a resource."""
- homepage = "https://www.roguewave.com/products-services/totalview"
- maintainers = ["dshrader"]
+ homepage = "https://totalview.io"
+ maintainers = ["dshrader", "petertea"]
manual_download = True
license_required = True
license_comment = "#"
- license_files = ["licenses/license.dat"]
- license_vars = ["TV_LICENSE_FILE"]
+ license_files = ["licenses/license.dat", "licenses/tv_license_file"]
+ license_vars = ["LM_LICENSE_FILE", "TV_LICENSE_FILE"]
# As the install of Totalview is via multiple tarballs, the base install
# will be the documentation. The architecture-specific tarballs are added
# as resources dependent on the specific architecture used.
- version("2021.1.16", sha256="4c51c7b6ab6b6afa7635ba2e9fc3b0ef833806f775a0ad0da26b13d6320625dd")
- version("2019.2.18", sha256="09e5c554032af945f8cf147dd548421267e50e906cc9686fb5cd0e8e63fcf650")
+ version("2022.3.6", sha256="3f60714b8c885c562433e30c8bcde7e6383b3517664f37f25da7bf7f9110f308")
+ version("2022.2.13", sha256="4bf625c760454e532fe66666f2f5479d38f36f569f104bbe3341c0f48cbc8766")
+ version("2022.1.11", sha256="0042afdbb024b99350c395decf2606b6913479ab0117bfd7bd4252d91843ef69")
+ version("2021.4.10", sha256="c476288ebe1964e0803c7316975c71a957e52f45187b135bc1dc3b65491bb61d")
+ version("2021.3.9", sha256="fd947ce755e76a6a06747755aa61bedd0c1428999a46e920db9498ac930ddc29")
# Distributed with Totalview
variant("memoryscape", default=True, description="Install memoryscape")
@@ -39,47 +42,169 @@ class Totalview(Package):
# Because the actual source tarball is architecture dependent, the main
# download is the documentation tarball and the source is downloaded as a
# resource once the target architecture is known.
+
+ # Version 2022.3.6
resource(
- name="x86_64",
- url="totalview_{0}_linux_x86-64.tar".format(version),
+ name="crayx86",
+ url="file://totalview_2022.3.6_linux_x86-64.tar",
+ destination=".",
+ sha256="a2639c52bfd4c7484b728d6a0158239074ff0e0c52208a5452b12b878016a519",
+ when="@2022.3.6 platform=cray target=x86_64:",
+ )
+ resource(
+ name="x86-64",
+ url="file://totalview.2022.3.6-linux-x86-64.tar",
+ destination=".",
+ sha256="a2639c52bfd4c7484b728d6a0158239074ff0e0c52208a5452b12b878016a519",
+ when="@2022.3.6 platform=linux target=x86_64:",
+ )
+ resource(
+ name="ppcle",
+ url="file://totalview_2022.3.6_linux_powerle.tar",
destination=".",
- sha256="3b0ab078deff3654ddc912a004d256f1376978aa1c4dd5a8a41fa9fbb474d07c",
- when="@2019.2.18 target=x86_64:",
+ sha256="93771a6ce99cff6d11e8172ff57da16aed76ab8ad1804e1d18186fba6de945f7",
+ when="@2022.3.6 platform=linux target=ppc64le:",
)
resource(
name="aarch64",
- url="totalview_{0}_linux_arm64.tar".format(version),
+ url="file://totalview_2022.3.6_linux_arm64.tar",
destination=".",
- sha256="3bbda1aa7c06ce82874c1517bf949c9f6cbd0f4c9ebe283d21f0643f6e724b6b",
- when="@2019.2.18 target=aarch64:",
+ sha256="5c18a9a187196980f9bd0fbbb77bb8e5c1d51442188ca44d58a9c49329c98783",
+ when="@2022.3.6 platform=linux target=aarch64:",
+ )
+ resource(
+ name="darwinx86",
+ url="file://totalview.2022.3.6-darwin-x86.tar",
+ destination=".",
+ sha256="f558877f7debbeeef200f587edf4cbba41b6bc8db5a0166757445cc652de8a33",
+ when="@2022.3.6 platform=darwin target=x86_64:",
+ )
+
+ # Version 2022.2.13
+ resource(
+ name="crayx86",
+ url="file://totalview_2022.2.13_linux_x86-64.tar",
+ destination=".",
+ sha256="aebd11b837ce18b8200859ea762caa56e2cea346daa114f2841aa0f05a422309",
+ when="@2022.2.13 platform=cray target=x86_64:",
+ )
+ resource(
+ name="x86-64",
+ url="file://totalview.2022.2.13-linux-x86-64.tar",
+ destination=".",
+ sha256="aebd11b837ce18b8200859ea762caa56e2cea346daa114f2841aa0f05a422309",
+ when="@2022.2.13 platform=linux target=x86_64:",
)
resource(
name="ppcle",
- url="totalview_{0}_linux_powerle.tar".format(version),
+ url="file://totalview_2022.2.13_linux_powerle.tar",
destination=".",
- sha256="c0e4dbf145312fc7143ad0b7e9474e653933581990e0b9d07237c73dbdff8365",
- when="@2019.2.18 target=ppc64le:",
+ sha256="0136be160576b51b03e6409b06d6cc22b5535380894e0fdc6569e2238e12120e",
+ when="@2022.2.13 platform=linux target=ppc64le:",
)
resource(
- name="x86_64",
- url="totalview_{0}_linux_x86-64.tar".format(version),
+ name="aarch64",
+ url="file://totalview_2022.2.13_linux_arm64.tar",
+ destination=".",
+ sha256="d82154222e1ae5fce0bb7abd19b6782494ecb1f76a9a5f38a19e9dcd40bd42aa",
+ when="@2022.2.13 platform=linux target=aarch64:",
+ )
+ resource(
+ name="darwinx86",
+ url="file://totalview.2022.2.13-darwin-x86.tar",
+ destination=".",
+ sha256="abcad08e80967959f556cb9f2a7d6dfa7f38e33213fe56f7f3198ff94cd9f3fe",
+ when="@2022.2.13 platform=darwin target=x86_64:",
+ )
+
+ # Version 2022.1.11
+ resource(
+ name="crayx86",
+ url="file://totalview_2022.1.11_linux_x86-64.tar",
+ destination=".",
+ sha256="3ec9a7d702572dbbafa41726a036c94b549f9a5911ed6fd6aa55f7b377554bac",
+ when="@2022.1.11 platform=cray target=x86_64:",
+ )
+ resource(
+ name="x86-64",
+ url="file://totalview.2022.1.11-linux-x86-64.tar",
destination=".",
- sha256="129e991d3ce4df9f9f04adbf79b62d3c2706d7732ec305f3d3c97a6b4d1f5a13",
- when="@2021.1.16 target=x86_64:",
+ sha256="3ec9a7d702572dbbafa41726a036c94b549f9a5911ed6fd6aa55f7b377554bac",
+ when="@2022.1.11 platform=linux target=x86_64:",
+ )
+ resource(
+ name="ppcle",
+ url="file://totalview_2022.1.11_linux_powerle.tar",
+ destination=".",
+ sha256="4c49546508f7e0b1a91bea3ea8d71f6f9dc76989c69a4fd78012a4ae8fa44aa6",
+ when="@2022.1.11 platform=linux target=ppc64le:",
+ )
+ resource(
+ name="aarch64",
+ url="file://totalview_2022.1.11_linux_arm64.tar",
+ destination=".",
+ sha256="89407c043679d161b6e204fc4ad5686b7ac18742081a045f19388c7294e5ddbe",
+ when="@2022.1.11 platform=linux target=aarch64:",
+ )
+ resource(
+ name="darwinx86",
+ url="file://totalview.2022.1.11-darwin-x86.tar",
+ destination=".",
+ sha256="3a99eda8b7be225e0b7596b3c52032809378c86ea736c88e915c0a0e8efedbe4",
+ when="@2022.1.11 platform=darwin target=x86_64:",
+ )
+
+ # Version 2021.4.10
+ resource(
+ name="crayx86",
+ url="file://totalview_2021.4.10_linux_x86-64.tar",
+ destination=".",
+ sha256="7e5509b2cfb219100b0032304bdad7d422657c0736c386ba64bdb1bf11d10a1d",
+ when="@2021.4.10 platform=cray target=x86_64:",
+ )
+ resource(
+ name="x86-64",
+ url="file://totalview.2021.4.10-linux-x86-64.tar",
+ destination=".",
+ sha256="7e5509b2cfb219100b0032304bdad7d422657c0736c386ba64bdb1bf11d10a1d",
+ when="@2021.4.10 platform=linux target=x86_64:",
+ )
+ resource(
+ name="ppcle",
+ url="file://totalview_2021.4.10_linux_powerle.tar",
+ destination=".",
+ sha256="79e812d1cd600172c5ea29c4aa6fb660d293300683419af36dd0e52cd7e15d56",
+ when="@2021.4.10 platform=linux target=ppc64le:",
)
resource(
name="aarch64",
- url="totalview_{0}_linux_arm64.tar".format(version),
+ url="file://totalview_2021.4.10_linux_arm64.tar",
+ destination=".",
+ sha256="46faaae1f33b4f4a20de345611092fbc65cd5759511c1fcf86ca71a0811c76fd",
+ when="@2021.4.10 platform=linux target=aarch64:",
+ )
+ resource(
+ name="darwinx86",
+ url="file://totalview.2021.4.10-darwin-x86.tar",
+ destination=".",
+ sha256="adbf95f86763e3cc5ec51fd504f3172bdcbb42a7f1f4e73b17cacca002729ad2",
+ when="@2021.4.10 platform=darwin target=x86_64:",
+ )
+
+ # Version 2021.3
+ resource(
+ name="x86_64",
+ url="file://totalview_2021.3.9_linux_x86-64.tar",
destination=".",
- sha256="d559c0e090b2a6b935986324a2f1b20c02c5a2991432b8305952c120db41cdb5",
- when="@2021.1.16 target=aarch64:",
+ sha256="6315ca855e1bee14678c640c3c9c8207b4f66c91714dcedd4aed592354112b48",
+ when="@2021.3.9 platform=linux target=x86_64:",
)
resource(
name="ppcle",
- url="totalview_{0}_linux_powerle.tar".format(version),
+ url="file://totalview_2021.3.9_linux_powerle.tar",
destination=".",
- sha256="88c6bf82bd0807f826e2920967b288ac40e9bc56554e55966dfea793bc9c2b0a",
- when="@2021.1.16 target=ppcle:",
+ sha256="a7657b61895805024f5d4e7550796a485f98ce297a585583cdd20fe0b9b30bbb",
+ when="@2021.3.9 platform=linux target=ppc64le:",
)
def url_for_version(self, version):
@@ -101,7 +226,11 @@ class Totalview(Package):
arg_list = ["-agree", "-nosymlink", "-directory", "{0}".format(prefix)]
# Platform specification.
- if spec.target.family == "x86_64":
+ if spec.target.family == "x86_64" and spec.platform == "linux":
+ arg_list.extend(["-platform", "linux-x86-64"])
+ elif spec.target.family == "x86_64" and spec.platform == "darwin":
+ arg_list.extend(["-platform", "darwin-x86"])
+ elif spec.target.family == "x86_64" and spec.platform == "cray":
arg_list.extend(["-platform", "linux-x86-64"])
elif spec.target.family == "x86":
arg_list.extend(["-platform", "linux-x86"])
@@ -114,18 +243,26 @@ class Totalview(Package):
else:
raise InstallError("Architecture {0} not permitted!".format(spec.target.family))
- # Docs are the 'base' install used with every architecture.
+ # Docs are the "base" install used with every architecture.
install_cmd.exe.extend(arg_list)
install_cmd("-install", "doc-pdf")
- # Run install script for totalview and memoryscape (optional).
+ # Run install script for totalview (which automatically installs memoryscape)
with working_dir("./totalview.{0}".format(self.version)):
install_cmd = which("./Install")
arg_list.extend(["-install", "totalview"])
- # If including memoryscape.
- if "+memoryscape" in spec:
- arg_list.append("memoryscape")
+ # TotalView automatically installs Memoryscape, so no need to add
install_cmd.exe.extend(arg_list)
install_cmd()
+
+ # If a license file was created, link to FNE_license or FNP_license
+ symlink(
+ join_path(self.prefix, "licenses", "tv_license_file"),
+ join_path(self.prefix, "toolworks", "FNE_license", "tv_license_file"),
+ )
+ symlink(
+ join_path(self.prefix, "licenses", "license.dat"),
+ join_path(self.prefix, "toolworks", "FNP_license", "license.dat"),
+ )