2023-07-29 12:19:18 +02:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
|
|
|
set -euo pipefail
|
|
|
|
|
2024-02-18 18:07:38 +01:00
|
|
|
xgit() {
|
2024-03-17 15:42:14 +01:00
|
|
|
git -c "user.name=Flake Update Bot" -c "user.email=flake-update-bot@clerie.de" -c "core.pager=cat" "$@"
|
2024-02-18 18:07:38 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
NOW="$(date --utc +%Y-%m-%d-%H-%M)"
|
|
|
|
|
|
|
|
xgit status || xgit clone gitea@git.clerie.de:clerie/nixfiles.git .
|
2023-07-29 12:19:18 +02:00
|
|
|
|
2023-09-01 16:38:34 +02:00
|
|
|
echo "[!] Download changes"
|
2024-02-18 18:07:38 +01:00
|
|
|
xgit fetch --all
|
|
|
|
|
|
|
|
echo "[!] Chechout remote master"
|
|
|
|
xgit checkout origin/master
|
|
|
|
|
2024-02-18 20:07:23 +01:00
|
|
|
UPDATE_BRANCH="updated-inputs-${NOW}"
|
2024-02-18 18:07:38 +01:00
|
|
|
echo "[!] Create branch ${UPDATE_BRANCH}"
|
|
|
|
xgit checkout -b "${UPDATE_BRANCH}"
|
|
|
|
|
|
|
|
echo "[!] Update nixpkgs"
|
|
|
|
nix flake lock --update-input nixpkgs
|
|
|
|
|
2023-09-01 16:38:34 +02:00
|
|
|
echo "[!] Commit changes"
|
2024-02-18 18:49:29 +01:00
|
|
|
xgit add flake.lock
|
2024-03-17 15:42:14 +01:00
|
|
|
|
2024-02-18 18:07:38 +01:00
|
|
|
xgit commit -m "Update nixpkgs ${NOW}" || true
|
|
|
|
|
2024-03-17 15:42:14 +01:00
|
|
|
xgit diff --name-status origin/updated-inputs "${UPDATE_BRANCH}"
|
|
|
|
|
|
|
|
echo "[!] biep"
|
|
|
|
if xgit diff --quiet origin/updated-inputs "${UPDATE_BRANCH}"
|
|
|
|
then
|
|
|
|
echo "[!] Nothing changed, removing branch"
|
|
|
|
xgit branch -D "${UPDATE_BRANCH}"
|
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
|
2024-02-18 18:49:29 +01:00
|
|
|
echo "[!] Publish ${UPDATE_BRANCH}"
|
|
|
|
xgit push --set-upstream origin "${UPDATE_BRANCH}"
|
|
|
|
|
2024-02-18 18:07:38 +01:00
|
|
|
echo "[!] Merge ${UPDATE_BRANCH} into updated-inputs"
|
|
|
|
xgit checkout updated-inputs
|
|
|
|
xgit merge -s ort -X theirs "${UPDATE_BRANCH}" -m "Update from ${UPDATE_BRANCH}"
|
|
|
|
|
|
|
|
echo "[!] Publish updated-inputs"
|
|
|
|
xgit push origin updated-inputs
|