Index: Makefile
===================================================================
--- Makefile (nonexistent)
+++ Makefile (revision 170)
@@ -0,0 +1,405 @@
+
+COMPONENT_TARGETS = $(HARDWARE_INTEL_PC32)
+COMPONENT_TARGETS += $(HARDWARE_INTEL_PC64)
+COMPONENT_TARGETS += $(HARDWARE_EBOX_3350DX2)
+COMPONENT_TARGETS += $(HARDWARE_CB1X)
+COMPONENT_TARGETS += $(HARDWARE_CB2X)
+COMPONENT_TARGETS += $(HARDWARE_CB3X)
+COMPONENT_TARGETS += $(HARDWARE_ORANGE_PP2E)
+COMPONENT_TARGETS += $(HARDWARE_NANOPI_NEO)
+COMPONENT_TARGETS += $(HARDWARE_ORANGE_PP)
+COMPONENT_TARGETS += $(HARDWARE_ORANGE_PL2)
+COMPONENT_TARGETS += $(HARDWARE_ORANGE_PI5)
+COMPONENT_TARGETS += $(HARDWARE_ORANGE_PI5B)
+COMPONENT_TARGETS += $(HARDWARE_ORANGE_PI5P)
+COMPONENT_TARGETS += $(HARDWARE_ROCK_5B)
+COMPONENT_TARGETS += $(HARDWARE_WECHIP_TX6)
+COMPONENT_TARGETS += $(HARDWARE_REPKA_PI3)
+COMPONENT_TARGETS += $(HARDWARE_FFRK3288)
+COMPONENT_TARGETS += $(HARDWARE_POIN2)
+COMPONENT_TARGETS += $(HARDWARE_RK3328_CC)
+COMPONENT_TARGETS += $(HARDWARE_KHADAS_EDGE)
+COMPONENT_TARGETS += $(HARDWARE_LEEZ_P710)
+COMPONENT_TARGETS += $(HARDWARE_M201)
+COMPONENT_TARGETS += $(HARDWARE_MXV)
+COMPONENT_TARGETS += $(HARDWARE_P201)
+COMPONENT_TARGETS += $(HARDWARE_NEXBOX_A95X)
+COMPONENT_TARGETS += $(HARDWARE_ODROID_C2)
+COMPONENT_TARGETS += $(HARDWARE_P212)
+COMPONENT_TARGETS += $(HARDWARE_KHADAS_VIM)
+COMPONENT_TARGETS += $(HARDWARE_Q201)
+COMPONENT_TARGETS += $(HARDWARE_ENYBOX_X2)
+COMPONENT_TARGETS += $(HARDWARE_KHADAS_VIM2)
+COMPONENT_TARGETS += $(HARDWARE_NIT6Q)
+COMPONENT_TARGETS += $(HARDWARE_OKMX6DL_C)
+COMPONENT_TARGETS += $(HARDWARE_OKMX6Q_C)
+COMPONENT_TARGETS += $(HARDWARE_BONE_BLACK)
+COMPONENT_TARGETS += $(HARDWARE_OMAP5UEVM)
+COMPONENT_TARGETS += $(HARDWARE_DRA7XXEVM)
+COMPONENT_TARGETS += $(HARDWARE_CI20)
+COMPONENT_TARGETS += $(HARDWARE_BAIKAL_T1)
+COMPONENT_TARGETS += $(HARDWARE_BAIKAL_M1)
+COMPONENT_TARGETS += $(HARDWARE_S824L)
+COMPONENT_TARGETS += $(HARDWARE_VESNIN)
+COMPONENT_TARGETS += $(HARDWARE_S824L_LSB)
+COMPONENT_TARGETS += $(HARDWARE_VESNIN_LSB)
+COMPONENT_TARGETS += $(HARDWARE_TL2WK2)
+COMPONENT_TARGETS += $(HARDWARE_TL2SV2)
+COMPONENT_TARGETS += $(HARDWARE_TL2WK2_LSB)
+COMPONENT_TARGETS += $(HARDWARE_TL2SV2_LSB)
+COMPONENT_TARGETS += $(HARDWARE_SIFIVE_U740)
+
+
+NEED_ABS_PATH = true
+COMPONENT_IS_3PP = true
+
+
+include ../../../../build-system/constants.mk
+
+
+SOURCE_REQUIRES = sources/packages/m/pipewire
+
+REQUIRES = app/daemon/0.8.4
+REQUIRES += app/dbus/1.13.18
+REQUIRES += app/eudev/3.2.10
+REQUIRES += libs/glib2/2.76.0
+REQUIRES += libs/libusb/1.0.24
+REQUIRES += libs/readline/8.2
+REQUIRES += libs/sbc/2.0
+
+REQUIRES += media/fdk-aac/2.0.2
+REQUIRES += media/libsndfile/1.0.28
+REQUIRES += media/opus/1.3.1
+
+REQUIRES += net/webrtc-audio-processing/0.3.1
+
+REQUIRES += X11/libs/libdrm/2.4.114
+REQUIRES += X11/X.org/lib/libXfixes/6.0.0
+REQUIRES += X11/libs/sdl/sdl2-mixer/2.6.3
+REQUIRES += X11/libs/gst-plugins-base/1.22.0
+
+REQUIRES += X11/app/ffmpeg/4.4.4
+REQUIRES += X11/media/alsa-plugins/1.2.7.1
+REQUIRES += X11/media/pulseaudio/16.1
+REQUIRES += X11/media/v4l-utils/1.24.1
+REQUIRES += X11/libs/vulkan/vulkan-loader/1.3.239.0
+
+# ======= __END_OF_REQUIRES__ =======
+
+
+version = 0.3.80
+tar_xz_archive = $(SRC_PACKAGE_PATH)/packages/m/pipewire/pipewire/pipewire-$(version).tar.xz
+SRC_ARCHIVE = $(tar_xz_archive)
+SRC_DIR = $(TARGET_BUILD_DIR)/pipewire-$(version)
+src_dir_name = pipewire-$(version)
+src_done = $(TARGET_BUILD_DIR)/.source_done
+
+session_version = 0.4.2
+session_archive = $(SRC_PACKAGE_PATH)/packages/m/pipewire/media-session/media-session-$(session_version).tar.xz
+
+PATCHES = PATCHES
+
+build_dir = $(TARGET_BUILD_DIR)/build
+build_target = $(TARGET_BUILD_DIR)/.build_done
+install_target = $(TARGET_BUILD_DIR)/.install_done
+
+cross_file = $(TARGET_BUILD_DIR)/$(TARGET)-cross
+
+
+####### Targets
+
+PKG_GROUP = xmedia
+
+#
+# *PKG_NAME & *PKG_VERSION shouldn't be a reference to value.
+#
+PIPEWIRE_PKG_NAME = pipewire
+PIPEWIRE_PKG_VERSION = 0.3.80
+PIPEWIRE_PKG_ARCH = $(PKGARCH)
+PIPEWIRE_PKG_DISTRO_NAME = $(DISTRO_NAME)
+PIPEWIRE_PKG_DISTRO_VERSION = $(DISTRO_VERSION)
+PIPEWIRE_PKG_GROUP = $(PKG_GROUP)
+### |---handy-ruler-------------------------------|
+PIPEWIRE_PKG_SHORT_DESCRIPTION = Multimedia processing
+PIPEWIRE_PKG_URL = $(BUG_URL)
+PIPEWIRE_PKG_LICENSE = custom
+PIPEWIRE_PKG_DESCRIPTION_FILE = $(TARGET_BUILD_DIR)/$(PIPEWIRE_PKG_NAME)-pkg-description
+PIPEWIRE_PKG_DESCRIPTION_FILE_IN = $(PIPEWIRE_PKG_NAME)-pkg-description.in
+PIPEWIRE_PKG_INSTALL_SCRIPT = $(PIPEWIRE_PKG_NAME)-pkg-install.sh
+
+PIPEWIRE_PKG = $(CURDIR)/$(TARGET_BUILD_DIR)/$(PIPEWIRE_PKG_NAME)-package
+
+pkg_basename = $(PIPEWIRE_PKG_NAME)-$(PIPEWIRE_PKG_VERSION)-$(PIPEWIRE_PKG_ARCH)-$(PIPEWIRE_PKG_DISTRO_NAME)-$(PIPEWIRE_PKG_DISTRO_VERSION)
+
+pkg_archive = $(TARGET_BUILD_DIR)/$(PKG_GROUP)/$(pkg_basename).$(pkg_arch_suffix)
+pkg_signature = $(call sign-name,$(pkg_archive))
+pkg_description = $(call desc-name,$(pkg_archive))
+products = $(call pkg-files,$(pkg_archive))
+
+BUILD_TARGETS = $(build_target)
+BUILD_TARGETS += $(install_target)
+
+PRODUCT_TARGETS = $(products)
+
+ROOTFS_TARGETS = $(pkg_archive)
+
+
+include ../../../../build-system/core.mk
+
+
+env_sysroot = DESTDIR=$(PIPEWIRE_PKG)
+
+
+#
+# https://mesonbuild.com/Reference-tables.html :
+# =============================================
+#
+ifneq ($(filter $(TOOLCHAIN),$(TOOLCHAIN_A1X_GLIBC) $(TOOLCHAIN_A2X_GLIBC) \
+ $(TOOLCHAIN_H3_GLIBC) $(TOOLCHAIN_RK328X_GLIBC) \
+ $(TOOLCHAIN_S8XX_GLIBC) $(TOOLCHAIN_IMX6_GLIBC) \
+ $(TOOLCHAIN_AM335X_GLIBC) $(TOOLCHAIN_OMAP543X_GLIBC)),)
+cpu_name = arm
+endian = little
+endif
+ifneq ($(filter $(TOOLCHAIN),$(TOOLCHAIN_H5_GLIBC) $(TOOLCHAIN_RK33XX_GLIBC) \
+ $(TOOLCHAIN_RK339X_GLIBC) $(TOOLCHAIN_RK358X_GLIBC) \
+ $(TOOLCHAIN_S9XX_GLIBC) \
+ $(TOOLCHAIN_A311X_GLIBC) $(TOOLCHAIN_M1000_GLIBC)),)
+cpu_name = aarch64
+endian = little
+endif
+ifneq ($(filter $(TOOLCHAIN),$(TOOLCHAIN_JZ47XX_GLIBC) $(TOOLCHAIN_P5600_GLIBC)),)
+cpu_name = mips
+endian = little
+endif
+ifneq ($(filter $(TOOLCHAIN),$(TOOLCHAIN_POWER8_GLIBC) $(TOOLCHAIN_POWER9_GLIBC)),)
+cpu_name = ppc64
+endian = big
+endif
+ifneq ($(filter $(TOOLCHAIN),$(TOOLCHAIN_POWER8LE_GLIBC) $(TOOLCHAIN_POWER9LE_GLIBC)),)
+cpu_name = ppc64
+endian = little
+endif
+ifneq ($(filter $(TOOLCHAIN),$(TOOLCHAIN_RISCV64_GLIBC)),)
+cpu_name = riscv64
+endian = little
+endif
+ifneq ($(filter $(TOOLCHAIN),$(TOOLCHAIN_I586_GLIBC) $(TOOLCHAIN_I686_GLIBC)),)
+cpu_name = x86
+endian = little
+endif
+ifneq ($(filter $(TOOLCHAIN),$(TOOLCHAIN_X86_64_GLIBC)),)
+cpu_name = x86_64
+endian = little
+endif
+
+
+ifeq ($(__ENABLE_STATIC__),yes)
+extra_configure_switches += --default-library=both
+else
+extra_configure_switches += --default-library=shared
+endif
+
+extra_configure_switches += -Ddocdir=/usr/share/doc/$(src_dir_name)
+extra_configure_switches += -Ddocs=disabled
+extra_configure_switches += -Dtests=disabled
+extra_configure_switches += -Dinstalled_tests=disabled
+extra_configure_switches += -Dman=enabled
+
+extra_configure_switches += -Dsystemd=disabled
+
+extra_configure_switches += -Dffmpeg=enabled
+extra_configure_switches += -Dpw-cat-ffmpeg=enabled
+extra_configure_switches += -Dvulkan=enabled
+#
+# 'echo-cancel-webrtc':
+# Downloads and build libwebrtc-audio-processing-1 library which
+# is not conflict with we already installed net:libwebrtc-audio-processing.
+# Also it requires 'abseil-cpp' as subproject
+# 'libcamera'
+# Downloads and build libcamera as subproject.
+# Due to cross-compilations errors we have to do
+# separated package.
+#
+# net:libwebrtc-audio-processing is already in system
+#
+extra_configure_switches += -Decho-cancel-webrtc=disabled
+extra_configure_switches += -Dlibcamera=disabled
+
+#
+# Jack2 is already in system
+#
+extra_configure_switches += -Djack=disabled
+extra_configure_switches += -Dpipewire-jack=disabled
+
+extra_configure_switches += -Dlibmysofa=disabled
+extra_configure_switches += -Droc=disabled
+extra_configure_switches += -Davahi=disabled
+extra_configure_switches += -Dlibcanberra=disabled
+extra_configure_switches += -Dlibffado=disabled
+
+extra_configure_switches += -Dbluez5-codec-lc3plus=disabled
+extra_configure_switches += -Dbluez5-backend-native-mm=enabled
+extra_configure_switches += -Dbluez5-codec-aac=enabled
+
+extra_configure_switches += -Dx11=enabled
+extra_configure_switches += -Dx11-xfixes=enabled
+
+extra_configure_switches += -Dudev=enabled
+extra_configure_switches += -Dudevrulesdir=/lib/udev/rules.d
+extra_configure_switches += -Dsession-managers=media-session
+
+CFLAGS += -Wno-unused-function -Wno-unused-value -Wno-maybe-uninitialized
+CFLAGS += -Wno-free-nonheap-object
+
+CFLAGS += -I$(TARGET_DEST_DIR)/usr/lib$(LIBSUFFIX)/glib-2.0/include
+
+
+####### Dependencies
+
+$(src_done): $(SRC_ARCHIVE) $(PATCHES_DEP)
+ $(UNPACK_SRC_ARCHIVE)
+ @echo "Expanding $(session_archive)"
+ @mkdir -p $(SRC_DIR)/subprojects/media-session
+ @tar -xJf $(session_archive) --strip 1 -C $(SRC_DIR)/subprojects/media-session
+ $(APPLY_PATCHES)
+ @touch $@
+
+$(build_target): $(src_done)
+ @mkdir -p $(build_dir)
+ @echo $(version) > $(SRC_DIR)/.tarball-version
+ @echo "" > $(cross_file)
+ @echo "[build_machine]" >> $(cross_file)
+ @echo "system = '$(shell uname -s | tr 'L' 'l')'" >> $(cross_file)
+ @echo "cpu_family = '$(shell uname -m)'" >> $(cross_file)
+ @echo "cpu = '$(shell uname -m)'" >> $(cross_file)
+ @echo "endian = '$(shell lscpu | grep Endian | tr -s ' ' | cut -f3 -d' ' | tr 'L' 'l')'" >> $(cross_file)
+ @echo "" >> $(cross_file)
+ @echo "[host_machine]" >> $(cross_file)
+ @echo "system = 'linux'" >> $(cross_file)
+ @echo "cpu_family = '$(cpu_name)'" >> $(cross_file)
+ @echo "cpu = '$(cpu_name)'" >> $(cross_file)
+ @echo "endian = '$(endian)'" >> $(cross_file)
+ @echo "" >> $(cross_file)
+ @echo "[target_machine]" >> $(cross_file)
+ @echo "system = 'linux'" >> $(cross_file)
+ @echo "cpu_family = '$(cpu_name)'" >> $(cross_file)
+ @echo "cpu = '$(cpu_name)'" >> $(cross_file)
+ @echo "endian = '$(endian)'" >> $(cross_file)
+ @echo "" >> $(cross_file)
+ @echo "[binaries]" >> $(cross_file)
+ @echo "c = '$(TOOLCHAIN_PATH)/bin/$(TARGET)-gcc'" >> $(cross_file)
+ @echo "cpp = '$(TOOLCHAIN_PATH)/bin/$(TARGET)-g++'" >> $(cross_file)
+ @echo "ar = '$(AR)'" >> $(cross_file)
+ @echo "strip = '$(STRIP)'" >> $(cross_file)
+ @echo "pkgconfig = 'pkg-config'" >> $(cross_file)
+ @echo "" >> $(cross_file)
+ @meson setup \
+ --prefix=/usr \
+ --libdir=lib$(LIBSUFFIX) \
+ --libexecdir=/usr/libexec \
+ --bindir=/usr/bin \
+ --sbindir=/usr/sbin \
+ --includedir=/usr/include \
+ --datadir=/usr/share \
+ --mandir=/usr/share/man \
+ --sysconfdir=/etc \
+ --localstatedir=/var \
+ --buildtype=release \
+ -Dc_args="`echo -n "--sysroot=$(TARGET_DEST_DIR) $(CFLAGS)" | tr -s ' '`" \
+ -Dc_link_args="`echo -n "--sysroot=$(TARGET_DEST_DIR) $(LDFLAGS)" | tr -s ' '`" \
+ -Dcpp_args="`echo -n "--sysroot=$(TARGET_DEST_DIR) $(CFLAGS)" | tr -s ' '`" \
+ -Dcpp_link_args="`echo -n "--sysroot=$(TARGET_DEST_DIR) $(LDFLAGS)" | tr -s ' '`" \
+ $(extra_configure_switches) \
+ --cross-file=$(cross_file) $(SRC_DIR) $(build_dir)
+ @cd $(build_dir) && ninja -v
+ @touch $@
+
+$(install_target): $(build_target)
+ @mkdir -p $(PIPEWIRE_PKG)
+ @cd $(build_dir) && $(env_sysroot) ninja install
+ # ======= Create system config file override directory: =======
+ @mkdir -p $(PIPEWIRE_PKG)/etc/pipewire
+ # ======= Add sample configuation files: =======
+ @mkdir -p $(PIPEWIRE_PKG)/etc/xdg/autostart
+ @cp -a $(CURDIR)/desktop/pipewire.desktop.sample $(PIPEWIRE_PKG)/etc/xdg/autostart
+ @cp -a $(CURDIR)/desktop/pipewire-media-session.desktop.sample $(PIPEWIRE_PKG)/etc/xdg/autostart
+ @cp -a $(CURDIR)/desktop/pipewire-pulse.desktop.sample $(PIPEWIRE_PKG)/etc/xdg/autostart
+ @chmod 644 $(PIPEWIRE_PKG)/etc/xdg/autostart/*
+ @mkdir -p $(PIPEWIRE_PKG)/usr/sbin
+ @cp -a $(CURDIR)/scripts/pipewire-disable $(PIPEWIRE_PKG)/usr/sbin
+ @cp -a $(CURDIR)/scripts/pipewire-enable $(PIPEWIRE_PKG)/usr/sbin
+ @chmod 755 $(PIPEWIRE_PKG)/usr/sbin/pipewire-disable $(PIPEWIRE_PKG)/usr/sbin/pipewire-enable
+ # ======= Install Documentation =======
+ @if [ -d $(PIPEWIRE_PKG)/usr/share/man ]; then \
+ ( cd $(PIPEWIRE_PKG)/usr/share/man ; \
+ for manpagedir in `find . -type d -name "man*"` ; do \
+ ( cd $$manpagedir ; \
+ for eachpage in `find . -type l -maxdepth 1` ; do \
+ ln -s `readlink $$eachpage`.gz $$eachpage.gz ; \
+ rm $$eachpage ; \
+ done ; \
+ gzip -9 *.? ; \
+ ) \
+ done \
+ ) \
+ fi
+ @mkdir -p $(PIPEWIRE_PKG)/usr/doc/$(src_dir_name)
+ @cp -a $(SRC_DIR)/COPYING $(SRC_DIR)/LICENSE \
+ $(PIPEWIRE_PKG)/usr/doc/$(src_dir_name)
+ @mkdir -p $(PIPEWIRE_PKG)/usr/share/doc/$(src_dir_name)
+ @( cd $(SRC_DIR) ; \
+ cp -a COPYING INSTALL.md LICENSE README.md \
+ $(PIPEWIRE_PKG)/usr/share/doc/$(src_dir_name) ; \
+ )
+ @( cd $(SRC_DIR) ; \
+ if [ -r NEWS ]; then \
+ DOCSDIR=`echo $(PIPEWIRE_PKG)/usr/share/doc/$(src_dir_name)` ; \
+ cat NEWS | head -n 1000 > $$DOCSDIR/NEWS ; \
+ touch -r NEWS $$DOCSDIR/NEWS ; \
+ fi \
+ )
+ # ======= Install the same to $(TARGET_DEST_DIR) =======
+ $(call install-into-devenv, $(PIPEWIRE_PKG))
+ # ======= tune pkg-config *.pc search path to the target destination for development =======
+ @( cd $(TARGET_DEST_DIR)/usr/lib$(LIBSUFFIX)/pkgconfig ; \
+ sed -i "s,/usr,$(TARGET_DEST_DIR)/usr,g" libpipewire-0.3.pc ; \
+ sed -i "s,/usr,$(TARGET_DEST_DIR)/usr,g" libspa-0.2.pc ; \
+ sed -i "s,^\(moduledir=\).*,\1/usr/lib$(LIBSUFFIX)/pipewire-0.3," libpipewire-0.3.pc ; \
+ sed -i "s,^\(plugindir=\).*,\1/usr/lib$(LIBSUFFIX)/spa-0.2," libspa-0.2.pc ; \
+ )
+ # ======= Strip binaries =======
+ @( cd $(PIPEWIRE_PKG) ; \
+ find . | xargs file | grep "executable" | grep ELF | cut -f 1 -d : | xargs $(STRIP) --strip-unneeded 2> /dev/null ; \
+ find . | xargs file | grep "shared object" | grep ELF | cut -f 1 -d : | xargs $(STRIP) --strip-unneeded 2> /dev/null ; \
+ )
+ifeq ($(__ENABLE_STATIC__),yes)
+ @( cd $(PIPEWIRE_PKG) ; \
+ find . | xargs file | grep "current ar archive" | cut -f 1 -d : | xargs $(STRIP) -g 2> /dev/null ; \
+ )
+endif
+ @touch $@
+
+$(PIPEWIRE_PKG_DESCRIPTION_FILE): $(PIPEWIRE_PKG_DESCRIPTION_FILE_IN)
+ @cat $< | $(SED) -e "s/@VERSION@/$(version)/g" > $@
+
+$(pkg_certificate) : $(pkg_archive) ;
+$(pkg_signature) : $(pkg_archive) ;
+$(pkg_description) : $(pkg_archive) ;
+
+$(pkg_archive): $(install_target) $(PIPEWIRE_PKG_DESCRIPTION_FILE) $(PIPEWIRE_PKG_INSTALL_SCRIPT)
+ @cp $(PIPEWIRE_PKG_DESCRIPTION_FILE) $(PIPEWIRE_PKG)/.DESCRIPTION
+ @cp $(PIPEWIRE_PKG_INSTALL_SCRIPT) $(PIPEWIRE_PKG)/.INSTALL
+ @$(BUILD_PKG_REQUIRES) $(PIPEWIRE_PKG)/.REQUIRES
+ @echo "pkgname=$(PIPEWIRE_PKG_NAME)" > $(PIPEWIRE_PKG)/.PKGINFO ; \
+ echo "pkgver=$(PIPEWIRE_PKG_VERSION)" >> $(PIPEWIRE_PKG)/.PKGINFO ; \
+ echo "arch=$(PIPEWIRE_PKG_ARCH)" >> $(PIPEWIRE_PKG)/.PKGINFO ; \
+ echo "distroname=$(PIPEWIRE_PKG_DISTRO_NAME)" >> $(PIPEWIRE_PKG)/.PKGINFO ; \
+ echo "distrover=$(PIPEWIRE_PKG_DISTRO_VERSION)" >> $(PIPEWIRE_PKG)/.PKGINFO ; \
+ echo "group=$(PIPEWIRE_PKG_GROUP)" >> $(PIPEWIRE_PKG)/.PKGINFO ; \
+ echo "short_description=\"$(PIPEWIRE_PKG_SHORT_DESCRIPTION)\"" >> $(PIPEWIRE_PKG)/.PKGINFO ; \
+ echo "url=$(PIPEWIRE_PKG_URL)" >> $(PIPEWIRE_PKG)/.PKGINFO ; \
+ echo "license=$(PIPEWIRE_PKG_LICENSE)" >> $(PIPEWIRE_PKG)/.PKGINFO
+ @$(PSEUDO) sh -c "cd $(PIPEWIRE_PKG) && \
+ chown -R root:root . && \
+ $(MAKE_PACKAGE) -J --linkadd=yes $(GNUPG_OPTIONS) -m -d .. ."
Index: PATCHES
===================================================================
Index: desktop/pipewire-media-session.desktop.sample
===================================================================
--- desktop/pipewire-media-session.desktop.sample (nonexistent)
+++ desktop/pipewire-media-session.desktop.sample (revision 170)
@@ -0,0 +1,9 @@
+[Desktop Entry]
+Version=1.0
+Name=PipeWire Media Session
+Comment=Start the PipeWire Media Session
+Exec=/usr/bin/daemon -frB --pidfiles=~/.run --name=pipewire-media-session /usr/bin/pipewire-media-session
+Terminal=false
+Type=Application
+X-GNOME-Autostart-Phase=Initialization
+X-KDE-autostart-phase=1
Index: desktop/pipewire-pulse.desktop.sample
===================================================================
--- desktop/pipewire-pulse.desktop.sample (nonexistent)
+++ desktop/pipewire-pulse.desktop.sample (revision 170)
@@ -0,0 +1,9 @@
+[Desktop Entry]
+Version=1.0
+Name=PipeWire Pulse
+Comment=Start the PipeWire Pulse
+Exec=/usr/bin/daemon -frB --pidfiles=~/.run --name=pipewire-pulse /usr/bin/pipewire-pulse
+Terminal=false
+Type=Application
+X-GNOME-Autostart-Phase=Initialization
+X-KDE-autostart-phase=1
Index: desktop/pipewire.desktop.sample
===================================================================
--- desktop/pipewire.desktop.sample (nonexistent)
+++ desktop/pipewire.desktop.sample (revision 170)
@@ -0,0 +1,9 @@
+[Desktop Entry]
+Version=1.0
+Name=PipeWire Media System
+Comment=Start the PipeWire Media System
+Exec=/usr/bin/daemon -frB --pidfiles=~/.run --name=pipewire /usr/bin/pipewire
+Terminal=false
+Type=Application
+X-GNOME-Autostart-Phase=Initialization
+X-KDE-autostart-phase=1
Index: pipewire-pkg-description.in
===================================================================
--- pipewire-pkg-description.in (nonexistent)
+++ pipewire-pkg-description.in (revision 170)
@@ -0,0 +1,19 @@
+# HOW TO EDIT THIS FILE:
+# The "handy ruler" below makes it easier to edit a package description. Line
+# up the first '|' above the ':' following the base package name, and the '|'
+# on the right side marks the last column you can put a character in. You must
+# make exactly 11 lines for the formatting to be correct. It's also
+# customary to leave one space after the ':'.
+
+ |-----handy-ruler------------------------------------------------------|
+pipewire: pipewire @VERSION@ (Multimedia processing)
+pipewire:
+pipewire: PipeWire is a project that aims to greatly improve handling
+pipewire: of audio and video under Linux. It provides a low-latency, graph
+pipewire: based processing engine on top of audio and video devices that
+pipewire: can be used to support the use cases currently handled by both
+pipewire: pulseaudio and JACK.
+pipewire:
+pipewire:
+pipewire: Homepage: https://pipewire.org/
+pipewire:
Index: pipewire-pkg-install.sh
===================================================================
--- pipewire-pkg-install.sh (nonexistent)
+++ pipewire-pkg-install.sh (revision 170)
@@ -0,0 +1,53 @@
+#!/bin/sh
+
+# Preserve new files
+install_file() {
+ NEW="$1"
+ OLD="`dirname $NEW`/`basename $NEW .new`"
+ # If there's no file by that name, mv it over:
+ if [ ! -r $OLD ]; then
+ mv $NEW $OLD
+ elif [ "`cat $OLD | md5sum`" = "`cat $NEW | md5sum`" ]; then # toss the redundant copy
+ rm $NEW
+ fi
+ # Otherwise, we leave the .new copy for the admin to consider...
+}
+
+
+# arg 1: the new package version
+pre_install() {
+ /bin/true
+}
+
+# arg 1: the new package version
+post_install() {
+ /bin/true
+}
+
+# arg 1: the new package version
+# arg 2: the old package version
+pre_update() {
+ /bin/true
+}
+
+# arg 1: the new package version
+# arg 2: the old package version
+post_update() {
+ post_install
+}
+
+# arg 1: the old package version
+pre_remove() {
+ /bin/true
+}
+
+# arg 1: the old package version
+post_remove() {
+ /bin/true
+}
+
+
+operation=$1
+shift
+
+$operation $*
Property changes on: pipewire-pkg-install.sh
___________________________________________________________________
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: scripts/pipewire-disable
===================================================================
--- scripts/pipewire-disable (nonexistent)
+++ scripts/pipewire-disable (revision 170)
@@ -0,0 +1,56 @@
+#!/bin/bash
+# Copyright 2022 Patrick J. Volkerding, Sebeka, Minnesota, USA
+# All rights reserved.
+#
+# Redistribution and use of this script, with or without modification, is
+# permitted provided that the following conditions are met:
+#
+# 1. Redistributions of this script must retain the above copyright
+# notice, this list of conditions and the following disclaimer.
+#
+# THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
+# WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+# MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
+# EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
+# PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
+# OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+# WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
+# OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
+# ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
+# This script will attempt to disable pipewire as the default audio server,
+# changing it back to pulseaudio.
+
+# Remove or rename the XDG autostart files:
+for file in /etc/xdg/autostart/pipewire-media-session.desktop /etc/xdg/autostart/pipewire-pulse.desktop /etc/xdg/autostart/pipewire.desktop ; do
+ if [ -r ${file}.sample ]; then
+ rm -f $file
+ elif [ -r $file ]; then
+ mv ${file} ${file}.sample
+ fi
+done
+
+# Enable pulseaudio.desktop:
+if grep -q "^Hidden=true$" /etc/xdg/autostart/pulseaudio.desktop ; then
+ grep -v "^Hidden=true$" /etc/xdg/autostart/pulseaudio.desktop > /etc/xdg/autostart/pulseaudio.desktop.new
+ mv /etc/xdg/autostart/pulseaudio.desktop.new /etc/xdg/autostart/pulseaudio.desktop
+fi
+
+# Edit /etc/pulse/client.conf to enable autospawn:
+sed -i "s/autospawn = no/autospawn = yes/g" /etc/pulse/client.conf
+sed -i "s/allow-autospawn-for-root = no/allow-autospawn-for-root = yes/g" /etc/pulse/client.conf
+
+echo "Pulseaudio enabled as system audio server."
+if ps ax | grep -q pipewire ; then
+ echo
+ echo "You may need to stop running daemon/pipewire processes."
+ echo "The clean way is to run these commands as the user that owns the processes:"
+ echo "/usr/bin/daemon --pidfiles=~/.run --name=pipewire --stop"
+ echo "/usr/bin/daemon --pidfiles=~/.run --name=pipewire-media-session --stop"
+ echo "/usr/bin/daemon --pidfiles=~/.run --name=pipewire-pulse --stop"
+ echo
+ echo "The quick and dirty way if nothing else on the machine is using the daemon"
+ echo "utility is to issue this command:"
+ echo "killall daemon"
+fi
Index: scripts/pipewire-enable
===================================================================
--- scripts/pipewire-enable (nonexistent)
+++ scripts/pipewire-enable (revision 170)
@@ -0,0 +1,48 @@
+#!/bin/bash
+# Copyright 2022 Patrick J. Volkerding, Sebeka, Minnesota, USA
+# All rights reserved.
+#
+# Redistribution and use of this script, with or without modification, is
+# permitted provided that the following conditions are met:
+#
+# 1. Redistributions of this script must retain the above copyright
+# notice, this list of conditions and the following disclaimer.
+#
+# THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
+# WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+# MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
+# EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
+# PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
+# OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+# WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
+# OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
+# ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
+# This script will attempt to enable pipewire as the default audio server.
+
+# Disable this, as it is almost certainly left over from when pipewire
+# used to store its config file in this location:
+if [ -f /etc/pipewire/pipewire.conf ]; then
+ for file in /etc/pipewire/*.conf ; do
+ mv ${file} ${file}.obsolete
+ done
+fi
+
+# Rename the XDG autostart files:
+for file in /etc/xdg/autostart/pipewire-media-session.desktop.sample /etc/xdg/autostart/pipewire-pulse.desktop.sample /etc/xdg/autostart/pipewire.desktop.sample ; do
+ if [ -r $file ]; then
+ mv $file /etc/xdg/autostart/$(basename $file .sample)
+ fi
+done
+
+# Disable pulseaudio.desktop:
+if ! grep -q "^Hidden=true$" /etc/xdg/autostart/pulseaudio.desktop ; then
+ echo "Hidden=true" >> /etc/xdg/autostart/pulseaudio.desktop
+fi
+
+# Edit /etc/pulse/client.conf to disable autospawn:
+sed -i "s/autospawn = yes/autospawn = no/g" /etc/pulse/client.conf
+sed -i "s/allow-autospawn-for-root = yes/allow-autospawn-for-root = no/g" /etc/pulse/client.conf
+
+echo "PipeWire enabled as system multimedia server."
Index: .
===================================================================
--- . (nonexistent)
+++ . (revision 170)
Property changes on: .
___________________________________________________________________
Added: svn:ignore
## -0,0 +1,74 ##
+
+# install dir
+dist
+
+# Target build dirs
+.a1x-newlib
+.a2x-newlib
+.at91sam7s-newlib
+
+.build-machine
+
+.a1x-glibc
+.a2x-glibc
+.h3-glibc
+.h5-glibc
+.i586-glibc
+.i686-glibc
+.imx6-glibc
+.jz47xx-glibc
+.makefile
+.am335x-glibc
+.omap543x-glibc
+.p5600-glibc
+.power8-glibc
+.power8le-glibc
+.power9-glibc
+.power9le-glibc
+.m1000-glibc
+.riscv64-glibc
+.rk328x-glibc
+.rk33xx-glibc
+.rk339x-glibc
+.rk358x-glibc
+.s8xx-glibc
+.s9xx-glibc
+.x86_64-glibc
+
+# Hidden files (each file)
+.makefile
+.dist
+.rootfs
+
+# src & hw requires
+.src_requires
+.src_requires_depend
+.requires
+.requires_depend
+
+# Tarballs
+*.gz
+*.bz2
+*.lz
+*.xz
+*.tgz
+*.txz
+
+# Signatures
+*.asc
+*.sig
+*.sign
+*.sha1sum
+
+# Patches
+*.patch
+
+# Descriptions
+*.dsc
+*.txt
+
+# Default linux config files
+*.defconfig
+
+# backup copies
+*~