X-Git-Url: https://diplodocus.org/git/nmh/blobdiff_plain/4914b77d7196e81a3a47a41d9efc09fec6e8d42c..bcc3cd247bb5bdad559ec33d348a6ccefa55bf80:/docs/contrib/build_nmh?ds=sidebyside diff --git a/docs/contrib/build_nmh b/docs/contrib/build_nmh index 7d7d9dd1..ef399f86 100755 --- a/docs/contrib/build_nmh +++ b/docs/contrib/build_nmh @@ -3,8 +3,7 @@ # Configures and builds nmh. # * This script must be invoked from an nmh source directory. # * This script retrieves configuration from the first existing nmh -# installation on your $PATH, if any, as well as any $EDITOR/$VISUAL -# and $PAGER environment variable settings. +# installation on your $PATH, if any. # * Unless the -y option is provided, this script then interactively # walks you through confirmation of common configuration settings. # @@ -45,7 +44,6 @@ #### #### OS-specific setup. #### -which=which ldd=ldd #### @@ -111,19 +109,25 @@ config_mts=smtp config_smtpservers=localhost config_sasl=n config_tls=n -config_editor=vi -for i in more less most cat; do - if which $i >/dev/null 2>&1; then - config_pager=$i - break - fi -done config_debug=n + +#### Find location of a program. Bourne shell just puts the name in +#### $0 if it's found from the PATH, so search that if necessary. +finddir() { + case $1 in + */*) dirname "$1" ;; + * ) IFS=: + for d in $PATH; do + [ -f "${d:=.}/$1" -a -x "$d/$1" ] && printf %s "$d" && break + done ;; + esac +} + + if install-mh -check >/dev/null 2>&1; then # Determine config options from installed nmh. - mhparam=`which mhparam` - mhbin=`dirname "$mhparam"` + mhbin=`finddir install-mh` config_prefix=`cd $mhbin/.. && pwd` @@ -145,23 +149,15 @@ if install-mh -check >/dev/null 2>&1; then fi fi - if $ldd "$mhbin/inc" | grep sasl >/dev/null; then + if $ldd "`$mhbin/mhparam libdir`/post" | grep sasl >/dev/null; then config_sasl=y fi - if $ldd "$mhbin/inc" | grep ssl >/dev/null; then + if $ldd "`$mhbin/mhparam libdir`/post" | grep ssl >/dev/null; then config_tls=y fi fi -if [ "$EDITOR" ]; then - config_editor="$EDITOR" -elif [ "$VISUAL" ]; then - config_editor="$VISUAL" -fi - -[ "$PAGER" ] && config_pager="$PAGER" - [ $debug -ge 1 ] && config_debug=y if [ $yes -eq 0 ]; then @@ -174,7 +170,7 @@ if [ $yes -eq 0 ]; then read locking [ "$locking" ] && config_locking="$locking" - printf 'MTS (smtp|sendmail) [%s]: ' $config_mts + printf 'MTS (smtp|sendmail/smtp|sendmail/pipe) [%s]: ' $config_mts read mts [ "$mts" ] && config_mts="$mts" @@ -201,14 +197,6 @@ if [ $yes -eq 0 ]; then config_tls=n fi - printf 'Default editor [%s]: ' $config_editor - read editor - [ "$editor" ] && config_editor="$editor" - - printf 'Pager [%s]: ' $config_pager - read pager - [ "$pager" ] && config_pager="$pager" - #### Don't confirm debug here: obey the -d option to this script. fi @@ -225,10 +213,6 @@ config_opts="--prefix=$config_prefix" config_opts="$config_opts --with-cyrus-sasl" [ "$config_tls" = y ] && \ config_opts="$config_opts --with-tls" -[ "$config_editor" ] && \ - config_opts="$config_opts --with-editor=$config_editor" -[ "$config_pager" ] && \ - config_opts="$config_opts --with-pager=$config_pager" [ $config_debug = y ] && \ config_opts="$config_opts --enable-debug" @@ -279,27 +263,29 @@ if [ $status -eq 0 ]; then status=$? if [ $status -eq 0 ]; then - if [ "${TESTS_SHELL}"x = x ]; then + if [ "$TESTS_SHELL"x = x ]; then #### Bonus: use heirloom shell to test, if available, and if #### TESTS_SHELL hadn't already been set. heirloom_shell=/usr/lib/heirloom/5bin/sh - if [ -x "${heirloom_shell}" ]; then - TESTS_SHELL="${heirloom_shell}"; export TESTS_SHELL + if [ -x "$heirloom_shell" ]; then + TESTS_SHELL="$heirloom_shell"; export TESTS_SHELL fi fi [ $verbose -ge 1 ] && echo testing . . . - checkoutput=`make $check 2>>"$logfile"` + checkoutput=`make $check AM_COLOR_TESTS=always 2>>"$logfile"` status=$? tests_summary=`echo "$checkoutput" | grep tests` #### If multiple tests not run, that line will be caught by the #### "grep tests" above. test_not_run=`echo "$checkoutput" | grep 'test was not run'` + fails=`echo "$checkoutput" | grep FAIL` if [ "$tests_summary" ]; then echo '===================' >>"$logfile" - echo "$tests_summary" >>"$logfile" [ "$test_not_run" ] && echo "$test_not_run" >>"$logfile" + [ "$fails" ] && echo "$fails" >>"$logfile" + echo "$tests_summary" >>"$logfile" echo '===================' >>"$logfile" [ "$check" = distcheck ] && \ echo "$checkoutput" | tail -n 4 >>"$logfile" @@ -322,7 +308,10 @@ if [ $status -eq 0 ]; then fi grep 'Error' "$logfile" -grep 'warn' "$logfile" +#### Ignore the warning when sbr/dtimep.c is built with flex 2.5.36 +#### or 2.5.37. +grep 'warn' "$logfile" | \ + grep -v 'sbr/dtimep.c:.*comparison between signed and unsigned' if [ $status -ne 0 ]; then echo build failed! echo build log is in "$logfile"