Elliott Hughes | d35df49 | 2017-02-15 15:19:05 -0800 | [diff] [blame] | 1 | #! /bin/sh |
| 2 | # Common wrapper for a few potentially missing GNU programs. |
| 3 | |
| 4 | scriptversion=2013-10-28.13; # UTC |
| 5 | |
| 6 | # Copyright (C) 1996-2013 Free Software Foundation, Inc. |
| 7 | # Originally written by Fran,cois Pinard <pinard@iro.umontreal.ca>, 1996. |
| 8 | |
| 9 | # This program is free software; you can redistribute it and/or modify |
| 10 | # it under the terms of the GNU General Public License as published by |
| 11 | # the Free Software Foundation; either version 2, or (at your option) |
| 12 | # any later version. |
| 13 | |
| 14 | # This program is distributed in the hope that it will be useful, |
| 15 | # but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 16 | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| 17 | # GNU General Public License for more details. |
| 18 | |
| 19 | # You should have received a copy of the GNU General Public License |
| 20 | # along with this program. If not, see <http://www.gnu.org/licenses/>. |
| 21 | |
| 22 | # As a special exception to the GNU General Public License, if you |
| 23 | # distribute this file as part of a program that contains a |
| 24 | # configuration script generated by Autoconf, you may include it under |
| 25 | # the same distribution terms that you use for the rest of that program. |
| 26 | |
| 27 | if test $# -eq 0; then |
| 28 | echo 1>&2 "Try '$0 --help' for more information" |
| 29 | exit 1 |
| 30 | fi |
| 31 | |
| 32 | case $1 in |
| 33 | |
| 34 | --is-lightweight) |
| 35 | # Used by our autoconf macros to check whether the available missing |
| 36 | # script is modern enough. |
| 37 | exit 0 |
| 38 | ;; |
| 39 | |
| 40 | --run) |
| 41 | # Back-compat with the calling convention used by older automake. |
| 42 | shift |
| 43 | ;; |
| 44 | |
| 45 | -h|--h|--he|--hel|--help) |
| 46 | echo "\ |
| 47 | $0 [OPTION]... PROGRAM [ARGUMENT]... |
| 48 | |
| 49 | Run 'PROGRAM [ARGUMENT]...', returning a proper advice when this fails due |
| 50 | to PROGRAM being missing or too old. |
| 51 | |
| 52 | Options: |
| 53 | -h, --help display this help and exit |
| 54 | -v, --version output version information and exit |
| 55 | |
| 56 | Supported PROGRAM values: |
| 57 | aclocal autoconf autoheader autom4te automake makeinfo |
| 58 | bison yacc flex lex help2man |
| 59 | |
| 60 | Version suffixes to PROGRAM as well as the prefixes 'gnu-', 'gnu', and |
| 61 | 'g' are ignored when checking the name. |
| 62 | |
| 63 | Send bug reports to <bug-automake@gnu.org>." |
| 64 | exit $? |
| 65 | ;; |
| 66 | |
| 67 | -v|--v|--ve|--ver|--vers|--versi|--versio|--version) |
| 68 | echo "missing $scriptversion (GNU Automake)" |
| 69 | exit $? |
| 70 | ;; |
| 71 | |
| 72 | -*) |
| 73 | echo 1>&2 "$0: unknown '$1' option" |
| 74 | echo 1>&2 "Try '$0 --help' for more information" |
| 75 | exit 1 |
| 76 | ;; |
| 77 | |
| 78 | esac |
| 79 | |
| 80 | # Run the given program, remember its exit status. |
| 81 | "$@"; st=$? |
| 82 | |
| 83 | # If it succeeded, we are done. |
| 84 | test $st -eq 0 && exit 0 |
| 85 | |
| 86 | # Also exit now if we it failed (or wasn't found), and '--version' was |
| 87 | # passed; such an option is passed most likely to detect whether the |
| 88 | # program is present and works. |
| 89 | case $2 in --version|--help) exit $st;; esac |
| 90 | |
| 91 | # Exit code 63 means version mismatch. This often happens when the user |
| 92 | # tries to use an ancient version of a tool on a file that requires a |
| 93 | # minimum version. |
| 94 | if test $st -eq 63; then |
| 95 | msg="probably too old" |
| 96 | elif test $st -eq 127; then |
| 97 | # Program was missing. |
| 98 | msg="missing on your system" |
| 99 | else |
| 100 | # Program was found and executed, but failed. Give up. |
| 101 | exit $st |
| 102 | fi |
| 103 | |
| 104 | perl_URL=http://www.perl.org/ |
| 105 | flex_URL=http://flex.sourceforge.net/ |
| 106 | gnu_software_URL=http://www.gnu.org/software |
| 107 | |
| 108 | program_details () |
| 109 | { |
| 110 | case $1 in |
| 111 | aclocal|automake) |
| 112 | echo "The '$1' program is part of the GNU Automake package:" |
| 113 | echo "<$gnu_software_URL/automake>" |
| 114 | echo "It also requires GNU Autoconf, GNU m4 and Perl in order to run:" |
| 115 | echo "<$gnu_software_URL/autoconf>" |
| 116 | echo "<$gnu_software_URL/m4/>" |
| 117 | echo "<$perl_URL>" |
| 118 | ;; |
| 119 | autoconf|autom4te|autoheader) |
| 120 | echo "The '$1' program is part of the GNU Autoconf package:" |
| 121 | echo "<$gnu_software_URL/autoconf/>" |
| 122 | echo "It also requires GNU m4 and Perl in order to run:" |
| 123 | echo "<$gnu_software_URL/m4/>" |
| 124 | echo "<$perl_URL>" |
| 125 | ;; |
| 126 | esac |
| 127 | } |
| 128 | |
| 129 | give_advice () |
| 130 | { |
| 131 | # Normalize program name to check for. |
| 132 | normalized_program=`echo "$1" | sed ' |
| 133 | s/^gnu-//; t |
| 134 | s/^gnu//; t |
| 135 | s/^g//; t'` |
| 136 | |
| 137 | printf '%s\n' "'$1' is $msg." |
| 138 | |
| 139 | configure_deps="'configure.ac' or m4 files included by 'configure.ac'" |
| 140 | case $normalized_program in |
| 141 | autoconf*) |
| 142 | echo "You should only need it if you modified 'configure.ac'," |
| 143 | echo "or m4 files included by it." |
| 144 | program_details 'autoconf' |
| 145 | ;; |
| 146 | autoheader*) |
| 147 | echo "You should only need it if you modified 'acconfig.h' or" |
| 148 | echo "$configure_deps." |
| 149 | program_details 'autoheader' |
| 150 | ;; |
| 151 | automake*) |
| 152 | echo "You should only need it if you modified 'Makefile.am' or" |
| 153 | echo "$configure_deps." |
| 154 | program_details 'automake' |
| 155 | ;; |
| 156 | aclocal*) |
| 157 | echo "You should only need it if you modified 'acinclude.m4' or" |
| 158 | echo "$configure_deps." |
| 159 | program_details 'aclocal' |
| 160 | ;; |
| 161 | autom4te*) |
| 162 | echo "You might have modified some maintainer files that require" |
| 163 | echo "the 'autom4te' program to be rebuilt." |
| 164 | program_details 'autom4te' |
| 165 | ;; |
| 166 | bison*|yacc*) |
| 167 | echo "You should only need it if you modified a '.y' file." |
| 168 | echo "You may want to install the GNU Bison package:" |
| 169 | echo "<$gnu_software_URL/bison/>" |
| 170 | ;; |
| 171 | lex*|flex*) |
| 172 | echo "You should only need it if you modified a '.l' file." |
| 173 | echo "You may want to install the Fast Lexical Analyzer package:" |
| 174 | echo "<$flex_URL>" |
| 175 | ;; |
| 176 | help2man*) |
| 177 | echo "You should only need it if you modified a dependency" \ |
| 178 | "of a man page." |
| 179 | echo "You may want to install the GNU Help2man package:" |
| 180 | echo "<$gnu_software_URL/help2man/>" |
| 181 | ;; |
| 182 | makeinfo*) |
| 183 | echo "You should only need it if you modified a '.texi' file, or" |
| 184 | echo "any other file indirectly affecting the aspect of the manual." |
| 185 | echo "You might want to install the Texinfo package:" |
| 186 | echo "<$gnu_software_URL/texinfo/>" |
| 187 | echo "The spurious makeinfo call might also be the consequence of" |
| 188 | echo "using a buggy 'make' (AIX, DU, IRIX), in which case you might" |
| 189 | echo "want to install GNU make:" |
| 190 | echo "<$gnu_software_URL/make/>" |
| 191 | ;; |
| 192 | *) |
| 193 | echo "You might have modified some files without having the proper" |
| 194 | echo "tools for further handling them. Check the 'README' file, it" |
| 195 | echo "often tells you about the needed prerequisites for installing" |
| 196 | echo "this package. You may also peek at any GNU archive site, in" |
| 197 | echo "case some other package contains this missing '$1' program." |
| 198 | ;; |
| 199 | esac |
| 200 | } |
| 201 | |
| 202 | give_advice "$1" | sed -e '1s/^/WARNING: /' \ |
| 203 | -e '2,$s/^/ /' >&2 |
| 204 | |
| 205 | # Propagate the correct exit status (expected to be 127 for a program |
| 206 | # not found, 63 for a program that failed due to version mismatch). |
| 207 | exit $st |
| 208 | |
| 209 | # Local variables: |
| 210 | # eval: (add-hook 'write-file-hooks 'time-stamp) |
| 211 | # time-stamp-start: "scriptversion=" |
| 212 | # time-stamp-format: "%:y-%02m-%02d.%02H" |
| 213 | # time-stamp-time-zone: "UTC" |
| 214 | # time-stamp-end: "; # UTC" |
| 215 | # End: |