X-Git-Url: https://git.tcpdump.org/tcpdump/blobdiff_plain/1f225ed4532bdf34ca42c12602ad33c3b732e90c..69f03c1c03b280b9c5863bfb47e8847d59b4ee6b:/build_matrix.sh diff --git a/build_matrix.sh b/build_matrix.sh index b16e03e5..f37589fa 100755 --- a/build_matrix.sh +++ b/build_matrix.sh @@ -13,24 +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 @@ -39,8 +49,7 @@ build_tcpdump() { export CRYPTO for SMB in $MATRIX_SMB; do export SMB - # shellcheck disable=SC2006 - COUNT=`increment $COUNT` + 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 @@ -49,18 +58,16 @@ 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 discard_cc_cache @@ -87,7 +94,7 @@ for CC in $MATRIX_CC; do echo_magenta 'Use system libpcap' >&2 purge_directory "$PREFIX" if [ -d ../libpcap ]; then - (cd ../libpcap; make distclean || echo '(Ignoring the make error.)') + (cd ../libpcap; "$MAKE_BIN" distclean || echo '(Ignoring the make error.)') fi build_tcpdump fi