X-Git-Url: https://diplodocus.org/git/nmh/blobdiff_plain/721fb2418b2e76c57e550b2f3ecf1bfefa8529d9..b0aa8cdb1c264e42d4931ca24968689c73381278:/docs/contrib/build_nmh diff --git a/docs/contrib/build_nmh b/docs/contrib/build_nmh index 44b2f31d..fc871f8f 100755 --- a/docs/contrib/build_nmh +++ b/docs/contrib/build_nmh @@ -1,13 +1,17 @@ #! /bin/sh # # Configures and builds nmh. -# * This script must be invoked from an nmh source directory. +# * If this script is not invoked from an nmh source directory, it +# will attempt to download the nmh sources. # * 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. # +# This file can be downloaded and immediately run using, e.g., +# wget http://git.savannah.gnu.org/cgit/nmh.git/plain/docs/contrib/build_nmh +# sh build_nmh +# # Typical usage: # The first time you invoke this script, use the -i option to install # nmh in the specified location. The script will walk you through the @@ -20,12 +24,13 @@ # # Option summary: # First time use: +# -b to specify branch to check out, only if downloading sources # -i to install nmh # -v to display progress # Subsequent uses, assuming installed nmh bin directory is on $PATH: # -y to accept all configuration options without confirmation # Output control: -# -l , default 'build_nmh.log' +# -l , default 'build_nmh.log', - for stdout/stderr # Advanced/developer use: # -c to run 'make distcheck' instead of 'make check' # -d to build nmh with debug enabled @@ -38,19 +43,48 @@ # 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 +usage="usage: $0 + [-b , only if downloading] + [-c to run 'make distcheck' instead of 'make check'] + [-d to build nmh with debug enabled] + [-i to install nmh] + [-l , default '$logfile'] + [-r to build rpm] + [-s to use 'make superclean': requires recent autoconf and automake] + [-v to display progress] + [-y to accept all configuration options without confirmation]" -#### -#### OS-specific setup. -#### -which=which -ldd=ldd +#### Exit with error message. +die() { + echo "$0: $*" 1>&2 + exit 1 +} + +#### 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 +} + +gitrepo=git.savannah.nongnu.org +invocation="$0 $*" +tmpfile=/tmp/build_nmh-$$.log +trap 'rm -f "$tmpfile"' EXIT #### #### Interpret command arguments. #### +branch=master check=check debug=0 install=0 @@ -59,18 +93,10 @@ build_rpm=0 superclean=0 verbose=0 yes=0 -usage="usage: $0 - [-c to run 'make distcheck' instead of 'make check'] - [-d to build nmh with debug enabled] - [-i to install nmh] - [-l , default '$logfile'] - [-r to build rpm] - [-s to use 'make superclean': requires recent autoconf and automake] - [-v to display progress] - [-y to accept all configuration options without confirmation]" -while getopts 'cdil:rsvy?' arg; do +while getopts 'cb:dil:rsvy?' arg; do case $arg in + b ) branch="$OPTARG" ;; c ) check=distcheck ;; d ) debug=1 ;; i ) install=1 ;; @@ -84,18 +110,56 @@ while getopts 'cdil:rsvy?' arg; do done shift `expr $OPTIND - 1` -#### No command line arguments are supported. -if [ $# -gt 0 ]; then - echo "usage: $0" - exit 1 -fi +#### Redirect all output to tmp file. Then at end of script, copy +#### it to either logfile or stdout. Also, grep it for errors and +#### warnings. +exec 3>&1 >"$tmpfile" 2>&1 + +echo "$invocation" + +#### No non-option command line arguments are supported. +[ $# -gt 0 ] && die "$usage" #### Check to see that we're in a nmh source directory. -if grep 'the authors of nmh' COPYRIGHT >/dev/null; then +if grep 'the authors of nmh' COPYRIGHT >/dev/null 2>&1; then : else - echo "$0: not in nmh source directory" - exit 1 + #### Download sources from repo. + gitdir=`finddir git` + if [ "$gitdir" ]; then + #### Use git repo. + [ "$verbose" -eq 0 ] && git_opts=--quiet + [ "$branch" == master ] || + git_opts="${git_opts:+$git_opts }--branch $branch" + if "$gitdir"/git clone --depth 1 $git_opts "git://$gitrepo/nmh.git"; then + cd nmh || die "failed to clone nmh" + printf "commit %s\n" `git log --max-count=1 --pretty=format:%H` + else + die 'failed to clone git repo' + fi + else + [ -e nmh-"$branch" ] && die "nmh-$branch exists, will not overrwrite" + + #### Use snapshot. + tarball="nmh-$branch.tar.gz" + repo="http://$gitrepo/cgit/nmh.git/snapshot" + snapshot="$repo/$tarball" + if [ "`finddir wget`" ]; then + [ "$verbose" -eq 0 ] && wget_opts='--quiet' + wget --output-document - $wget_opts "$snapshot" | gzip -d | tar xf - + elif [ "`finddir curl`" ]; then + [ "$verbose" -eq 0 ] && curl_opts='--silent --show-error' + curl --location $curl_opts "$snapshot" | gzip -d | tar xf - + else + die 'unable to find program to download nmh sources' + fi + + if [ -d nmh-"$branch" ]; then + cd nmh-"$branch" || die "failed to download and extract nmh-$branch" + else + die "failed to download nmh-$branch sources" + fi + fi fi #### @@ -106,104 +170,101 @@ fi #### Here are the config options that we will try to detect, then #### confirm, and finally set. config_prefix=/usr/local/nmh +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 + +#### 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"` + #### Determine config options from installed nmh. + 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 #### Confirm each config setting with user. - printf 'Install prefix [%s]: ' $config_prefix + printf 'Install prefix [%s]: ' $config_prefix >&3 read prefix [ "$prefix" ] && config_prefix="$prefix" - printf 'MTS (smtp|sendmail) [%s]: ' $config_mts + printf 'Locking type (dot|fcntl|flock|lockf) [determined by configure]: ' >&3 + read locking + [ "$locking" ] && config_locking="$locking" + + printf 'MTS (smtp|sendmail/smtp|sendmail/pipe) [%s]: ' $config_mts >&3 read mts [ "$mts" ] && config_mts="$mts" - if [ "$mts" -o "$mts" = smtp ]; then - : - else - printf 'SMTP server(s), space separated [%s]: ' $config_smtpservers + if [ "$config_mts" = smtp ]; then + printf 'SMTP server(s), space separated [%s]: ' $config_smtpservers >&3 read response servers=`echo $response | sed -e 's/ /\\\ /g'` [ "$servers" ] && config_smtpservers="$servers" fi - printf 'Cyrus SASL support [%s]: ' $config_sasl + printf 'Cyrus SASL support [%s]: ' $config_sasl >&3 read response - if [ "$response" = y -o "$response" = Y ]; then - config_sasl=y - elif [ "$response" = n -o "$response" = N ]; then - config_sasl=n - fi + [ "$response" = y -o "$response" = Y ] && config_sasl=y - printf 'TLS support [%s]: ' $config_tls + printf 'TLS support [%s]: ' $config_tls >&3 read response - if [ "$response" = y -o "$response" = Y ]; then - config_tls=y - elif [ "$response" = n -o "$response" = N ]; then - config_tls=n - fi - - printf 'Default editor [%s]: ' $config_editor - read editor - [ "$editor" ] && config_editor=$editor + [ "$response" = y -o "$response" = Y ] && config_tls=y - printf 'Pager [%s]: ' $config_pager - read pager - [ "$pager" ] && config_pager=$pager + printf 'OAuth2 support [%s]: ' $config_oauth >&3 + read response + [ "$response" = y -o "$response" = Y ] && config_oauth=y #### Don't confirm debug here: obey the -d option to this script. fi @@ -211,27 +272,35 @@ fi smtpservers= config_opts="--prefix=$config_prefix" -[ "$config_mts" -a "$config_mts" != smtp ] && \ +[ "$config_locking" ] && + config_opts="$config_opts --with-locking=$config_locking" +[ "$config_mts" -a "$config_mts" != smtp ] && config_opts="$config_opts --with-mts=$config_mts" -[ "$config_smtpservers" -a "$config_smtpservers" != localhost ] && \ +[ "$config_smtpservers" -a "$config_smtpservers" != localhost ] && smtpservers="--with-smtpservers=$config_smtpservers" -[ "$config_sasl" = y ] && \ - 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" +[ "$config_sasl" = y ] && config_opts="$config_opts --with-cyrus-sasl" +[ "$config_tls" = y ] && config_opts="$config_opts --with-tls" +[ "$config_oauth" = y ] && config_opts="$config_opts --with-oauth" +[ $config_debug = y ] && config_opts="$config_opts --enable-assert" + +#### dotlocking, the usual default, requires chgrp and chmod of inc. +installpriv= +if [ $install -ge 1 -a "$LOGNAME" != root ]; 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 + +[ -x tools/showbuildenv ] && tools/showbuildenv | grep -Ev 'PID=|SHLVL' #### -#### Clean up, and set up with autoconfig if necessary. +#### Set up with autoconfig if necessary. #### if [ -f Makefile ]; then - [ $verbose -ge 1 ] && echo cleaning . . . + [ $verbose -ge 1 ] && echo cleaning . . . >&3 if [ $superclean -ge 1 ]; then make superclean >/dev/null else @@ -239,61 +308,108 @@ if [ -f Makefile ]; then fi fi -/bin/rm -f $logfile -if [ -f configure -a -f Makefile.in ]; then - : -else - [ $verbose -ge 1 ] && echo autoconfiguring . . . - ./autogen.sh >>$logfile 2>&1 +if [ ! -f configure -o ! -f Makefile.in ]; then + [ $verbose -ge 1 ] && echo autoconfiguring . . . >&3 + ./autogen.sh + [ $? -ne 0 ] && + die "autogen failed, see MACHINES file for autoconf, +automake, flex, and bison requirements" fi #### #### Build. #### -[ $verbose -ge 1 ] && echo configuring . . . -echo ./configure $config_opts ${smtpservers:+"$smtpservers"} >>$logfile 2>&1 -./configure $config_opts ${smtpservers:+"$smtpservers"} >>$logfile 2>&1 +[ $verbose -ge 1 ] && echo configuring . . . >&3 +if [ -z "$CFLAGS" ]; then + #### Only use these flags with gcc. + if cc -dM -E - &1 | grep __GNUC__ >/dev/null; then + #### configure will supply -g -O2 with gcc, but only if CFLAGS + #### isn't defined. + CFLAGS='-g -O2 -ansi -pedantic' + fi +fi + +printf '\n./configure %s\n' "$config_opts${smtpservers:+ $smtpservers}" +./configure CFLAGS="${CFLAGS}" $config_opts${smtpservers:+" $smtpservers"} status=$? if [ $status -eq 0 ]; then - [ $verbose -ge 1 ] && echo building . . . - make >>$logfile 2>&1 + [ $verbose -ge 1 ] && echo building . . . >&3 + make status=$? if [ $status -eq 0 ]; then - [ $verbose -ge 1 ] && echo testing . . . - checkoutput=`make $check 2>>$logfile` + 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 + + if [ "$CFLAGS" ]; then + #### Pass DISTCHECK_CONFIGURE_FLAGS through an environment + #### variable to avoid automake's quoting. + DISTCHECK_CONFIGURE_FLAGS="CFLAGS='${CFLAGS}'" + export DISTCHECK_CONFIGURE_FLAGS + fi + + [ $verbose -ge 1 ] && echo testing . . . >&3 + checkoutput=`make $check AM_COLOR_TESTS=always` 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 - [ "$check" = distcheck ] && \ - echo "$checkoutput" | tail -n 4 >>$logfile + echo '===================' + [ "$test_not_run" ] && echo "$test_not_run" + [ "$fails" ] && echo "$fails" + echo "$tests_summary" + echo '===================' + [ "$check" = distcheck ] && echo "$checkoutput" | ${tail}4 fi if [ $status -eq 0 ]; then if [ $install -ge 1 ]; then - [ $verbose -ge 1 ] && echo installing . . . - (make install) >/dev/null 2>>$logfile + [ $verbose -ge 1 ] && echo installing . . . >&3 + ($installpriv make install) >/dev/null status=$? fi if [ $status -eq 0 -a $build_rpm -ge 1 ]; then - [ $verbose -ge 1 ] && echo building rpm . . . - make rpm >/dev/null 2>>$logfile + [ $verbose -ge 1 ] && echo building rpm . . . >&3 + make rpm >/dev/null status=$? fi fi fi fi -grep 'Error' $logfile -grep 'warn' $logfile -[ $status -ne 0 ] && echo build failed! -[ $status -eq 0 -a $verbose -ge 1 ] && echo build completed successfully +#### +#### Report results. +#### + +#### Disable output redirection (and flush) so that we can grep. +exec 1>&3 3>&- + +if [ "$logfile" != - ]; then + rm -f "$logfile" + exec 3>&1 >"$logfile" 2>&1 +fi + +cat "$tmpfile" +grep -E 'Error|warn' "$tmpfile" + +if [ $status -eq 0 ]; then + [ $verbose -ge 1 ] && echo build completed successfully >&3 +else + echo build failed! + [ "$logfile" = - ] || echo "build failed, build log is in $logfile" >&3 +fi exit $status