aboutsummaryrefslogtreecommitdiff
path: root/system/sdl-jstest/git2tarxz.sh
diff options
context:
space:
mode:
Diffstat (limited to 'system/sdl-jstest/git2tarxz.sh')
-rw-r--r--system/sdl-jstest/git2tarxz.sh50
1 files changed, 50 insertions, 0 deletions
diff --git a/system/sdl-jstest/git2tarxz.sh b/system/sdl-jstest/git2tarxz.sh
new file mode 100644
index 000000000000..627abe3e96da
--- /dev/null
+++ b/system/sdl-jstest/git2tarxz.sh
@@ -0,0 +1,50 @@
+#!/bin/sh
+
+# Create source tarball from sdl-jstest git repo, with generated version
+# number. Since the build expects to have the git log available (for
+# embedding the git hash in --version output), don't rm -rf .git,
+# but do use --depth 1 when cloning.
+
+# Note that this script doesn't need to be run as root. It does need to
+# be able to write to the current directory it's run from.
+
+# Takes one optional argument, which is the commit or tag to create a
+# tarball of. With no arg, HEAD is used.
+
+PRGNAM=sdl-jstest
+CLONE_URL=https://gitlab.com/$PRGNAM/$PRGNAM.git
+
+set -e
+
+GITDIR=$( mktemp -dt $PRGNAM.git.XXXXXX )
+rm -rf $GITDIR
+git clone --depth 1 $CLONE_URL $GITDIR
+
+CWD="$( pwd )"
+cd $GITDIR
+
+if [ "$1" != "" ]; then
+ git reset --hard "$1" || exit 1
+fi
+
+git submodule update --init --recursive
+
+GIT_SHA=$( git rev-parse --short HEAD )
+
+DATE=$( git log --date=format:%Y%m%d --format=%cd | head -1 )
+
+VERSION=${DATE}_${GIT_SHA}
+
+mv .git .keep.git
+find . -name .git\* -print0 | xargs -0 rm -rf
+mv .keep.git .git
+rm -rf .git/modules .git/hooks
+
+cd "$CWD"
+rm -rf $PRGNAM-$VERSION $PRGNAM-$VERSION.tar.xz
+mv $GITDIR $PRGNAM-$VERSION
+tar cvfJ $PRGNAM-$VERSION.tar.xz $PRGNAM-$VERSION
+
+echo
+echo "Created tarball: $PRGNAM-$VERSION.tar.xz"
+echo "VERSION=$VERSION"