commit: 62a3a815e48df992b237d9b681ceb39f342df63a Author: Joerg Bornkessel <hd_brummy <AT> gentoo <DOT> org> AuthorDate: Thu May 26 09:03:55 2016 +0000 Commit: Joerg Bornkessel <hd_brummy <AT> gentoo <DOT> org> CommitDate: Thu May 26 09:05:27 2016 +0000 URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=62a3a815
vdr-plugin-2.eclass: added EAPI=6 support eclass/vdr-plugin-2.eclass | 86 +++++++++++++++++++++++++--------------------- 1 file changed, 47 insertions(+), 39 deletions(-) diff --git a/eclass/vdr-plugin-2.eclass b/eclass/vdr-plugin-2.eclass index ae09a34..d65f624 100644 --- a/eclass/vdr-plugin-2.eclass +++ b/eclass/vdr-plugin-2.eclass @@ -1,4 +1,4 @@ -# Copyright 1999-2015 Gentoo Foundation +# Copyright 1999-2016 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 # $Id$ @@ -90,7 +90,7 @@ # @CODE # Applying your own local/user patches: -# This is done by using the +# This is done by using the # (EAPI = 4,5) epatch_user() function of the eutils.eclass, # (EAPI = 6) eapply_user function integrated in EAPI = 6. # Simply add your patches into one of these directories: @@ -104,10 +104,7 @@ inherit flag-o-matic toolchain-funcs unpacker case ${EAPI:-0} in - 4|5) - ;; - 6) - ewarn "EAPI 6 support for test purpose only, plz report bugs to v...@gentoo.org" + 4|5|6) ;; *) die "EAPI ${EAPI} unsupported." ;; @@ -145,6 +142,7 @@ fi # Called from src_install # file maintained by normal portage-methods create_plugindb_file() { + #ToDo: rename this to vdr_... local NEW_VDRPLUGINDB_DIR=/usr/share/vdr/vdrplugin-rebuild/ local DB_FILE="${NEW_VDRPLUGINDB_DIR}/${CATEGORY}-${PF}" insinto "${NEW_VDRPLUGINDB_DIR}" @@ -156,6 +154,7 @@ create_plugindb_file() { # EBUILD=${CATEGORY}/${PN} # EBUILD_V=${PVR} # EOT +# obsolet? fix me later... { echo "VDRPLUGIN_DB=1" echo "CREATOR=ECLASS" @@ -166,6 +165,7 @@ create_plugindb_file() { } create_header_checksum_file() { + #ToDo: rename this to vdr_... # Danger: Not using $ROOT here, as compile will also not use it !!! # If vdr in $ROOT and / differ, plugins will not run anyway @@ -232,6 +232,7 @@ vdr_patchmakefile() { #sed -i Makefile \ # -e "s:^DVBDIR.*$:DVBDIR = ${DVB_INCLUDE_DIR}:" \ # -e 's:-I$(DVBDIR)/include:-I$(DVBDIR):' + # obsolet? fix me later... if ! grep -q APIVERSION Makefile; then ebegin " Converting to APIVERSION" @@ -260,6 +261,7 @@ vdr_patchmakefile() { } dev_check() { + # ToDo: rename this to vdr_...; IMPORTANT: check availabel plugins, if we use this function in the tree... # A lot useful debug infos # set VDR_MAINTAINER_MODE="1" in make.conf if [[ -n ${VDR_MAINTAINER_MODE} ]]; then @@ -268,6 +270,7 @@ dev_check() { } gettext_missing() { + #ToDo: rename this to vdr_... # plugins without converting to gettext local GETTEXT_MISSING=$( grep xgettext Makefile ) @@ -277,6 +280,7 @@ gettext_missing() { } detect_po_dir() { + # ToDo: rename this to vdr_... # helper function [[ -f po ]] && local po_dir="${S}" @@ -287,9 +291,10 @@ detect_po_dir() { } linguas_support() { + # ToDo: rename this to vdr_... # Patching Makefile for linguas support. # Only locales, enabled through the LINGUAS (make.conf) variable will be -# "compiled" and installed. +# compiled and installed. einfo "Patching for Linguas support" einfo "available Languages for ${P} are:" @@ -311,12 +316,9 @@ linguas_support() { vdr_i18n() { # i18n handling was deprecated since >=media-video/vdr-1.5.9, # finally with >=media-video/vdr-1.7.27 it has been dropped entirely and some -# plugins will fail to "compile" because they're still using the old variant. +# plugins will fail to compile because they're still using the old variant. # Simply remove the i18n.o object from Makefile (OBJECT) and # remove "static const tI18nPhrase*" from i18n.h. -# -# Plugins that are still using the old method will be pmasked until they're -# fixed or in case of maintainer timeout they'll be masked for removal. gettext_missing @@ -348,6 +350,7 @@ vdr_i18n() { } remove_i18n_include() { + # ToDo: rename this to vdr_...; IMPORTANT!!! We use this in the tree # remove uneeded i18.n includes local f @@ -391,6 +394,7 @@ vdr-plugin-2_pkg_setup() { # Plugins need to be compiled with position independent code, otherwise linking # VDR against it will fail + # depricated if fi, as we have only >=vdr-2 in the tree, fix me later... if has_version ">=media-video/vdr-1.7.13"; then append-cxxflags -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE -D_LARGEFILE64_SOURCE fi @@ -452,15 +456,15 @@ vdr-plugin-2_src_util() { unpacker_src_unpack ;; add_local_patch) - cd "${S}" || die "Could not change to plugin-source-directory!" - if [[ ${EAPI} == 6 ]]; then + cd "${S}" || die "Could not change to plugin-source-directory (src_util)" + if [[ ${EAPI} != [45] ]]; then eapply_user else epatch_user fi ;; patchmakefile) - cd "${S}" || die "Could not change to plugin-source-directory!" + cd "${S}" || die "Could not change to plugin-source-directory (src_util)" vdr_patchmakefile ;; i18n) @@ -500,7 +504,9 @@ vdr-plugin-2_src_prepare() { die "vdr-plugin-2_src_prepare not called!" fi - [[ ${PATCHES[@]} ]] && epatch "${PATCHES[@]}" + [[ ${EAPI} == [45] ]] && [[ ${PATCHES[@]} ]] && epatch "${PATCHES[@]}" + [[ ${EAPI} != [45] ]] && [[ ${PATCHES[@]} ]] && eapply "${PATCHES[@]}" + debug-print "$FUNCNAME: applying user patches" vdr-plugin-2_src_util prepare @@ -520,16 +526,14 @@ vdr-plugin-2_src_compile() { eerror "Please report this at bugs.gentoo.org." die "vdr-plugin-2_src_compile not called!" fi - cd "${S}" - - BUILD_TARGETS=${BUILD_TARGETS:-${VDRPLUGIN_MAKE_TARGET:-all }} - emake ${BUILD_PARAMS} \ - ${BUILD_TARGETS} \ - LOCALEDIR="${TMP_LOCALE_DIR}" \ - LOCDIR="${TMP_LOCALE_DIR}" \ - LIBDIR="${S}" \ - TMPDIR="${T}" \ - || die "emake failed" + cd "${S}" || die "could not change to plugin source directory (src_compile)" + + emake all ${BUILD_PARAMS} \ + LOCALEDIR="${TMP_LOCALE_DIR}" \ + LOCDIR="${TMP_LOCALE_DIR}" \ + LIBDIR="${S}" \ + TMPDIR="${T}" \ + || die "emake all failed" ;; esac @@ -546,7 +550,7 @@ vdr-plugin-2_src_install() { die "vdr-plugin-2_src_install not called!" fi - cd "${WORKDIR}" + cd "${WORKDIR}" || die "could not change to plugin workdir directory (src_install)" if [[ -n ${VDR_MAINTAINER_MODE} ]]; then local mname="${P}-Makefile" @@ -566,16 +570,15 @@ vdr-plugin-2_src_install() { fi - cd "${S}" + cd "${S}" || die "could not change to plugin source directory (src_install)" local SOFILE_STRING=$(grep SOFILE Makefile) if [[ -n ${SOFILE_STRING} ]]; then - BUILD_TARGETS=${BUILD_TARGETS:-${VDRPLUGIN_MAKE_TARGET:-install }} - einstall ${BUILD_PARAMS} \ - ${BUILD_TARGETS} \ - TMPDIR="${T}" \ - DESTDIR="${D}" \ - || die "einstall (makefile target) failed" + emake install \ + ${BUILD_PARAMS} \ + TMPDIR="${T}" \ + DESTDIR="${D}" \ + || die "emake install (makefile target) failed" else dev_check "Plugin use still the old Makefile handling" insinto "${VDR_PLUGIN_DIR}" @@ -584,7 +587,7 @@ vdr-plugin-2_src_install() { if [[ -d ${TMP_LOCALE_DIR} ]]; then einfo "Installing locales" - cd "${TMP_LOCALE_DIR}" + cd "${TMP_LOCALE_DIR}" || die "could not change to TMP_LOCALE_DIR" local linguas for linguas in ${LINGUAS[*]}; do @@ -593,7 +596,7 @@ vdr-plugin-2_src_install() { done fi - cd "${D}/usr/$(get_libdir)/vdr/plugins" + cd "${D}/usr/$(get_libdir)/vdr/plugins" || die "could not change to D/usr/libdir/vdr/plugins" # create list of all created plugin libs vdr_plugin_list="" @@ -604,14 +607,19 @@ vdr-plugin-2_src_install() { vdr_plugin_list="${vdr_plugin_list} ${p_name}" done - cd "${S}" + cd "${S}" || die "could not change to plugin source directory (src_install)" create_header_checksum_file ${vdr_plugin_list} create_plugindb_file ${vdr_plugin_list} - local docfile - for docfile in README* HISTORY CHANGELOG; do - [[ -f ${docfile} ]] && dodoc ${docfile} + local commondoc=( README* HISTORY CHANGELOG ) + for docfile in "${commondoc[@]}"; do + if [[ ${EAPI} == "6" ]]; then + local DOCS="${DOCS} ${docfile}" + [[ -f ${docfile} ]] && einstalldocs "${DOCS[@]}" + else + [[ -f ${docfile} ]] && dodoc ${docfile} + fi done # if VDR_CONFD_FILE is empty and ${FILESDIR}/confd exists take it