Merge pull request #259122 from spikespaz/prismlauncher-glfw-wayland

prismlauncher: add withWaylandGLFW override
This commit is contained in:
Weijia Wang 2024-01-03 11:21:12 +01:00 committed by GitHub
commit 6794a0533f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -1,9 +1,12 @@
{ lib { lib
, stdenv , stdenv
, symlinkJoin , symlinkJoin
, prismlauncher-unwrapped , makeWrapper
, wrapQtAppsHook , wrapQtAppsHook
, addOpenGLRunpath , addOpenGLRunpath
, prismlauncher-unwrapped
, qtbase # needed for wrapQtAppsHook , qtbase # needed for wrapQtAppsHook
, qtsvg , qtsvg
, qtwayland , qtwayland
@ -11,6 +14,7 @@
, libpulseaudio , libpulseaudio
, libGL , libGL
, glfw , glfw
, glfw-wayland-minecraft
, openal , openal
, jdk8 , jdk8
, jdk17 , jdk17
@ -25,23 +29,43 @@
, gamemodeSupport ? stdenv.isLinux , gamemodeSupport ? stdenv.isLinux
, textToSpeechSupport ? stdenv.isLinux , textToSpeechSupport ? stdenv.isLinux
, controllerSupport ? stdenv.isLinux , controllerSupport ? stdenv.isLinux
# The flag `withWaylandGLFW` enables runtime-checking of `WAYLAND_DISPLAY`;
# if the option is enabled, a patched version of GLFW will be added to
# `LD_LIBRARY_PATH` so that the launcher can use the correct one
# depending on the desktop environment used.
, withWaylandGLFW ? false
, jdks ? [ jdk17 jdk8 ] , jdks ? [ jdk17 jdk8 ]
, additionalLibs ? [ ] , additionalLibs ? [ ]
, additionalPrograms ? [ ] , additionalPrograms ? [ ]
}: }:
assert lib.assertMsg (withWaylandGLFW -> stdenv.isLinux) "withWaylandGLFW is only available on Linux";
let let
prismlauncherFinal = prismlauncher-unwrapped.override { # By default, this package uses a binary wrapper for `wrapQtAppsHook`.
# Enabling `shellWrapper` will add `makeWrapper` to `nativeBuildInputs`,
# causing `wrapQtAppsHook` to output a shell wrapper instead.
# This is needed for checking environment variables at runtime
# and modifying others if necessary (see above option for example).
# Warning: This can make the program start slower, by about four milliseconds.
shellWrapper = withWaylandGLFW;
prismlauncher' = prismlauncher-unwrapped.override {
inherit msaClientID gamemodeSupport; inherit msaClientID gamemodeSupport;
}; };
in in
symlinkJoin {
name = "prismlauncher-${prismlauncherFinal.version}";
paths = [ prismlauncherFinal ]; symlinkJoin {
name = "prismlauncher-${prismlauncher'.version}";
paths = [ prismlauncher' ];
nativeBuildInputs = [ nativeBuildInputs = [
wrapQtAppsHook wrapQtAppsHook
]; ]
++ lib.optional shellWrapper makeWrapper;
buildInputs = [ buildInputs = [
qtbase qtbase
@ -49,20 +73,29 @@ symlinkJoin {
] ]
++ lib.optional (lib.versionAtLeast qtbase.version "6" && stdenv.isLinux) qtwayland; ++ lib.optional (lib.versionAtLeast qtbase.version "6" && stdenv.isLinux) qtwayland;
waylandPreExec = ''
if [ -n "$WAYLAND_DISPLAY" ]; then
export LD_LIBRARY_PATH=${lib.getLib glfw-wayland-minecraft}/lib:"$LD_LIBRARY_PATH"
fi
'';
postBuild = '' postBuild = ''
${lib.optionalString withWaylandGLFW ''
qtWrapperArgs+=(--run "$waylandPreExec")
''}
wrapQtAppsHook wrapQtAppsHook
''; '';
qtWrapperArgs = qtWrapperArgs =
let let
runtimeLibs = (with xorg; [ runtimeLibs = [
libX11 xorg.libX11
libXext xorg.libXext
libXcursor xorg.libXcursor
libXrandr xorg.libXrandr
libXxf86vm xorg.libXxf86vm
])
++ [
# lwjgl # lwjgl
libpulseaudio libpulseaudio
libGL libGL
@ -93,5 +126,5 @@ symlinkJoin {
"--prefix PATH : ${lib.makeBinPath runtimePrograms}" "--prefix PATH : ${lib.makeBinPath runtimePrograms}"
]; ];
inherit (prismlauncherFinal) meta; inherit (prismlauncher') meta;
} }