checkin all script
This commit is contained in:
28
checkin-all
Executable file
28
checkin-all
Executable file
@@ -0,0 +1,28 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
GIT_HOME="${HOME}/git"
|
||||||
|
|
||||||
|
for dir in "${GIT_HOME}"/*/; do
|
||||||
|
if [ -d "${dir}/.git" ]; then
|
||||||
|
repo=$(basename "${dir}")
|
||||||
|
remote=$(git -C "${dir}" remote get-url origin 2>/dev/null || true)
|
||||||
|
case "${remote}" in
|
||||||
|
*schmeeve*)
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo " Skipping (not your repo: ${remote})"
|
||||||
|
continue
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
echo "=== ${repo} ==="
|
||||||
|
cd "${dir}"
|
||||||
|
if [ -n "$(git status --porcelain 2>/dev/null)" ]; then
|
||||||
|
echo " Changes found → committing and pushing..."
|
||||||
|
git commit -a -m "auto: $(date '+%Y-%m-%d %H:%M')" || echo " Nothing to commit (maybe no tracked files changed)"
|
||||||
|
git push
|
||||||
|
else
|
||||||
|
echo " Clean."
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
done
|
||||||
Reference in New Issue
Block a user