diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2020-01-20 18:55:38 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-01-20 18:55:38 +0000 |
commit | 7d42200919e5fa63caf12bda7e2dd46dc1210b1a (patch) | |
tree | 6f875e52e7ee44ff75f476f1ea24f71432660666 | |
parent | b2bf127b542325e59229f98b518b4be8d49573e7 (diff) | |
parent | 244d7a9d3b87e4ab1826126efc2766712e9a535f (diff) | |
download | rspamd-7d42200919e5fa63caf12bda7e2dd46dc1210b1a.tar.gz rspamd-7d42200919e5fa63caf12bda7e2dd46dc1210b1a.zip |
Merge pull request #3226 from Lekensteyn/dist-simplify
[Minor] Simplify creation of dist tarball that is reproducible
-rwxr-xr-x | dist.sh | 32 |
1 files changed, 14 insertions, 18 deletions
@@ -1,5 +1,8 @@ #!/bin/sh +# Creates a tarball with the concatenation of a git tree and the submodules. +# Hidden files such as .gitignore are skipped. +# GNU tar TAR=${2:-"tar"} if [ $# -lt 1 ] ; then @@ -10,24 +13,17 @@ fi FNAME=$1 PREFIX=`basename $FNAME | sed -e 's/\.tar.*$//'` -OUT="" -while true ; do - _mktemp=`which mktemp` - if [ F"$_mktemp" != "F" ] ; then - OUT=`$_mktemp /tmp/files-XXXXXXXX` - break - else - OUT="/tmp/files-`strings -7 /dev/urandom | head -1 | sed -e 's/[^[:alnum:]]//g'`" - fi - if [ ! -f "$OUT" ] ; then break ; fi -done +ALL_TAR=$(mktemp) || { echo "mktemp is missing!"; exit 1; } +TMP_TAR=$(mktemp) || { echo "mktemp is missing!"; exit 1; } +trap 'rm -f "$TMP_TAR" "$ALL_TAR"' EXIT -git ls-files > $OUT -SUBMODULES=`git submodule | cut -d ' ' -f 3` +# Create tarball for main repo contents. +git archive --prefix="$PREFIX/" HEAD ":!.*" ":!**/.*" > "$ALL_TAR" -for sub in $SUBMODULES ; do - (cd $sub && git ls-files | sed -e "s|^|$sub/|" >> $OUT) -done +# Append submodule contents, if any. +export PREFIX TMP_TAR ALL_TAR +git submodule --quiet foreach --recursive \ + 'git archive --prefix="$PREFIX/$displaypath/" HEAD ":!.*" ":!**/.*" > "$TMP_TAR"; + tar Af "$ALL_TAR" "$TMP_TAR"' -${TAR} -c --exclude='.[^/]*' --exclude='*.xz' --exclude='*.gz' --no-recursion --transform "s|^|$PREFIX/|" -a -T $OUT -v -f $FNAME -rm -f $OUT +xz < "$ALL_TAR" > "$FNAME" |