commit:     295c67cebdfd7e7cf810c3ec7563e9bbfc903473
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Jul 15 09:47:08 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 15 09:47:08 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=295c67ce

media-video/pipewire: fix gentoo-pipewire-launcher vs bad config file

With a config file defined that does *not* itself define GENTOO_PIPEWIRE_*,
we may fail to startup properly. Always set fallback values for the logging
dests, not just when a config doesn't exist.

Thanks-to: Paul Zander <negril.nx+gentoo <AT> gmail.com>
Signed-off-by: Sam James <sam <AT> gentoo.org>

 .../pipewire/files/gentoo-pipewire-launcher.in-r4  | 85 ++++++++++++++++++++++
 ...re-1.4.9999.ebuild => pipewire-1.4.6-r1.ebuild} |  0
 media-video/pipewire/pipewire-1.4.9999.ebuild      |  2 +-
 media-video/pipewire/pipewire-9999.ebuild          |  2 +-
 4 files changed, 87 insertions(+), 2 deletions(-)

diff --git a/media-video/pipewire/files/gentoo-pipewire-launcher.in-r4 
b/media-video/pipewire/files/gentoo-pipewire-launcher.in-r4
new file mode 100644
index 000000000000..1804d5aad682
--- /dev/null
+++ b/media-video/pipewire/files/gentoo-pipewire-launcher.in-r4
@@ -0,0 +1,85 @@
+#!/bin/sh
+
+# PipeWire launcher script for XDG compliant desktops on OpenRC.
+#
+# systemd users are very _STRONGLY_ advised to use the much
+# more reliable and predictable user units instead.
+
+# WARNING: This script assumes being run inside XDG compliant session,
+# which means D-Bus session instance is expected to be correctly set up
+# prior to this script starting. If that is not true, things may break!
+
+DATE_FORMAT='+%Y-%m-%dT%H:%M:%S%Z'
+
+CONF="${XDG_CONFIG_HOME:-${HOME}/.config}/gentoo-pipewire-launcher.conf"
+if [ -f "${CONF}" ]
+then
+    . "${CONF}"
+fi
+
+: "${GENTOO_PIPEWIRE_LOG:='/dev/null'}"
+: "${GENTOO_PIPEWIRE_PULSE_LOG:='/dev/null'}"
+: "${GENTOO_WIREPLUMBER_LOG:='/dev/null'}"
+
+for L in \
+    "${GENTOO_PIPEWIRE_LOG}" \
+    "${GENTOO_PIPEWIRE_PULSE_LOG}" \
+    "${GENTOO_WIREPLUMBER_LOG}"
+do
+   if [ ! -e "${L}" ]
+   then
+       touch "${L}"
+   fi
+done
+
+restart () {
+    echo "Terminating PipeWire processes ..."
+    pkill -u "${USER}" -x pipewire\|wireplumber 1>/dev/null 2>&1
+
+    # pidwait was renamed to pwait w/ procps-4 (bug #914030)
+    if command -v pidwait > /dev/null ; then
+        pidwait -u "${USER}" -x pipewire\|wireplumber
+    elif command -v pwait > /dev/null ; then
+        pwait -u "${USER}" -x pipewire\|wireplumber
+    fi
+
+    echo "PipeWire terminated."
+}
+
+if [ "${#}" -gt 0 ]
+then
+    if [ "${1}" = 'restart' ]
+    then
+       restart
+    else
+        echo "Unrecognised argument." >&2
+        echo "Usage: gentoo-pipewire-launcher [restart]" >&2
+       exit 1
+    fi
+fi
+
+if pgrep -u "${USER}" -x pipewire\|wireplumber 1>/dev/null 2>&1
+then
+    echo "PipeWire already running, exiting." >&2
+    echo "(Use 'gentoo-pipewire-launcher restart' to restart PipeWire and 
WirePlumber.)" >&2
+    exit 1
+fi
+
+# The core daemon which by itself does probably nothing.
+echo "[$(@GENTOO_PORTAGE_EPREFIX@/bin/date ${DATE_FORMAT})] Starting 
PipeWire." 1>>"${GENTOO_PIPEWIRE_LOG}"
+@GENTOO_PORTAGE_EPREFIX@/usr/bin/pipewire 1>>"${GENTOO_PIPEWIRE_LOG}" 2>&1 &
+
+# The so called pipewire-pulse daemon used for PulseAudio compatibility.
+# Commenting this out will stop the PA proxying daemon from starting,
+# however ALSA (with pipewire-alsa), JACK (with jack-sdk) and PW API using
+# clients will still have access to audio and may end up clashing with
+# non-PW apps over HW control (most notably, /usr/bin/pulseaudio daemon).
+echo "[$(@GENTOO_PORTAGE_EPREFIX@/bin/date ${DATE_FORMAT})] Starting 
PipeWire-Pulse." 1>>"${GENTOO_PIPEWIRE_PULSE_LOG}"
+@GENTOO_PORTAGE_EPREFIX@/usr/bin/pipewire -c pipewire-pulse.conf 
1>>"${GENTOO_PIPEWIRE_PULSE_LOG}" 2>&1 &
+
+# Hack for bug #822498
+sleep 1
+
+# Finally a session manager is required for PipeWire to do anything.
+echo "[$(@GENTOO_PORTAGE_EPREFIX@/bin/date ${DATE_FORMAT})] Starting 
WirePlumber." 1>>"${GENTOO_WIREPLUMBER_LOG}"
+exec @GENTOO_PORTAGE_EPREFIX@/usr/bin/wireplumber 
1>>"${GENTOO_WIREPLUMBER_LOG}" 2>&1

diff --git a/media-video/pipewire/pipewire-1.4.9999.ebuild 
b/media-video/pipewire/pipewire-1.4.6-r1.ebuild
similarity index 100%
copy from media-video/pipewire/pipewire-1.4.9999.ebuild
copy to media-video/pipewire/pipewire-1.4.6-r1.ebuild

diff --git a/media-video/pipewire/pipewire-1.4.9999.ebuild 
b/media-video/pipewire/pipewire-1.4.9999.ebuild
index 91903abf7323..b6f2d947b3cb 100644
--- a/media-video/pipewire/pipewire-1.4.9999.ebuild
+++ b/media-video/pipewire/pipewire-1.4.9999.ebuild
@@ -370,7 +370,7 @@ multilib_src_install_all() {
                newins "${FILESDIR}"/pipewire.desktop-r2 pipewire.desktop
 
                exeinto /usr/bin
-               newexe "${FILESDIR}"/gentoo-pipewire-launcher.in-r3 
gentoo-pipewire-launcher
+               newexe "${FILESDIR}"/gentoo-pipewire-launcher.in-r4 
gentoo-pipewire-launcher
 
                doman "${FILESDIR}"/gentoo-pipewire-launcher.1
 

diff --git a/media-video/pipewire/pipewire-9999.ebuild 
b/media-video/pipewire/pipewire-9999.ebuild
index 6d7d756e39c6..55f4a26c8bc2 100644
--- a/media-video/pipewire/pipewire-9999.ebuild
+++ b/media-video/pipewire/pipewire-9999.ebuild
@@ -368,7 +368,7 @@ multilib_src_install_all() {
                newins "${FILESDIR}"/pipewire.desktop-r2 pipewire.desktop
 
                exeinto /usr/bin
-               newexe "${FILESDIR}"/gentoo-pipewire-launcher.in-r3 
gentoo-pipewire-launcher
+               newexe "${FILESDIR}"/gentoo-pipewire-launcher.in-r4 
gentoo-pipewire-launcher
 
                doman "${FILESDIR}"/gentoo-pipewire-launcher.1
 

Reply via email to