When building with mkosi I would get the following:
[1/477] Generating version.h with a custom command
fatal: detected dubious ownership in repository at '/work/src'
To add an exception for this directory, call:
git config --global --add safe.directory /work/src
and then the tag would be generated as 'v254-'. This is obviously some problem
with the setup, but we should handle this gracefully. Let's fall back to 'v254'
instead.
In the case where we have a repo but no tags, use --dirty=^ too, as in the case
with tags.
I tested four cases:
- normal checkout
- checkout with .git removed
- checkout with .git chowned to root
- checkout wiht all tags removed
#!/usr/bin/env bash
# SPDX-License-Identifier: LGPL-2.1-or-later
-set -eu
+set -u
set -o pipefail
dir="${1:?}"
#
# If the working tree has no tags (CI builds), the first git-describe will fail
# and we fall back to project_version-commitid instead.
+
+ c=''
if [ -e "${dir}/.git" ]; then
- c="$(git -C "$dir" describe --abbrev=7 --dirty=^ 2>/dev/null ||
- echo "${fallback}-$(git -C "$dir" describe --always --abbrev=7)")"
- else
- c="${fallback}"
+ c="$(git -C "$dir" describe --abbrev=7 --dirty=^ 2>/dev/null)"
+ if [ -z "$c" ]; then
+ # This call might still fail with permission issues
+ suffix="$(git -C "$dir" describe --always --abbrev=7 --dirty=^ 2>/dev/null)"
+ [ -n "$suffix" ] && c="${fallback}-${suffix}"
+ fi
fi
+ [ -z "$c" ] && c="${fallback}"
echo "$c" | sed 's/^v//; s/-rc/~rc/'
fi