Files
Space-Theme/scripts/worktree-sync.sh

51 lines
1.6 KiB
Bash
Executable File

#!/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