summaryrefslogtreecommitdiffstats
path: root/dist.sh
diff options
context:
space:
mode:
authorPeter Wu <peter@lekensteyn.nl>2020-01-18 16:26:39 +0000
committerPeter Wu <peter@lekensteyn.nl>2020-01-18 16:26:39 +0000
commit244d7a9d3b87e4ab1826126efc2766712e9a535f (patch)
tree3299cab7e63b96a6399bb9816278de781e264213 /dist.sh
parentfcf7825b5891f9bd6b3bbfea364c7f0717b54938 (diff)
downloadrspamd-244d7a9d3b87e4ab1826126efc2766712e9a535f.tar.gz
rspamd-244d7a9d3b87e4ab1826126efc2766712e9a535f.zip
[Minor] Simplify creation of dist tarball that is reproducible
Instead of archiving files from the working tree, distribute files as committed. Use the 'git archive' command to achieve this, it results in a reproducible tarball with the same timestamp as the latest commit.
Diffstat (limited to 'dist.sh')
-rwxr-xr-xdist.sh32
1 files changed, 14 insertions, 18 deletions
diff --git a/dist.sh b/dist.sh
index 6e10cae2f..12e05a23f 100755
--- a/dist.sh
+++ b/dist.sh
@@ -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"