commit:     06f179962d70c06c3df26d562b16fbdae19c2215
Author:     Jimi Huotari <chiitoo <AT> gentoo <DOT> org>
AuthorDate: Mon Dec 30 17:31:13 2024 +0000
Commit:     Jimi Huotari <chiitoo <AT> gentoo <DOT> org>
CommitDate: Mon Dec 30 17:37:49 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=06f17996

media-video/obs-studio: fix libX11 linking

Closes: https://bugs.gentoo.org/946057
Signed-off-by: Jimi Huotari <chiitoo <AT> gentoo.org>

 .../files/obs-studio-31.0.0-libx11-link.patch      |  28 +++
 media-video/obs-studio/obs-studio-31.0.0-r2.ebuild | 277 +++++++++++++++++++++
 2 files changed, 305 insertions(+)

diff --git a/media-video/obs-studio/files/obs-studio-31.0.0-libx11-link.patch 
b/media-video/obs-studio/files/obs-studio-31.0.0-libx11-link.patch
new file mode 100644
index 000000000000..40aa5c2130d3
--- /dev/null
+++ b/media-video/obs-studio/files/obs-studio-31.0.0-libx11-link.patch
@@ -0,0 +1,28 @@
+- https://bugs.gentoo.org/946057
+- https://github.com/obsproject/obs-studio/issues/11667
+
+From 428142d7022989af61a684a680e2d6ecc5b7ca8a Mon Sep 17 00:00:00 2001
+From: Kurt Kartaltepe <[email protected]>
+Date: Tue, 24 Dec 2024 10:22:40 -0800
+Subject: [PATCH] libobs: Fix underlinking by adding libx11
+
+We directly depend on libx11 for various operations in obs-nix-x11.c,
+not just xcb. So be sure to link it in too.
+
+fixes #11667
+---
+ libobs/cmake/os-linux.cmake | 1 +
+ 1 file changed, 1 insertion(+)
+
+diff --git a/libobs/cmake/os-linux.cmake b/libobs/cmake/os-linux.cmake
+index 317e75cab0c1dd..1af874f4f1fefe 100644
+--- a/libobs/cmake/os-linux.cmake
++++ b/libobs/cmake/os-linux.cmake
+@@ -47,6 +47,7 @@ endif()
+ target_link_libraries(
+   libobs
+   PRIVATE
++    X11::X11
+     X11::x11-xcb
+     xcb::xcb
+     LibUUID::LibUUID

diff --git a/media-video/obs-studio/obs-studio-31.0.0-r2.ebuild 
b/media-video/obs-studio/obs-studio-31.0.0-r2.ebuild
new file mode 100644
index 000000000000..79bc62763bf4
--- /dev/null
+++ b/media-video/obs-studio/obs-studio-31.0.0-r2.ebuild
@@ -0,0 +1,277 @@
+# Copyright 1999-2024 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+CMAKE_REMOVE_MODULES_LIST=( FindFreetype )
+LUA_COMPAT=( luajit )
+# For the time being upstream supports up to Python 3.12 only.
+# Any issues found with 3.13 should be reported as a Gentoo bug.
+PYTHON_COMPAT=( python3_{10..13} )
+
+inherit cmake flag-o-matic lua-single optfeature python-single-r1 xdg
+
+CEF_VERSION="cef_binary_6533_linux_x86_64"
+OBS_BROWSER_COMMIT="a76b4d8810a0a33e91ac5b76a0b1af2f22bf8efd"
+OBS_WEBSOCKET_COMMIT="eed8a49933786383d11f4868a4e5604a9ee303c6"
+
+DESCRIPTION="Software for Recording and Streaming Live Video Content"
+HOMEPAGE="https://obsproject.com";
+
+if [[ ${PV} == 9999 ]]; then
+       inherit git-r3
+       EGIT_REPO_URI="https://github.com/obsproject/obs-studio.git";
+       EGIT_SUBMODULES=(
+               plugins/obs-browser
+               plugins/obs-websocket
+       )
+else
+       SRC_URI="
+               https://github.com/obsproject/${PN}/archive/${PV}.tar.gz
+                       -> ${P}.tar.gz
+               
https://github.com/obsproject/obs-browser/archive/${OBS_BROWSER_COMMIT}.tar.gz
+                       -> obs-browser-${OBS_BROWSER_COMMIT}.tar.gz
+               
https://github.com/obsproject/obs-websocket/archive/${OBS_WEBSOCKET_COMMIT}.tar.gz
+                       -> obs-websocket-${OBS_WEBSOCKET_COMMIT}.tar.gz
+       "
+       KEYWORDS="~amd64 ~arm64 ~ppc64 ~x86"
+fi
+
+SRC_URI+=" browser? ( 
https://cdn-fastly.obsproject.com/downloads/${CEF_VERSION}.tar.xz )"
+
+LICENSE="Boost-1.0 GPL-2+ MIT Unlicense"
+SLOT="0"
+IUSE="
+       +alsa browser decklink fdk jack lua mpegts nvenc pipewire pulseaudio
+       python qsv sndio speex test-input truetype v4l vlc wayland websocket
+"
+REQUIRED_USE="
+       browser? ( || ( alsa pulseaudio ) )
+       lua? ( ${LUA_REQUIRED_USE} )
+       python? ( ${PYTHON_REQUIRED_USE} )
+"
+
+BDEPEND="
+       lua? ( dev-lang/swig )
+       python? ( dev-lang/swig )
+"
+# media-video/ffmpeg[opus] required due to bug 909566
+DEPEND="
+       dev-cpp/nlohmann_json
+       dev-libs/glib:2
+       dev-libs/jansson:=
+       dev-libs/uthash
+       dev-qt/qtbase:6[network,widgets,xml(+)]
+       dev-qt/qtsvg:6
+       media-libs/libglvnd[X]
+       media-libs/libva
+       media-libs/rnnoise
+       media-libs/x264:=
+       >=media-video/ffmpeg-6.1:=[nvenc?,opus,x264]
+       net-misc/curl
+       net-libs/mbedtls:=
+       sys-apps/dbus
+       sys-apps/pciutils
+       sys-apps/util-linux
+       sys-libs/zlib:=
+       x11-libs/libX11
+       x11-libs/libxcb:=
+       x11-libs/libXcomposite
+       x11-libs/libXfixes
+       x11-libs/libxkbcommon
+       alsa? ( media-libs/alsa-lib )
+       browser? (
+               || (
+                       >=app-accessibility/at-spi2-core-2.46.0:2
+                       ( app-accessibility/at-spi2-atk dev-libs/atk )
+               )
+               dev-libs/expat
+               dev-libs/glib
+               dev-libs/nspr
+               dev-libs/nss
+               dev-libs/wayland
+               media-libs/alsa-lib
+               media-libs/fontconfig
+               media-libs/mesa[gbm(+)]
+               net-print/cups
+               x11-libs/cairo
+               x11-libs/libdrm
+               x11-libs/libXcursor
+               x11-libs/libXdamage
+               x11-libs/libXext
+               x11-libs/libXi
+               x11-libs/libxkbcommon
+               x11-libs/libXrandr
+               x11-libs/libXrender
+               x11-libs/libXScrnSaver
+               x11-libs/libxshmfence
+               x11-libs/libXtst
+               x11-libs/pango
+       )
+       fdk? ( media-libs/fdk-aac:= )
+       jack? ( virtual/jack )
+       lua? ( ${LUA_DEPS} )
+       mpegts? (
+               net-libs/librist
+               net-libs/srt
+       )
+       nvenc? ( >=media-libs/nv-codec-headers-12 )
+       pipewire? ( media-video/pipewire:= )
+       pulseaudio? ( media-libs/libpulse )
+       python? ( ${PYTHON_DEPS} )
+       qsv? ( media-libs/libvpl )
+       sndio? ( media-sound/sndio )
+       speex? ( media-libs/speexdsp )
+       truetype? (
+               media-libs/fontconfig
+               media-libs/freetype
+       )
+       v4l? (
+               media-libs/libv4l
+               virtual/udev
+       )
+       vlc? ( media-video/vlc:= )
+       wayland? (
+               dev-libs/wayland
+               x11-libs/libxkbcommon
+       )
+       websocket? (
+               dev-cpp/asio
+               dev-cpp/websocketpp
+               dev-libs/qr-code-generator
+       )
+"
+RDEPEND="${DEPEND}
+       qsv? ( media-libs/intel-mediasdk )
+"
+
+PATCHES=( "${FILESDIR}"/${PN}-31.0.0-libx11-link.patch )
+
+QA_PREBUILT="
+       usr/lib*/obs-plugins/chrome-sandbox
+       usr/lib*/obs-plugins/libcef.so
+       usr/lib*/obs-plugins/libEGL.so
+       usr/lib*/obs-plugins/libGLESv2.so
+       usr/lib*/obs-plugins/libvk_swiftshader.so
+       usr/lib*/obs-plugins/libvulkan.so.1
+       usr/lib*/obs-plugins/swiftshader/libEGL.so
+       usr/lib*/obs-plugins/swiftshader/libGLESv2.so
+"
+
+pkg_setup() {
+       use lua && lua-single_pkg_setup
+       use python && python-single-r1_pkg_setup
+}
+
+src_unpack() {
+       default
+
+       if [[ ${PV} == 9999 ]]; then
+               git-r3_src_unpack
+       else
+               rm -d ${P}/plugins/obs-browser || die
+               mv obs-browser-${OBS_BROWSER_COMMIT} ${P}/plugins/obs-browser 
|| die
+
+               rm -d ${P}/plugins/obs-websocket || die
+               mv obs-websocket-${OBS_WEBSOCKET_COMMIT} 
${P}/plugins/obs-websocket || die
+       fi
+}
+
+src_prepare() {
+       # -Werror=lto-type-mismatch
+       # https://bugs.gentoo.org/867250
+       # https://github.com/obsproject/obs-studio/issues/8988
+       use wayland && filter-lto
+
+       cmake_src_prepare
+
+       pushd deps/json11 &> /dev/null || die
+               eapply "${FILESDIR}/json11-1.0.0-include-cstdint.patch"
+       popd &> /dev/null || die
+}
+
+src_configure() {
+       local libdir=$(get_libdir)
+       local mycmakeargs=(
+               $(usev browser -DCEF_ROOT_DIR=../${CEF_VERSION})
+               -DENABLE_ALSA=$(usex alsa)
+               -DENABLE_AJA=OFF
+               -DENABLE_BROWSER=$(usex browser)
+               -DENABLE_CCACHE=OFF
+               -DENABLE_DECKLINK=$(usex decklink)
+               -DENABLE_FFMPEG_NVENC=$(usex nvenc)
+               -DENABLE_FREETYPE=$(usex truetype)
+               -DENABLE_JACK=$(usex jack)
+               -DENABLE_LIBFDK=$(usex fdk)
+               -DENABLE_NEW_MPEGTS_OUTPUT=$(usex mpegts)
+               -DENABLE_NVENC=$(usex nvenc)
+               -DENABLE_PIPEWIRE=$(usex pipewire)
+               -DENABLE_PULSEAUDIO=$(usex pulseaudio)
+               -DENABLE_QSV11=$(usex qsv)
+               -DENABLE_RNNOISE=ON
+               -DENABLE_SNDIO=$(usex sndio)
+               -DENABLE_SPEEXDSP=$(usex speex)
+               -DENABLE_TEST_INPUT=$(usex test-input)
+               -DENABLE_V4L2=$(usex v4l)
+               -DENABLE_VLC=$(usex vlc)
+               -DENABLE_VST=ON
+               -DENABLE_WAYLAND=$(usex wayland)
+               -DENABLE_WEBRTC=OFF # Requires libdatachannel.
+               -DENABLE_WEBSOCKET=$(usex websocket)
+       )
+
+       if [[ ${PV} != 9999 ]]; then
+               mycmakeargs+=(
+                       -DOBS_VERSION_OVERRIDE=${PV}
+               )
+       fi
+
+       if use lua || use python; then
+               mycmakeargs+=(
+                       -DENABLE_SCRIPTING_LUA=$(usex lua)
+                       -DENABLE_SCRIPTING_PYTHON=$(usex python)
+                       -DENABLE_SCRIPTING=ON
+               )
+       else
+               mycmakeargs+=( -DENABLE_SCRIPTING=OFF )
+       fi
+
+       if use browser; then
+               mycmakeargs+=( -DENABLE_WHATSNEW=ON )
+       else
+               mycmakeargs+=( -DENABLE_WHATSNEW=OFF )
+       fi
+
+       cmake_src_configure
+}
+
+src_install() {
+       cmake_src_install
+
+       # external plugins may need some things not installed by default, 
install them here
+       insinto /usr/include/obs/UI/obs-frontend-api
+       doins UI/obs-frontend-api/obs-frontend-api.h
+}
+
+pkg_postinst() {
+       xdg_pkg_postinst
+
+       if ! use alsa && ! use pulseaudio; then
+               elog
+               elog "For the audio capture features to be available,"
+               elog "at least one of the 'alsa' or 'pulseaudio' USE-flags 
needs to"
+               elog "be enabled."
+               elog
+       fi
+
+       if use v4l && has_version media-video/v4l2loopback; then
+               elog
+               elog "Depending on system configuration, the v4l2loopback 
kernel module"
+               elog "may need to be loaded manually, and needs to be re-built 
after"
+               elog "kernel changes."
+               elog
+       fi
+
+       optfeature "VA-API hardware encoding" media-video/ffmpeg[vaapi]
+       optfeature "virtual camera support" media-video/v4l2loopback
+}

Reply via email to