X-Git-Url: https://git.tcpdump.org/tcpdump/blobdiff_plain/d1d2537fbbc75b82c9f94599fa16c9697a35f7d2..69f03c1c03b280b9c5863bfb47e8847d59b4ee6b:/build_matrix.sh diff --git a/build_matrix.sh b/build_matrix.sh index 8d13fcff..f37589fa 100755 --- a/build_matrix.sh +++ b/build_matrix.sh @@ -13,17 +13,34 @@ : "${MATRIX_CMAKE:=no yes}" : "${MATRIX_CRYPTO:=no yes}" : "${MATRIX_SMB:=no yes}" +# Set this variable to "yes" before calling this script to disregard all cmake +# warnings in a particular environment (CI or a local working copy). Set it +# to "yes" in this script or in build.sh when a matrix subset is known to be +# not cmake warning-free because of the version or whatever other factor +# that the scripts can detect both in and out of CI. +: "${TCPDUMP_CMAKE_TAINTED:=no}" +# Set this variable to "yes" before calling this script to disregard all +# warnings in a particular environment (CI or a local working copy). Set it +# to "yes" in this script or in build.sh when a matrix subset is known to be +# not warning-free because of the OS, the compiler or whatever other factor +# that the scripts can detect both in and out of CI. +: "${TCPDUMP_TAINTED:=no}" +# Some OSes have native make without parallel jobs support and sometimes have +# GNU Make available as "gmake". +: "${MAKE_BIN:=make}" . ./build_common.sh print_sysinfo # Install directory prefix if [ -z "$PREFIX" ]; then - # shellcheck disable=SC2006 PREFIX=`mktempdir tcpdump_build_matrix` echo "PREFIX set to '$PREFIX'" export PREFIX fi COUNT=0 +export TCPDUMP_TAINTED +export TCPDUMP_CMAKE_TAINTED +export MAKE_BIN build_tcpdump() { for CMAKE in $MATRIX_CMAKE; do @@ -32,9 +49,8 @@ build_tcpdump() { export CRYPTO for SMB in $MATRIX_SMB; do export SMB - # shellcheck disable=SC2006 - COUNT=`increment $COUNT` - echo_magenta "===== SETUP $COUNT: BUILD_LIBPCAP=$BUILD_LIBPCAP REMOTE=${REMOTE:-?} CC=$CC CMAKE=$CMAKE CRYPTO=$CRYPTO SMB=$SMB =====" + COUNT=`increment "$COUNT"` + echo_magenta "===== SETUP $COUNT: BUILD_LIBPCAP=$BUILD_LIBPCAP REMOTE=${REMOTE:-?} CC=$CC CMAKE=$CMAKE CRYPTO=$CRYPTO SMB=$SMB =====" >&2 # Run one build with setup environment variables: # BUILD_LIBPCAP, REMOTE, CC, CMAKE, CRYPTO and SMB run_after_echo ./build.sh @@ -42,23 +58,20 @@ build_tcpdump() { if [ "$CMAKE" = yes ]; then run_after_echo rm -rf build else - run_after_echo make distclean + run_after_echo "$MAKE_BIN" distclean fi run_after_echo rm -rf "$PREFIX"/bin/tcpdump* run_after_echo git status -suall - # Cancel changes in configure - run_after_echo git checkout configure done done done } -touch .devel configure +touch .devel for CC in $MATRIX_CC; do export CC - # Exclude gcc on macOS (it is just an alias for clang). - # shellcheck disable=SC2006 - if [ "$CC" = gcc ] && [ "`uname -s`" = Darwin ]; then + discard_cc_cache + if gcc_is_clang_in_disguise; then echo '(skipped)' continue fi @@ -68,7 +81,7 @@ for CC in $MATRIX_CC; do for REMOTE in $MATRIX_REMOTE; do export REMOTE # Build libpcap with Autoconf. - echo_magenta "Build libpcap (CMAKE=no REMOTE=$REMOTE)" + echo_magenta "Build libpcap (CMAKE=no REMOTE=$REMOTE)" >&2 (cd ../libpcap && CMAKE=no ./build.sh) # Set PKG_CONFIG_PATH for configure when building libpcap if [ "$CMAKE" != no ]; then @@ -78,14 +91,16 @@ for CC in $MATRIX_CC; do build_tcpdump done else - echo_magenta 'Use system libpcap' + echo_magenta 'Use system libpcap' >&2 purge_directory "$PREFIX" - (cd ../libpcap; make distclean || echo '(Ignoring the make error.)') + if [ -d ../libpcap ]; then + (cd ../libpcap; "$MAKE_BIN" distclean || echo '(Ignoring the make error.)') + fi build_tcpdump fi done done run_after_echo rm -rf "$PREFIX" -echo_magenta "Tested setup count: $COUNT" +echo_magenta "Tested setup count: $COUNT" >&2 # vi: set tabstop=4 softtabstop=0 expandtab shiftwidth=4 smarttab autoindent :