dev: update scripts to push subrepos

Signed-off-by: Stephen Gutekanst <stephen@hexops.com>
This commit is contained in:
Stephen Gutekanst 2022-08-26 11:54:18 -07:00 committed by Stephen Gutekanst
parent b6a512ebac
commit 79ec61396f
3 changed files with 56 additions and 28 deletions

View file

@ -1,6 +0,0 @@
#!/usr/bin/env bash
set -exuo pipefail
cd "$(dirname "${BASH_SOURCE[0]}")"/..
./dev/update-subrepos.sh
git subtree pull --prefix glfw mach-glfw main

View file

@ -1,8 +1,59 @@
#!/usr/bin/env bash #!/usr/bin/env bash
set -exuo pipefail set -euo pipefail
cd "$(dirname "${BASH_SOURCE[0]}")"/.. cd "$(dirname "${BASH_SOURCE[0]}")"/..
./dev/update-subrepos.sh push_subrepo() {
git subtree push --prefix libs/glfw mach-glfw main local project=$1
git subtree push --prefix libs/gpu-dawn mach-gpu-dawn main
git subtree push --prefix libs/freetype mach-freetype main echo " ----------------------------------------------------------------------------"
echo " | 🚀🐒 Preparing: mach-$project"
echo " ----------------------------------------------------------------------------"
cp -R staging-clean staging/
cd staging/
# Rewrite e.g. libs/freetype/ -> freetype/ so we have Git history for that subrepo in one path
# only (git subtree cannot follow renames.) For glfw, gpu-dawn, and freetype they were in the
# root before being under libs/ and so this is required to generate the proper history.
if [[ "$project" == "glfw" ]]; then
# glfw has an unfortunately non-linear history, and so we can't preserve commit hashes
# or else the subtree push cannot rebuild history properly.
git filter-repo --force \
--path $project \
--path "libs/$project" \
--path-rename libs/$project:$project
else
git filter-repo --force \
--preserve-commit-hashes \
--path $project \
--path "libs/$project" \
--path-rename libs/$project:$project
fi
# Push changes to the external subrepo.
if [ -n "${GITHUB_ACTIONS:-}" ]; then
git remote add -f "mach-$project" "https://slimsag:$ACCESS_TOKEN@github.com/hexops/mach-$project" || true
else
git remote add -f "mach-$project" "git@github.com:hexops/mach-$project" || true
fi
git fetch "mach-$project"
echo " ----------------------------------------------------------------------------"
echo " | 🚀🐒 Pushing: mach-$project"
echo " ----------------------------------------------------------------------------"
git subtree push --prefix "$project" "mach-$project" main
cd ..
rm -rf staging/
echo " ----------------------------------------------------------------------------"
echo " | 🚀🐒 Finished: mach-$project"
echo " ----------------------------------------------------------------------------"
}
rm -rf staging-clean/ staging/
git clone https://github.com/hexops/mach staging-clean
push_subrepo 'glfw'
push_subrepo 'gpu-dawn'
push_subrepo 'freetype'
rm -rf staging-clean

View file

@ -1,17 +0,0 @@
#!/usr/bin/env bash
set -exuo pipefail
cd "$(dirname "${BASH_SOURCE[0]}")"/..
if [ -n "${GITHUB_ACTIONS:-}" ]; then
git remote add -f mach-glfw "https://slimsag:$ACCESS_TOKEN@github.com/hexops/mach-glfw" || true
git remote add -f mach-gpu-dawn "https://slimsag:$ACCESS_TOKEN@github.com/hexops/mach-gpu-dawn" || true
git remote add -f mach-freetype "https://slimsag:$ACCESS_TOKEN@github.com/hexops/mach-freetype" || true
else
git remote add -f mach-glfw git@github.com:hexops/mach-glfw || true
git remote add -f mach-gpu-dawn git@github.com:hexops/mach-gpu-dawn || true
git remote add -f mach-freetype git@github.com:hexops/mach-freetype || true
fi
git fetch mach-glfw
git fetch mach-gpu-dawn
git fetch mach-freetype