commit:     c8c159c93f5495f05da439b054764c771649971d
Author:     Matthias Maier <tamiko <AT> gentoo <DOT> org>
AuthorDate: Wed Feb  4 20:04:18 2026 +0000
Commit:     Matthias Maier <tamiko <AT> gentoo <DOT> org>
CommitDate: Wed Feb  4 20:08:29 2026 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c8c159c9

sci-visualization/paraview: add 6.0.1

Closes: https://bugs.gentoo.org/952703
Signed-off-by: Matthias Maier <tamiko <AT> gentoo.org>

 sci-visualization/paraview/Manifest                |   1 +
 .../paraview-6.0.1-avoid_file_collisions.patch     |  12 ++
 .../paraview/files/paraview-6.0.1-qt-6.10.patch    |  80 +++++++
 sci-visualization/paraview/paraview-6.0.1.ebuild   | 236 +++++++++++++++++++++
 4 files changed, 329 insertions(+)

diff --git a/sci-visualization/paraview/Manifest 
b/sci-visualization/paraview/Manifest
index 6c2eae18ed11..60f792d4fe30 100644
--- a/sci-visualization/paraview/Manifest
+++ b/sci-visualization/paraview/Manifest
@@ -1,2 +1,3 @@
 DIST ParaView-v5.13.2.tar.xz 147014296 BLAKE2B 
c9e841ff91099a54f66d1eca0659b2b33d0870917d02ba7f0efaf66d8b008439f35a8957dcd4a01efc0246423c178b3c3a5fcdff0de929892dbb332c001ceb12
 SHA512 
828db2425cd73aaccaa1d76b0e1a4a0fec69d069698b6797603204519eb01aad12dbcfa3e5a540cea37664ec9d47b17bc67f27c7603d79f76a6b8c53fade40b6
 DIST ParaView-v5.13.3.tar.xz 85255156 BLAKE2B 
bce853c06d28303f85f1a64a95cc10aea36d50f553729a2d9fcccea74d7ac3c451f3cf4fda8d97faf25e74dfd125f77ca32cccca2d34acdf3fc01292c6ed055f
 SHA512 
2a862ae28c05af683e63a7c4a317f70bd58dc804354c84f70bca38689ef8e954ddec5b90218e5f1673ce7d8324d01a4a31b602a02dffdfd1e5b2abe8f54d10b7
+DIST ParaView-v6.0.1.tar.xz 89088960 BLAKE2B 
e19a8b56f619fb47630152439af3ac7f3be1138b938db443f579e87a9c403bdd8b38798fa591c3607232252ebca49b62762935bb03f0ac416399d9502a24820d
 SHA512 
ae6303061e11686b4fb06d98cbfce4ba058d51cd95c7da3c86d6bda69e2db9df92c74482e10e605f52280c803dc92605a644c19a641c171797e0dd520f00e7bf

diff --git 
a/sci-visualization/paraview/files/paraview-6.0.1-avoid_file_collisions.patch 
b/sci-visualization/paraview/files/paraview-6.0.1-avoid_file_collisions.patch
new file mode 100644
index 000000000000..864562fdc0ba
--- /dev/null
+++ 
b/sci-visualization/paraview/files/paraview-6.0.1-avoid_file_collisions.patch
@@ -0,0 +1,12 @@
+diff --git a/VTK/CMake/vtkVersion.cmake b/VTK/CMake/vtkVersion.cmake
+index c22be0fd..bf759a75 100644
+--- a/VTK/CMake/vtkVersion.cmake
++++ b/VTK/CMake/vtkVersion.cmake
+@@ -1,6 +1,6 @@
+ # VTK version number components.
+ set(VTK_MAJOR_VERSION 9)
+-set(VTK_MINOR_VERSION 5)
++set(VTK_MINOR_VERSION 99)
+ 
+ # Git conflict avoidance barrier. When branching for an `X.Y.0.rc1` branch, if
+ # the date component is updated while it is in progress, the bump of the minor

diff --git a/sci-visualization/paraview/files/paraview-6.0.1-qt-6.10.patch 
b/sci-visualization/paraview/files/paraview-6.0.1-qt-6.10.patch
new file mode 100644
index 000000000000..bc68106a9c70
--- /dev/null
+++ b/sci-visualization/paraview/files/paraview-6.0.1-qt-6.10.patch
@@ -0,0 +1,80 @@
+diff --git a/Qt/Core/pqFlatTreeViewEventTranslator.cxx 
b/Qt/Core/pqFlatTreeViewEventTranslator.cxx
+index 52775c6f..3a62c534 100644
+--- a/Qt/Core/pqFlatTreeViewEventTranslator.cxx
++++ b/Qt/Core/pqFlatTreeViewEventTranslator.cxx
+@@ -73,8 +73,8 @@ bool pqFlatTreeViewEventTranslator::translateEvent(QObject* 
Object, QEvent* Even
+ 
+       QString info = QString("%1,%2,%3,%4,%5,%6")
+                        .arg(mouseEvent->button())
+-                       .arg(mouseEvent->buttons())
+-                       .arg(mouseEvent->modifiers())
++                       .arg(static_cast<int>(mouseEvent->buttons()))
++                       .arg(static_cast<int>(mouseEvent->modifiers()))
+                        .arg(relPt.x())
+                        .arg(relPt.y())
+                        .arg(idxStr);
+diff --git a/Qt/Core/pqQVTKWidgetEventTranslator.cxx 
b/Qt/Core/pqQVTKWidgetEventTranslator.cxx
+index dfc95227..d2b64267 100644
+--- a/Qt/Core/pqQVTKWidgetEventTranslator.cxx
++++ b/Qt/Core/pqQVTKWidgetEventTranslator.cxx
+@@ -90,8 +90,8 @@ bool pqQVTKWidgetEventTranslator::translateEvent(
+               .arg(normalized_x)
+               .arg(normalized_y)
+               .arg(mouseEvent->button())
+-              .arg(mouseEvent->buttons())
+-              .arg(mouseEvent->modifiers()));
++              .arg(static_cast<int>(mouseEvent->buttons()))
++              .arg(static_cast<int>(mouseEvent->modifiers())));
+         }
+         return true;
+         break;
+@@ -118,15 +118,15 @@ bool pqQVTKWidgetEventTranslator::translateEvent(
+               .arg(normalized_x)
+               .arg(normalized_y)
+               .arg(mouseEvent->button())
+-              .arg(mouseEvent->buttons())
+-              .arg(mouseEvent->modifiers()));
++              .arg(static_cast<int>(mouseEvent->buttons()))
++              .arg(static_cast<int>(mouseEvent->modifiers())));
+           Q_EMIT recordEvent(widget, "mouseRelease",
+             QString("(%1,%2,%3,%4,%5)")
+               .arg(normalized_x)
+               .arg(normalized_y)
+               .arg(mouseEvent->button())
+-              .arg(mouseEvent->buttons())
+-              .arg(mouseEvent->modifiers()));
++              .arg(static_cast<int>(mouseEvent->buttons()))
++              .arg(static_cast<int>(mouseEvent->modifiers())));
+         }
+         return true;
+         break;
+diff --git 
a/ThirdParty/QtTesting/vtkqttesting/pqAbstractItemViewEventTranslator.cxx 
b/ThirdParty/QtTesting/vtkqttesting/pqAbstractItemViewEventTranslator.cxx
+index 31b1d44e..61ce1ddf 100644
+--- a/ThirdParty/QtTesting/vtkqttesting/pqAbstractItemViewEventTranslator.cxx
++++ b/ThirdParty/QtTesting/vtkqttesting/pqAbstractItemViewEventTranslator.cxx
+@@ -90,8 +90,8 @@ bool 
pqAbstractItemViewEventTranslator::translateEvent(QObject* Object, QEvent*
+ 
+       QString info = QString("%1,%2,%3,%4,%5,%6")
+                        .arg(mouseEvent->button())
+-                       .arg(mouseEvent->buttons())
+-                       .arg(mouseEvent->modifiers())
++                       .arg(static_cast<int>(mouseEvent->buttons()))
++                       .arg(static_cast<int>(mouseEvent->modifiers()))
+                        .arg(relPt.x())
+                        .arg(relPt.y())
+                        .arg(idxStr);
+diff --git 
a/ThirdParty/QtTesting/vtkqttesting/pqBasicWidgetEventTranslator.cxx 
b/ThirdParty/QtTesting/vtkqttesting/pqBasicWidgetEventTranslator.cxx
+index afdd3604..9217f27b 100644
+--- a/ThirdParty/QtTesting/vtkqttesting/pqBasicWidgetEventTranslator.cxx
++++ b/ThirdParty/QtTesting/vtkqttesting/pqBasicWidgetEventTranslator.cxx
+@@ -53,8 +53,8 @@ bool pqBasicWidgetEventTranslator::translateEvent(
+ #endif
+         QString info = QString("%1,%2,%3,%4,%5")
+                          .arg(mouseEvent->button())
+-                         .arg(mouseEvent->buttons())
+-                         .arg(mouseEvent->modifiers())
++                         .arg(static_cast<int>(mouseEvent->buttons()))
++                         .arg(static_cast<int>(mouseEvent->modifiers()))
+                          .arg(pos.x())
+                          .arg(pos.y());
+ 

diff --git a/sci-visualization/paraview/paraview-6.0.1.ebuild 
b/sci-visualization/paraview/paraview-6.0.1.ebuild
new file mode 100644
index 000000000000..0360db2d8ce1
--- /dev/null
+++ b/sci-visualization/paraview/paraview-6.0.1.ebuild
@@ -0,0 +1,236 @@
+# Copyright 1999-2026 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+PYTHON_COMPAT=( python3_{11..14} )
+DOCS_BUILDER="doxygen"
+inherit cmake flag-o-matic desktop docs python-single-r1 qmake-utils 
toolchain-funcs xdg
+
+MAJOR_PV="$(ver_cut 1-2)"
+MINOR_PV="$(ver_cut 3)"
+RC_PV="$(ver_cut 4-5)"
+RC_PV="${RC_PV:+-${RC_PV^^}}"
+MY_P="ParaView-v${MAJOR_PV}.${MINOR_PV}${RC_PV}"
+
+DESCRIPTION="Powerful scientific data visualization application"
+HOMEPAGE="https://www.paraview.org";
+SRC_URI="https://www.paraview.org/files/v${MAJOR_PV}/${MY_P}.tar.xz";
+S="${WORKDIR}/${MY_P}"
+
+# TODO: check licenses of plugins (USE=plugins)
+LICENSE="BSD MIT PSF-2 VTK"
+SLOT="0"
+KEYWORDS="~amd64 ~x86"
+IUSE="boost cg examples ffmpeg mpi nvcontrol openmp plugins python +qt6 
+sqlite test tk +webengine"
+
+RESTRICT="mirror test"
+
+REQUIRED_USE="
+       python? ( mpi ${PYTHON_REQUIRED_USE} )
+       webengine? ( qt6 )
+       qt6? ( sqlite )"
+
+RDEPEND="
+       app-arch/lz4
+       dev-libs/expat
+       dev-libs/jsoncpp:=
+       dev-libs/libxml2:2=
+       dev-libs/protobuf:=
+       dev-libs/pugixml
+       media-libs/freetype
+       media-libs/glew:0
+       media-libs/libpng:0
+       media-libs/libtheora:=
+       media-libs/tiff:=
+       sci-libs/cgnslib
+       sci-libs/hdf5:=[mpi=]
+       >=sci-libs/netcdf-4.2[hdf5]
+       >=sci-libs/netcdf-cxx-4.2:3
+       virtual/zlib:=
+       virtual/glu
+       media-libs/libjpeg-turbo:=
+       x11-libs/libX11
+       x11-libs/libXext
+       x11-libs/libXmu
+       x11-libs/libXt
+       virtual/opengl
+       ffmpeg? ( media-video/ffmpeg )
+       mpi? ( virtual/mpi[romio] )
+       python? (
+               ${PYTHON_DEPS}
+               $(python_gen_cond_dep '
+                       dev-python/constantly[${PYTHON_USEDEP}]
+                       dev-python/incremental[${PYTHON_USEDEP}]
+                       dev-python/matplotlib[${PYTHON_USEDEP}]
+                       dev-python/numpy[${PYTHON_USEDEP}]
+                       dev-python/pygments[${PYTHON_USEDEP}]
+                       dev-python/sip:5[${PYTHON_USEDEP}]
+                       dev-python/six[${PYTHON_USEDEP}]
+                       dev-python/twisted[${PYTHON_USEDEP}]
+                       dev-python/zope-interface[${PYTHON_USEDEP}]
+                       mpi? ( dev-python/mpi4py )
+                       qt6? ( dev-python/pyqt6[opengl,${PYTHON_USEDEP}] )
+               ')
+       )
+       qt6? (
+               dev-qt/qt5compat:6
+               dev-qt/qtbase:6[gui,opengl,sql]
+               dev-qt/qtdeclarative:6
+               dev-qt/qtsvg:6
+               dev-qt/qttools:6[assistant,designer,widgets]
+       )
+       sqlite? ( dev-db/sqlite:3 )
+       tk? ( dev-lang/tk:0= )
+       webengine? ( dev-qt/qtwebengine:6[widgets] )
+"
+DEPEND="${RDEPEND}
+       ${PYTHON_DEPS}
+       boost? (
+               $(python_gen_cond_dep '
+                       dev-libs/boost[python,${PYTHON_USEDEP}]
+               ')
+       )
+"
+BDEPEND="
+       openmp? ( virtual/fortran )
+"
+
+PATCHES=(
+       "${FILESDIR}"/${P}-avoid_file_collisions.patch
+       "${FILESDIR}"/${P}-qt-6.10.patch # bug #967029
+)
+
+# false positive when checking for available HDF5 interface, bug #904731
+QA_CONFIG_IMPL_DECL_SKIP=(
+       H5Pset_coll_metadata_write
+       H5Pset_all_coll_metadata_ops
+)
+
+pkg_pretend() {
+       [[ ${MERGE_TYPE} != binary ]] && use openmp && tc-check-openmp
+}
+
+pkg_setup() {
+       [[ ${MERGE_TYPE} != binary ]] && use openmp && tc-check-openmp
+       use python && python-single-r1_pkg_setup
+       PVLIBDIR=$(get_libdir)/${PN}-${MAJOR_PV}
+}
+
+src_prepare() {
+       # Bug #661812
+       mkdir -p Plugins/StreamLinesRepresentation/doc || die
+
+       cmake_src_prepare
+
+       # lib64 fixes
+       sed -i \
+               -e "s:/lib/python:/$(get_libdir)/python:g" \
+               VTK/ThirdParty/xdmf3/vtkxdmf3/CMakeLists.txt || die
+       sed -i \
+               -e "s:lib/paraview-:$(get_libdir)/paraview-:g" \
+               Remoting/Application/vtkInitializationHelper.cxx || die
+}
+
+src_configure() {
+       # Needed to compile bundled VTK in ParaView 5.11.1 with gcc 12
+       # see also, bug #863299
+       filter-lto
+       append-cflags $(test-flags-CC -fno-strict-aliasing \
+               -Wno-error=incompatible-function-pointer-types 
-Wno-error=int-conversion)
+       append-cxxflags $(test-flags-CXX -fno-strict-aliasing \
+               -Wno-error=incompatible-function-pointer-types 
-Wno-error=int-conversion)
+
+       # Make sure qmlplugindump is in path:
+       export PATH="$(qt6_get_bindir):${PATH}"
+
+       local mycmakeargs=(
+               -DCMAKE_INSTALL_LIBDIR="${PVLIBDIR}"
+               # paraview-6.0.0 onwards expects a relative path for 
documentation
+               -DCMAKE_INSTALL_DOCDIR="share/doc/${PF}"
+
+               -UBUILD_SHARED_LIBS
+               -DPARAVIEW_BUILD_SHARED_LIBS=ON
+               -DCMAKE_VERBOSE_MAKEFILE=ON
+
+               # boost
+               -DVTK_MODULE_ENABLE_VTK_IOInfovis="$(usex boost YES NO)"
+
+               # doc
+               -DPARAVIEW_BUILD_DEVELOPER_DOCUMENTATION="$(usex doc)"
+
+               # examples
+               -DBUILD_EXAMPLES="$(usex examples)"
+
+               # ffmpeg
+               -DPARAVIEW_ENABLE_FFMPEG="$(usex ffmpeg)"
+
+               # mpi
+               -DPARAVIEW_USE_MPI="$(usex mpi)"
+               -DXDMF_BUILD_MPI="$(usex mpi)"
+               -DVTK_GROUP_ENABLE_MPI="$(usex mpi YES NO)"
+
+               # plugins
+               -DPARAVIEW_PLUGINS_DEFAULT="$(usex plugins)"
+
+               # python
+               -DModule_pqPython="$(usex python)"
+               -DPARAVIEW_USE_PYTHON="$(usex python)"
+
+               # qt6
+               -DPARAVIEW_USE_QT="$(usex qt6)"
+               -DPARAVIEW_QT_VERSION="6"
+               -DVTK_QT_VERSION="6"
+               -DModule_pqPython="$(usex qt6 "$(usex python)" "off")"
+               -DVTK_USE_NVCONTROL="$(usex nvcontrol)"
+               -DVTK_GROUP_ENABLE_Qt="$(usex qt6 YES NO)"
+               -DCMAKE_INSTALL_QMLDIR="${EPREFIX}/usr/$(get_libdir)/qt6/qml"
+
+               # sqlite
+               -DVTK_MODULE_ENABLE_VTK_sqlite="$(usex sqlite YES NO)"
+
+               # test
+               -DBUILD_TESTING="$(usex test)"
+
+               # tk
+               -DVTK_USE_TK="$(usex tk)"
+               -DVTK_GROUP_ENABLE_Tk="$(usex tk YES NO)"
+
+               # webengine
+               -DPARAVIEW_USE_QTWEBENGINE="$(usex webengine)"
+               -DVTK_GROUP_ENABLE_Web="$(usex webengine YES NO)"
+       )
+
+       if use openmp; then
+               mycmakeargs+=( -DVTK_SMP_IMPLEMENTATION_TYPE=OpenMP )
+       fi
+
+       if use qt6; then
+               mycmakeargs+=(
+                       
-DOPENGL_gl_LIBRARY="${EPREFIX}"/usr/$(get_libdir)/libGL.so
+                       
-DOPENGL_glu_LIBRARY="${EPREFIX}"/usr/$(get_libdir)/libGLU.so
+               )
+       fi
+
+       cmake_src_configure
+}
+
+src_install() {
+       cmake_src_install
+
+       # remove wrapper binaries and put the actual executable in place
+       for i in 
{paraview-config,pvserver,pvdataserver,pvrenderserver,pvbatch,pvpython,paraview};
 do
+               if [ -f "${ED}"/usr/lib/"$i" ]; then
+                       mv "${ED}"/usr/lib/"$i" "${ED}"/usr/bin/"$i" || die
+               fi
+       done
+
+       # set up the environment
+       echo "LDPATH=${EPREFIX}/usr/${PVLIBDIR}" > "${T}"/40${PN} || die
+       doenvd "${T}"/40${PN}
+
+       newicon "${S}"/Clients/ParaView/pvIcon-96x96.png paraview.png
+       make_desktop_entry paraview "Paraview" paraview
+
+       use python && python_optimize 
"${ED}/usr/$(get_libdir)/${PN}-${MAJOR_PV}"
+}

Reply via email to