summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorThomas Watson <twatson52@icloud.com>2021-01-13 16:18:58 -0600
committerThomas Watson <twatson52@icloud.com>2021-01-14 11:21:36 -0600
commitb6779d541a87fd413623c650d5fa9831d267032c (patch)
treec4bd0d88969e1587701410bdb6f801f0a1d5c310
parent6e83386e825857ec11b786cb58425a5d57ad2716 (diff)
lxqt: fix themes and translations
LXQt binaries look for their themes and translations based on the name of the binary, which is changed by the wrapper script. This patches liblxqt to recover the original name from the wrapped binary name.
-rw-r--r--pkgs/desktops/lxqt/liblxqt/default.nix3
-rw-r--r--pkgs/desktops/lxqt/liblxqt/fix-application-path.patch23
2 files changed, 26 insertions, 0 deletions
diff --git a/pkgs/desktops/lxqt/liblxqt/default.nix b/pkgs/desktops/lxqt/liblxqt/default.nix
index ee915491f857..959afe1b887a 100644
--- a/pkgs/desktops/lxqt/liblxqt/default.nix
+++ b/pkgs/desktops/lxqt/liblxqt/default.nix
@@ -39,6 +39,9 @@ mkDerivation rec {
xorg.libXScrnSaver
];
+ # convert name of wrapped binary, e.g. .lxqt-whatever-wrapped to the original name, e.g. lxqt-whatever so binaries can find their resources
+ patches = [ ./fix-application-path.patch ];
+
postPatch = ''
sed -i "s|\''${POLKITQT-1_POLICY_FILES_INSTALL_DIR}|''${out}/share/polkit-1/actions|" CMakeLists.txt
'';
diff --git a/pkgs/desktops/lxqt/liblxqt/fix-application-path.patch b/pkgs/desktops/lxqt/liblxqt/fix-application-path.patch
new file mode 100644
index 000000000000..12ef97db5d82
--- /dev/null
+++ b/pkgs/desktops/lxqt/liblxqt/fix-application-path.patch
@@ -0,0 +1,23 @@
+--- a/lxqtapplication.cpp
++++ b/lxqtapplication.cpp
+@@ -77,7 +77,7 @@ Application::Application(int &argc, char** argv, bool handleQuitSignals)
+
+ void Application::updateTheme()
+ {
+- const QString styleSheetKey = QFileInfo(applicationFilePath()).fileName();
++ const QString styleSheetKey = QFileInfo(applicationFilePath()).fileName().mid(1).chopped(8);
+ setStyleSheet(lxqtTheme.qss(styleSheetKey));
+ Q_EMIT themeChanged();
+ }
+
+--- a/lxqttranslator.cpp
++++ b/lxqttranslator.cpp
+@@ -147,7 +147,7 @@ bool Translator::translateApplication(const QString &applicationName)
+ if (!applicationName.isEmpty())
+ return translate(applicationName);
+ else
+- return translate(QFileInfo(QCoreApplication::applicationFilePath()).baseName());
++ return translate(QFileInfo(QCoreApplication::applicationFilePath()).baseName().mid(1).chopped(8));
+ }
+
+