X-Git-Url: https://diplodocus.org/git/nmh/blobdiff_plain/0a94d4c33a354667aada700e136beb235a9e0a90..c2a69f6b1ae454f3bbcc645020bb2408e9d46612:/docs/contrib/build_nmh diff --git a/docs/contrib/build_nmh b/docs/contrib/build_nmh index 4405005f..25a02642 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. # @@ -38,35 +37,11 @@ # ncurses-devel # cyrus-sasl-devel, if using sasl # openssl-devel, if using TLS +# libcurl-devel, if using oauth # autoconf and automake, with -s (see docs/README.developers for versions) # rpm-build, with -r -#### -#### OS-specific setup. -#### -which=which -ldd=ldd -locking=dot - -os=${OSTYPE:-`uname -s`} -#### It'd be nice to have configure decide what locking style to use. -#### In the meantime, select it manually. To determine what style -#### locking your system uses by default, try something like this, -#### assuming that strace is installed: -#### $ echo test | strace -o /tmp/mail.strace mail -s test $LOGNAME -#### Then look in /tmp/mail.strace for fcntl, flock, and lockf system -#### calls and opens of dot files in the mail spool. -#### These might help but are old: -#### https://bugzilla.mozilla.org/show_bug.cgi?id=239013#c9 -#### http://www.jwz.org/doc/movemail.html -case "$os" in - aix) locking=fcntl ;; - freebsd*) locking=flock ;; - linux* ) locking=fcntl ;; -esac - - #### #### Interpret command arguments. #### @@ -120,75 +95,82 @@ fi #### spaces (currently just smtpservers) specially. #### -#### dotlocking, the usual default, requires chgrp and chmod of inc. -installpriv= -if [ $install -ge 1 -a `id -u` -ne 0 -a "$OSTYPE" != cygwin ]; then - if [ "x$locking" = x -o "$locking" = dot ]; then - echo "$0: "'install requires chgrp and chmod 2755' - echo 'so will sudo to install. Terminate with Ctrl-C if unacceptable.' - installpriv=sudo - fi -fi - - #### Here are the config options that we will try to detect, then #### confirm, and finally set. config_prefix=/usr/local/nmh -config_locking="$locking" +config_locking= 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_oauth=n 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 +} + +#### Figure out whether or not to use -n with tail. +case `printf 'OK\n' | tail -n 1 2>&1` in + OK) tail='tail -n ' ;; + *) tail='tail -' ;; +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` - mtsconf=`dirname "$mhbin"`/etc/mts.conf + mtsconf=`mhparam etcdir`/mts.conf if [ -f "$mtsconf" ]; then - mts_entry=`grep '^mts:' $mtsconf` - if [ "mts_entry" ]; then - mts=`echo $mts_entry | sed -e 's/^mts: *//'` + mts_entry=`grep '^mts:' "$mtsconf"` + if [ "$mts_entry" ]; then + mts=`echo "$mts_entry" | sed -e 's/^mts: *//'` if [ "$mts" -a "$mts" != smtp ]; then config_mts="$mts" fi fi - mtsconfservers=`grep '^servers:' $mtsconf` + mtsconfservers=`grep '^servers:' "$mtsconf"` if [ "$mtsconfservers" ]; then - servers=`echo $mtsconfservers | sed -e 's/^servers: *//' -e 's/ /\\\ /g'` + servers=`echo "$mtsconfservers" | \ + sed -e 's/^servers: *//' -e 's/ /\\\ /g'` [ "$servers" ] && config_smtpservers="$servers" fi fi - if $ldd $mhbin/inc | grep sasl >/dev/null; then - config_sasl=y - fi - - if $ldd $mhbin/inc | grep ssl >/dev/null; then - config_tls=y + if test -x "$mhbin/mhparam"; then + if mhparam sasl >/dev/null; then + case `$mhbin/mhparam sasl` in + *sasl*) config_sasl=y ;; + esac + + case `$mhbin/mhparam tls` in + *tls*) config_tls=y ;; + esac + + case `$mhbin/mhparam oauth` in + *oauth*) config_oauth=y ;; + esac + else + tput smso + echo "$0: SASL, TLS, and OAuth2 detection not supported with current nmh" + [ $yes -eq 1 ] && echo "will not configure them in" + tput rmso + fi 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 @@ -197,15 +179,15 @@ if [ $yes -eq 0 ]; then read prefix [ "$prefix" ] && config_prefix="$prefix" - printf 'Locking type (dot|fcntl|flock|lockf) [%s]: ' $config_locking + printf 'Locking type (dot|fcntl|flock|lockf) [determined by configure]: ' 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" - if [ ! "$mts" -o "$mts" = smtp ]; then + if [ "$config_mts" = smtp ]; then printf 'SMTP server(s), space separated [%s]: ' $config_smtpservers read response servers=`echo $response | sed -e 's/ /\\\ /g'` @@ -228,13 +210,13 @@ 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 + printf 'OAuth2 support [%s]: ' $config_oauth + read response + if [ "$response" = y -o "$response" = Y ]; then + config_oauth=y + elif [ "$response" = n -o "$response" = N ]; then + config_oauth=n + fi #### Don't confirm debug here: obey the -d option to this script. fi @@ -252,12 +234,20 @@ 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_oauth" = y ] && \ + config_opts="$config_opts --with-oauth" [ $config_debug = y ] && \ - config_opts="$config_opts --enable-debug" + config_opts="$config_opts --enable-debug --enable-assert" + +#### dotlocking, the usual default, requires chgrp and chmod of inc. +installpriv= +if [ $install -ge 1 -a `id -u` -ne 0 ]; then + if [ "$config_locking" = dot ]; then + echo "$0: "'install requires chgrp and chmod 2755' + echo 'so will sudo to install. Terminate with Ctrl-C if unacceptable.' + installpriv=sudo + fi +fi #### @@ -272,12 +262,10 @@ if [ -f Makefile ]; then fi fi -/bin/rm -f $logfile -if [ -f configure -a -f Makefile.in ]; then - : -else +/bin/rm -f "$logfile" +if [ ! -f configure -o ! -f Makefile.in ]; then [ $verbose -ge 1 ] && echo autoconfiguring . . . - ./autogen.sh >>$logfile 2>&1 + ./autogen.sh >>"$logfile" 2>&1 fi @@ -285,47 +273,69 @@ fi #### Build. #### [ $verbose -ge 1 ] && echo configuring . . . -echo ./configure $config_opts ${smtpservers:+"$smtpservers"} >>$logfile 2>&1 -./configure $config_opts ${smtpservers:+"$smtpservers"} >>$logfile 2>&1 +echo ./configure $config_opts ${smtpservers:+"$smtpservers"} >>"$logfile" 2>&1 +./configure CFLAGS="${CFLAGS:+$CFLAGS }-g -O2 -ansi -pedantic" \ + $config_opts ${smtpservers:+"$smtpservers"} >>"$logfile" 2>&1 status=$? if [ $status -eq 0 ]; then [ $verbose -ge 1 ] && echo building . . . - make >>$logfile 2>&1 + make >>"$logfile" 2>&1 status=$? if [ $status -eq 0 ]; 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 + fi + fi + [ $verbose -ge 1 ] && echo testing . . . - checkoutput=`make $check SETGID_MAIL= 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 - echo '===================' >>$logfile + echo '===================' >>"$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 + echo "$checkoutput" | ${tail}4 >>"$logfile" fi if [ $status -eq 0 ]; then if [ $install -ge 1 ]; then [ $verbose -ge 1 ] && echo installing . . . - ($installpriv make install) >/dev/null 2>>$logfile + ($installpriv make install) >/dev/null 2>>"$logfile" status=$? fi if [ $status -eq 0 -a $build_rpm -ge 1 ]; then [ $verbose -ge 1 ] && echo building rpm . . . - make rpm >/dev/null 2>>$logfile + make rpm >/dev/null 2>>"$logfile" status=$? fi fi fi fi -grep -E 'Error|warn' $logfile -[ $status -ne 0 ] && echo build failed! -[ $status -eq 0 -a $verbose -ge 1 ] && echo build completed successfully +grep Error "$logfile" +grep warn "$logfile" + +if [ $status -eq 0 ]; then + [ $verbose -ge 1 ] && echo build completed successfully +else + echo build failed! + echo build log is in "$logfile" +fi exit $status