Add worktree sandbox and test env workflow
This commit is contained in:
50
scripts/worktree-sync.sh
Executable file
50
scripts/worktree-sync.sh
Executable file
@@ -0,0 +1,50 @@
|
||||
#!/usr/bin/env bash
|
||||
set -euo pipefail
|
||||
|
||||
SCRIPT_DIR=$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)
|
||||
REPO_ROOT=$(cd "${SCRIPT_DIR}/.." && pwd)
|
||||
DEFAULT_SANDBOX="${REPO_ROOT}/../galaxyforge-sandbox"
|
||||
SANDBOX_PATH="${1:-$DEFAULT_SANDBOX}"
|
||||
|
||||
if [[ "$SANDBOX_PATH" != /* ]]; then
|
||||
SANDBOX_PATH="${REPO_ROOT}/${SANDBOX_PATH}"
|
||||
fi
|
||||
|
||||
SANDBOX_PATH=$(realpath -m "$SANDBOX_PATH")
|
||||
|
||||
if ! git -C "$REPO_ROOT" rev-parse --is-inside-work-tree >/dev/null 2>&1; then
|
||||
echo "Fehler: Repo-Root nicht gefunden: $REPO_ROOT" >&2
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if [[ ! -d "$SANDBOX_PATH" ]]; then
|
||||
echo "Fehler: Sandbox nicht gefunden: $SANDBOX_PATH" >&2
|
||||
echo "Bitte scripts/worktree-init.sh ausfuehren." >&2
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if ! git -C "$SANDBOX_PATH" rev-parse --is-inside-work-tree >/dev/null 2>&1; then
|
||||
echo "Fehler: Pfad ist kein Git-Worktree: $SANDBOX_PATH" >&2
|
||||
exit 1
|
||||
fi
|
||||
|
||||
COMMIT=$(git -C "$REPO_ROOT" rev-parse HEAD)
|
||||
|
||||
git -C "$SANDBOX_PATH" checkout --detach -f "$COMMIT" >/dev/null
|
||||
|
||||
echo "Sandbox auf Commit $COMMIT synchronisiert."
|
||||
|
||||
if ! git -C "$REPO_ROOT" diff --quiet HEAD; then
|
||||
if ! git -C "$REPO_ROOT" diff --binary HEAD | git -C "$SANDBOX_PATH" apply --whitespace=nowarn; then
|
||||
echo "Fehler: Patch konnte nicht angewendet werden. Bitte Sandbox bereinigen oder Konflikte pruefen." >&2
|
||||
exit 1
|
||||
fi
|
||||
echo "Uncommitted Aenderungen aus dem Haupt-Worktree wurden angewendet."
|
||||
else
|
||||
echo "Keine uncommitted Aenderungen im Haupt-Worktree gefunden."
|
||||
fi
|
||||
|
||||
UNTRACKED=$(git -C "$REPO_ROOT" ls-files --others --exclude-standard)
|
||||
if [[ -n "$UNTRACKED" ]]; then
|
||||
echo "Hinweis: Untracked Dateien wurden nicht uebernommen."
|
||||
fi
|
||||
Reference in New Issue
Block a user