commit:     84b0ebc2a69ba80e91d079ab7b73f54a2a4fbf5f
Author:     Paul Zander <negril.nx+gentoo <AT> gmail <DOT> com>
AuthorDate: Tue Nov 11 13:16:18 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Nov 18 14:56:04 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=84b0ebc2

sci-libs/vtk: add 9.5.2

Bug: https://bugs.gentoo.org/963035
Closes: https://bugs.gentoo.org/966144
Closes: https://bugs.gentoo.org/965701
Signed-off-by: Paul Zander <negril.nx+gentoo <AT> gmail.com>
Part-of: https://github.com/gentoo/gentoo/pull/44665
Signed-off-by: Sam James <sam <AT> gentoo.org>

 sci-libs/vtk/Manifest                        |    6 +
 sci-libs/vtk/files/vtk-9.5.0-cuda-13-1.patch |   99 +++
 sci-libs/vtk/files/vtk-9.5.0-cuda-13-2.patch |   94 +++
 sci-libs/vtk/metadata.xml                    |    3 +-
 sci-libs/vtk/vtk-9.5.2.ebuild                | 1021 ++++++++++++++++++++++++++
 5 files changed, 1222 insertions(+), 1 deletion(-)

diff --git a/sci-libs/vtk/Manifest b/sci-libs/vtk/Manifest
index 3d59af9f9c7d..81b2144a403a 100644
--- a/sci-libs/vtk/Manifest
+++ b/sci-libs/vtk/Manifest
@@ -1,6 +1,12 @@
 DIST VTK-9.4.2.tar.gz 118621433 BLAKE2B 
5e9ffff915e41fad349cb0fc7aba3620e946362a6e91f7291c1a052691cbebfa3d5cb2a686e561f99f44a8aa608caa2d0201ce8b7cabed6337378bf354b69390
 SHA512 
740919c9b63ad91c5ae45b90b502585a78e9f08b32f06308c475d874decc1e99e813c49c67d37586886ad4860e61630cd51569747003dcf88b3fb744c481f515
+DIST VTK-9.5.2.tar.gz 50189467 BLAKE2B 
6e7dab56c4f48d066ca44637f8839e9abc973d2831381ef5aec860aa1daa49ac9beca223e439c12dda2c33056b45395043f2edc54f55f9d169719b6c96499f40
 SHA512 
fc8157a89fa603a7f7fce356e2f638ae69e0ea629a507458bdbb173daf511c61e39a1f0d7201b196a5b3a7ffa7e3e821398b62521faadf85edb1119a1e8b8e8e
 DIST VTKData-9.4.2.tar.gz 1095344755 BLAKE2B 
d995ef59df2d12c85bd8b44280cec3b7b7a9a494ae19c68eda432310e07d92f6da8649f89dd75485c40d49c86ce28bf8e120900a9cb4545454154e04909866b1
 SHA512 
a379d442ad4f378c961aef3e285b87b633412eddc7b28f99893d34c700ce07eae5267dd33e29fd1aa065095e541145cd5baba3d6c54d9da3e00aea0b7573c51c
+DIST VTKData-9.5.2.tar.gz 1096057742 BLAKE2B 
3c50adba539e7457268cd122246361e2161a003264cf4df6a3c7c3b62e9f35026588ad046112c0dd0b8360f6f8f67d5fc6f034bd5cdd4bb67d746dcf2ebb2a86
 SHA512 
1be895bed613ed0f0ace0ba5e138afacc3d61b57e437299b3aecf6beff702ad1a2d02036fd147853bbbcb6a1f9d20a51831c0263fdc5b8e62ece9a6f8f7d410e
 DIST VTKDataFiles-9.4.2.tar.gz 1127688904 BLAKE2B 
7cf79325e3d8b5eb935f936321b5465c77a1764afeb9206c2709cca48044f686cd7a3e450686c145a4d9b47b32c9f1e8b8661b499ea30e1c2c47f9200eb6d1d9
 SHA512 
93bcc16ef7989d2e76effb9b6f778f50f9d0048d1c2a89fa55a6c2c9c8ae228d22cea77f588a729db82c0ab0e87cbd37053c228600fcb9f5734caa3cb714fb7a
+DIST VTKDataFiles-9.5.2.tar.gz 1128658332 BLAKE2B 
c3c3e259479f78bb0cc60b48e00d3fad21dd8bb924e16b87801d230c2f684fc04431873eb7fd5617cb93a09319038f835da17357888ba207f4e10faf19bf6c01
 SHA512 
f3503fea75aa248fb5b225e4e6437fe47b2eabdc39ffd4113e5f87a5d9edd232afef7e21375e40cf3a6e979f399a7fcc5bdc0b09a6759a2baa491eb360ce0c8b
 DIST VTKLargeData-9.4.2.tar.gz 247520755 BLAKE2B 
d006a0b5a9296332cafcee0917dab1db76e90fa145dbb3093b82dcb668ef38947db97711a00d5013e16147eb3df3cad0f501262897ba342741fa1205a115f31f
 SHA512 
7e896f7b3ee2a454f24bd4b55fe10658d90abd4352ca4d1baed4c67c2606dda7a408ca4d807b05362e311432c0961df0cddfa5236e3aa233ddf28e4a3d48cd58
+DIST VTKLargeData-9.5.2.tar.gz 247524517 BLAKE2B 
439daacebf50ff65019b42ba3f9a244428ea1d49951e135a655acd65342d6a7ee6a01c313b2565e574910218eebdd8e0291ecfc4c6615b3111050b7233d5a7c8
 SHA512 
f1ee327bc9ffa4f4055e169b940239031c00e18a3109bb720c5bcc3a68821761c2d5eb573db5245956721cf534b58d3fa737c2ecdac8c90cd3dada565c1a40d5
 DIST VTKLargeDataFiles-9.4.2.tar.gz 247504324 BLAKE2B 
650b1f8b9bc8a386a3172fa091cb27dbdfdfe8a7317d7afe109ec4273bfbf3bb67c947e83b7ae47a096327cfba9bc5d655375a7ae7ff46b85291ed684f2f3497
 SHA512 
c43b3b46a2a3a3ad5938d4b3b323cab8cc51591c9a514abf6fdb33a51009572c6fdb0653b3e49ebe594ab6ff204dbe49f4d9d34a3fb0d56db1b2392674301d02
+DIST VTKLargeDataFiles-9.5.2.tar.gz 247505288 BLAKE2B 
49c02df1cda16b0ff8b447d3785afaef56c15aa447f4bc464676a2b52cd9f9812221e566480ca17990538f69f84ea818b5776c422105a3eb53dc63d5518ca0de
 SHA512 
1ee7beba1ca7eeabe634cf31ff2c377ea708fa0ddd40b60e90ab582e4e439ad130a84449d138040f2c47741026ace4613272409f2b958ebc315a55f62a1fa7e8
 DIST vtkDocHtml-9.4.2.tar.gz 191366459 BLAKE2B 
36edb0abc9b72def067fc8ce937c7f3154b071a73932634d753ab112436cf66a4b2b5ccc5f2a474ada4d869c4b61457e514bb2e52c4ccf3fb7d27150aadaed4c
 SHA512 
3beb5c1e49f897d320069517134b34ce9bb8ef21a38f95f76e9e06a7bd260532e62e540b3e684daa93641525fe0097d272edfe8370a2a4eb72176d0fd3575b87
+DIST vtkDocHtml-9.5.2.tar.gz 193518054 BLAKE2B 
1af2d23d049dbd0ccf6307b3fa0a25c917850c70c7e5ce14e76b02baa7fd4d9be1c2f453dfd1a54b3da30ff8ee5ac374d1ad41225cc6affb3ac29ca037d20687
 SHA512 
76b572f4b4a0bc4c7573334522017578e2eb1cfd83bdc973c515b65ec23a4fe8e2d7914cc1d4c78d574187068df918ccb575904252f96d88ed94428460698721

diff --git a/sci-libs/vtk/files/vtk-9.5.0-cuda-13-1.patch 
b/sci-libs/vtk/files/vtk-9.5.0-cuda-13-1.patch
new file mode 100644
index 000000000000..5a98ca155005
--- /dev/null
+++ b/sci-libs/vtk/files/vtk-9.5.0-cuda-13-1.patch
@@ -0,0 +1,99 @@
+From 00d84bf753a0f4d79ea3025c04862d0308cbcb6b Mon Sep 17 00:00:00 2001
+From: Paul Zander <[email protected]>
+Date: Mon, 25 Aug 2025 21:14:03 +0200
+Subject: [PATCH] cuda 13
+
+Signed-off-by: Paul Zander <[email protected]>
+
+diff --git 
a/ThirdParty/viskores/vtkviskores/viskores/viskores/cont/cuda/internal/CudaAllocator.cu
 
b/ThirdParty/viskores/vtkviskores/viskores/viskores/cont/cuda/internal/CudaAllocator.cu
+index cc2da2b..ad382ee 100644
+--- 
a/ThirdParty/viskores/vtkviskores/viskores/viskores/cont/cuda/internal/CudaAllocator.cu
++++ 
b/ThirdParty/viskores/vtkviskores/viskores/viskores/cont/cuda/internal/CudaAllocator.cu
+@@ -284,10 +284,14 @@ void CudaAllocator::PrepareForControl(const void* ptr, 
std::size_t numBytes)
+ {
+   if (IsManagedPointer(ptr) && numBytes >= Threshold)
+   {
++    // Create device location with specific device ID
++    cudaMemLocation hostLoc;
++    hostLoc.type = cudaMemLocationTypeHost;
++
+     // TODO these hints need to be benchmarked and adjusted once we start
+     // sharing the pointers between cont/exec
+-    VISKORES_CUDA_CALL(cudaMemAdvise(ptr, numBytes, 
cudaMemAdviseSetAccessedBy, cudaCpuDeviceId));
+-    VISKORES_CUDA_CALL(cudaMemPrefetchAsync(ptr, numBytes, cudaCpuDeviceId, 
cudaStreamPerThread));
++    VISKORES_CUDA_CALL(cudaMemAdvise(ptr, numBytes, 
cudaMemAdviseSetAccessedBy, hostLoc));
++    VISKORES_CUDA_CALL(cudaMemPrefetchAsync(ptr, numBytes, hostLoc, 0));
+   }
+ }
+ 
+@@ -299,10 +303,15 @@ void CudaAllocator::PrepareForInput(const void* ptr, 
std::size_t numBytes)
+     viskores::cont::RuntimeDeviceInformation()
+       .GetRuntimeConfiguration(viskores::cont::DeviceAdapterTagCuda())
+       .GetDeviceInstance(dev);
++
++    cudaMemLocation deviceLoc;
++    deviceLoc.type = cudaMemLocationTypeDevice;
++    deviceLoc.id   = dev;
++
+     // VISKORES_CUDA_CALL(cudaMemAdvise(ptr, numBytes, 
cudaMemAdviseSetPreferredLocation, dev));
+     // VISKORES_CUDA_CALL(cudaMemAdvise(ptr, numBytes, 
cudaMemAdviseSetReadMostly, dev));
+-    VISKORES_CUDA_CALL(cudaMemAdvise(ptr, numBytes, 
cudaMemAdviseSetAccessedBy, dev));
+-    VISKORES_CUDA_CALL(cudaMemPrefetchAsync(ptr, numBytes, dev, 
cudaStreamPerThread));
++    VISKORES_CUDA_CALL(cudaMemAdvise(ptr, numBytes, 
cudaMemAdviseSetAccessedBy, deviceLoc));
++    VISKORES_CUDA_CALL(cudaMemPrefetchAsync(ptr, numBytes, deviceLoc, 0, 
cudaStreamPerThread));
+   }
+ }
+ 
+@@ -314,10 +323,15 @@ void CudaAllocator::PrepareForOutput(const void* ptr, 
std::size_t numBytes)
+     viskores::cont::RuntimeDeviceInformation()
+       .GetRuntimeConfiguration(viskores::cont::DeviceAdapterTagCuda())
+       .GetDeviceInstance(dev);
++
++    cudaMemLocation deviceLoc;
++    deviceLoc.type = cudaMemLocationTypeDevice;
++    deviceLoc.id   = dev;
++
+     // VISKORES_CUDA_CALL(cudaMemAdvise(ptr, numBytes, 
cudaMemAdviseSetPreferredLocation, dev));
+     // VISKORES_CUDA_CALL(cudaMemAdvise(ptr, numBytes, 
cudaMemAdviseUnsetReadMostly, dev));
+-    VISKORES_CUDA_CALL(cudaMemAdvise(ptr, numBytes, 
cudaMemAdviseSetAccessedBy, dev));
+-    VISKORES_CUDA_CALL(cudaMemPrefetchAsync(ptr, numBytes, dev, 
cudaStreamPerThread));
++    VISKORES_CUDA_CALL(cudaMemAdvise(ptr, numBytes, 
cudaMemAdviseSetAccessedBy, deviceLoc));
++    VISKORES_CUDA_CALL(cudaMemPrefetchAsync(ptr, numBytes, deviceLoc, 0, 
cudaStreamPerThread));
+   }
+ }
+ 
+@@ -329,10 +343,15 @@ void CudaAllocator::PrepareForInPlace(const void* ptr, 
std::size_t numBytes)
+     viskores::cont::RuntimeDeviceInformation()
+       .GetRuntimeConfiguration(viskores::cont::DeviceAdapterTagCuda())
+       .GetDeviceInstance(dev);
++
++    cudaMemLocation deviceLoc;
++    deviceLoc.type = cudaMemLocationTypeDevice;
++    deviceLoc.id   = dev;
++
+     // VISKORES_CUDA_CALL(cudaMemAdvise(ptr, numBytes, 
cudaMemAdviseSetPreferredLocation, dev));
+     // VISKORES_CUDA_CALL(cudaMemAdvise(ptr, numBytes, 
cudaMemAdviseUnsetReadMostly, dev));
+-    VISKORES_CUDA_CALL(cudaMemAdvise(ptr, numBytes, 
cudaMemAdviseSetAccessedBy, dev));
+-    VISKORES_CUDA_CALL(cudaMemPrefetchAsync(ptr, numBytes, dev, 
cudaStreamPerThread));
++    VISKORES_CUDA_CALL(cudaMemAdvise(ptr, numBytes, 
cudaMemAdviseSetAccessedBy, deviceLoc));
++    VISKORES_CUDA_CALL(cudaMemPrefetchAsync(ptr, numBytes, deviceLoc, 0, 
cudaStreamPerThread));
+   }
+ }
+ 
+diff --git a/ThirdParty/viskores/vtkviskores/viskores/viskores/Swap.h 
b/ThirdParty/viskores/vtkviskores/viskores/viskores/Swap.h
+index 918075e..4d380db 100644
+--- a/ThirdParty/viskores/vtkviskores/viskores/viskores/Swap.h
++++ b/ThirdParty/viskores/vtkviskores/viskores/viskores/Swap.h
+@@ -41,7 +41,8 @@ namespace viskores
+ // defined in the `viskores` namespace as an argument. If that function has 
an unqualified call to
+ // `Swap`, it results in ADL being used, causing the templated functions 
`cub::Swap` and
+ // `viskores::Swap` to conflict.
+-#if defined(VISKORES_CUDA_VERSION_MAJOR) && (VISKORES_CUDA_VERSION_MAJOR >= 
12)
++// This was deprecated in favour of `cuda::std::swap` in CUDA 13.
++#if defined(VISKORES_CUDA_VERSION_MAJOR) && (VISKORES_CUDA_VERSION_MAJOR == 
12)
+ using cub::Swap;
+ #else
+ template <typename T>
+-- 
+2.51.0
+

diff --git a/sci-libs/vtk/files/vtk-9.5.0-cuda-13-2.patch 
b/sci-libs/vtk/files/vtk-9.5.0-cuda-13-2.patch
new file mode 100644
index 000000000000..ad5eea01e3d2
--- /dev/null
+++ b/sci-libs/vtk/files/vtk-9.5.0-cuda-13-2.patch
@@ -0,0 +1,94 @@
+From 5a12651b95801fce812b02bf8f854e9f5a332f6e Mon Sep 17 00:00:00 2001
+From: Paul Zander <[email protected]>
+Date: Tue, 5 Aug 2025 15:17:29 +0200
+Subject: [PATCH] vtk-9.5.0 cuda-13
+
+Signed-off-by: Paul Zander <[email protected]>
+
+diff --git a/Examples/Emscripten/Cxx/WrappedAsyncClipper/CMakeLists.txt 
b/Examples/Emscripten/Cxx/WrappedAsyncClipper/CMakeLists.txt
+index c7762f3..fbf67a2 100644
+--- a/Examples/Emscripten/Cxx/WrappedAsyncClipper/CMakeLists.txt
++++ b/Examples/Emscripten/Cxx/WrappedAsyncClipper/CMakeLists.txt
+@@ -26,7 +26,7 @@ find_package(VTK
+ # Compile example code
+ # 
-----------------------------------------------------------------------------
+ add_executable(WrappedAsyncClipper WrappedAsyncClipper.cxx 
WrappedAsyncClipper.h)
+-target_compile_features(WrappedAsyncClipper PRIVATE cxx_std_14) # for 
initialized lambda captures
++target_compile_features(WrappedAsyncClipper PRIVATE cxx_std_17) # for 
initialized lambda captures
+ target_link_libraries(WrappedAsyncClipper PRIVATE ${VTK_LIBRARIES})
+ 
+ # 
-----------------------------------------------------------------------------
+diff --git 
a/ThirdParty/viskores/vtkviskores/viskores/CMake/ViskoresCompilerFlags.cmake 
b/ThirdParty/viskores/vtkviskores/viskores/CMake/ViskoresCompilerFlags.cmake
+index 246b587..5dd37c2 100644
+--- 
a/ThirdParty/viskores/vtkviskores/viskores/CMake/ViskoresCompilerFlags.cmake
++++ 
b/ThirdParty/viskores/vtkviskores/viskores/CMake/ViskoresCompilerFlags.cmake
+@@ -54,7 +54,7 @@ target_link_libraries(viskores_compiler_flags
+   INTERFACE $<BUILD_INTERFACE:viskores_vectorization_flags>)
+ 
+ # setup that we need C++14 support
+-target_compile_features(viskores_compiler_flags INTERFACE cxx_std_14)
++target_compile_features(viskores_compiler_flags INTERFACE cxx_std_17)
+ 
+ # setup our static libraries so that a separate ELF section
+ # is generated for each function. This allows for the linker to
+diff --git 
a/ThirdParty/viskores/vtkviskores/viskores/CMake/ViskoresDeviceAdapters.cmake 
b/ThirdParty/viskores/vtkviskores/viskores/CMake/ViskoresDeviceAdapters.cmake
+index d1df6aa..232df64 100644
+--- 
a/ThirdParty/viskores/vtkviskores/viskores/CMake/ViskoresDeviceAdapters.cmake
++++ 
b/ThirdParty/viskores/vtkviskores/viskores/CMake/ViskoresDeviceAdapters.cmake
+@@ -106,10 +106,14 @@ if(Viskores_ENABLE_CUDA)
+ 
+     target_compile_options(viskores_cuda INTERFACE 
$<$<COMPILE_LANGUAGE:CUDA>:--expt-relaxed-constexpr>)
+ 
+-    if(CMAKE_CUDA_COMPILER_ID STREQUAL "NVIDIA" AND
+-      CMAKE_CUDA_COMPILER_VERSION VERSION_GREATER_EQUAL 11.0)
+-      # CUDA 11+ deprecated C++11 support
+-      target_compile_features(viskores_cuda INTERFACE cxx_std_14)
++    if(CMAKE_CUDA_COMPILER_ID STREQUAL "NVIDIA")
++      if(CMAKE_CUDA_COMPILER_VERSION VERSION_GREATER_EQUAL 13.0)
++        # CUDA 13+ deprecated C++14 support
++        target_compile_features(viskores_cuda INTERFACE cxx_std_17)
++      elseif(CMAKE_CUDA_COMPILER_VERSION VERSION_GREATER_EQUAL 11.0)
++        # CUDA 11+ deprecated C++11 support
++        target_compile_features(viskores_cuda INTERFACE cxx_std_17)
++      endif()
+     endif()
+ 
+     # If we have specified CMAKE_CUDA_ARCHITECTURES and CMake >= 3.18 we are
+diff --git a/ThirdParty/viskores/vtkviskores/viskores/CMakeLists.txt 
b/ThirdParty/viskores/vtkviskores/viskores/CMakeLists.txt
+index 40289e1..5f4ca11 100644
+--- a/ThirdParty/viskores/vtkviskores/viskores/CMakeLists.txt
++++ b/ThirdParty/viskores/vtkviskores/viskores/CMakeLists.txt
+@@ -20,7 +20,7 @@ cmake_minimum_required(VERSION 3.15 FATAL_ERROR)
+ project (Viskores)
+ 
+ # We only allow c++14
+-set(CMAKE_CXX_STANDARD 14)
++set(CMAKE_CXX_STANDARD 17)
+ set(CMAKE_CXX_STANDARD_REQUIRED ON)
+ 
+ # When using C++14 support make sure you use the standard C++ extensions 
rather
+diff --git 
a/ThirdParty/viskores/vtkviskores/viskores/viskores/thirdparty/diy/viskoresdiy/CMakeLists.txt
 
b/ThirdParty/viskores/vtkviskores/viskores/viskores/thirdparty/diy/viskoresdiy/CMakeLists.txt
+index d7aee18..86b592d 100644
+--- 
a/ThirdParty/viskores/vtkviskores/viskores/viskores/thirdparty/diy/viskoresdiy/CMakeLists.txt
++++ 
b/ThirdParty/viskores/vtkviskores/viskores/viskores/thirdparty/diy/viskoresdiy/CMakeLists.txt
+@@ -161,7 +161,7 @@ function(add_diy_mpi_library use_mpi)
+ 
+     add_library(${lib_name} ${sources})
+     set_target_properties(${lib_name} PROPERTIES POSITION_INDEPENDENT_CODE ON)
+-    target_compile_features(${lib_name} PRIVATE cxx_std_14)
++    target_compile_features(${lib_name} PRIVATE cxx_std_17)
+     target_compile_definitions(${lib_name}
+         PRIVATE -DVISKORESDIY_HAS_MPI=${has_mpi_val}
+         PRIVATE -Ddiy=${diy_prefix}         # mangle diy namespace
+@@ -207,7 +207,7 @@ if (build_diy_mpi_lib)
+ endif() # build_diy_mpi_lib
+ 
+ add_library(${diy_prefix} INTERFACE)
+-target_compile_features(${diy_prefix} INTERFACE cxx_std_14)
++target_compile_features(${diy_prefix} INTERFACE cxx_std_17)
+ target_compile_definitions(${diy_prefix} INTERFACE ${diy_definitions})
+ target_include_directories(${diy_prefix} SYSTEM INTERFACE
+     "$<BUILD_INTERFACE:${PROJECT_SOURCE_DIR}/include>"
+-- 
+2.50.1
+

diff --git a/sci-libs/vtk/metadata.xml b/sci-libs/vtk/metadata.xml
index 32a17561720b..347da8ced6bd 100644
--- a/sci-libs/vtk/metadata.xml
+++ b/sci-libs/vtk/metadata.xml
@@ -27,7 +27,8 @@
     <flag name="rendering">Building Redering modules</flag>
     <flag name="tbb">Use <pkg>dev-cpp/tbb</pkg> to handle smp support</flag>
     <flag name="views">Building Views modules</flag>
-    <flag name="vtkm">Build the vtkm accelerations modules</flag>
+    <flag name="vtkm" restrict="&lt;sci-libs/vtk-9.5">Build the vtkm 
accelerations modules</flag>
+    <flag name="vtkm" restrict="&gt;=sci-libs/vtk-9.5">Build the viskores 
accelerations modules</flag>
     <flag name="web">Install web component</flag>
   </use>
   <upstream>

diff --git a/sci-libs/vtk/vtk-9.5.2.ebuild b/sci-libs/vtk/vtk-9.5.2.ebuild
new file mode 100644
index 000000000000..92e61ee7119a
--- /dev/null
+++ b/sci-libs/vtk/vtk-9.5.2.ebuild
@@ -0,0 +1,1021 @@
+# Copyright 1999-2025 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+# TODO:
+# - add USE flag for remote modules? Those modules can be downloaded properly 
before building.
+# - vtkm was renamed to viskores. Rename once usemove is implemented.
+
+PYTHON_COMPAT=( python3_{11..13} )
+PYTHON_REQ_USE="tk?"
+
+WEBAPP_OPTIONAL=yes
+WEBAPP_MANUAL_SLOT=yes
+
+inherit check-reqs cmake cuda java-pkg-opt-2 multiprocessing python-single-r1 
toolchain-funcs virtualx webapp
+
+# Short package version
+MY_PV="$(ver_cut 1-2)"
+
+DESCRIPTION="The Visualization Toolkit"
+HOMEPAGE="https://www.vtk.org/";
+SRC_URI="
+       https://www.vtk.org/files/release/${MY_PV}/VTK-${PV}.tar.gz
+       doc? (
+               
https://www.vtk.org/files/release/${MY_PV}/vtkDocHtml-${PV}.tar.gz
+       )
+       examples? (
+               
https://www.vtk.org/files/release/${MY_PV}/VTKLargeData-${PV}.tar.gz
+               
https://www.vtk.org/files/release/${MY_PV}/VTKLargeDataFiles-${PV}.tar.gz
+       )
+       test? (
+               https://www.vtk.org/files/release/${MY_PV}/VTKData-${PV}.tar.gz
+               
https://www.vtk.org/files/release/${MY_PV}/VTKDataFiles-${PV}.tar.gz
+               
https://www.vtk.org/files/release/${MY_PV}/VTKLargeData-${PV}.tar.gz
+               
https://www.vtk.org/files/release/${MY_PV}/VTKLargeDataFiles-${PV}.tar.gz
+       )
+"
+S="${WORKDIR}/VTK-${PV}"
+
+LICENSE="BSD LGPL-2"
+SLOT="0/${MY_PV}"
+KEYWORDS="~amd64 ~arm ~arm64 ~x86 ~amd64-linux ~x86-linux"
+
+# TODO: Like to simplify these. Mostly the flags related to Groups.
+IUSE="all-modules boost +cgns cuda debug doc examples ffmpeg gdal gles2-only 
imaging
+       java +logging minimal mpi mysql +netcdf odbc opencascade openmp openvdb 
pdal postgres
+       python qt6 +rendering tbb test +threads tk +truetype video_cards_nvidia 
+views vtkm web"
+
+RESTRICT="!test? ( test )"
+
+REQUIRED_USE="
+       all-modules? (
+               boost cgns ffmpeg gdal imaging mysql netcdf odbc opencascade 
openvdb pdal
+               postgres rendering truetype views
+       )
+       cuda? ( video_cards_nvidia vtkm )
+       java? ( rendering )
+       minimal? ( !gdal !rendering )
+       !minimal? ( cgns netcdf rendering )
+       python? ( ${PYTHON_REQUIRED_USE} )
+       qt6? ( rendering )
+       tk? ( python rendering )
+       web? ( python )
+       rendering? ( truetype views )
+"
+
+# eigen, nlohmann_json, pegtl and utfcpp are referenced in the cmake files
+# and need to be available when VTK consumers configure the dependencies.
+RDEPEND="
+       app-arch/lz4:=
+       app-arch/xz-utils
+       dev-cpp/eigen:=
+       dev-cpp/nlohmann_json
+       dev-db/sqlite:3
+       dev-libs/double-conversion:=
+       dev-libs/expat
+       dev-libs/jsoncpp:=
+       >=dev-libs/libfmt-8.1.1:=
+       dev-libs/libxml2:2=
+       >=dev-libs/pegtl-3
+       dev-libs/pugixml
+       dev-libs/utfcpp
+       media-libs/freetype
+       media-libs/libjpeg-turbo:=
+       media-libs/libogg
+       media-libs/libpng:=
+       media-libs/tiff:=
+       sci-libs/hdf5:=[mpi=]
+       virtual/zlib:=
+       boost? ( dev-libs/boost:=[mpi?] )
+       cgns? (
+               >=sci-libs/cgnslib-4.1.1:=[hdf5,mpi=]
+       )
+       cuda? ( dev-util/nvidia-cuda-toolkit:= )
+       ffmpeg? ( media-video/ffmpeg:= )
+       gdal? ( sci-libs/gdal:= )
+       java? ( >=virtual/jdk-11:= )
+       !minimal? (
+               >=media-libs/libharu-2.4.0:=
+               media-libs/libtheora:=
+               sci-libs/proj:=
+       )
+       mpi? ( virtual/mpi[romio] )
+       mysql? ( dev-db/mariadb-connector-c:= )
+       netcdf? ( sci-libs/netcdf:=[mpi=] )
+       odbc? ( dev-db/unixODBC )
+       openvdb? ( media-gfx/openvdb:= )
+       opencascade? ( sci-libs/opencascade:= )
+       pdal? ( sci-libs/pdal:= )
+       postgres? ( dev-db/postgresql:= )
+       python? (
+               ${PYTHON_DEPS}
+               $(python_gen_cond_dep '
+                       mpi? ( dev-python/mpi4py[${PYTHON_USEDEP}] )
+                       rendering? ( dev-python/matplotlib[${PYTHON_USEDEP}] )
+               ')
+       )
+       qt6? (
+               dev-qt/qtbase:6[gui,opengl,sql,widgets]
+               dev-qt/qtdeclarative:6[opengl]
+               dev-qt/qtshadertools:6
+               x11-libs/libxkbcommon
+       )
+       rendering? (
+               media-libs/libglvnd[X]
+               x11-libs/gl2ps
+               x11-libs/libXcursor
+               x11-libs/libX11
+       )
+       tbb? ( dev-cpp/tbb:= )
+       tk? ( dev-lang/tk:= )
+       truetype? ( media-libs/fontconfig )
+       video_cards_nvidia? ( x11-drivers/nvidia-drivers[tools,static-libs] )
+       views? (
+               x11-libs/libX11
+       )
+       vtkm? (
+               sci-libs/hdf5[cxx]
+               mpi? (
+                       sci-libs/hdf5[unsupported]
+               )
+       )
+       web? ( ${WEBAPP_DEPEND} )
+"
+
+DEPEND="
+       ${RDEPEND}
+       dev-cpp/cli11
+       test? (
+               media-libs/glew
+               x11-libs/libXcursor
+               rendering? ( media-libs/freeglut )
+       )
+"
+BDEPEND="virtual/pkgconfig"
+
+PATCHES=(
+       "${FILESDIR}/${PN}-9.2.5-pegtl-3.x.patch"
+       "${FILESDIR}/${PN}-9.3.0-java.patch"
+
+       "${FILESDIR}/${PN}-9.4.2-pegtl-3.x.patch"
+       "${FILESDIR}/${PN}-9.4.2-ThirdParty-libfmt-12.patch"
+       "${FILESDIR}/${PN}-9.5.0-cuda-13-1.patch"
+       "${FILESDIR}/${PN}-9.5.0-cuda-13-2.patch"
+)
+
+DOCS=( CONTRIBUTING.md README.md )
+
+vtk_check_reqs() {
+       local dsk="$((
+               2048
+               + $(usex cuda 5120 0)
+               + $(usex doc 3072 0)
+               + $(usex examples 2048 0)
+               + $(usex test 8192 0)
+       ))"
+
+       local -x CHECKREQS_DISK_BUILD=${dsk}M
+
+       # In case users are not aware of the extra NINJAOPTS, check
+       # for the more common MAKEOPTS, in case NINJAOPTS is empty
+       local jobs=1
+       if [[ -n "${NINJAOPTS}" ]]; then
+               jobs=$(makeopts_jobs "${NINJAOPTS}" "$(get_nproc)")
+       elif [[ -n "${MAKEOPTS}" ]]; then
+               jobs=$(makeopts_jobs "${MAKEOPTS}" "$(get_nproc)")
+       fi
+
+       if use cuda; then
+               local mem="$((
+                       $(usex cuda $(( 7 * 1024 )) 0) * $(( jobs > 4 ? 4 : 
jobs ))
+               ))"
+               local CHECKREQS_MEMORY=${mem}M
+       fi
+
+       "check-reqs_pkg_${EBUILD_PHASE}"
+}
+
+cuda_get_host_compiler() {
+       if [[ -n "${NVCC_CCBIN}" ]]; then
+               echo "${NVCC_CCBIN}"
+               return
+       fi
+
+       if [[ -n "${CUDAHOSTCXX}" ]]; then
+               echo "${CUDAHOSTCXX}"
+               return
+       fi
+
+       einfo "Trying to find working CUDA host compiler"
+
+       if ! tc-is-gcc && ! tc-is-clang; then
+               die "$(tc-get-compiler-type) compiler is not supported"
+       fi
+
+       local compiler compiler_type compiler_version
+       local package package_version
+       local NVCC_CCBIN_default
+
+       compiler_type="$(tc-get-compiler-type)"
+       compiler_version="$("${compiler_type}-major-version")"
+
+       # try the default compiler first
+       NVCC_CCBIN="$(tc-getCXX)"
+       NVCC_CCBIN_default="${NVCC_CCBIN}-${compiler_version}"
+
+       compiler="${NVCC_CCBIN/%-${compiler_version}}"
+
+       # store the package so we can re-use it later
+       package="sys-devel/${compiler_type}"
+       package_version="${package}"
+
+       ebegin "testing ${NVCC_CCBIN_default} (default)"
+
+       while ! nvcc -v -ccbin "${NVCC_CCBIN}" - -x cu <<<"int main(){}" &>> 
"${T}/cuda_get_host_compiler.log" ; do
+               eend 1
+
+               while true; do
+                       # prepare next version
+                       if ! package_version="<$(best_version 
"${package_version}")"; then
+                               die "could not find a supported version of 
${compiler}"
+                       fi
+
+                       NVCC_CCBIN="${compiler}-$(ver_cut 1 
"${package_version/#<${package}-/}")"
+
+                       [[ "${NVCC_CCBIN}" != "${NVCC_CCBIN_default}" ]] && 
break
+               done
+               ebegin "testing ${NVCC_CCBIN}"
+       done
+       eend $?
+
+       # clean temp file
+       rm -f a.out
+
+       echo "${NVCC_CCBIN}"
+       export NVCC_CCBIN
+}
+
+cuda_get_host_native_arch() {
+       [[ -n ${CUDAARCHS} ]] && echo "${CUDAARCHS}"
+
+       __nvcc_device_query || die "failed to query the native device"
+}
+
+vtk_add_sandbox() {
+       local WRITE=()
+
+       # mesa via virtx will make use of udmabuf if it exists
+       [[ -c "/dev/udmabuf" ]] && WRITE+=( "/dev/udmabuf" )
+
+       readarray -t dris <<<"$(
+               find /sys/class/drm/*/device/drm \
+                       -mindepth 1 -maxdepth 1 -type d -exec basename {} \; \
+                       | sort | uniq | sed 's:^:/dev/dri/:'
+       )"
+
+       [[ -n "${dris[*]}" ]] && WRITE+=( "${dris[@]}" )
+
+       if [[ -d /sys/module/nvidia ]]; then
+               # /dev/nvidia{0-9}
+               readarray -t nvidia_devs <<<"$(
+                       find /dev -regextype posix-extended  -regex 
'/dev/nvidia(|-(nvswitch|vgpu))[0-9]*'
+               )"
+
+               [[ -n "${nvidia_devs[*]}" ]] && WRITE+=( "${nvidia_devs[@]}" )
+
+               WRITE+=(
+                       "/dev/nvidiactl"
+                       "/dev/nvidia-modeset"
+
+                       "/dev/nvidia-vgpuctl"
+
+                       "/dev/nvidia-nvlink"
+                       "/dev/nvidia-nvswitchctl"
+
+                       "/dev/nvidia-uvm"
+                       "/dev/nvidia-uvm-tools"
+
+                       # "/dev/nvidia-caps/nvidia-cap%d"
+                       "/dev/nvidia-caps/"
+                       # "/dev/nvidia-caps-imex-channels/channel%d"
+                       "/dev/nvidia-caps-imex-channels/"
+               )
+       fi
+
+       # for portage
+       WRITE+=( "/proc/self/task/" )
+
+       local dev
+       for dev in "${WRITE[@]}"; do
+               if [[ ! -e "${dev}" ]]; then
+                       eqawarn "${dev} does not exist"
+                       # continue
+               fi
+
+               if [[ -w "${dev}" ]]; then
+                       eqawarn "${dev} is already writable"
+                       # continue
+               fi
+
+               eqawarn "addwrite ${dev}"
+               addwrite "${dev}"
+
+               if [[ ! -d "${dev}" ]] && [[ ! -w "${dev}" ]]; then
+                       eerror "can not access ${dev} after addwrite"
+               fi
+       done
+}
+
+pkg_pretend() {
+       [[ ${MERGE_TYPE} != binary ]] && has openmp && tc-check-openmp
+
+       vtk_check_reqs
+
+       # When building binpkgs you probably want to include all targets
+       if use cuda && [[ ${MERGE_TYPE} == "buildonly" ]] && [[ -n 
"${CUDAARCHS}" ]]; then
+               local info_message="When building a binary package it's 
recommended to unset CUDAARCHS"
+               einfo "$info_message so all available architectures are build."
+       fi
+}
+
+pkg_setup() {
+       [[ ${MERGE_TYPE} != binary ]] && has openmp && tc-check-openmp
+
+       vtk_check_reqs
+
+       if use cuda && [[ ! -e /dev/nvidia-uvm ]]; then
+               # NOTE We try to load nvidia-uvm and nvidia-modeset here,
+               # so __nvcc_device_query does not fail later.
+
+               nvidia-smi -L || true
+       fi
+
+       use java && java-pkg-opt-2_pkg_setup
+       use python && python-single-r1_pkg_setup
+       use web && webapp_pkg_setup
+}
+
+# Note: The following libraries are marked as internal by kitware
+#      and can currently not unbundled:
+#      diy2, exodusII, fides, h5part, kissfft, loguru, verdict, vpic,
+#      viskores, xdmf{2,3}, zfp
+# TODO: exprtk, ioss
+# Note: As of v9.2.2 we no longer drop bundled libraries, when using system
+# libraries. This just saves a little space. CMake logic of VTK on ThirdParty
+# libraries avoids automagic builds, so deletion is not needed to catch these.
+src_prepare() {
+       if use doc; then
+               einfo "Removing .md5 files from documents."
+               rm -f "${WORKDIR}"/html/*.md5 || die "Failed to remove 
superfluous hashes"
+               sed -e "s|\${VTK_BINARY_DIR}/Utilities/Doxygen/doc|${WORKDIR}|" 
\
+                       -i Utilities/Doxygen/CMakeLists.txt || die
+       fi
+
+       cmake_src_prepare
+
+       if use test; then
+               ebegin "Copying data files to ${BUILD_DIR}"
+               mkdir -p "${BUILD_DIR}/ExternalData" || die
+               pushd "${BUILD_DIR}/ExternalData" >/dev/null || die
+               ln -sf "../../${S}/.ExternalData/README.rst" . || die
+               ln -sf "../../${S}/.ExternalData/SHA512" . || die
+               popd >/dev/null || die
+               eend "$?"
+       fi
+}
+
+# TODO: check these and consider to use them
+#      VTK_BUILD_SCALED_SOA_ARRAYS
+#      VTK_DISPATCH_{AOS,SOA,TYPED}_ARRAYS
+src_configure() {
+       local mycmakeargs=(
+               -DCMAKE_DISABLE_FIND_PACKAGE_Git="yes"
+               -DVTK_GIT_DESCRIBE="v${PV}"
+               -DVTK_VERSION_FULL="${PV}"
+               -DGIT_EXECUTABLE="${T}/notgit"
+
+               -DCMAKE_POLICY_DEFAULT_CMP0167="OLD"
+               -DCMAKE_POLICY_DEFAULT_CMP0174="OLD"
+               -DCMAKE_POLICY_DEFAULT_CMP0177="OLD"
+
+               -DCMAKE_INSTALL_LICENSEDIR="share/${PN}/licenses"
+               # c++17 since 9.5.0
+               -DVTK_IGNORE_CMAKE_CXX17_CHECKS="no"
+
+               # -DCMAKE_UNITY_BUILD=ON
+               # -DCMAKE_UNITY_BUILD_BATCH_SIZE=16
+
+               -DVTK_ANDROID_BUILD=OFF
+               -DVTK_IOS_BUILD=OFF
+
+               -DVTK_BUILD_ALL_MODULES="$(usex all-modules)"
+               # we use the pre-built documentation and install these with 
USE=doc
+               -DVTK_BUILD_DOCUMENTATION=OFF
+               -DVTK_BUILD_EXAMPLES="$(usex examples)"
+
+               # no package in the tree: https://github.com/LLNL/conduit
+               -DVTK_ENABLE_CATALYST=OFF
+               -DVTK_ENABLE_KITS=OFF
+               -DVTK_ENABLE_LOGGING="$(usex logging)"
+               # defaults to ON: USE flag for this?
+               -DVTK_ENABLE_REMOTE_MODULES=OFF
+
+               # disable fetching files during build
+               -DVTK_FORBID_DOWNLOADS="yes"
+
+               -DVTK_GROUP_ENABLE_Imaging="$(usex imaging "YES" "NO")"
+               -DVTK_GROUP_ENABLE_MPI="$(usex mpi "YES" "NO")"
+               -DVTK_GROUP_ENABLE_Qt="$(usex qt6 "YES" "NO")"
+               -DVTK_GROUP_ENABLE_Rendering="$(usex rendering "YES" "NO")"
+               -DVTK_GROUP_ENABLE_StandAlone="$(usex minimal "NO" "YES")"
+               -DVTK_GROUP_ENABLE_Views="$(usex views "YES" "NO")"
+               -DVTK_GROUP_ENABLE_Web="$(usex web "YES" "NO")"
+
+               -DVTK_INSTALL_SDK=ON
+
+               -DVTK_MODULE_ENABLE_VTK_IOCGNSReader="$(usex cgns "YES" "NO")"
+               -DVTK_MODULE_ENABLE_VTK_IOExportPDF="$(usex minimal "NO" "YES")"
+               -DVTK_MODULE_ENABLE_VTK_IOLAS="NO" # las is dead
+               -DVTK_MODULE_ENABLE_VTK_IONetCDF="$(usex netcdf "YES" "NO")"
+               -DVTK_MODULE_ENABLE_VTK_IOOCCT="$(usex opencascade "YES" "NO")"
+               -DVTK_MODULE_ENABLE_VTK_IOOggTheora="$(usex minimal "NO" "YES")"
+               -DVTK_MODULE_ENABLE_VTK_IOOpenVDB="$(usex openvdb "YES" "NO")"
+               -DVTK_MODULE_ENABLE_VTK_IOSQL="YES" # sqlite
+               -DVTK_MODULE_ENABLE_VTK_IOPDAL="$(usex pdal "YES" "NO")"
+               -DVTK_MODULE_ENABLE_VTK_IOXML="YES"
+               -DVTK_MODULE_ENABLE_VTK_IOXMLParser="YES"
+               -DVTK_MODULE_ENABLE_VTK_RenderingFreeType="$(usex truetype 
"YES" "NO")"
+               -DVTK_MODULE_ENABLE_VTK_RenderingFreeTypeFontConfig="$(usex 
truetype "YES" "NO")"
+               -DVTK_MODULE_ENABLE_VTK_cgns="$(usex cgns "YES" "NO")"
+               # -DVTK_MODULE_ENABLE_VTK_cli11
+               # -DVTK_MODULE_ENABLE_VTK_dy2
+               -DVTK_MODULE_ENABLE_VTK_doubleconversion="YES"
+               -DVTK_MODULE_ENABLE_VTK_eigen="YES"
+               # -DVTK_MODULE_ENABLE_VTK_exodusII
+               -DVTK_MODULE_ENABLE_VTK_expat="YES"
+               # -DVTK_MODULE_ENABLE_VTK_exprtk
+               # -DVTK_MODULE_ENABLE_VTK_fast_float
+               # -DVTK_MODULE_ENABLE_VTK_fides
+               -DVTK_MODULE_ENABLE_VTK_fmt="YES"
+               -DVTK_MODULE_ENABLE_VTK_freetype="$(usex truetype "YES" "NO")"
+               # -DVTK_MODULE_ENABLE_VTK_glad
+               # -DVTK_MODULE_ENABLE_VTK_h5part
+               -DVTK_MODULE_ENABLE_VTK_hdf5="YES"
+               # -DVTK_MODULE_ENABLE_VTK_ioss
+               -DVTK_MODULE_ENABLE_VTK_jpeg="YES"
+               -DVTK_MODULE_ENABLE_VTK_jsoncpp="YES"
+               # -DVTK_MODULE_ENABLE_VTK_kissfft
+               # -DVTK_MODULE_ENABLE_VTK_kwiml
+               -DVTK_MODULE_ENABLE_VTK_libharu="$(usex minimal "NO" "YES")"
+               -DVTK_MODULE_ENABLE_VTK_libproj="$(usex minimal "NO" "YES")"
+               -DVTK_MODULE_ENABLE_VTK_libxml2="YES"
+               # -DVTK_MODULE_ENABLE_VTK_loguru
+               -DVTK_MODULE_ENABLE_VTK_lz4="YES"
+               -DVTK_MODULE_ENABLE_VTK_lzma="YES"
+               # -DVTK_MODULE_ENABLE_VTK_metaio
+               -DVTK_MODULE_ENABLE_VTK_netcdf="$(usex netcdf "YES" "NO")"
+               -DVTK_MODULE_ENABLE_VTK_nlohmannjson="YES"
+               # -DVTK_MODULE_ENABLE_VTK_octree
+               -DVTK_MODULE_ENABLE_VTK_ogg="YES"
+               -DVTK_MODULE_ENABLE_VTK_pegtl="YES"
+               -DVTK_MODULE_ENABLE_VTK_png="YES"
+               -DVTK_MODULE_ENABLE_VTK_pugixml="YES"
+               # -DVTK_MODULE_ENABLE_VTK_scn
+               -DVTK_MODULE_ENABLE_VTK_sqlite="YES"
+               -DVTK_MODULE_ENABLE_VTK_theora="$(usex minimal "NO" "YES")"
+               -DVTK_MODULE_ENABLE_VTK_tiff="YES"
+               # -DVTK_MODULE_ENABLE_VTK_token
+               -DVTK_MODULE_ENABLE_VTK_utf8="YES"
+               # -DVTK_MODULE_ENABLE_VTK_verdict
+               # -DVTK_MODULE_ENABLE_VTK_vpic
+               # -DVTK_MODULE_ENABLE_VTK_vtksys
+               -DVTK_MODULE_ENABLE_VTK_vtkviskores="$(usex vtkm "YES" "NO")"
+               # -DVTK_MODULE_ENABLE_VTK_xdmf2
+               # -DVTK_MODULE_ENABLE_VTK_xdmf3
+               -DVTK_MODULE_ENABLE_VTK_zlib="YES"
+
+               # not packaged in Gentoo
+               -DVTK_MODULE_USE_EXTERNAL_VTK_fast_float=OFF
+               -DVTK_MODULE_USE_EXTERNAL_VTK_exprtk=OFF
+               -DVTK_MODULE_USE_EXTERNAL_VTK_ioss=OFF
+               -DVTK_MODULE_USE_EXTERNAL_VTK_token=OFF
+               -DVTK_MODULE_USE_EXTERNAL_VTK_verdict=OFF
+               -DVTK_MODULE_USE_EXTERNAL_VTK_vtkviskores=OFF
+
+               -DVTK_RELOCATABLE_INSTALL=ON
+               -DVTK_UNIFIED_INSTALL_TREE=ON
+
+               -DVTK_SMP_ENABLE_OPENMP="$(usex openmp)"
+               -DVTK_SMP_ENABLE_STDTHREAD="$(usex threads)"
+               -DVTK_SMP_ENABLE_TBB="$(usex tbb)"
+
+               -DVTK_USE_CUDA="$(usex cuda)"
+               -DVTK_USE_KOKKOS="no" # "$(usex hip)" # requires kokkos
+               # use system libraries where possible
+               -DVTK_USE_EXTERNAL=ON
+               # avoid finding package from either ::guru or ::sci
+               -DVTK_USE_MEMKIND=OFF
+               -DVTK_USE_MPI="$(usex mpi)"
+               -DVTK_USE_TK="$(usex tk)"
+               -DVTK_USE_X=ON
+
+               -DVTK_WHEEL_BUILD=OFF
+
+               -DVTK_WRAP_JAVA="$(usex java)"
+               -DVTK_WRAP_PYTHON="$(usex python)"
+       )
+
+       if use all-modules; then
+               mycmakeargs+=(
+                       # no package in ::gentoo
+                       -DVTK_ENABLE_OSPRAY=OFF
+                       # TODO: some of these are tied to the 
VTK_ENABLE_REMOTE_MODULES
+                       # option. Check whether we can download them clean and 
enable
+                       # them.
+                       -DVTK_MODULE_ENABLE_VTK_DomainsMicroscopy="NO"
+                       -DVTK_MODULE_ENABLE_VTK_fides="NO"
+                       -DVTK_MODULE_ENABLE_VTK_FiltersOpenTURNS="NO"
+                       -DVTK_MODULE_ENABLE_VTK_IOADIOS2="NO"
+                       -DVTK_MODULE_ENABLE_VTK_IOFides="NO"
+
+                       -DVTK_MODULE_ENABLE_VTK_RenderingOpenVR="NO"
+                       -DVTK_MODULE_ENABLE_VTK_RenderingOpenXR="NO"
+
+                       -DVTK_MODULE_USE_EXTERNAL_VTK_cli11="YES"
+               )
+       fi
+
+       if use boost; then
+               mycmakeargs+=(
+                       -DVTK_MODULE_ENABLE_VTK_InfovisBoost="YES"
+                       
-DVTK_MODULE_ENABLE_VTK_InfovisBoostGraphAlgorithms="YES"
+               )
+       fi
+
+       if use cuda; then
+               cuda_add_sandbox -w
+               addwrite "/proc/self/task"
+               addpredict "/dev/char/"
+
+               if ! test -w /dev/nvidiactl; then
+                       # eqawarn "Can't access the GPU at /dev/nvidiactl."
+                       # eqawarn "User $(id -nu) is not in the group 
\"video\"."
+                       if [[ -z "${CUDAARCHS}" ]]; then
+                               # build all targets
+                               mycmakeargs+=(
+                                       -DCMAKE_CUDA_ARCHITECTURES="all"
+                               )
+                       fi
+               else
+                       local -x CUDAARCHS
+                       : "${CUDAARCHS:="$(cuda_get_host_native_arch)"}"
+               fi
+
+               # set NVCC_CCBIN
+               local -x CUDAHOSTCXX CUDAHOSTLD
+               CUDAHOSTCXX="$(cuda_get_host_compiler)"
+               CUDAHOSTLD="$(tc-getCXX)"
+               export NVCC_CCBIN="${CUDAHOSTCXX}"
+
+               if tc-is-gcc; then
+                       # Filter out IMPLICIT_LINK_DIRECTORIES picked up by 
CMAKE_DETERMINE_COMPILER_ABI(CUDA)
+                       # See 
/usr/share/cmake/Help/variable/CMAKE_LANG_IMPLICIT_LINK_DIRECTORIES.rst
+                       CMAKE_CUDA_IMPLICIT_LINK_DIRECTORIES_EXCLUDE=$(
+                               "${CUDAHOSTLD}" -E -v - <<<"int main(){}" |& \
+                               grep LIBRARY_PATH | cut -d '=' -f 2 | cut -d 
':' -f 1
+                       )
+               fi
+       fi
+
+       if use debug; then
+               mycmakeargs+=(
+                       -DVTK_DEBUG_LEAKS=ON
+                       -DVTK_DEBUG_MODULE=ON
+                       -DVTK_DEBUG_MODULE_ALL=ON
+                       -DVTK_ENABLE_SANITIZER=ON
+                       -DVTK_EXTRA_COMPILER_WARNINGS=ON
+                       -DVTK_WARN_ON_DISPATCH_FAILURE=ON
+               )
+               if use rendering; then
+                       mycmakeargs+=( 
-DVTK_OPENGL_ENABLE_STREAM_ANNOTATIONS=ON )
+               fi
+       fi
+
+       if use examples || use test; then
+               mycmakeargs+=( -DVTK_USE_LARGE_DATA=ON )
+       fi
+
+       if use ffmpeg; then
+               mycmakeargs+=( -DVTK_MODULE_ENABLE_VTK_IOFFMPEG="YES" )
+               if use rendering; then
+                       mycmakeargs+=( 
-DVTK_MODULE_ENABLE_VTK_RenderingFFMPEGOpenGL2="YES" )
+               fi
+       fi
+
+       if use gdal; then
+               mycmakeargs+=(
+                       -DVTK_MODULE_ENABLE_VTK_GeovisGDAL="YES"
+                       -DVTK_MODULE_ENABLE_VTK_IOGDAL="YES"
+                       -DVTK_MODULE_ENABLE_VTK_IOGeoJSON="YES"
+               )
+       fi
+
+       if use imaging; then
+               mycmakeargs+=(
+                       -DVTK_MODULE_ENABLE_VTK_ImagingColor="YES"
+                       -DVTK_MODULE_ENABLE_VTK_ImagingCore="YES"
+                       -DVTK_MODULE_ENABLE_VTK_ImagingFourier="YES"
+                       -DVTK_MODULE_ENABLE_VTK_ImagingGeneral="YES"
+                       -DVTK_MODULE_ENABLE_VTK_ImagingHybrid="YES"
+                       -DVTK_MODULE_ENABLE_VTK_ImagingMath="YES"
+                       -DVTK_MODULE_ENABLE_VTK_ImagingMorphological="YES"
+                       -DVTK_MODULE_ENABLE_VTK_ImagingOpenGL2="YES"
+                       -DVTK_MODULE_ENABLE_VTK_ImagingSources="YES"
+                       -DVTK_MODULE_ENABLE_VTK_ImagingStatistics="YES"
+                       -DVTK_MODULE_ENABLE_VTK_ImagingStencil="YES"
+               )
+               use rendering && mycmakeargs+=( 
-DVTK_MODULE_ENABLE_VTK_RenderingImage="YES" )
+       fi
+
+       if ! use java && ! use python; then
+               # defaults to ON
+               mycmakeargs+=( -DVTK_ENABLE_WRAPPING=OFF )
+       fi
+
+       if use java; then
+               mycmakeargs+=(
+                       -DCMAKE_INSTALL_JARDIR="share/${PN}"
+                       -DVTK_ENABLE_WRAPPING=ON
+                       -DVTK_MODULE_ENABLE_VTK_Java="YES"
+                       -DVTK_JAVA_RELEASE_VERSION="$(java-config -g 
PROVIDES_VERSION)"
+               )
+       fi
+
+       if use minimal; then
+               mycmakeargs+=(
+                       
-DVTK_MODULE_ENABLE_VTK_CommonComputationalGeometry="YES"
+                       -DVTK_MODULE_ENABLE_VTK_CommonExecutionModel="YES"
+                       -DVTK_MODULE_ENABLE_VTK_CommonMath="YES"
+                       -DVTK_MODULE_ENABLE_VTK_CommonMisc="YES"
+                       -DVTK_MODULE_ENABLE_VTK_CommonSystem="YES"
+                       -DVTK_MODULE_ENABLE_VTK_CommonTransforms="YES"
+
+                       -DVTK_MODULE_ENABLE_VTK_FiltersCellGrid="YES"
+                       -DVTK_MODULE_ENABLE_VTK_FiltersCore="YES"
+                       -DVTK_MODULE_ENABLE_VTK_FiltersExtraction="YES"
+                       -DVTK_MODULE_ENABLE_VTK_FiltersGeneral="YES"
+                       -DVTK_MODULE_ENABLE_VTK_FiltersGeneric="YES"
+                       -DVTK_MODULE_ENABLE_VTK_FiltersGeometry="YES"
+                       -DVTK_MODULE_ENABLE_VTK_FiltersHybrid="NO"
+                       -DVTK_MODULE_ENABLE_VTK_FiltersHyperTree="YES"
+                       -DVTK_MODULE_ENABLE_VTK_FiltersReduction="YES"
+                       -DVTK_MODULE_ENABLE_VTK_FiltersSources="YES"
+                       -DVTK_MODULE_ENABLE_VTK_FiltersStatistics="YES"
+                       -DVTK_MODULE_ENABLE_VTK_FiltersVerdict="YES"
+
+                       -DVTK_MODULE_ENABLE_VTK_IOCellGrid="YES"
+                       -DVTK_MODULE_ENABLE_VTK_IOCore="YES"
+                       -DVTK_MODULE_ENABLE_VTK_IOGeometry="NO"
+                       -DVTK_MODULE_ENABLE_VTK_IOLegacy="YES"
+
+                       -DVTK_MODULE_ENABLE_VTK_ParallelCore="YES"
+                       -DVTK_MODULE_ENABLE_VTK_ParallelDIY="YES"
+               )
+       fi
+
+       if use mpi; then
+               mycmakeargs+=(
+                       -DVTK_MODULE_ENABLE_VTK_IOH5part="YES"
+                       -DVTK_MODULE_ENABLE_VTK_IOMPIParallel="YES"
+                       -DVTK_MODULE_ENABLE_VTK_IOParallel="YES"
+                       -DVTK_MODULE_ENABLE_VTK_IOParallelNetCDF="$(usex netcdf 
"YES" "NO")"
+                       -DVTK_MODULE_ENABLE_VTK_IOParallelXML="YES"
+                       -DVTK_MODULE_ENABLE_VTK_ParallelMPI="YES"
+                       -DVTK_MODULE_ENABLE_VTK_h5part="YES"
+                       -DVTK_MODULE_USE_EXTERNAL_VTK_verdict=OFF
+               )
+               use imaging && mycmakeargs+=( 
-DVTK_MODULE_ENABLE_VTK_IOMPIImage="YES" )
+               use python && mycmakeargs+=( 
-DVTK_MODULE_ENABLE_VTK_ParallelMPI4Py="YES" )
+               if use rendering; then
+                       mycmakeargs+=(
+                               -DVTK_MODULE_ENABLE_VTK_RenderingParallel="YES"
+                               
-DVTK_MODULE_ENABLE_VTK_RenderingParallelLIC="YES"
+                       )
+               fi
+               use vtkm && mycmakeargs+=( -DVTKm_ENABLE_MPI=ON )
+       fi
+
+       use mysql && mycmakeargs+=( -DVTK_MODULE_ENABLE_VTK_IOMySQL="YES" )
+       use odbc && mycmakeargs+=( -DVTK_MODULE_ENABLE_VTK_IOODBC="YES" )
+       use openvdb && mycmakeargs+=( 
-DOpenVDB_CMAKE_PATH="${ESYSROOT}/usr/$(get_libdir)/cmake/OpenVDB" )
+       use postgres && mycmakeargs+=( 
-DVTK_MODULE_ENABLE_VTK_IOPostgreSQL="YES" )
+
+       if use python; then
+               mycmakeargs+=(
+                       -DPython3_EXECUTABLE="${PYTHON}"
+                       -DVTK_ENABLE_WRAPPING=ON
+                       -DVTK_MODULE_ENABLE_VTK_Python="YES"
+                       -DVTK_MODULE_ENABLE_VTK_PythonInterpreter="YES"
+                       -DVTK_MODULE_ENABLE_VTK_WrappingPythonCore="YES"
+                       -DVTK_PYTHON_OPTIONAL_LINK="OFF"
+                       
-DVTK_PYTHON_SITE_PACKAGES_SUFFIX="lib/${EPYTHON}/site-packages"
+               )
+               use rendering && mycmakeargs+=( 
-DVTK_MODULE_ENABLE_VTK_PythonContext2D="YES" )
+       fi
+
+       if use qt6; then
+               mycmakeargs+=(
+                       
-DCMAKE_INSTALL_QMLDIR="${EPFREIX}/usr/$(get_libdir)/qt6/qml"
+                       -DVTK_QT_VERSION="6"
+                       -DVTK_MODULE_ENABLE_VTK_GUISupportQt="YES"
+                       -DVTK_MODULE_ENABLE_VTK_GUISupportQtQuick="YES"
+               )
+
+               if has_version "dev-qt/qtbase:6[gles2-only]" || use gles2-only; 
then
+                       mycmakeargs+=(
+                               # Force using EGL & GLES
+                               -DVTK_OPENGL_HAS_EGL=ON
+                               -DVTK_OPENGL_USE_GLES=ON
+                       )
+               fi
+               if use mysql || use postgres; then
+                       mycmakeargs+=( 
-DVTK_MODULE_ENABLE_VTK_GUISupportQtSQL="YES" )
+               fi
+               if use rendering; then
+                       mycmakeargs+=( 
-DVTK_MODULE_ENABLE_VTK_RenderingQt="YES" )
+               fi
+               if use views; then
+                       mycmakeargs+=( -DVTK_MODULE_ENABLE_VTK_ViewsQt="YES" )
+               fi
+       fi
+
+       if use rendering; then
+               mycmakeargs+=(
+                       -DVTK_ENABLE_OSPRAY=OFF
+
+                       -DVTK_MODULE_ENABLE_VTK_IOExportGL2PS="YES"
+                       -DVTK_MODULE_ENABLE_VTK_RenderingAnari="NO"  # no 
package in ::gentoo
+                       -DVTK_MODULE_ENABLE_VTK_RenderingAnnotation="YES"
+                       -DVTK_MODULE_ENABLE_VTK_RenderingContext2D="YES"
+                       -DVTK_MODULE_ENABLE_VTK_RenderingContextOpenGL2="YES"
+                       -DVTK_MODULE_ENABLE_VTK_RenderingCore="YES"
+                       -DVTK_MODULE_ENABLE_VTK_RenderingExternal="YES"
+                       -DVTK_MODULE_ENABLE_VTK_RenderingGL2PSOpenGL2="YES"
+                       -DVTK_MODULE_ENABLE_VTK_RenderingHyperTreeGrid="YES"
+                       -DVTK_MODULE_ENABLE_VTK_RenderingLICOpenGL2="YES"
+                       -DVTK_MODULE_ENABLE_VTK_RenderingLOD="YES"
+                       -DVTK_MODULE_ENABLE_VTK_RenderingLabel="YES"
+                       -DVTK_MODULE_ENABLE_VTK_RenderingOpenGL2="YES"
+                       -DVTK_MODULE_ENABLE_VTK_RenderingRayTracing="YES"
+                       -DVTK_MODULE_ENABLE_VTK_RenderingSceneGraph="YES"
+                       -DVTK_MODULE_ENABLE_VTK_RenderingUI="YES"
+                       -DVTK_MODULE_ENABLE_VTK_RenderingVolume="YES"
+                       -DVTK_MODULE_ENABLE_VTK_RenderingVolumeAMR="YES"
+                       -DVTK_MODULE_ENABLE_VTK_RenderingVolumeOpenGL2="YES"
+                       -DVTK_MODULE_ENABLE_VTK_gl2ps="YES"
+               )
+               use python && mycmakeargs+=( 
-DVTK_MODULE_ENABLE_VTK_RenderingMatplotlib="YES" )
+               use tk && mycmakeargs+=( 
-DVTK_MODULE_ENABLE_VTK_RenderingTk="YES" )
+               use views && mycmakeargs+=( 
-DVTK_MODULE_ENABLE_VTK_ViewsContext2D="YES" )
+               use web && mycmakeargs+=( 
-DVTK_MODULE_ENABLE_VTK_RenderingVtkJS="YES" )
+       fi
+
+       # Testing has been changed in 9.2.5: it is now allowed without
+       # requiring to download, if the data files are available locally!
+       if use test; then
+               mycmakeargs+=(
+                       -DVTK_BUILD_TESTING=ON
+                       # disable fetching data files for the default 'all' 
target
+                       -DVTK_DATA_EXCLUDE_FROM_ALL=OFF
+
+                       # requested even if all use flags are off
+                       -DVTK_MODULE_ENABLE_VTK_octree="YES"
+                       -DVTK_MODULE_ENABLE_VTK_ViewsCore="YES"
+
+                       -DVTK_MODULE_USE_EXTERNAL_VTK_cli11="YES"
+                       # not packaged in Gentoo
+                       -DVTK_MODULE_USE_EXTERNAL_VTK_scn=OFF
+               )
+       else
+               mycmakeargs+=( -DVTK_BUILD_TESTING=OFF )
+       fi
+
+       # FIXME: upstream provides 4 threading models, as of 9.1.0. These are
+       # sequential, stdthread, openmp and tbb. AFAICS all of them can be
+       # enabled at the same time. Sequential and STDThread are enabled by
+       # default. The default selected type for the build is sequential.
+       # Assuming sequential < STDThread < openmp < tbb wrt speed, although
+       # this is dependent on the actual scenario where threading is used.
+       if use tbb; then
+               mycmakeargs+=( -DVTK_SMP_IMPLEMENTATION_TYPE="TBB" )
+       elif use openmp; then # FIXME doesn't work with clang
+               mycmakeargs+=( -DVTK_SMP_IMPLEMENTATION_TYPE="OpenMP" )
+       elif use threads; then
+               mycmakeargs+=( -DVTK_SMP_IMPLEMENTATION_TYPE="STDThread" )
+       else
+               mycmakeargs+=( -DVTK_SMP_IMPLEMENTATION_TYPE="Sequential" )
+       fi
+
+       if use tk; then
+               mycmakeargs+=(
+                       -DVTK_GROUP_ENABLE_Tk="YES"
+               )
+       fi
+
+       if use views; then
+               mycmakeargs+=(
+                       -DVTK_MODULE_ENABLE_VTK_ViewsCore="YES"
+                       -DVTK_MODULE_ENABLE_VTK_ViewsInfovis="YES"
+               )
+       fi
+
+       if use vtkm; then
+               mycmakeargs+=(
+                       -DVTK_MODULE_ENABLE_VTK_AcceleratorsVTKmCore="YES"
+                       -DVTK_MODULE_ENABLE_VTK_AcceleratorsVTKmDataModel="YES"
+                       -DVTK_MODULE_ENABLE_VTK_AcceleratorsVTKmFilters="YES"
+                       -DViskores_ENABLE_CPACK="no" # "Enable CPack packaging 
of Viskores" ON
+                       -DViskores_ENABLE_CUDA="$(usex cuda)" # "Enable Cuda 
support" OFF
+                       -DViskores_ENABLE_DOCUMENTATION="$(usex doc)" # "Build 
Doxygen documentation" OFF
+                       -DViskores_ENABLE_EXAMPLES="$(usex examples)" # "Build 
examples" OFF
+                       -DViskores_ENABLE_HDF5_IO="yes" # "Enable HDF5 support" 
OFF
+                       -DViskores_HDF5_IS_PARALLEL="$(usex mpi)"
+                       -DViskores_ENABLE_LOGGING="$(usex logging)" # "Enable 
Viskores Logging" ON
+                       -DViskores_ENABLE_MPI="$(usex mpi)" # "Enable MPI 
support" OFF
+                       -DViskores_ENABLE_OPENMP="$(usex openmp)" # "Enable 
OpenMP support" OFF
+                       -DViskores_ENABLE_RENDERING="$(usex rendering)" # 
"Enable rendering library" ON
+                       -DViskores_ENABLE_TBB="$(usex tbb)" # "Enable TBB 
support" OFF
+                       -DViskores_ENABLE_TESTING="$(usex test)" # "Enable 
Viskores Testing" ON
+                       -DViskores_ENABLE_TUTORIALS="no" # "Build tutorials" OFF
+                       -DViskores_NO_ASSERT_CUDA="yes" # "Disable assertions 
for CUDA devices." ON
+                       -DViskores_NO_ASSERT_HIP="yes" # "Disable assertions 
for HIP devices." ON
+                       -DViskores_NO_ASSERT="no" # "Disable assertions in 
debugging builds." OFF
+                       -DViskores_NO_INSTALL_README_LICENSE="ON" # bug #793221 
# "disable the installation of README and LICENSE files" OFF
+                       -DViskores_SKIP_LIBRARY_VERSIONS="no" # "Skip 
versioning VTK-m libraries" OFF
+                       -DViskores_Vectorization="none" # only sets compiler 
flags
+               )
+       fi
+
+       if use web; then
+               mycmakeargs+=(
+                       -DVTK_MODULE_ENABLE_VTK_WebCore="YES"
+                       -DVTK_MODULE_ENABLE_VTK_WebGLExporter="YES"
+               )
+               use python && mycmakeargs+=( 
-DVTK_MODULE_ENABLE_VTK_WebPython="YES" )
+       fi
+
+       cmake_src_configure
+}
+
+src_compile() {
+       use test && cmake_build VTKData
+       cmake_src_compile
+}
+
+src_test() {
+       vtk_add_sandbox
+
+       addwrite /dev/fuse
+
+       # The build system prepends /usr/$(get_libdir) to the RUNPATH instead 
of appending.
+       # Set LD_LIBRARY_PATH to use the just build libraries.
+       local -x 
LD_LIBRARY_PATH="${BUILD_DIR}/$(get_libdir)${LD_LIBRARY_PATH:+:$LD_LIBRARY_PATH}"
+
+       # export VTK_SMP_BACKEND_IN_USE="STDThread"
+
+       local -a CMAKE_SKIP_TESTS
+
+       if [[ "${CMAKE_RUN_OPTIONAL_TESTS:=no}" != "yes" ]]; then
+               local -a REALLY_BAD_TESTS BAD_TESTS RANDOM_FAIL_TESTS
+
+               # don't work at all
+               REALLY_BAD_TESTS=(
+                       # (Failed)
+                       "VTK::ChartsCoreCxx-TestLinePlot3D$"
+                       
"VTK::CommonDataModelCxx-TestHyperTreeGridGeometricLocator$"
+                       "VTK::FiltersCoreCxx-TestImplicitPolyDataDistanceCube$"
+                       
"VTK::FiltersCoreCxx-TestQuadricDecimationMaximumError$" # test alone
+                       "VTK::FiltersCorePython-TestSphereTreeFilter$"
+                       
"VTK::FiltersFlowPathsCxx-TestEvenlySpacedStreamlines2D$"
+                       "VTK::FiltersFlowPathsCxx-TestParticleTracers$"
+                       "VTK::FiltersGeneralCxx-TestContourTriangulatorHoles$"
+                       "VTK::IOExportGL2PSCxx-TestGL2PSBillboardTextActor3D"
+                       "VTK::IOExportGL2PSCxx-TestGL2PSExporterRaster"
+                       "VTK::IOExportGL2PSCxx-TestGL2PSExporterVolumeRaster"
+                       "VTK::IOExportGL2PSCxx-TestGL2PSLabeledDataMapper"
+                       "VTK::IOExportGL2PSCxx-TestGL2PSTextActor"
+                       "VTK::IOExportGL2PSCxx-TestGL2PSTextMapper"
+                       "VTK::InteractionWidgetsCxx-TestFinitePlaneWidget$" # 
test alone
+                       "VTK::InteractionWidgetsPython-TestTensorWidget2$" # 
fails under xvfb
+                       "VTK::RenderingCorePython-pickImageData$"
+                       "VTK::RenderingExternalCxx-TestGLUTRenderWindow$"
+                       
"VTK::RenderingFreeTypeFontConfigCxx-TestSystemFontRendering$"
+                       "VTK::RenderingOpenGL2Cxx-TestGlyph3DMapperPickability$"
+                       # (Subprocess aborted)
+                       # File missing? 
ExternalData/Testing/Data/MotionFX/position_file/Sprocket_New.prn
+                       "VTK::IOMotionFXCxx-TestMotionFXCFGReaderPositionFile$"
+                       "VTK::RenderingOpenGL2Cxx-TestFluidMapper$"
+               )
+
+               # don't work in src_test but when on their own
+               BAD_TESTS=(
+               )
+
+               if use vtkm && use cuda; then
+                       REALLY_BAD_TESTS+=(
+                               # vtkm + cuda
+                               # (Subprocess aborted)
+                               
"VTK::AcceleratorsVTKmFiltersCxx-TestVTKMAbort$" #
+                               "VTK::AcceleratorsVTKmFiltersCxx-TestVTKMClip$" 
#
+                               
"VTK::AcceleratorsVTKmFiltersCxx-TestVTKMClipWithImplicitFunction$" #
+                               
"VTK::AcceleratorsVTKmFiltersPython-TestVTKMSlice$" #
+                       )
+               fi
+
+               RANDOM_FAIL_TESTS=(
+                       # (Failed)
+                       "VTK::FiltersVerdictCxx-TestCellQuality$"
+                       "VTK::FiltersCellGridCxx-TestCellGridEvaluator$"
+               )
+
+               CMAKE_SKIP_TESTS+=(
+                       "${REALLY_BAD_TESTS[@]}"
+                       "${BAD_TESTS[@]}"
+                       "${RANDOM_FAIL_TESTS[@]}"
+               )
+       fi
+
+       CMAKE_SKIP_TESTS+=(
+               # requires VTK_USE_MICROSOFT_MEDIA_FOUNDATION
+               "^VTK::IOMovieCxx-Test" # Skipped
+       )
+
+       # see VTK_SMP_IMPLEMENTATION_TYPE
+       if use tbb; then
+               local -x VTK_SMP_BACKEND_IN_USE="TBB"
+       # # FIXME Times out under openmp
+       # elif use openmp; then
+       #       local -x VTK_SMP_BACKEND_IN_USE="OpenMP"
+       elif use threads; then
+               local -x VTK_SMP_BACKEND_IN_USE="STDThread"
+       else
+               local -x VTK_SMP_BACKEND_IN_USE="Sequential"
+       fi
+
+       if use openmp; then
+               CMAKE_SKIP_TESTS+=(
+                       "^VTK::CommonCoreCxx-TestSMP$"
+               )
+       fi
+
+       # TODO Why?
+       local -x CC="$(tc-getCC)"
+       local -x CXX="$(tc-getCXX)"
+
+       virtx cmake_src_test -j1
+}
+
+src_install() {
+       use web && webapp_src_preinst
+
+       # Stop web page images from being compressed
+       if use doc; then
+               HTML_DOCS=( "${WORKDIR}/html/." )
+       fi
+
+       cmake_src_install
+
+       use java && java-pkg_regjar "${ED}/usr/share/${PN}/${PN}.jar"
+
+       # install examples
+       if use examples; then
+               einfo "Installing examples"
+               mv -v {E,e}xamples || die
+               dodoc -r examples
+               docompress -x "/usr/share/doc/${PF}/examples"
+
+               einfo "Installing datafiles"
+               insinto "/usr/share/${PN}/data"
+               doins -r "${S}/.ExternalData"
+       fi
+
+       use python && python_optimize
+
+       use web && webapp_src_install
+}
+
+# webapp.eclass exports these but we want it optional #534036
+pkg_postinst() {
+       use web && webapp_pkg_postinst
+
+       if use examples; then
+               einfo "You can get more and updated examples at"
+               einfo "https://kitware.github.io/vtk-examples/site/";
+       fi
+}
+
+pkg_prerm() {
+       use web && webapp_pkg_prerm
+}


Reply via email to