From b55d426c9ee6ba3de1163c53f5f296ba792b802f Mon Sep 17 00:00:00 2001 From: Michał Górny Date: Sun, 30 Mar 2014 08:41:53 +0000 Subject: Support rewriting symlinks in MULTILIB_CHOST_TOOLS, bug #506062. --- eclass/ChangeLog | 5 ++++- eclass/multilib-build.eclass | 23 ++++++++++++++++++++--- 2 files changed, 24 insertions(+), 4 deletions(-) (limited to 'eclass') diff --git a/eclass/ChangeLog b/eclass/ChangeLog index af0017a39e67..a579283e5dac 100644 --- a/eclass/ChangeLog +++ b/eclass/ChangeLog @@ -1,6 +1,9 @@ # ChangeLog for eclass directory # Copyright 1999-2014 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/eclass/ChangeLog,v 1.1186 2014/03/29 16:06:44 ulm Exp $ +# $Header: /var/cvsroot/gentoo-x86/eclass/ChangeLog,v 1.1187 2014/03/30 08:41:53 mgorny Exp $ + + 30 Mar 2014; Michał Górny multilib-build.eclass: + Support rewriting symlinks in MULTILIB_CHOST_TOOLS, bug #506062. 29 Mar 2014; Ulrich Müller check-reqs.eclass: Move test for MERGE_TYPE from check-reqs_pkg_setup() to check-reqs_run(). diff --git a/eclass/multilib-build.eclass b/eclass/multilib-build.eclass index 59d452c9e396..359ad45fff4f 100644 --- a/eclass/multilib-build.eclass +++ b/eclass/multilib-build.eclass @@ -1,6 +1,6 @@ # Copyright 1999-2014 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/eclass/multilib-build.eclass,v 1.28 2014/03/29 03:00:44 vapier Exp $ +# $Header: /var/cvsroot/gentoo-x86/eclass/multilib-build.eclass,v 1.29 2014/03/30 08:41:53 mgorny Exp $ # @ECLASS: multilib-build.eclass # @MAINTAINER: @@ -246,8 +246,13 @@ multilib_copy_sources() { # and the native variant will be symlinked to the generic name. # # This variable has to be a bash array. Paths shall be relative to -# installation root (${ED}), and name regular files. Recursive wrapping -# is not supported. +# installation root (${ED}), and name regular files or symbolic +# links to regular files. Recursive wrapping is not supported. +# +# If symbolic link is passed, both symlink path and symlink target +# will be changed. As a result, the symlink target is expected +# to be wrapped as well (either by listing in MULTILIB_CHOST_TOOLS +# or externally). # # Please note that tool wrapping is *discouraged*. It is preferred to # install pkg-config files for each ABI, and require reverse @@ -374,6 +379,18 @@ _EOF_ local dir=${f%/*} local fn=${f##*/} + if [[ -L ${root}/${f} ]]; then + # rewrite the symlink target + local target=$(readlink "${root}/${f}") + local target_dir + local target_fn=${target##*/} + + [[ ${target} == */* ]] && target_dir=${target%/*} + + ln -f -s "${target_dir+${target_dir}/}${CHOST}-${target_fn}" \ + "${root}/${f}" || die + fi + mv "${root}/${f}" "${root}/${dir}/${CHOST}-${fn}" || die # symlink the native one back -- cgit v1.2.3-65-gdbad