diff options
author | Andreas Schneider <asn@samba.org> | 2021-08-26 14:52:14 +0200 |
---|---|---|
committer | Jule Anger <janger@samba.org> | 2022-05-30 09:24:14 +0000 |
commit | a10fd81856605732f280bc16ec1d21e5c8850551 (patch) | |
tree | 0945088bde729415bee392cc93a76c0f1df7bea5 | |
parent | e75837c115bc288758baa51001c66102d2fba61c (diff) | |
download | samba-a10fd81856605732f280bc16ec1d21e5c8850551.tar.gz |
third_party: Add a script to update waf
./third_party/waf/update.sh
Signed-off-by: Andreas Schneider <asn@samba.org>
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
(cherry picked from commit e41bc0f43f6d86d554f37881263c43c356994726)
-rwxr-xr-x | third_party/update.sh | 5 | ||||
-rwxr-xr-x | third_party/waf/update.sh | 79 |
2 files changed, 79 insertions, 5 deletions
diff --git a/third_party/update.sh b/third_party/update.sh index a510e8a7042..29456991874 100755 --- a/third_party/update.sh +++ b/third_party/update.sh @@ -23,9 +23,4 @@ hg clone https://bitbucket.org/micktwomey/pyiso8601 "$WORKDIR/pyiso8601" rm -rf "$WORKDIR/pyiso8601/.hg" rsync -avz --delete "$WORKDIR/pyiso8601/" "$THIRD_PARTY_DIR/pyiso8601/" -echo "Updating waf..." -git clone git://git.samba.org/third_party/waf.waf15/ "$WORKDIR/waf" -rm -rf "$WORKDIR/waf/.git" -rsync -C -avz --delete "$WORKDIR/waf/" "$THIRD_PARTY_DIR/waf/" - rm -rf "$WORKDIR" diff --git a/third_party/waf/update.sh b/third_party/waf/update.sh new file mode 100755 index 00000000000..16bda84a3f0 --- /dev/null +++ b/third_party/waf/update.sh @@ -0,0 +1,79 @@ +#!/bin/bash + +if [[ $# -lt 1 ]]; then + echo "Usage: update.sh VERSION" + exit 1 +fi + +WAF_VERSION="${1}" +WAF_GIT="https://gitlab.com/ita1024/waf.git" +WAF_UPDATE_SCRIPT="$(readlink -f "$0")" +WAF_SAMBA_DIR="$(dirname "${WAF_UPDATE_SCRIPT}")" +WAF_TMPDIR=$(mktemp --tmpdir -d waf-XXXXXXXX) + +echo "VERSION: ${WAF_VERSION}" +echo "GIT URL: ${WAF_GIT}" +echo "WAF SAMBA DIR: ${WAF_SAMBA_DIR}" +echo "WAF TMP DIR: ${WAF_TMPDIR}" + +cleanup_tmpdir() { + popd 2>/dev/null || true + rm -rf "$WAF_TMPDIR" +} +trap cleanup_tmpdir SIGINT + +cleanup_and_exit() { + cleanup_tmpdir + if test "$1" = 0 -o -z "$1" ; then + exit 0 + else + exit "$1" + fi +} + +# Checkout the git tree +mkdir -p "${WAF_TMPDIR}" +pushd "${WAF_TMPDIR}" || cleanup_and_exit 1 + +git clone "${WAF_GIT}" +ret=$? +if [ $ret -ne 0 ]; then + echo "ERROR: Failed to clone repository" + cleanup_and_exit 1 +fi + + +pushd waf || cleanup_and_exit 1 +git checkout -b "waf-${WAF_VERSION}" "waf-${WAF_VERSION}" +ret=$? +if [ $ret -ne 0 ]; then + echo "ERROR: Failed to checkout waf-${WAF_VERSION} repository" + cleanup_and_exit 1 +fi +popd || cleanup_and_exit 1 + +popd || cleanup_and_exit 1 + +# Update waflib +pushd "${WAF_SAMBA_DIR}" || cleanup_and_exit 1 +pwd + +rm -rf waflib/ +rsync -av "${WAF_TMPDIR}/waf/waflib" . +ret=$? +if [ $ret -ne 0 ]; then + echo "ERROR: Failed copy waflib" + cleanup_and_exit 1 +fi +chmod -x waflib/Context.py + +git add waflib + +popd || cleanup_and_exit 1 + +echo +echo "Now please change VERSION in buildtools/bin/waf and" +echo "Context.HEXVERSION in buildtools/wafsamba/wafsamba.py" +echo + +cleanup_and_exit 0 |