summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAron Griffis <agriffis@gentoo.org>2004-07-07 16:14:02 +0000
committerAron Griffis <agriffis@gentoo.org>2004-07-07 16:14:02 +0000
commit21c508069e20e62cc010bac19be618018e6d7d8d (patch)
treef9b8743c8d3bad83a0595b3e5dec6e1de8a2f178 /eclass/gnuconfig.eclass
parentRemoved obsolete versions (diff)
downloadhistorical-21c508069e20e62cc010bac19be618018e6d7d8d.tar.gz
historical-21c508069e20e62cc010bac19be618018e6d7d8d.tar.bz2
historical-21c508069e20e62cc010bac19be618018e6d7d8d.zip
allow first arg to be starting directory for gnuconfig_update #56279
Diffstat (limited to 'eclass/gnuconfig.eclass')
-rw-r--r--eclass/gnuconfig.eclass30
1 files changed, 21 insertions, 9 deletions
diff --git a/eclass/gnuconfig.eclass b/eclass/gnuconfig.eclass
index 8fbb32f3f4cf..f6ce8d5a3fa3 100644
--- a/eclass/gnuconfig.eclass
+++ b/eclass/gnuconfig.eclass
@@ -1,6 +1,6 @@
# Copyright 1999-2004 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
-# $Header: /var/cvsroot/gentoo-x86/eclass/gnuconfig.eclass,v 1.20 2004/07/05 09:15:27 solar Exp $
+# $Header: /var/cvsroot/gentoo-x86/eclass/gnuconfig.eclass,v 1.21 2004/07/07 16:14:02 agriffis Exp $
#
# Author: Will Woods <wwoods@gentoo.org>
#
@@ -32,32 +32,44 @@ gnuconfig_update() {
else
gnuconfig_do_update config.sub config.guess
fi
+
+ return $?
}
# Copy the newest available version of specified files over any old ones in the
# source dir. This function shouldn't be called directly - use gnuconfig_update
gnuconfig_do_update() {
- [ $# -eq 0 ] && die "do not call gnuconfig_do_update(); use gnuconfig_update()"
+ local startdir configsubs_dir target targetlist file
+
+ if [[ ${1} == /* ]]; then
+ startdir=${1%/} # remove possible trailing slash
+ shift
+ else
+ startdir=${S}
+ fi
+
+ [ $# -eq 0 ] && die "do not call gnuconfig_do_update; use gnuconfig_update"
- local configsubs_dir="$(gnuconfig_findnewest)"
- local target targetlist file
+ configsubs_dir="$(gnuconfig_findnewest)"
einfo "Using GNU config files from ${configsubs_dir}"
for file in "$@" ; do
if [ ! -r ${configsubs_dir}/${file} ] ; then
eerror "Can't read ${configsubs_dir}/${file}, skipping.."
continue
fi
- targetlist=`find ${S} -name "${file}"`
+ targetlist=`find "${startdir}" -name "${file}"`
if [ -n "$targetlist" ] ; then
- for target in $targetlist; do
- einfo " Updating ${target/$S\//}"
- cp -f ${configsubs_dir}/${file} ${target}
+ for target in "$targetlist"; do
+ einfo " Updating ${target/$startdir\//}"
+ cp -f ${configsubs_dir}/${file} "${target}"
eend $?
done
else
- ewarn " No ${file} found in ${S}, skipping.."
+ ewarn " No ${file} found in ${startdir}, skipping.."
fi
done
+
+ return 0
}
# this searches the standard locations for the newest config.{sub|guess}, and