On 04/01/18 11:21, David Seifert wrote: > On Thu, 2018-01-04 at 10:43 +0000, M. J. Everitt wrote: >> On 04/01/18 10:23, Pacho Ramos wrote: >>> El mié, 03-01-2018 a las 17:13 +0100, Ulrich Müller escribió: >>>> Split off functions preserve_old_lib and preserve_old_lib_notify >>>> from >>>> eutils.eclass into a dedicated preserve-libs.eclass. These >>>> functions >>>> are rarely used and are independent of the rest of eutils, >>>> therefore >>>> moving them into their own eclass will help clarifying eclass >>>> inheritance in ebuilds. >>>> >>>> For backwards compatibility, eutils inherits the new eclass in >>>> existing EAPIs. >>>> --- >>>> eclass/eutils.eclass | 65 ++----------------------------- >>>> -------- >>>> eclass/preserve-libs.eclass | 74 >>>> +++++++++++++++++++++++++++++++++++++++++++++ >>>> 2 files changed, 76 insertions(+), 63 deletions(-) >>>> create mode 100644 eclass/preserve-libs.eclass >>>> >>>> diff --git a/eclass/eutils.eclass b/eclass/eutils.eclass >>>> index 7d4193e76b51..91d329e99c9e 100644 >>>> --- a/eclass/eutils.eclass >>>> +++ b/eclass/eutils.eclass >>>> @@ -1,4 +1,4 @@ >>>> -# Copyright 1999-2017 Gentoo Foundation >>>> +# Copyright 1999-2018 Gentoo Foundation >>>> # Distributed under the terms of the GNU General Public License >>>> v2 >>>> >>>> # @ECLASS: eutils.eclass >>>> @@ -20,7 +20,7 @@ _EUTILS_ECLASS=1 >>>> # implicitly inherited (now split) eclasses >>>> case ${EAPI:-0} in >>>> 0|1|2|3|4|5|6) >>>> - inherit desktop epatch estack ltprune multilib >>>> toolchain-funcs >>>> + inherit desktop epatch estack ltprune multilib preserve- >>>> libs >>>> toolchain-funcs >>>> ;; >>>> esac >>>> >>>> @@ -172,67 +172,6 @@ _eutils_eprefix_init() { >>>> has "${EAPI:-0}" 0 1 2 && : ${ED:=${D}} ${EPREFIX:=} >>>> ${EROOT:=${ROOT}} >>>> } >>>> >>>> -# @FUNCTION: preserve_old_lib >>>> -# @USAGE: <libs to preserve> [more libs] >>>> -# @DESCRIPTION: >>>> -# These functions are useful when a lib in your package changes >>>> ABI SONAME. >>>> -# An example might be from libogg.so.0 to libogg.so.1. Removing >>>> libogg.so.0 >>>> -# would break packages that link against it. Most people get >>>> around this >>>> -# by using the portage SLOT mechanism, but that is not always a >>>> relevant >>>> -# solution, so instead you can call this from pkg_preinst. See >>>> also the >>>> -# preserve_old_lib_notify function. >>>> -preserve_old_lib() { >>>> - _eutils_eprefix_init >>>> - if [[ ${EBUILD_PHASE} != "preinst" ]] ; then >>>> - eerror "preserve_old_lib() must be called from >>>> pkg_preinst() >>>> only" >>>> - die "Invalid preserve_old_lib() usage" >>>> - fi >>>> - [[ -z $1 ]] && die "Usage: preserve_old_lib <library to >>>> preserve> >>>> [more libraries to preserve]" >>>> - >>>> - # let portage worry about it >>>> - has preserve-libs ${FEATURES} && return 0 >>>> - >>>> - local lib dir >>>> - for lib in "$@" ; do >>>> - [[ -e ${EROOT}/${lib} ]] || continue >>>> - dir=${lib%/*} >>>> - dodir ${dir} || die "dodir ${dir} failed" >>>> - cp "${EROOT}"/${lib} "${ED}"/${lib} || die "cp >>>> ${lib} failed" >>>> - touch "${ED}"/${lib} >>>> - done >>>> -} >>>> - >>>> -# @FUNCTION: preserve_old_lib_notify >>>> -# @USAGE: <libs to notify> [more libs] >>>> -# @DESCRIPTION: >>>> -# Spit helpful messages about the libraries preserved by >>>> preserve_old_lib. >>>> -preserve_old_lib_notify() { >>>> - if [[ ${EBUILD_PHASE} != "postinst" ]] ; then >>>> - eerror "preserve_old_lib_notify() must be called >>>> from >>>> pkg_postinst() only" >>>> - die "Invalid preserve_old_lib_notify() usage" >>>> - fi >>>> - >>>> - # let portage worry about it >>>> - has preserve-libs ${FEATURES} && return 0 >>>> - >>>> - _eutils_eprefix_init >>>> - >>>> - local lib notice=0 >>>> - for lib in "$@" ; do >>>> - [[ -e ${EROOT}/${lib} ]] || continue >>>> - if [[ ${notice} -eq 0 ]] ; then >>>> - notice=1 >>>> - ewarn "Old versions of installed >>>> libraries were >>>> detected on your system." >>>> - ewarn "In order to avoid breaking >>>> packages that >>>> depend on these old libs," >>>> - ewarn "the libraries are not being >>>> removed. You need >>>> to run revdep-rebuild" >>>> - ewarn "in order to remove these old >>>> dependencies. If >>>> you do not have this" >>>> - ewarn "helper program, simply emerge the >>>> 'gentoolkit' >>>> package." >>>> - ewarn >>>> - fi >>>> - ewarn " # revdep-rebuild --library '${lib}' && >>>> rm '${lib}'" >>>> - done >>>> -} >>>> - >>>> # @FUNCTION: built_with_use >>>> # @USAGE: [--hidden] [--missing <action>] [-a|-o] <DEPEND ATOM> >>>> <List of USE >>>> flags> >>>> # @DESCRIPTION: >>>> diff --git a/eclass/preserve-libs.eclass b/eclass/preserve- >>>> libs.eclass >>>> new file mode 100644 >>>> index 000000000000..548c6411fcf0 >>>> --- /dev/null >>>> +++ b/eclass/preserve-libs.eclass >>>> @@ -0,0 +1,74 @@ >>>> +# Copyright 1999-2018 Gentoo Foundation >>>> +# Distributed under the terms of the GNU General Public License >>>> v2 >>>> + >>>> +# @ECLASS: preserve-libs.eclass >>>> +# @MAINTAINER: >>>> +# base-sys...@gentoo.org >>>> +# @BLURB: preserve libraries after SONAME changes >>>> + >>>> +if [[ -z ${_PRESERVE_LIBS_ECLASS} ]]; then >>>> +_PRESERVE_LIBS_ECLASS=1 >>>> + >>>> +# @FUNCTION: preserve_old_lib >>>> +# @USAGE: <libs to preserve> [more libs] >>>> +# @DESCRIPTION: >>>> +# These functions are useful when a lib in your package changes >>>> ABI SONAME. >>>> +# An example might be from libogg.so.0 to libogg.so.1. Removing >>>> libogg.so.0 >>>> +# would break packages that link against it. Most people get >>>> around this >>>> +# by using the portage SLOT mechanism, but that is not always a >>>> relevant >>>> +# solution, so instead you can call this from pkg_preinst. See >>>> also the >>>> +# preserve_old_lib_notify function. >>>> +preserve_old_lib() { >>>> + if [[ ${EBUILD_PHASE} != "preinst" ]] ; then >>>> + eerror "preserve_old_lib() must be called from >>>> pkg_preinst() >>>> only" >>>> + die "Invalid preserve_old_lib() usage" >>>> + fi >>>> + [[ -z $1 ]] && die "Usage: preserve_old_lib <library to >>>> preserve> >>>> [more libraries to preserve]" >>>> + >>>> + # let portage worry about it >>>> + has preserve-libs ${FEATURES} && return 0 >>>> + >>>> + has "${EAPI:-0}" 0 1 2 && local ED=${D} EROOT=${ROOT} >>>> + >>>> + local lib dir >>>> + for lib in "$@" ; do >>>> + [[ -e ${EROOT}/${lib} ]] || continue >>>> + dir=${lib%/*} >>>> + dodir ${dir} || die "dodir ${dir} failed" >>>> + cp "${EROOT}"/${lib} "${ED}"/${lib} || die "cp >>>> ${lib} failed" >>>> + touch "${ED}"/${lib} >>>> + done >>>> +} >>>> + >>>> +# @FUNCTION: preserve_old_lib_notify >>>> +# @USAGE: <libs to notify> [more libs] >>>> +# @DESCRIPTION: >>>> +# Spit helpful messages about the libraries preserved by >>>> preserve_old_lib. >>>> +preserve_old_lib_notify() { >>>> + if [[ ${EBUILD_PHASE} != "postinst" ]] ; then >>>> + eerror "preserve_old_lib_notify() must be called >>>> from >>>> pkg_postinst() only" >>>> + die "Invalid preserve_old_lib_notify() usage" >>>> + fi >>>> + >>>> + # let portage worry about it >>>> + has preserve-libs ${FEATURES} && return 0 >>>> + >>>> + has "${EAPI:-0}" 0 1 2 && local EROOT=${ROOT} >>>> + >>>> + local lib notice=0 >>>> + for lib in "$@" ; do >>>> + [[ -e ${EROOT}/${lib} ]] || continue >>>> + if [[ ${notice} -eq 0 ]] ; then >>>> + notice=1 >>>> + ewarn "Old versions of installed >>>> libraries were >>>> detected on your system." >>>> + ewarn "In order to avoid breaking >>>> packages that >>>> depend on these old libs," >>>> + ewarn "the libraries are not being >>>> removed. You need >>>> to run revdep-rebuild" >>>> + ewarn "in order to remove these old >>>> dependencies. If >>>> you do not have this" >>>> + ewarn "helper program, simply emerge the >>>> 'gentoolkit' >>>> package." >>>> + ewarn >>>> + fi >>>> + ewarn " # revdep-rebuild --library '${lib}' && >>>> rm '${lib}'" >>>> + done >>>> +} >>>> + >>>> +fi >>> I have seen this is only used by: >>> app-arch/xz-utils >>> dev-libs/gmp >>> dev-libs/libpcre >>> dev-libs/mpc >>> dev-libs/mpfr >>> net-nds/openldap >>> sys-libs/gdbm >>> sys-libs/ncurses >>> sys-libs/readline >>> sys-process/audit >>> >>> Maybe we could deprecate it and try to drop it in the future :/ >>> >> Bear in mind several of these packages are in base-system and are >> stuck >> around the EAPI3/4 mark and may not be using some of the new EAPI >> 'features' yet ... >> >> Best not kill them off just yet or there'll be no stages to install >> from >> .. and releng have only just got the catalyst-3 transition working, >> with >> 17.0 profiles to come next .. >> >> :] >> > Never mind that this has 0 to do with EAPI3/4 or with newer EAPI > 'features' and is all about the fact that FEATURES=preserve-libs is > only implemented in Portage, without comparable functionality in > paludis or pkgcore. > > When you don't know why the function exists, prefer not to give advice > on how to proceed. > Oh I -am- sorry .. did I piss in your cornflakes too? XD
</sarcasm>
signature.asc
Description: OpenPGP digital signature