mirror of https://github.com/PCSX2/pcsx2.git
CI/AppImage: Add I_WANT_A_BROKEN_WAYLAND_UI environment variable
This commit is contained in:
parent
3b3fb28412
commit
bb7e08cdce
|
@ -42,6 +42,16 @@ BINARY=pcsx2-qt
|
||||||
APPDIRNAME=PCSX2.AppDir
|
APPDIRNAME=PCSX2.AppDir
|
||||||
STRIP=strip
|
STRIP=strip
|
||||||
|
|
||||||
|
declare -a MANUAL_QT_LIBS=(
|
||||||
|
"libQt6WaylandEglClientHwIntegration.so.6"
|
||||||
|
)
|
||||||
|
|
||||||
|
declare -a MANUAL_QT_PLUGINS=(
|
||||||
|
"wayland-decoration-client"
|
||||||
|
"wayland-graphics-integration-client"
|
||||||
|
"wayland-shell-integration"
|
||||||
|
)
|
||||||
|
|
||||||
set -e
|
set -e
|
||||||
|
|
||||||
LINUXDEPLOY=./linuxdeploy-x86_64.AppImage
|
LINUXDEPLOY=./linuxdeploy-x86_64.AppImage
|
||||||
|
@ -65,7 +75,6 @@ if [ ! -f "$APPIMAGETOOL" ]; then
|
||||||
fi
|
fi
|
||||||
|
|
||||||
OUTDIR=$(realpath "./$APPDIRNAME")
|
OUTDIR=$(realpath "./$APPDIRNAME")
|
||||||
SCRIPTDIR=$(dirname "${BASH_SOURCE[0]}")
|
|
||||||
rm -fr "$OUTDIR"
|
rm -fr "$OUTDIR"
|
||||||
|
|
||||||
# Why the nastyness? linuxdeploy strips our main binary, and there's no option to turn it off.
|
# Why the nastyness? linuxdeploy strips our main binary, and there's no option to turn it off.
|
||||||
|
@ -89,7 +98,8 @@ cp "$PCSX2DIR/.github/workflows/scripts/linux/pcsx2-qt.desktop" "net.pcsx2.PCSX2
|
||||||
cp "$PCSX2DIR/bin/resources/icons/AppIconLarge.png" "PCSX2.png"
|
cp "$PCSX2DIR/bin/resources/icons/AppIconLarge.png" "PCSX2.png"
|
||||||
|
|
||||||
echo "Running linuxdeploy to create AppDir..."
|
echo "Running linuxdeploy to create AppDir..."
|
||||||
EXTRA_QT_PLUGINS="core;gui;network;svg;widgets;xcbqpa" \
|
EXTRA_QT_PLUGINS="core;gui;network;svg;waylandclient;widgets;xcbqpa" \
|
||||||
|
EXTRA_PLATFORM_PLUGINS="libqwayland-egl.so;libqwayland-generic.so" \
|
||||||
QMAKE="$DEPSDIR/bin/qmake" \
|
QMAKE="$DEPSDIR/bin/qmake" \
|
||||||
NO_STRIP="1" \
|
NO_STRIP="1" \
|
||||||
$LINUXDEPLOY --plugin qt --appdir="$OUTDIR" --executable="$BUILDDIR/bin/pcsx2-qt" \
|
$LINUXDEPLOY --plugin qt --appdir="$OUTDIR" --executable="$BUILDDIR/bin/pcsx2-qt" \
|
||||||
|
@ -98,6 +108,34 @@ $LINUXDEPLOY --plugin qt --appdir="$OUTDIR" --executable="$BUILDDIR/bin/pcsx2-qt
|
||||||
echo "Copying resources into AppDir..."
|
echo "Copying resources into AppDir..."
|
||||||
cp -a "$BUILDDIR/bin/resources" "$OUTDIR/usr/bin"
|
cp -a "$BUILDDIR/bin/resources" "$OUTDIR/usr/bin"
|
||||||
|
|
||||||
|
# LinuxDeploy's Qt plugin doesn't include Wayland support. So manually copy in the additional Wayland libraries.
|
||||||
|
echo "Copying Qt Wayland libraries..."
|
||||||
|
for lib in "${MANUAL_QT_LIBS[@]}"; do
|
||||||
|
srcpath="$DEPSDIR/lib/$lib"
|
||||||
|
dstpath="$OUTDIR/usr/lib/$lib"
|
||||||
|
echo " $srcpath -> $dstpath"
|
||||||
|
cp "$srcpath" "$dstpath"
|
||||||
|
$PATCHELF --set-rpath '$ORIGIN' "$dstpath"
|
||||||
|
done
|
||||||
|
|
||||||
|
# .. and plugins.
|
||||||
|
echo "Copying Qt Wayland plugins..."
|
||||||
|
for GROUP in "${MANUAL_QT_PLUGINS[@]}"; do
|
||||||
|
srcpath="$DEPSDIR/plugins/$GROUP"
|
||||||
|
dstpath="$OUTDIR/usr/plugins/$GROUP"
|
||||||
|
echo " $srcpath -> $dstpath"
|
||||||
|
mkdir -p "$dstpath"
|
||||||
|
|
||||||
|
for srcsopath in $(find "$DEPSDIR/plugins/$GROUP" -iname '*.so'); do
|
||||||
|
# This is ../../ because it's usually plugins/group/name.so
|
||||||
|
soname=$(basename "$srcsopath")
|
||||||
|
dstsopath="$dstpath/$soname"
|
||||||
|
echo " $srcsopath -> $dstsopath"
|
||||||
|
cp "$srcsopath" "$dstsopath"
|
||||||
|
$PATCHELF --set-rpath '$ORIGIN/../../lib:$ORIGIN' "$dstsopath"
|
||||||
|
done
|
||||||
|
done
|
||||||
|
|
||||||
# Restore unstripped deps (for cache).
|
# Restore unstripped deps (for cache).
|
||||||
rm -fr "$DEPSDIR"
|
rm -fr "$DEPSDIR"
|
||||||
mv "$DEPSDIR.bak" "$DEPSDIR"
|
mv "$DEPSDIR.bak" "$DEPSDIR"
|
||||||
|
@ -111,6 +149,17 @@ echo "Generating AppStream metainfo..."
|
||||||
mkdir -p "$OUTDIR/usr/share/metainfo"
|
mkdir -p "$OUTDIR/usr/share/metainfo"
|
||||||
"$SCRIPTDIR/generate-metainfo.sh" "$OUTDIR/usr/share/metainfo/net.pcsx2.PCSX2.appdata.xml"
|
"$SCRIPTDIR/generate-metainfo.sh" "$OUTDIR/usr/share/metainfo/net.pcsx2.PCSX2.appdata.xml"
|
||||||
|
|
||||||
|
# Copy in AppRun hooks.
|
||||||
|
# Unfortunately linuxdeploy is a bit lame and doesn't let us provide our own AppRun hooks, instead
|
||||||
|
# they have to come from plugins.. and screw writing one of those just to disable Wayland.
|
||||||
|
echo "Copying AppRun hooks..."
|
||||||
|
mkdir -p "$OUTDIR/apprun-hooks"
|
||||||
|
for hookpath in "$SCRIPTDIR/apprun-hooks"/*; do
|
||||||
|
hookname=$(basename "$hookpath")
|
||||||
|
cp -v "$hookpath" "$OUTDIR/apprun-hooks/$hookname"
|
||||||
|
sed -i -e 's/exec /source "$this_dir"\/apprun-hooks\/"'"$hookname"'"\nexec /' "$OUTDIR/AppRun"
|
||||||
|
done
|
||||||
|
|
||||||
echo "Generating AppImage..."
|
echo "Generating AppImage..."
|
||||||
rm -f "$NAME.AppImage"
|
rm -f "$NAME.AppImage"
|
||||||
$APPIMAGETOOL -v "$OUTDIR" "$NAME.AppImage"
|
$APPIMAGETOOL -v "$OUTDIR" "$NAME.AppImage"
|
||||||
|
|
|
@ -0,0 +1,9 @@
|
||||||
|
if [[ -z "$I_WANT_A_BROKEN_WAYLAND_UI" ]]; then
|
||||||
|
echo "Forcing X11 instead of Wayland, due to various protocol limitations"
|
||||||
|
echo "and Qt issues. If you want to use Wayland, launch PCSX2 with"
|
||||||
|
echo "I_WANT_A_BROKEN_WAYLAND_UI=YES set."
|
||||||
|
export QT_QPA_PLATFORM=xcb
|
||||||
|
else
|
||||||
|
echo "Wayland is not being disabled. Do not complain when things break."
|
||||||
|
fi
|
||||||
|
|
Loading…
Reference in New Issue