dev: update scripts to push subrepos
Signed-off-by: Stephen Gutekanst <stephen@hexops.com>
This commit is contained in:
parent
b6a512ebac
commit
79ec61396f
3 changed files with 56 additions and 28 deletions
|
|
@ -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
|
|
||||||
|
|
@ -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
|
||||||
|
|
|
||||||
|
|
@ -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
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue