diff --git a/src/lib/crypto/kimchi_backend/common/gen_version.sh b/src/lib/crypto/kimchi_backend/common/gen_version.sh index 6f3c97a1971..4260551bbbf 100755 --- a/src/lib/crypto/kimchi_backend/common/gen_version.sh +++ b/src/lib/crypto/kimchi_backend/common/gen_version.sh @@ -1,8 +1,17 @@ #!/usr/bin/env bash set -e -o pipefail if [ -z ${MARLIN_REPO_SHA+x} ]; then - marlin_submodule_dir=$(git submodule status | grep proof-systems | sed 's/^[-\ ]//g' | cut -d ' ' -f 2) - marlin_repo_sha=$(cd $marlin_submodule_dir && git rev-parse --short=8 --verify HEAD) + # Check for the existence of the 'mina' submodule + git_root=$(git rev-parse --show-toplevel) + mina_submodule=$(git submodule status | grep "mina" || true) + + if [[ -n "$mina_submodule" ]]; then + marlin_submodule_dir=$(git -C "$git_root/src/mina" submodule status | grep proof-systems | sed 's/^[-\ ]//g' | cut -d ' ' -f 2) + marlin_repo_sha=$(git -C "$git_root/src/mina/$marlin_submodule_dir" rev-parse --short=8 --verify HEAD) + else + marlin_submodule_dir=$(git submodule status | grep proof-systems | sed 's/^[-\ ]//g' | cut -d ' ' -f 2) + marlin_repo_sha=$(git -C "$marlin_submodule_dir" rev-parse --short=8 --verify HEAD) + fi else marlin_repo_sha=$(cut -b -8 <<< "$MARLIN_REPO_SHA") fi diff --git a/src/lib/mina_version/normal/gen.sh b/src/lib/mina_version/normal/gen.sh index ee45e3683ec..ad34bfa5b6c 100755 --- a/src/lib/mina_version/normal/gen.sh +++ b/src/lib/mina_version/normal/gen.sh @@ -12,7 +12,12 @@ pushd "$root" > /dev/null if [[ -e .git ]] && ! git diff --quiet; then id="[DIRTY]$id"; fi commit_date="${MINA_COMMIT_DATE-$(git show HEAD -s --format="%cI" || echo "")}" - pushd src/lib/crypto/proof-systems > /dev/null + mina_submodule=$(git submodule status | grep "mina" || true) + if [[ -n "$mina_submodule" ]]; then + pushd src/mina/src/lib/crypto/proof-systems > /dev/null + else + pushd src/lib/crypto/proof-systems > /dev/null + fi marlin_commit_id="${MARLIN_COMMIT_ID-$(git rev-parse --verify HEAD || echo "")}" marlin_commit_id_short="$(printf '%s' "$marlin_commit_id" | cut -c1-8)" if [[ -e .git ]] && ! git diff --quiet; then marlin_commit_id="[DIRTY]$marlin_commit_id"; fi