From 124a95a62c264394f08d70dc0eb66db06b8c9d04 Mon Sep 17 00:00:00 2001 From: Martin Dummer Date: Thu, 6 May 2021 00:31:44 +0200 Subject: media-video/vdr: add gcc-11 compile fix vdr defines std:: functions "min" "max" and "swap" as Template, which collides with gcc-11. Add a patch from upstream which fixes this, and fixes also compile problems with all media-video/vdr-* plugins using this functions, too Closes: https://bugs.gentoo.org/786882 Closes: https://bugs.gentoo.org/787389 Closes: https://bugs.gentoo.org/787236 Closes: https://bugs.gentoo.org/787140 Closes: https://bugs.gentoo.org/786801 Closes: https://bugs.gentoo.org/786795 Closes: https://bugs.gentoo.org/786672 Closes: https://bugs.gentoo.org/786285 Closes: https://bugs.gentoo.org/786258 Closes: https://bugs.gentoo.org/788583 Package-Manager: Portage-3.0.17, Repoman-3.0.2 Signed-off-by: Martin Dummer Closes: https://github.com/gentoo/gentoo/pull/20695 Signed-off-by: Joonas Niilola --- media-video/vdr/files/vdr-2.2.0_gcc11.patch | 29 +++ media-video/vdr/files/vdr-2.4.7_gcc11.patch | 314 +++------------------------- media-video/vdr/vdr-2.2.0-r7.ebuild | 302 ++++++++++++++++++++++++++ media-video/vdr/vdr-2.4.7-r1.ebuild | 209 ++++++++++++++++++ media-video/vdr/vdr-2.4.7.ebuild | 209 ------------------ 5 files changed, 564 insertions(+), 499 deletions(-) create mode 100644 media-video/vdr/files/vdr-2.2.0_gcc11.patch create mode 100644 media-video/vdr/vdr-2.2.0-r7.ebuild create mode 100644 media-video/vdr/vdr-2.4.7-r1.ebuild delete mode 100644 media-video/vdr/vdr-2.4.7.ebuild (limited to 'media-video') diff --git a/media-video/vdr/files/vdr-2.2.0_gcc11.patch b/media-video/vdr/files/vdr-2.2.0_gcc11.patch new file mode 100644 index 000000000000..297cdceabf56 --- /dev/null +++ b/media-video/vdr/files/vdr-2.2.0_gcc11.patch @@ -0,0 +1,29 @@ +Fix compile with gcc-11, officially from kls + +Signed-off-by: Martin Dummer + +--- a/tools.h 2021-05-05 21:48:32.382919856 +0200 ++++ b/tools.h 2021-05-05 21:53:10.184522278 +0200 +@@ -50,7 +50,10 @@ + #define CHECK(s) { if ((s) < 0) LOG_ERROR; } // used for 'ioctl()' calls + #define FATALERRNO (errno && errno != EAGAIN && errno != EINTR) + +-#ifndef __STL_CONFIG_H // in case some plugin needs to use the STL ++// In case some plugin needs to use the STL and gets an error message regarding one ++// of these functions, you can #define DISABLE_TEMPLATES_COLLIDING_WITH_STL before ++// including any VDR header files. ++#if !defined(DISABLE_TEMPLATES_COLLIDING_WITH_STL) + template inline T min(T a, T b) { return a <= b ? a : b; } + template inline T max(T a, T b) { return a >= b ? a : b; } + template inline int sgn(T a) { return a < 0 ? -1 : a > 0 ? 1 : 0; } +--- a/recording.c 2021-05-05 22:08:23.898974097 +0200 ++++ b/recording.c 2021-05-05 22:08:39.323280274 +0200 +@@ -2949,7 +2949,7 @@ + } + // found a non existing file suffix + } +- if (Open() >= 0) { ++ if (Open()) { + if (!record && Offset >= 0 && file && file->Seek(Offset, SEEK_SET) != Offset) { + LOG_ERROR_STR(fileName); + return NULL; diff --git a/media-video/vdr/files/vdr-2.4.7_gcc11.patch b/media-video/vdr/files/vdr-2.4.7_gcc11.patch index 866b018b5b79..1e37b2f0010c 100644 --- a/media-video/vdr/files/vdr-2.4.7_gcc11.patch +++ b/media-video/vdr/files/vdr-2.4.7_gcc11.patch @@ -1,292 +1,26 @@ -https://bugs.gentoo.org/786882 +Fix compile with gcc-11, officially from kls -compile fix for gcc-11 +Signed-off-by: Martin Dummer -Signed-off-by: Joerg Bornkessel (02 May 2021) -diff -Naur vdr-2.4.7.orig/channels.c vdr-2.4.7/channels.c ---- vdr-2.4.7.orig/channels.c 2021-05-02 19:34:32.312653108 +0200 -+++ vdr-2.4.7/channels.c 2021-05-02 19:39:19.241653108 +0200 -@@ -11,6 +11,7 @@ - #include - #include "device.h" - #include "libsi/si.h" -+using namespace std; - - // IMPORTANT NOTE: in the 'sscanf()' calls there is a blank after the '%d' - // format characters in order to allow any number of blanks after a numeric -diff -Naur vdr-2.4.7.orig/ci.c vdr-2.4.7/ci.c ---- vdr-2.4.7.orig/ci.c 2021-05-02 19:34:32.313653108 +0200 -+++ vdr-2.4.7/ci.c 2021-05-02 19:49:53.216653108 +0200 -@@ -27,6 +27,8 @@ - #include "skins.h" - #include "tools.h" - -+using namespace std; -+ - // Set these to 'true' for debug output: - static bool DumpTPDUDataTransfer = false; - static bool DebugProtocol = false; -diff -Naur vdr-2.4.7.orig/device.c vdr-2.4.7/device.c ---- vdr-2.4.7.orig/device.c 2021-05-02 19:34:32.313653108 +0200 -+++ vdr-2.4.7/device.c 2021-05-02 19:43:19.071653108 +0200 -@@ -20,6 +20,8 @@ - #include "status.h" - #include "transfer.h" - -+using namespace std; -+ - // --- cLiveSubtitle --------------------------------------------------------- - - class cLiveSubtitle : public cReceiver { -diff -Naur vdr-2.4.7.orig/diseqc.c vdr-2.4.7/diseqc.c ---- vdr-2.4.7.orig/diseqc.c 2021-05-02 19:34:32.314653108 +0200 -+++ vdr-2.4.7/diseqc.c 2021-05-02 19:50:14.177653108 +0200 -@@ -14,6 +14,8 @@ - #include "sources.h" - #include "thread.h" - -+using namespace std; -+ - #define ALL_DEVICES (~0) // all bits set to '1' - #define MAX_DEVICES 32 // each bit in a 32-bit integer represents one device - -diff -Naur vdr-2.4.7.orig/dvbdevice.c vdr-2.4.7/dvbdevice.c ---- vdr-2.4.7.orig/dvbdevice.c 2021-05-02 19:34:32.314653108 +0200 -+++ vdr-2.4.7/dvbdevice.c 2021-05-02 19:50:35.634653108 +0200 -@@ -21,6 +21,8 @@ - #include "menuitems.h" - #include "sourceparams.h" - -+using namespace std; -+ - static int DvbApiVersion = 0x0000; // the version of the DVB driver actually in use (will be determined by the first device created) - - #define DVBS_TUNE_TIMEOUT 9000 //ms -diff -Naur vdr-2.4.7.orig/dvbplayer.c vdr-2.4.7/dvbplayer.c ---- vdr-2.4.7.orig/dvbplayer.c 2021-05-02 19:34:32.314653108 +0200 -+++ vdr-2.4.7/dvbplayer.c 2021-05-02 19:43:47.344653108 +0200 -@@ -15,6 +15,8 @@ - #include "thread.h" - #include "tools.h" - -+using namespace std; -+ - // --- cPtsIndex ------------------------------------------------------------- - - #define PTSINDEX_ENTRIES 1024 -diff -Naur vdr-2.4.7.orig/dvbspu.c vdr-2.4.7/dvbspu.c ---- vdr-2.4.7.orig/dvbspu.c 2021-05-02 19:34:32.314653108 +0200 -+++ vdr-2.4.7/dvbspu.c 2021-05-02 19:44:08.952653108 +0200 -@@ -17,6 +17,8 @@ - #include - #include - -+using namespace std; -+ - /* - * cDvbSpubitmap: - * -diff -Naur vdr-2.4.7.orig/dvbsubtitle.c vdr-2.4.7/dvbsubtitle.c ---- vdr-2.4.7.orig/dvbsubtitle.c 2021-05-02 19:34:32.315653108 +0200 -+++ vdr-2.4.7/dvbsubtitle.c 2021-05-02 19:44:42.537653108 +0200 -@@ -16,6 +16,8 @@ - #include "device.h" - #include "libsi/si.h" - -+using namespace std; -+ - #define PAGE_COMPOSITION_SEGMENT 0x10 - #define REGION_COMPOSITION_SEGMENT 0x11 - #define CLUT_DEFINITION_SEGMENT 0x12 -diff -Naur vdr-2.4.7.orig/eit.c vdr-2.4.7/eit.c ---- vdr-2.4.7.orig/eit.c 2021-05-02 19:34:32.315653108 +0200 -+++ vdr-2.4.7/eit.c 2021-05-02 19:45:16.962653108 +0200 -@@ -18,6 +18,8 @@ - #include "libsi/section.h" - #include "libsi/descriptor.h" - -+using namespace std; -+ - #define VALID_TIME (31536000 * 2) // two years - - #define DBGEIT 0 -diff -Naur vdr-2.4.7.orig/font.c vdr-2.4.7/font.c ---- vdr-2.4.7.orig/font.c 2021-05-02 19:34:32.315653108 +0200 -+++ vdr-2.4.7/font.c 2021-05-02 19:51:53.540653108 +0200 -@@ -21,6 +21,8 @@ - #include "osd.h" - #include "tools.h" - -+using namespace std; -+ - const char *DefaultFontOsd = "Sans Serif:Bold"; - const char *DefaultFontSml = "Sans Serif"; - const char *DefaultFontFix = "Courier:Bold"; -diff -Naur vdr-2.4.7.orig/menu.c vdr-2.4.7/menu.c ---- vdr-2.4.7.orig/menu.c 2021-05-02 19:34:32.317653108 +0200 -+++ vdr-2.4.7/menu.c 2021-05-02 19:45:44.891653108 +0200 -@@ -33,6 +33,8 @@ - #include "transfer.h" - #include "videodir.h" - -+using namespace std; -+ - #define MAXWAIT4EPGINFO 3 // seconds - #define MODETIMEOUT 3 // seconds - #define NEWTIMERLIMIT 120 // seconds until the start time of a new timer created from the Schedule menu, -diff -Naur vdr-2.4.7.orig/menuitems.c vdr-2.4.7/menuitems.c ---- vdr-2.4.7.orig/menuitems.c 2021-05-02 19:34:32.318653108 +0200 -+++ vdr-2.4.7/menuitems.c 2021-05-02 19:46:02.483653108 +0200 -@@ -17,6 +17,8 @@ - #include "skins.h" - #include "status.h" - -+using namespace std; -+ - #define AUTO_ADVANCE_TIMEOUT 1500 // ms before auto advance when entering characters via numeric keys - - const char *FileNameChars = trNOOP("FileNameChars$ abcdefghijklmnopqrstuvwxyz0123456789-.,#~\\^$[]|()*+?{}/:%@&"); -diff -Naur vdr-2.4.7.orig/mtd.c vdr-2.4.7/mtd.c ---- vdr-2.4.7.orig/mtd.c 2021-05-02 19:34:32.318653108 +0200 -+++ vdr-2.4.7/mtd.c 2021-05-02 19:46:23.355653108 +0200 -@@ -10,6 +10,8 @@ - #include "mtd.h" - #include "receiver.h" - -+using namespace std; -+ - //#define DEBUG_MTD - #ifdef DEBUG_MTD - #define DBGMTD(a...) dsyslog(a) -diff -Naur vdr-2.4.7.orig/nit.c vdr-2.4.7/nit.c ---- vdr-2.4.7.orig/nit.c 2021-05-02 19:34:32.318653108 +0200 -+++ vdr-2.4.7/nit.c 2021-05-02 19:52:19.012653108 +0200 -@@ -16,6 +16,8 @@ - #include "libsi/descriptor.h" - #include "tools.h" - -+using namespace std; -+ - #define DVB_SYSTEM_1 0 // see also dvbdevice.c - #define DVB_SYSTEM_2 1 - -diff -Naur vdr-2.4.7.orig/osd.c vdr-2.4.7/osd.c ---- vdr-2.4.7.orig/osd.c 2021-05-02 19:34:32.318653108 +0200 -+++ vdr-2.4.7/osd.c 2021-05-02 19:47:12.501653108 +0200 -@@ -16,6 +16,8 @@ - #include "device.h" - #include "tools.h" - -+using namespace std; -+ - tColor HsvToColor(double H, double S, double V) - { - if (S > 0) { -diff -Naur vdr-2.4.7.orig/osdbase.c vdr-2.4.7/osdbase.c ---- vdr-2.4.7.orig/osdbase.c 2021-05-02 19:34:32.318653108 +0200 -+++ vdr-2.4.7/osdbase.c 2021-05-02 19:46:53.516653108 +0200 -@@ -15,6 +15,8 @@ - #include "remote.h" - #include "status.h" - -+using namespace std; -+ - // --- cOsdItem -------------------------------------------------------------- - - cOsdItem::cOsdItem(eOSState State) -diff -Naur vdr-2.4.7.orig/recording.c vdr-2.4.7/recording.c ---- vdr-2.4.7.orig/recording.c 2021-05-02 19:34:32.323653108 +0200 -+++ vdr-2.4.7/recording.c 2021-05-02 19:47:45.990653108 +0200 -@@ -31,6 +31,8 @@ - #include "tools.h" - #include "videodir.h" - -+using namespace std; -+ - #define SUMMARYFALLBACK - - #define RECEXT ".rec" -diff -Naur vdr-2.4.7.orig/remux.c vdr-2.4.7/remux.c ---- vdr-2.4.7.orig/remux.c 2021-05-02 19:34:32.323653108 +0200 -+++ vdr-2.4.7/remux.c 2021-05-02 19:48:03.230653108 +0200 -@@ -16,6 +16,8 @@ - #include "shutdown.h" - #include "tools.h" - -+using namespace std; -+ - // Set these to 'true' for debug output: - static bool DebugPatPmt = false; - static bool DebugFrames = false; -diff -Naur vdr-2.4.7.orig/skinclassic.c vdr-2.4.7/skinclassic.c ---- vdr-2.4.7.orig/skinclassic.c 2021-05-02 19:34:32.324653108 +0200 -+++ vdr-2.4.7/skinclassic.c 2021-05-02 19:48:26.271653108 +0200 -@@ -14,6 +14,8 @@ - #include "themes.h" - #include "videodir.h" - -+using namespace std; -+ - #define ScrollWidth (Setup.FontOsdSize / 4) - #define TextFrame (Setup.FontOsdSize / 10) - #define TextSpacing (Setup.FontOsdSize / 4) -diff -Naur vdr-2.4.7.orig/skinlcars.c vdr-2.4.7/skinlcars.c ---- vdr-2.4.7.orig/skinlcars.c 2021-05-02 19:34:32.324653108 +0200 -+++ vdr-2.4.7/skinlcars.c 2021-05-02 19:48:46.063653108 +0200 -@@ -63,6 +63,8 @@ - #include "symbols/teletext.xpm" - #include "symbols/volume.xpm" - -+using namespace std; -+ - #define Gap (Setup.FontOsdSize / 5 & ~1) // must be even - #define TextFrame (Setup.FontOsdSize / TEXT_ALIGN_BORDER) - #define TextSpacing (2 * TextFrame) -diff -Naur vdr-2.4.7.orig/skinsttng.c vdr-2.4.7/skinsttng.c ---- vdr-2.4.7.orig/skinsttng.c 2021-05-02 19:34:32.324653108 +0200 -+++ vdr-2.4.7/skinsttng.c 2021-05-02 19:49:15.256653108 +0200 -@@ -50,6 +50,8 @@ - #include "symbols/teletext.xpm" - #include "symbols/volume.xpm" - -+using namespace std; -+ - #define Roundness (Setup.FontOsdSize / 2) - #define Gap (Setup.FontOsdSize / 5) - #define ScrollWidth (Setup.FontOsdSize / 4) -diff -Naur vdr-2.4.7.orig/thread.c vdr-2.4.7/thread.c ---- vdr-2.4.7.orig/thread.c 2021-05-02 19:59:16.883653108 +0200 -+++ vdr-2.4.7/thread.c 2021-05-02 20:00:08.879653108 +0200 -@@ -24,6 +24,8 @@ - #include - #include "tools.h" - -+using namespace std; -+ - #define ABORT { dsyslog("ABORT!"); cBackTrace::BackTrace(); abort(); } - - //#define DEBUG_LOCKING // uncomment this line to activate debug output for locking -diff -Naur vdr-2.4.7.orig/timers.c vdr-2.4.7/timers.c ---- vdr-2.4.7.orig/timers.c 2021-05-02 19:59:16.883653108 +0200 -+++ vdr-2.4.7/timers.c 2021-05-02 19:59:52.287653108 +0200 -@@ -17,6 +17,8 @@ - #include "status.h" - #include "svdrp.h" - -+using namespace std; -+ - // IMPORTANT NOTE: in the 'sscanf()' calls there is a blank after the '%d' - // format characters in order to allow any number of blanks after a numeric - // value! -diff -Naur vdr-2.4.7.orig/tools.c vdr-2.4.7/tools.c ---- vdr-2.4.7.orig/tools.c 2021-05-02 20:02:40.535653108 +0200 -+++ vdr-2.4.7/tools.c 2021-05-02 20:03:06.859653108 +0200 -@@ -28,6 +28,8 @@ - #include "i18n.h" - #include "thread.h" - -+using namespace std; -+ - int SysLogLevel = 3; - - #define MAXSYSLOGBUF 256 +--- a/tools.h 2021/01/19 20:38:28 5.3 ++++ b/tools.h 2021/05/05 15:16:45 +@@ -53,17 +53,15 @@ + + // In case some plugin needs to use the STL and gets an error message regarding one + // of these functions, you can #define DISABLE_TEMPLATES_COLLIDING_WITH_STL before +-// including tools.h. +-#if !defined(__STL_CONFIG_H) // for old versions of the STL +-#if !defined(DISABLE_TEMPLATES_COLLIDING_WITH_STL) && !defined(_STL_ALGOBASE_H) ++// including any VDR header files. ++#if !defined(DISABLE_TEMPLATES_COLLIDING_WITH_STL) + template inline T min(T a, T b) { return a <= b ? a : b; } + template inline T max(T a, T b) { return a >= b ? a : b; } + #endif + template inline int sgn(T a) { return a < 0 ? -1 : a > 0 ? 1 : 0; } +-#if !defined(DISABLE_TEMPLATES_COLLIDING_WITH_STL) && !defined(_MOVE_H) ++#if !defined(DISABLE_TEMPLATES_COLLIDING_WITH_STL) + template inline void swap(T &a, T &b) { T t = a; a = b; b = t; } + #endif +-#endif + + template inline T constrain(T v, T l, T h) { return v < l ? l : v > h ? h : v; } diff --git a/media-video/vdr/vdr-2.2.0-r7.ebuild b/media-video/vdr/vdr-2.2.0-r7.ebuild new file mode 100644 index 000000000000..42c9e675b2b5 --- /dev/null +++ b/media-video/vdr/vdr-2.2.0-r7.ebuild @@ -0,0 +1,302 @@ +# Copyright 2021 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI=7 + +inherit flag-o-matic l10n toolchain-funcs + +# Switches supported by extensions-patch +EXT_PATCH_FLAGS="alternatechannel graphtft naludump permashift pinplugin + mainmenuhooks menuorg menuselection resumereset ttxtsubs" + +# names of the use-flags +EXT_PATCH_FLAGS_RENAMED="" + +# names ext-patch uses internally, here only used for maintainer checks +EXT_PATCH_FLAGS_RENAMED_EXT_NAME="bidi no_kbd sdnotify" + +MY_PV="${PV%_p*}" +MY_P="${PN}-${MY_PV}" +S="${WORKDIR}/${MY_P}" + +EXT_P="extpng-${P}-gentoo-edition-v1" + +DESCRIPTION="Video Disk Recorder - turns a pc into a powerful set top box for DVB" +HOMEPAGE="http://www.tvdr.de/" +SRC_URI="ftp://ftp.tvdr.de/vdr/${MY_P}.tar.bz2 + mirror://gentoo/${EXT_P}.patch.bz2" + +LICENSE="GPL-2+" +SLOT="0" +KEYWORDS="~amd64 ~arm ~arm64 ~ppc ~x86" +IUSE="bidi debug keyboard html systemd vanilla ${EXT_PATCH_FLAGS} ${EXT_PATCH_FLAGS_RENAMED}" + +COMMON_DEPEND=" + virtual/jpeg:* + sys-libs/libcap + >=media-libs/fontconfig-2.4.2 + >=media-libs/freetype-2" +DEPEND="${COMMON_DEPEND} + >=virtual/linuxtv-dvb-headers-5.3" +RDEPEND="${COMMON_DEPEND} + dev-lang/perl + >=media-tv/gentoo-vdr-scripts-2.7 + media-fonts/corefonts + bidi? ( dev-libs/fribidi ) + systemd? ( sys-apps/systemd )" +BDEPEND="sys-devel/gettext" + +CONF_DIR="/etc/vdr" +CAP_FILE="${S}/capabilities.sh" +CAPS="# Capabilities of the vdr-executable for use by startscript etc." + +pkg_setup() { + use debug && append-flags -g + + PLUGIN_LIBDIR="/usr/$(get_libdir)/vdr/plugins" + + tc-export CC CXX AR +} + +add_cap() { + local arg + for arg; do + CAPS="${CAPS}\n${arg}=1" + done +} + +enable_patch() { + local arg ARG_UPPER + for arg; do + ARG_UPPER=$(echo $arg | tr '[:lower:]' '[:upper:]') + echo "${ARG_UPPER} = 1" >> Make.config || die "cannot write to Make.config" + + # codesnippet to bring the extpng defines into the vdr.pc CXXFLAGS CFLAGS + echo "-DUSE_${ARG_UPPER}" >> "${T}"/defines.tmp || die "cannot write to defines.tmp" + cat "${T}"/defines.tmp | tr \\\012 ' ' > "${T}"/defines.IUSE || die "cannot write to defines.tmp" + export DEFINES_IUSE=$( cat ${T}/defines.IUSE ) + done +} + +extensions_add_make_conf() { + # copy all ifdef for extensions-patch to Make.config + sed -e '1,/need to touch the following:/d' \ + -e '/need to touch the following/,/^$/d' \ + Make.config.template >> Make.config || die "cannot write to Make.config" +} + +extensions_all_defines() { + # extract all possible settings for extensions-patch + sed -e '/^#\?[A-Z].*= 1/!d' -e 's/^#\?//' -e 's/ .*//' \ + Make.config.template \ + | sort \ + | tr '[:upper:]' '[:lower:]' || die "error in function extensions_all_defines" +} + +lang_po() { + LING_PO=$( ls ${S}/po | sed -e "s:.po::g" | cut -d_ -f1 | tr \\\012 ' ' ) +} + +src_configure() { + # support languages, written from right to left + export "BIDI=$(usex bidi 1 0)" + # systemd notification support + export "SDNOTIFY=$(usex systemd 1 0)" + # with/without keyboard + export "USE_KBD=$(usex keyboard 1 0)" +} + +src_prepare() { + # apply maintenance-patches + ebegin "Changing paths for gentoo" + + local DVBDIR="/usr/include" + local i + for i in ${DVB_HEADER_PATH} /usr/include/v4l-dvb-hg /usr/include; do + [[ -d ${i} ]] || continue + if [[ -f ${i}/linux/dvb/dmx.h ]]; then + einfo "Found DVB header files in ${i}" + DVBDIR="${i}" + break + fi + done + + # checking for s2api headers + local api_version + api_version=$(awk -F' ' '/define DVB_API_VERSION / {print $3}' "${DVBDIR}"/linux/dvb/version.h) + api_version=${api_version}*$(awk -F' ' '/define DVB_API_VERSION_MINOR / {print $3}' "${DVBDIR}"/linux/dvb/version.h) + + if [[ ${api_version:-0} -lt 5*3 ]]; then + eerror "DVB header files do not contain s2api support or too old for ${P}" + eerror "You cannot compile VDR against old dvb-header" + die "DVB headers too old" + fi + + cat > Make.config <<-EOT || die "cannot write to Make.config" + # + # Generated by ebuild ${PF} + # + PREFIX = /usr + DVBDIR = ${DVBDIR} + PLUGINLIBDIR = ${PLUGIN_LIBDIR} + CONFDIR = ${CONF_DIR} + VIDEODIR = /var/vdr/video + LOCDIR = \$(PREFIX)/share/locale + INCDIR = \$(PREFIX)/include + + DEFINES += -DCONFDIR=\"\$(CONFDIR)\" + INCLUDES += -I\$(DVBDIR) + + # >=vdr-1.7.36-r1; parameter only used for compiletime on vdr + # PLUGINLIBDIR (plugin Makefile old) = LIBDIR (plugin Makefile new) + LIBDIR = ${PLUGIN_LIBDIR} + PCDIR = /usr/$(get_libdir)/pkgconfig + + EOT + eend 0 + + # wrt bug 586070 + if has_version ">=sys-apps/systemd-230"; then + sed -e "s:libsystemd-daemon:libsystemd:g" -i Makefile || die "sed libsystemd failed" + fi + + if ! use vanilla; then + + # Now apply extensions patch + eapply "${WORKDIR}/${EXT_P}.patch" + sed -e 's/PERMASHIFT_V1/PERMASHIFT/g' -i "${S}"/*.[ch] "${S}"/Make.config* || die "sed failed" + + # This allows us to start even if some plugin does not exist + # or is not loadable. + enable_patch PLUGINMISSING + + if [[ -n ${VDR_MAINTAINER_MODE} ]]; then + einfo "Doing maintainer checks:" + + # we do not support these patches + # (or have them already hard enabled) + local IGNORE_PATCHES="pluginmissing" + + extensions_all_defines > "${T}"/new.IUSE || die "cannot write to new.IUSE" + echo $EXT_PATCH_FLAGS $EXT_PATCH_FLAGS_RENAMED_EXT_NAME \ + $IGNORE_PATCHES | \ + tr ' ' '\n' |sort > "${T}"/old.IUSE || die "cannot write to old.IUSE" + local DIFFS=$(diff -u "${T}"/old.IUSE "${T}"/new.IUSE|grep '^[+-][^+-]') + if [[ -z ${DIFFS} ]]; then + einfo "EXT_PATCH_FLAGS are up to date." + else + ewarn "IUSE differences!" + local diff + for diff in $DIFFS; do + ewarn "$diff" + done + fi + fi + + ebegin "Enabling selected patches" + local flag + for flag in $EXT_PATCH_FLAGS; do + use $flag && enable_patch ${flag} + done + + eend 0 + + extensions_add_make_conf + + # add defined use-flags compile options to vdr.pc + sed -e "s:\$(CDEFINES) \$(CINCLUDES) \$(HDRDIR):\$(CDEFINES) \$(CINCLUDES) \$(HDRDIR) \$(DEFINES_IUSE):" \ + -i Makefile || die "sed fails on Makefile" + + ebegin "Make depend" + emake .dependencies >/dev/null + eend $? "make depend failed" + + eapply "${FILESDIR}/${P}_gcc7extpng.patch" + eapply "${FILESDIR}/${P}_gcc11.patch" + fi + + eapply "${FILESDIR}/${P}_gentoo.patch" + eapply "${FILESDIR}/${P}_unsignedtosigned.patch" + eapply "${FILESDIR}/${P}_glibc-2.24.patch" + eapply "${FILESDIR}/${P}-jpeg-9c.patch" + eapply "${FILESDIR}/${P}_glibc-2.31.patch" + + # fix some makefile issues + sed -e "s:ifndef NO_KBD:ifeq (\$(USE_KBD),1):" \ + -e "s:ifdef BIDI:ifeq (\$(BIDI),1):" \ + -e "s:ifdef SDNOTIFY:ifeq (\$(SDNOTIFY),1):" \ + -i "${S}"/Makefile || die "sed fails on Makefile" + + eapply_user + + add_cap CAP_UTF8 + + add_cap CAP_IRCTRL_RUNTIME_PARAM \ + CAP_VFAT_RUNTIME_PARAM \ + CAP_CHUID \ + CAP_SHUTDOWN_AUTO_RETRY + + echo -e ${CAPS} > "${CAP_FILE}" + + # LINGUAS support + einfo "\n \t VDR supports the LINGUAS values" + + lang_po + + einfo "\t Please set one of this values in your sytem make.conf" + einfo "\t LINGUAS=\"${LING_PO}\"\n" + + if [[ -z ${LINGUAS} ]]; then + einfo "\n \t No values in LINGUAS=" + einfo "\t You will get only english text on OSD \n" + fi + + strip-linguas ${LING_PO} en +} + +src_install() { + # trick makefile not to create a videodir by supplying it with an existing + # directory + emake install \ + VIDEODIR="/" \ + DESTDIR="${ED}" install + + keepdir "${PLUGIN_LIBDIR}" + + # backup for plugins they don't be able to create this dir + keepdir "${CONF_DIR}"/plugins + + if use html; then + local HTML_DOCS=( *.html ) + fi + + local DOCS=( MANUAL INSTALL README* HISTORY CONTRIBUTORS ) + + einstalldocs + + insinto /usr/share/vdr + doins "${CAP_FILE}" + + if use alternatechannel; then + insinto /etc/vdr + doins "${FILESDIR}"/channel_alternative.conf + fi + + chown -R vdr:vdr "${ED}/${CONF_DIR}" || die "chown failed" +} + +pkg_postinst() { + + elog "\n\t---- 15 YEARS ANNIVERSARY EDITON ----\n" + elog "\tA lot of thanks to Klaus Schmidinger" + elog "\tfor this nice piece of Software...\n" + + elog "It is a good idea to run vdrplugin-rebuild now." + + elog "To get nice symbols in OSD we recommend to install" + elog "\t1. emerge media-fonts/vdrsymbols-ttf" + elog "\t2. select font VDRSymbolsSans in Setup" + elog "" + elog "To get an idea how to proceed now, have a look at our vdr-guide:" + elog "\thttps://wiki.gentoo.org/wiki/VDR" +} diff --git a/media-video/vdr/vdr-2.4.7-r1.ebuild b/media-video/vdr/vdr-2.4.7-r1.ebuild new file mode 100644 index 000000000000..8fda32ee217b --- /dev/null +++ b/media-video/vdr/vdr-2.4.7-r1.ebuild @@ -0,0 +1,209 @@ +# Copyright 2021 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI=7 + +inherit flag-o-matic l10n toolchain-funcs + +DESCRIPTION="Video Disk Recorder - turns a pc into a powerful set top box for DVB" +HOMEPAGE="http://www.tvdr.de/" +SRC_URI="http://git.tvdr.de/?p=vdr.git;a=snapshot;h=refs/tags/2.4.7;sf=tbz2 -> ${P}.tbz2 + mainmenuhooks? ( http://vdr.websitec.de/download/${PN}/${PN}-2.4.1/${PN}-2.4.1_mainmenuhook-1.0.1.patch.bz2 ) + menuorg? ( https://projects.vdr-developer.org/projects/plg-menuorg/repository/revisions/master/raw/vdr-patch/vdr-menuorg-2.3.x.diff ) + naludump? ( https://www.udo-richter.de/vdr/files/vdr-2.1.5-naludump-0.1.diff ) + pinplugin? ( http://vdr.websitec.de/download/${PN}/vdr-2.4.6/${PN}-2.4.6_pinplugin.patch.bz2 ) + ttxtsubs? ( http://vdr.websitec.de/download/${PN}/vdr-2.4.6/${PN}-2.4.6_ttxtsubs_v2.patch.bz2 ) + permashift? ( http://vdr.websitec.de/download/${PN}/vdr-2.4.6/vdr-2.4-patch-for-permashift.diff.bz2 )" + +LICENSE="GPL-2+" +SLOT="0" +KEYWORDS="~amd64 ~arm ~arm64 ~ppc ~x86" +IUSE="bidi debug demoplugins html keyboard mainmenuhooks menuorg naludump permashift pinplugin systemd ttxtsubs verbose" + +COMMON_DEPEND=" + virtual/jpeg:* + sys-libs/libcap + >=media-libs/fontconfig-2.4.2 + >=media-libs/freetype-2" +DEPEND="${COMMON_DEPEND} + >=virtual/linuxtv-dvb-headers-5.3" +RDEPEND="${COMMON_DEPEND} + dev-lang/perl + media-tv/gentoo-vdr-scripts + media-fonts/corefonts + bidi? ( dev-libs/fribidi ) + systemd? ( sys-apps/systemd )" +BDEPEND="sys-devel/gettext" + +REQUIRED_USE="pinplugin? ( !mainmenuhooks ) + permashift? ( !naludump !pinplugin )" + +CONF_DIR="/etc/vdr" +CAP_FILE="${S}/capabilities.sh" +CAPS="# Capabilities of the vdr-executable for use by startscript etc." + +pkg_setup() { + use debug && append-flags -g + + PLUGIN_LIBDIR="/usr/$(get_libdir)/vdr/plugins" + + # use the corrected DIR /var/lib/vdr/* for acct/{user,group) handling + if has_version ">=media-tv/gentoo-vdr-scripts-3.0_rc1"; then + VIDEO_DIR="/var/lib/vdr/video" + else + VIDEO_DIR="/var/vdr/video" + fi + + tc-export CC CXX AR +} + +add_cap() { + local arg + for arg; do + CAPS="${CAPS}\n${arg}=1" + done +} + +lang_po() { + LING_PO=$( ls ${S}/po | sed -e "s:.po::g" | cut -d_ -f1 | tr \\\012 ' ' ) +} + +src_configure() { + # support languages, written from right to left + export "BIDI=$(usex bidi 1 0)" + # systemd notification support + export "SDNOTIFY=$(usex systemd 1 0)" + # with/without keyboard + export "USE_KBD=$(usex keyboard 1 0)" + # detailed compile output for debug + export "VERBOSE=$(usex verbose 1 0)" +} + +src_prepare() { + # apply maintenance-patches + ebegin "Changing paths for gentoo" + + local DVBDIR=/usr/include + local i + for i in ${DVB_HEADER_PATH} /usr/include/v4l-dvb-hg /usr/include; do + [[ -d ${i} ]] || continue + if [[ -f ${i}/linux/dvb/dmx.h ]]; then + einfo "Found DVB header files in ${i}" + DVBDIR=${i} + break + fi + done + + # checking for s2api headers + local api_version + api_version=$(awk -F' ' '/define DVB_API_VERSION / {print $3}' "${DVBDIR}"/linux/dvb/version.h) + api_version=${api_version}*$(awk -F' ' '/define DVB_API_VERSION_MINOR / {print $3}' "${DVBDIR}"/linux/dvb/version.h) + + if [[ ${api_version:-0} -lt 5*3 ]]; then + eerror "DVB header files do not contain s2api support or too old for ${P}" + eerror "You cannot compile VDR against old dvb-header" + die "DVB headers too old" + fi + + cat > Make.config <<-EOT || die "cannot write to Make.config" + # + # Generated by ebuild ${PF} + # + PREFIX = /usr + DVBDIR = ${DVBDIR} + PLUGINLIBDIR = ${PLUGIN_LIBDIR} + CONFDIR = ${CONF_DIR} + ARGSDIR = \$(CONFDIR)/conf.d + VIDEODIR = ${VIDEO_DIR} + LOCDIR = \$(PREFIX)/share/locale + INCDIR = \$(PREFIX)/include + + DEFINES += -DCONFDIR=\"\$(CONFDIR)\" + INCLUDES += -I\$(DVBDIR) + + # >=vdr-1.7.36-r1; parameter only used for compiletime on vdr + # PLUGINLIBDIR (plugin Makefile old) = LIBDIR (plugin Makefile new) + LIBDIR = ${PLUGIN_LIBDIR} + PCDIR = /usr/$(get_libdir)/pkgconfig + + EOT + eend 0 + + eapply "${FILESDIR}/${PN}-2.4.6_gentoo.patch" + use demoplugins || eapply "${FILESDIR}/vdr-2.4_remove_plugins.patch" + eapply "${FILESDIR}/${PN}-2.4.6_makefile-variables.patch" + + # fix clang/LLVM compile + eapply "${FILESDIR}/${PN}-2.4.6_clang.patch" + + # fix gcc-11 compile + eapply "${FILESDIR}/${P}_gcc11.patch" + + use naludump && eapply "${DISTDIR}/${PN}-2.1.5-naludump-0.1.diff" + use permashift && eapply "${WORKDIR}/${PN}-2.4-patch-for-permashift.diff" + use pinplugin && eapply "${WORKDIR}/${PN}-2.4.6_pinplugin.patch" + use ttxtsubs && eapply "${WORKDIR}/${PN}-2.4.6_ttxtsubs_v2.patch" + use menuorg && eapply "${DISTDIR}/vdr-menuorg-2.3.x.diff" + use mainmenuhooks && eapply "${WORKDIR}/${PN}-2.4.1_mainmenuhook-1.0.1.patch" + + add_cap CAP_UTF8 \ + CAP_IRCTRL_RUNTIME_PARAM \ + CAP_VFAT_RUNTIME_PARAM \ + CAP_CHUID \ + CAP_SHUTDOWN_AUTO_RETRY + + echo -e ${CAPS} > "${CAP_FILE}" || die "cannot write to CAP_FILE" + + # LINGUAS support + einfo "\n \t VDR supports the LINGUAS values" + + lang_po + + einfo "\t Please set one of this values in your sytem make.conf" + einfo "\t LINGUAS=\"${LING_PO}\"\n" + + if [[ -z ${LINGUAS} ]]; then + einfo "\n \t No values in LINGUAS=" + einfo "\t You will get only english text on OSD \n" + fi + + strip-linguas ${LING_PO} en + + default +} + +src_install() { + # trick the makefile to not create a VIDEODIR by supplying it with an + # existing directory + emake VIDEODIR="/" DESTDIR="${ED}" install + + keepdir "${PLUGIN_LIBDIR}" + + # backup for plugins they don't be able to create this dir + keepdir "${CONF_DIR}/plugins" + + if use html; then + local HTML_DOCS=( *.html ) + fi + local DOCS=( MANUAL INSTALL README* HISTORY CONTRIBUTORS UPDATE-2* ) + einstalldocs + + insinto /usr/share/vdr + doins "${CAP_FILE}" + + fowners vdr:vdr "${CONF_DIR}" -R +} + +pkg_postinst() { + elog "Please read the /usr/share/doc/${PF}/UPDATE-2.4" + elog "for major changes in this version\n" + + elog "It is a good idea to run vdrplugin-rebuild now.\n" + + elog "To get nice symbols in OSD we recommend to install" + elog "\t1. emerge media-fonts/vdrsymbols-ttf" + elog "\t2. select font VDRSymbolsSans in Setup\n" + + elog "To get an idea how to proceed now, have a look at our vdr-guide:" + elog "\thttps://wiki.gentoo.org/wiki/VDR" +} diff --git a/media-video/vdr/vdr-2.4.7.ebuild b/media-video/vdr/vdr-2.4.7.ebuild deleted file mode 100644 index c1f9413c3022..000000000000 --- a/media-video/vdr/vdr-2.4.7.ebuild +++ /dev/null @@ -1,209 +0,0 @@ -# Copyright 2021 Gentoo Authors -# Distributed under the terms of the GNU General Public License v2 - -EAPI=7 - -inherit flag-o-matic l10n toolchain-funcs - -DESCRIPTION="Video Disk Recorder - turns a pc into a powerful set top box for DVB" -HOMEPAGE="http://www.tvdr.de/" -SRC_URI="http://git.tvdr.de/?p=vdr.git;a=snapshot;h=refs/tags/2.4.7;sf=tbz2 -> ${P}.tbz2 - mainmenuhooks? ( http://vdr.websitec.de/download/${PN}/${PN}-2.4.1/${PN}-2.4.1_mainmenuhook-1.0.1.patch.bz2 ) - menuorg? ( https://projects.vdr-developer.org/projects/plg-menuorg/repository/revisions/master/raw/vdr-patch/vdr-menuorg-2.3.x.diff ) - naludump? ( http://www.udo-richter.de/vdr/files/vdr-2.1.5-naludump-0.1.diff ) - pinplugin? ( http://vdr.websitec.de/download/${PN}/${P}/${PN}-2.4.6_pinplugin.patch.bz2 ) - ttxtsubs? ( http://vdr.websitec.de/download/${PN}/${P}/${PN}-2.4.6_ttxtsubs_v2.patch.bz2 ) - permashift? ( http://vdr.websitec.de/download/${PN}/${P}/vdr-2.4-patch-for-permashift.diff.bz2 )" - -LICENSE="GPL-2+" -SLOT="0" -KEYWORDS="~amd64 ~arm ~arm64 ~ppc ~x86" -IUSE="bidi debug demoplugins html keyboard mainmenuhooks menuorg naludump permashift pinplugin systemd ttxtsubs verbose" - -COMMON_DEPEND=" - virtual/jpeg:* - sys-libs/libcap - >=media-libs/fontconfig-2.4.2 - >=media-libs/freetype-2" -DEPEND="${COMMON_DEPEND} - >=virtual/linuxtv-dvb-headers-5.3" -RDEPEND="${COMMON_DEPEND} - dev-lang/perl - media-tv/gentoo-vdr-scripts - media-fonts/corefonts - bidi? ( dev-libs/fribidi ) - systemd? ( sys-apps/systemd )" -BDEPEND="sys-devel/gettext" - -REQUIRED_USE="pinplugin? ( !mainmenuhooks ) - permashift? ( !naludump !pinplugin )" - -CONF_DIR="/etc/vdr" -CAP_FILE="${S}/capabilities.sh" -CAPS="# Capabilities of the vdr-executable for use by startscript etc." - -pkg_setup() { - use debug && append-flags -g - - PLUGIN_LIBDIR="/usr/$(get_libdir)/vdr/plugins" - - # use the corrected DIR /var/lib/vdr/* for acct/{user,group) handling - if has_version ">=media-tv/gentoo-vdr-scripts-3.0_rc1"; then - VIDEO_DIR="/var/lib/vdr/video" - else - VIDEO_DIR="/var/vdr/video" - fi - - tc-export CC CXX AR -} - -add_cap() { - local arg - for arg; do - CAPS="${CAPS}\n${arg}=1" - done -} - -lang_po() { - LING_PO=$( ls ${S}/po | sed -e "s:.po::g" | cut -d_ -f1 | tr \\\012 ' ' ) -} - -src_configure() { - # support languages, written from right to left - export "BIDI=$(usex bidi 1 0)" - # systemd notification support - export "SDNOTIFY=$(usex systemd 1 0)" - # with/without keyboard - export "USE_KBD=$(usex keyboard 1 0)" - # detailed compile output for debug - export "VERBOSE=$(usex verbose 1 0)" -} - -src_prepare() { - # apply maintenance-patches - ebegin "Changing paths for gentoo" - - local DVBDIR=/usr/include - local i - for i in ${DVB_HEADER_PATH} /usr/include/v4l-dvb-hg /usr/include; do - [[ -d ${i} ]] || continue - if [[ -f ${i}/linux/dvb/dmx.h ]]; then - einfo "Found DVB header files in ${i}" - DVBDIR=${i} - break - fi - done - - # checking for s2api headers - local api_version - api_version=$(awk -F' ' '/define DVB_API_VERSION / {print $3}' "${DVBDIR}"/linux/dvb/version.h) - api_version=${api_version}*$(awk -F' ' '/define DVB_API_VERSION_MINOR / {print $3}' "${DVBDIR}"/linux/dvb/version.h) - - if [[ ${api_version:-0} -lt 5*3 ]]; then - eerror "DVB header files do not contain s2api support or too old for ${P}" - eerror "You cannot compile VDR against old dvb-header" - die "DVB headers too old" - fi - - cat > Make.config <<-EOT || die "cannot write to Make.config" - # - # Generated by ebuild ${PF} - # - PREFIX = /usr - DVBDIR = ${DVBDIR} - PLUGINLIBDIR = ${PLUGIN_LIBDIR} - CONFDIR = ${CONF_DIR} - ARGSDIR = \$(CONFDIR)/conf.d - VIDEODIR = ${VIDEO_DIR} - LOCDIR = \$(PREFIX)/share/locale - INCDIR = \$(PREFIX)/include - - DEFINES += -DCONFDIR=\"\$(CONFDIR)\" - INCLUDES += -I\$(DVBDIR) - - # >=vdr-1.7.36-r1; parameter only used for compiletime on vdr - # PLUGINLIBDIR (plugin Makefile old) = LIBDIR (plugin Makefile new) - LIBDIR = ${PLUGIN_LIBDIR} - PCDIR = /usr/$(get_libdir)/pkgconfig - - EOT - eend 0 - - eapply "${FILESDIR}/${PN}-2.4.6_gentoo.patch" - use demoplugins || eapply "${FILESDIR}/vdr-2.4_remove_plugins.patch" - eapply "${FILESDIR}/${PN}-2.4.6_makefile-variables.patch" - - # fix clang/LLVM compile - eapply "${FILESDIR}/${PN}-2.4.6_clang.patch" - - # fix gcc-11 compile - eapply "${FILESDIR}/${P}_gcc11.patch" - - use naludump && eapply "${DISTDIR}/${PN}-2.1.5-naludump-0.1.diff" - use permashift && eapply "${WORKDIR}/${PN}-2.4-patch-for-permashift.diff" - use pinplugin && eapply "${WORKDIR}/${PN}-2.4.6_pinplugin.patch" - use ttxtsubs && eapply "${WORKDIR}/${PN}-2.4.6_ttxtsubs_v2.patch" - use menuorg && eapply "${DISTDIR}/vdr-menuorg-2.3.x.diff" - use mainmenuhooks && eapply "${WORKDIR}/${PN}-2.4.1_mainmenuhook-1.0.1.patch" - - add_cap CAP_UTF8 \ - CAP_IRCTRL_RUNTIME_PARAM \ - CAP_VFAT_RUNTIME_PARAM \ - CAP_CHUID \ - CAP_SHUTDOWN_AUTO_RETRY - - echo -e ${CAPS} > "${CAP_FILE}" || die "cannot write to CAP_FILE" - - # LINGUAS support - einfo "\n \t VDR supports the LINGUAS values" - - lang_po - - einfo "\t Please set one of this values in your sytem make.conf" - einfo "\t LINGUAS=\"${LING_PO}\"\n" - - if [[ -z ${LINGUAS} ]]; then - einfo "\n \t No values in LINGUAS=" - einfo "\t You will get only english text on OSD \n" - fi - - strip-linguas ${LING_PO} en - - default -} - -src_install() { - # trick the makefile to not create a VIDEODIR by supplying it with an - # existing directory - emake VIDEODIR="/" DESTDIR="${ED}" install - - keepdir "${PLUGIN_LIBDIR}" - - # backup for plugins they don't be able to create this dir - keepdir "${CONF_DIR}/plugins" - - if use html; then - local HTML_DOCS=( *.html ) - fi - local DOCS=( MANUAL INSTALL README* HISTORY CONTRIBUTORS UPDATE-2* ) - einstalldocs - - insinto /usr/share/vdr - doins "${CAP_FILE}" - - fowners vdr:vdr "${CONF_DIR}" -R -} - -pkg_postinst() { - elog "Please read the /usr/share/doc/${PF}/UPDATE-2.4" - elog "for major changes in this version\n" - - elog "It is a good idea to run vdrplugin-rebuild now.\n" - - elog "To get nice symbols in OSD we recommend to install" - elog "\t1. emerge media-fonts/vdrsymbols-ttf" - elog "\t2. select font VDRSymbolsSans in Setup\n" - - elog "To get an idea how to proceed now, have a look at our vdr-guide:" - elog "\thttps://wiki.gentoo.org/wiki/VDR" -} -- cgit v1.2.3-65-gdbad