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