Skip to content

Commit

Permalink
gnuconfig.eclass: provide basic @eclass block, docs
Browse files Browse the repository at this point in the history
Signed-off-by: Sam James <[email protected]>
  • Loading branch information
thesamesam committed Apr 11, 2021
1 parent fe3f657 commit 4575a79
Showing 1 changed file with 33 additions and 10 deletions.
43 changes: 33 additions & 10 deletions eclass/gnuconfig.eclass
Original file line number Diff line number Diff line change
@@ -1,25 +1,40 @@
# Copyright 1999-2020 Gentoo Authors
# Copyright 1999-2021 Gentoo Authors
# Distributed under the terms of the GNU General Public License v2
#
# Author: Will Woods <[email protected]>
#

# @ECLASS: gnuconfig.eclass
# @MAINTAINER:
# Sam James <[email protected]>
# @AUTHOR:
# Will Woods <[email protected]>
# @SUPPORTED_EAPIS: 5 6 7
# @BLURB: Refresh bundled gnuconfig files (config.guess, config.sub)
# @DESCRIPTION:
# This eclass is used to automatically update files that typically come with
# automake to the newest version available on the system. The most common use
# of this is to update config.guess and config.sub when configure dies from
# misguessing your canonical system name (CHOST). It can also be used to update
# other files that come with automake, e.g. depcomp, mkinstalldirs, etc.
#
# usage: gnuconfig_update [file1 file2 ...]

DEPEND="sys-devel/gnuconfig"

if [[ -z ${_GNUCONFIG_ECLASS} ]] ; then
_GNUCONFIG_CLASS=1

BDEPEND="sys-devel/gnuconfig"

[[ ${EAPI} == [56] ]] && DEPEND="${BDEPEND}"

# @FUNCTION: gnuconfig_update
# @USAGE: [file1 file2 ...]
# @DESCRIPTION:
# if called without arguments, config.guess and config.sub will be updated.
# All files in the source tree ($S) with the given name(s) will be replaced
# with the newest available versions chosen from the list of locations in
# gnuconfig_findnewest(), below.
#
# gnuconfig_update should generally be called from src_unpack()


DEPEND="sys-devel/gnuconfig"

#
# Wrapper function for gnuconfig_do_update. If no arguments are given, update
# config.sub and config.guess (old default behavior), otherwise update the
# named files.
Expand All @@ -42,6 +57,9 @@ gnuconfig_update() {
return $?
}

# @FUNCTION: gnuconfig_do_update
# @INTERNAL
# @DESCRIPTION:
# 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
#
Expand Down Expand Up @@ -75,7 +93,10 @@ gnuconfig_do_update() {
return 0
}

# this searches the standard locations for the newest config.{sub|guess}, and
# @FUNCTION: gnuconfig_findnewest
# @INTERNAL
# @DESCRIPTION:
# This searches the standard locations for the newest config.{sub|guess}, and
# returns the directory where they can be found.
gnuconfig_findnewest() {
local locations=(
Expand All @@ -88,3 +109,5 @@ gnuconfig_findnewest() {
sort -r -n -t\' -k2 | \
sed -n '1{s,/config.sub:.*$,,;p;q}'
}

fi

0 comments on commit 4575a79

Please sign in to comment.