Fixing get version same commit

This commit is contained in:
2025-03-30 23:45:24 +02:00
parent de56a4e17a
commit cf88e48c78

View File

@@ -19,29 +19,37 @@ runs:
fi
if [[ -n "${SEMVER_UPDATE}" ]]; then
git fetch --tags --force
log_info "Requested $(yellow)${SEMVER_UPDATE}$(reset_color) update"
git fetch --tags --force &>/dev/null
last_version="$(git describe --tags --abbrev=0 --match "v*" 2> /dev/null || echo "")"
if [[ -z "$last_version" ]]; then
last_version="v0.0.0"
fi
last_version="${last_version:1}"
log_info "Last version: ${last_version}"
# Split the version into components
IFS='.' read -r major minor patch <<< "${last_version%%-*}"
if git tag --points-at HEAD | grep -q "^${last_version}"; then
log_info "A tag already exists on the current commit, using it"
NEW_VERSION="${last_version:1}"
else
git fetch --tags --force --unshallow || echo "No fetch needed"
last_version="$(git describe --tags --abbrev=0 --match "v*" 2> /dev/null || echo "")"
# Increment the appropriate part of the version
case "${SEMVER_UPDATE}" in
"Major"*) NEW_VERSION="$((major + 1)).0.0"
;;
"Minor"*) NEW_VERSION="$major.$((minor + 1)).0"
;;
"Patch"*) NEW_VERSION="$major.$minor.$((patch + 1))"
;;
esac
if [[ -z "${last_version}" ]]; then
last_version="v0.0.0"
fi
last_version="${last_version:1}"
log_info "Last version: ${last_version}"
log_info "Requested ${SEMVER_UPDATE} update"
# Split the version into components
IFS='.' read -r major minor patch <<< "${last_version%%-*}"
# Increment the appropriate part of the version
case "${SEMVER_UPDATE}" in
"Major"*) NEW_VERSION="$((major + 1)).0.0"
;;
"Minor"*) NEW_VERSION="$major.$((minor + 1)).0"
;;
"Patch"*) NEW_VERSION="$major.$minor.$((patch + 1))"
;;
esac
fi;
NEW_VERSION="v${NEW_VERSION}"
elif [[ "${{ github.ref }}" == refs/tags/* ]]; then