#!/bin/sh # # Copyright (C) 2015-2022 Free Software Foundation, Inc. # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation; either version 3 of the License, or # (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program. If not, see . # progname=$0 # func_exit STATUS # exits with a given status. # This function needs to be used, rather than 'exit', when a 'trap' handler is # in effect that refers to $?. func_exit () { (exit $1); exit $1 } # func_tmpdir # creates a temporary directory. # Input: # - progname name of this program # Sets variable # - tmp pathname of freshly created temporary directory func_tmpdir () { # Use the environment variable TMPDIR, falling back to /tmp. This allows # users to specify a different temporary directory, for example, if their # /tmp is filled up or too small. : ${TMPDIR=/tmp} { # Use the mktemp program if available. If not available, hide the error # message. tmp=`(umask 077 && mktemp -d "$TMPDIR/glXXXXXX") 2>/dev/null` && test -n "$tmp" && test -d "$tmp" } || { # Use a simple mkdir command. It is guaranteed to fail if the directory # already exists. $RANDOM is bash specific and expands to empty in shells # other than bash, ksh and zsh. Its use does not increase security; # rather, it minimizes the probability of failure in a very cluttered /tmp # directory. tmp=$TMPDIR/gl$$-$RANDOM (umask 077 && mkdir "$tmp") } || { echo "$progname: cannot create a temporary directory in $TMPDIR" >&2 func_exit 1 } } func_tmpdir trap 'exit_status=$? if test "$signal" != EXIT; then echo "caught signal SIG$signal" >&2 fi rm -rf "$tmp" exit $exit_status' EXIT for signal in HUP INT QUIT PIPE TERM; do trap '{ signal='$signal'; func_exit 1; }' $signal done signal=EXIT sed_literal_to_basic_regex='s/\\/\\\\/g s/\[/\\[/g s/\^/\\^/g s/\([.*$]\)/[\1]/g' while read file; do file_regex=`echo "$file" | sed -e "$sed_literal_to_basic_regex"` if grep "^$file_regex " "$tmp/cache" > "$tmp/result" 2>/dev/null; then sed -n -e 's,.* \([^ ]*\)$,\1,p' < "$tmp/result" else (cd "$GNULIB_SRCDIR" \ && find modules -type f -print | while read modfile; do sed -n -e '/^Files:/,/^$/p' < "$modfile" \ | sed -e '/^Files:/d' -e '/^$/d' > "$tmp/files" module=$(echo $modfile | sed -e 's,modules/,,') module_regex=`echo "$module" | sed -e "$sed_literal_to_basic_regex"` if test ! -f "$tmp/cache" \ || ! grep " $module_regex\$" "$tmp/cache" >/dev/null 2>&1; then sed -e "s,\$, $module," < "$tmp/files" >> "$tmp/cache" fi grep "^$file_regex$" "$tmp/files" > /dev/null 2>&1 && echo "$module" done) fi done rm -rf "$tmp" # Undo the effect of the previous 'trap' command. Some shellology: # We cannot use "trap - 0 1 2 3 13 15", because Solaris sh would attempt to # execute the command "-". "trap '' ..." is fine only for signal 0 (= normal # exit); for the others we need to call 'exit' explicitly. The value of $? is # 128 + signal number and is set before the trap-registered command is run. trap '' 0 trap 'func_exit $?' 1 2 3 13 15 exit 0