Merge pull request #185496 from tpwrules/fix-qgis-build
qgis, qgis-ltr: fix build
This commit is contained in:
commit
1909dcbd8b
4 changed files with 105 additions and 27 deletions
59
pkgs/applications/gis/qgis/set-pyqt-package-dirs.patch
Normal file
59
pkgs/applications/gis/qgis/set-pyqt-package-dirs.patch
Normal file
|
@ -0,0 +1,59 @@
|
||||||
|
diff --git a/cmake/FindPyQt5.cmake b/cmake/FindPyQt5.cmake
|
||||||
|
index b51fd0075e..87ee317e05 100644
|
||||||
|
--- a/cmake/FindPyQt5.cmake
|
||||||
|
+++ b/cmake/FindPyQt5.cmake
|
||||||
|
@@ -25,7 +25,7 @@ ELSE(EXISTS PYQT5_VERSION_STR)
|
||||||
|
IF(SIP_BUILD_EXECUTABLE)
|
||||||
|
# SIP >= 5.0 path
|
||||||
|
|
||||||
|
- FILE(GLOB _pyqt5_metadata "${Python_SITEARCH}/PyQt5-*.dist-info/METADATA")
|
||||||
|
+ FILE(GLOB _pyqt5_metadata "@pyQt5PackageDir@/PyQt5-*.dist-info/METADATA")
|
||||||
|
IF(_pyqt5_metadata)
|
||||||
|
FILE(READ ${_pyqt5_metadata} _pyqt5_metadata_contents)
|
||||||
|
STRING(REGEX REPLACE ".*\nVersion: ([^\n]+).*$" "\\1" PYQT5_VERSION_STR ${_pyqt5_metadata_contents})
|
||||||
|
@@ -34,8 +34,8 @@ ELSE(EXISTS PYQT5_VERSION_STR)
|
||||||
|
ENDIF(_pyqt5_metadata)
|
||||||
|
|
||||||
|
IF(PYQT5_VERSION_STR)
|
||||||
|
- SET(PYQT5_MOD_DIR "${Python_SITEARCH}/PyQt5")
|
||||||
|
- SET(PYQT5_SIP_DIR "${Python_SITEARCH}/PyQt5/bindings")
|
||||||
|
+ SET(PYQT5_MOD_DIR "@pyQt5PackageDir@/PyQt5")
|
||||||
|
+ SET(PYQT5_SIP_DIR "@pyQt5PackageDir@/PyQt5/bindings")
|
||||||
|
FIND_PROGRAM(__pyuic5 "pyuic5")
|
||||||
|
GET_FILENAME_COMPONENT(PYQT5_BIN_DIR ${__pyuic5} DIRECTORY)
|
||||||
|
|
||||||
|
diff --git a/cmake/FindQsci.cmake b/cmake/FindQsci.cmake
|
||||||
|
index 69e41c1fe9..5456c3d59b 100644
|
||||||
|
--- a/cmake/FindQsci.cmake
|
||||||
|
+++ b/cmake/FindQsci.cmake
|
||||||
|
@@ -24,7 +24,7 @@ ELSE(QSCI_MOD_VERSION_STR)
|
||||||
|
IF(SIP_BUILD_EXECUTABLE)
|
||||||
|
# SIP >= 5.0 path
|
||||||
|
|
||||||
|
- FILE(GLOB _qsci_metadata "${Python_SITEARCH}/QScintilla*.dist-info/METADATA")
|
||||||
|
+ FILE(GLOB _qsci_metadata "@qsciPackageDir@/QScintilla*.dist-info/METADATA")
|
||||||
|
IF(_qsci_metadata)
|
||||||
|
FILE(READ ${_qsci_metadata} _qsci_metadata_contents)
|
||||||
|
STRING(REGEX REPLACE ".*\nVersion: ([^\n]+).*$" "\\1" QSCI_MOD_VERSION_STR ${_qsci_metadata_contents})
|
||||||
|
@@ -33,7 +33,7 @@ ELSE(QSCI_MOD_VERSION_STR)
|
||||||
|
ENDIF(_qsci_metadata)
|
||||||
|
|
||||||
|
IF(QSCI_MOD_VERSION_STR)
|
||||||
|
- SET(QSCI_SIP_DIR "${PYQT5_SIP_DIR}")
|
||||||
|
+ SET(QSCI_SIP_DIR "@qsciPackageDir@/PyQt5/bindings")
|
||||||
|
SET(QSCI_FOUND TRUE)
|
||||||
|
ENDIF(QSCI_MOD_VERSION_STR)
|
||||||
|
|
||||||
|
diff --git a/python/CMakeLists.txt b/python/CMakeLists.txt
|
||||||
|
index 4cd19c3af4..668cc6a5e6 100644
|
||||||
|
--- a/python/CMakeLists.txt
|
||||||
|
+++ b/python/CMakeLists.txt
|
||||||
|
@@ -206,7 +206,7 @@ if (WITH_GUI)
|
||||||
|
install(FILES ${QGIS_PYTHON_OUTPUT_DIRECTORY}/_gui.pyi DESTINATION ${QGIS_PYTHON_DIR})
|
||||||
|
endif()
|
||||||
|
if(QSCI_SIP_DIR)
|
||||||
|
- set(SIP_EXTRA_OPTIONS ${SIP_EXTRA_OPTIONS} -I ${QSCI_SIP_DIR})
|
||||||
|
+ set(SIP_BUILD_EXTRA_OPTIONS ${SIP_BUILD_EXTRA_OPTIONS} --include-dir=${QSCI_SIP_DIR})
|
||||||
|
else()
|
||||||
|
message(STATUS "Qsci sip file not found - disabling bindings for derived classes")
|
||||||
|
set(SIP_DISABLE_FEATURES ${SIP_DISABLE_FEATURES} HAVE_QSCI_SIP)
|
|
@ -38,6 +38,8 @@
|
||||||
, pdal
|
, pdal
|
||||||
, zstd
|
, zstd
|
||||||
, makeWrapper
|
, makeWrapper
|
||||||
|
, wrapGAppsHook
|
||||||
|
, substituteAll
|
||||||
}:
|
}:
|
||||||
|
|
||||||
let
|
let
|
||||||
|
@ -64,7 +66,9 @@ let
|
||||||
urllib3
|
urllib3
|
||||||
pygments
|
pygments
|
||||||
pyqt5
|
pyqt5
|
||||||
sip_4
|
pyqt-builder
|
||||||
|
sip
|
||||||
|
setuptools
|
||||||
owslib
|
owslib
|
||||||
six
|
six
|
||||||
];
|
];
|
||||||
|
@ -116,29 +120,31 @@ in mkDerivation rec {
|
||||||
++ lib.optional withWebKit qtwebkit
|
++ lib.optional withWebKit qtwebkit
|
||||||
++ pythonBuildInputs;
|
++ pythonBuildInputs;
|
||||||
|
|
||||||
nativeBuildInputs = [ makeWrapper cmake flex bison ninja ];
|
nativeBuildInputs = [ makeWrapper wrapGAppsHook cmake flex bison ninja ];
|
||||||
|
|
||||||
# Force this pyqt_sip_dir variable to point to the sip dir in PyQt5
|
patches = [
|
||||||
#
|
(substituteAll {
|
||||||
# TODO: Correct PyQt5 to provide the expected directory and fix
|
src = ./set-pyqt-package-dirs.patch;
|
||||||
# build to use PYQT5_SIP_DIR consistently.
|
pyQt5PackageDir = "${py.pkgs.pyqt5}/${py.pkgs.python.sitePackages}";
|
||||||
postPatch = ''
|
qsciPackageDir = "${py.pkgs.qscintilla-qt5}/${py.pkgs.python.sitePackages}";
|
||||||
substituteInPlace cmake/FindPyQt5.py \
|
})
|
||||||
--replace 'sip_dir = cfg.default_sip_dir' 'sip_dir = "${py.pkgs.pyqt5}/${py.pkgs.python.sitePackages}/PyQt5/bindings"'
|
];
|
||||||
'';
|
|
||||||
|
|
||||||
cmakeFlags = [
|
cmakeFlags = [
|
||||||
"-DWITH_3D=True"
|
"-DWITH_3D=True"
|
||||||
"-DWITH_PDAL=TRUE"
|
"-DWITH_PDAL=TRUE"
|
||||||
"-DPYQT5_SIP_DIR=${py.pkgs.pyqt5}/${py.pkgs.python.sitePackages}/PyQt5/bindings"
|
|
||||||
"-DQSCI_SIP_DIR=${py.pkgs.qscintilla-qt5}/${py.pkgs.python.sitePackages}/PyQt5/bindings"
|
|
||||||
] ++ lib.optional (!withWebKit) "-DWITH_QTWEBKIT=OFF"
|
] ++ lib.optional (!withWebKit) "-DWITH_QTWEBKIT=OFF"
|
||||||
++ lib.optional withGrass "-DGRASS_PREFIX7=${grass}/grass78";
|
++ lib.optional withGrass "-DGRASS_PREFIX7=${grass}/grass78";
|
||||||
|
|
||||||
|
dontWrapGApps = true; # wrapper params passed below
|
||||||
|
|
||||||
postFixup = lib.optionalString withGrass ''
|
postFixup = lib.optionalString withGrass ''
|
||||||
# grass has to be availble on the command line even though we baked in
|
# grass has to be availble on the command line even though we baked in
|
||||||
# the path at build time using GRASS_PREFIX
|
# the path at build time using GRASS_PREFIX.
|
||||||
|
# using wrapGAppsHook also prevents file dialogs from crashing the program
|
||||||
|
# on non-NixOS
|
||||||
wrapProgram $out/bin/qgis \
|
wrapProgram $out/bin/qgis \
|
||||||
|
"''${gappsWrapperArgs[@]}" \
|
||||||
--prefix PATH : ${lib.makeBinPath [ grass ]}
|
--prefix PATH : ${lib.makeBinPath [ grass ]}
|
||||||
'';
|
'';
|
||||||
|
|
||||||
|
|
|
@ -38,6 +38,8 @@
|
||||||
, pdal
|
, pdal
|
||||||
, zstd
|
, zstd
|
||||||
, makeWrapper
|
, makeWrapper
|
||||||
|
, wrapGAppsHook
|
||||||
|
, substituteAll
|
||||||
}:
|
}:
|
||||||
|
|
||||||
let
|
let
|
||||||
|
@ -64,7 +66,9 @@ let
|
||||||
urllib3
|
urllib3
|
||||||
pygments
|
pygments
|
||||||
pyqt5
|
pyqt5
|
||||||
sip_4
|
pyqt-builder
|
||||||
|
sip
|
||||||
|
setuptools
|
||||||
owslib
|
owslib
|
||||||
six
|
six
|
||||||
];
|
];
|
||||||
|
@ -116,29 +120,31 @@ in mkDerivation rec {
|
||||||
++ lib.optional withWebKit qtwebkit
|
++ lib.optional withWebKit qtwebkit
|
||||||
++ pythonBuildInputs;
|
++ pythonBuildInputs;
|
||||||
|
|
||||||
nativeBuildInputs = [ makeWrapper cmake flex bison ninja ];
|
nativeBuildInputs = [ makeWrapper wrapGAppsHook cmake flex bison ninja ];
|
||||||
|
|
||||||
# Force this pyqt_sip_dir variable to point to the sip dir in PyQt5
|
patches = [
|
||||||
#
|
(substituteAll {
|
||||||
# TODO: Correct PyQt5 to provide the expected directory and fix
|
src = ./set-pyqt-package-dirs.patch;
|
||||||
# build to use PYQT5_SIP_DIR consistently.
|
pyQt5PackageDir = "${py.pkgs.pyqt5}/${py.pkgs.python.sitePackages}";
|
||||||
postPatch = ''
|
qsciPackageDir = "${py.pkgs.qscintilla-qt5}/${py.pkgs.python.sitePackages}";
|
||||||
substituteInPlace cmake/FindPyQt5.py \
|
})
|
||||||
--replace 'sip_dir = cfg.default_sip_dir' 'sip_dir = "${py.pkgs.pyqt5}/${py.pkgs.python.sitePackages}/PyQt5/bindings"'
|
];
|
||||||
'';
|
|
||||||
|
|
||||||
cmakeFlags = [
|
cmakeFlags = [
|
||||||
"-DWITH_3D=True"
|
"-DWITH_3D=True"
|
||||||
"-DWITH_PDAL=TRUE"
|
"-DWITH_PDAL=TRUE"
|
||||||
"-DPYQT5_SIP_DIR=${py.pkgs.pyqt5}/${py.pkgs.python.sitePackages}/PyQt5/bindings"
|
|
||||||
"-DQSCI_SIP_DIR=${py.pkgs.qscintilla-qt5}/${py.pkgs.python.sitePackages}/PyQt5/bindings"
|
|
||||||
] ++ lib.optional (!withWebKit) "-DWITH_QTWEBKIT=OFF"
|
] ++ lib.optional (!withWebKit) "-DWITH_QTWEBKIT=OFF"
|
||||||
++ lib.optional withGrass "-DGRASS_PREFIX7=${grass}/grass78";
|
++ lib.optional withGrass "-DGRASS_PREFIX7=${grass}/grass78";
|
||||||
|
|
||||||
|
dontWrapGApps = true; # wrapper params passed below
|
||||||
|
|
||||||
postFixup = lib.optionalString withGrass ''
|
postFixup = lib.optionalString withGrass ''
|
||||||
# grass has to be availble on the command line even though we baked in
|
# grass has to be availble on the command line even though we baked in
|
||||||
# the path at build time using GRASS_PREFIX
|
# the path at build time using GRASS_PREFIX.
|
||||||
|
# using wrapGAppsHook also prevents file dialogs from crashing the program
|
||||||
|
# on non-NixOS
|
||||||
wrapProgram $out/bin/qgis \
|
wrapProgram $out/bin/qgis \
|
||||||
|
"''${gappsWrapperArgs[@]}" \
|
||||||
--prefix PATH : ${lib.makeBinPath [ grass ]}
|
--prefix PATH : ${lib.makeBinPath [ grass ]}
|
||||||
'';
|
'';
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
{ lib, stdenv, fetchPypi, buildPythonPackage, packaging, ply, toml }:
|
{ lib, stdenv, fetchPypi, buildPythonPackage, packaging, ply, toml, fetchpatch }:
|
||||||
|
|
||||||
buildPythonPackage rec {
|
buildPythonPackage rec {
|
||||||
pname = "sip";
|
pname = "sip";
|
||||||
|
@ -15,6 +15,13 @@ buildPythonPackage rec {
|
||||||
# and PIP will refuse to install the resulting wheel.
|
# and PIP will refuse to install the resulting wheel.
|
||||||
# remove once upstream fixes this, hopefully in 6.5.2
|
# remove once upstream fixes this, hopefully in 6.5.2
|
||||||
./fix-manylinux-version.patch
|
./fix-manylinux-version.patch
|
||||||
|
|
||||||
|
# fix issue triggered by QGIS 3.26.x, already fixed upstream
|
||||||
|
# in SIP, waiting for release past 6.6.2
|
||||||
|
(fetchpatch {
|
||||||
|
url = "https://riverbankcomputing.com/hg/sip/raw-diff/323d39a2d602/sipbuild/generator/parser/instantiations.py";
|
||||||
|
hash = "sha256-QEQuRzXA+wK9Dt22U/LgIwtherY9pJURGJYpKpJkiok=";
|
||||||
|
})
|
||||||
];
|
];
|
||||||
|
|
||||||
propagatedBuildInputs = [ packaging ply toml ];
|
propagatedBuildInputs = [ packaging ply toml ];
|
||||||
|
|
Loading…
Reference in a new issue