X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/795e98eac92b86652d3fe9de6657ffffc009d90e..dce08883afbf575127601743e2482c3bd8604d3a:/version-at-commit.sh diff --git a/version-at-commit.sh b/version-at-commit.sh index 89684cf2..e42b8753 100755 --- a/version-at-commit.sh +++ b/version-at-commit.sh @@ -1,9 +1,12 @@ #!/bin/bash +# Copyright (C) The Arvados Authors. All rights reserved. +# +# SPDX-License-Identifier: AGPL-3.0 set -e -o pipefail commit="$1" versionglob="[0-9].[0-9]*.[0-9]*" -devsuffix=".dev" +devsuffix="~dev" # automatically assign version # @@ -11,12 +14,12 @@ devsuffix=".dev" # # 1. commit is directly tagged. print that. # -# 2. commit is on master or a development branch, the nearest tag is older -# than commit where this branch joins master. +# 2. commit is on main or a development branch, the nearest tag is older +# than commit where this branch joins main. # -> take greatest version tag in repo X.Y.Z and assign X.(Y+1).0 # # 3. commit is on a release branch, the nearest tag is newer -# than the commit where this branch joins master. +# than the commit where this branch joins main. # -> take nearest tag X.Y.Z and assign X.Y.(Z+1) tagged=$(git tag --points-at "$commit") @@ -25,21 +28,21 @@ if [[ -n "$tagged" ]] ; then echo $tagged else # 1. get the nearest tag with 'git describe' - # 2. get the merge base between this commit and master + # 2. get the merge base between this commit and main # 3. if the tag is an ancestor of the merge base, # (tag is older than merge base) increment minor version # else, tag is newer than merge base, so increment point version nearest_tag=$(git describe --tags --abbrev=0 --match "$versionglob" "$commit") - merge_base=$(git merge-base origin/master "$commit") + merge_base=$(git merge-base origin/main "$commit") if git merge-base --is-ancestor "$nearest_tag" "$merge_base" ; then - # x.(y+1).0.devTIMESTAMP, where x.y.z is the newest version that does not contain $commit + # x.(y+1).0~devTIMESTAMP, where x.y.z is the newest version that does not contain $commit # grep reads the list of tags (-f) that contain $commit and filters them out (-v) # this prevents a newer tag from retroactively changing the versions of everything before it - v=$(git tag | grep -vFf <(git tag --contains "$commit") | sort -Vr | head -n1 | perl -pe 's/\.(\d+)\.\d+/".".($1+1).".0"/e') + v=$(git tag | grep -vFf <(git tag --contains "$commit") | sort -Vr | head -n1 | perl -pe 's/(\d+)\.(\d+)\.\d+.*/"$1.".($2+1).".0"/e') else - # x.y.(z+1).devTIMESTAMP, where x.y.z is the latest released ancestor of $commit + # x.y.(z+1)~devTIMESTAMP, where x.y.z is the latest released ancestor of $commit v=$(echo $nearest_tag | perl -pe 's/(\d+)$/$1+1/e') fi isodate=$(TZ=UTC git log -n1 --format=%cd --date=iso "$commit")