#!/bin/bash # Definiere den Namen für das Docker-Image und den Container IMAGE_NAME="gemini-dev-env" CONTAINER_NAME="gemini-session" # Sicherstellen, dass der Config-Ordner existiert mkdir -p .gemini-config # Prüfen, ob das Docker-Image existiert if ! docker image inspect "$IMAGE_NAME" &> /dev/null; then echo "Docker-Image '$IMAGE_NAME' nicht gefunden. Baue es jetzt aus 'gemini.Dockerfile'..." docker build -t "$IMAGE_NAME" -f gemini.Dockerfile . if [ $? -ne 0 ]; then echo "FEHLER: Docker-Image konnte nicht gebaut werden." exit 1 fi fi echo "Räume alte '$CONTAINER_NAME' auf, falls vorhanden..." docker rm -f "$CONTAINER_NAME" > /dev/null 2>&1 echo "Starte eine neue, interaktive Gemini-Session..." # Führe dev_session.py im Hintergrund aus und fange die Ausgabe ab # Der Kontext für die Gemini CLI wird von dev_session.py in speziellen Markierungen ausgegeben DEV_SESSION_OUTPUT=$(docker run -i --rm \ -v "$(pwd):/app" \ -v "$(pwd)/.gemini-config:/root/.config" \ -w /app \ --name "${CONTAINER_NAME}-temp" \ "$IMAGE_NAME" \ python3 dev_session.py 2>&1) # Extrahiere den CLI-Kontext aus der Ausgabe CLI_CONTEXT=$(echo "$DEV_SESSION_OUTPUT" | sed -n '/---GEMINI_CLI_CONTEXT_START---/,/---GEMINI_CLI_CONTEXT_END---/{//!p}') # Gib die Ausgaben von dev_session.py (außer dem Kontext) vor dem Start der CLI aus echo "$DEV_SESSION_OUTPUT" | sed '/---GEMINI_CLI_CONTEXT_START---/,/---GEMINI_CLI_CONTEXT_END---/d' # Starte die Gemini CLI mit dem extrahierten Kontext # Die --initial-prompt Option sorgt dafür, dass der Kontext als erste Eingabe dient docker run -it --rm \ -v "$(pwd):/app" \ -v "$(pwd)/.gemini-config:/root/.config" \ -w /app \ --name "$CONTAINER_NAME" \ "$IMAGE_NAME" \ gemini --initial-prompt "$CLI_CONTEXT" # Nach Beendigung der Session (z.B. durch Strg+C) wird aufgeräumt echo "Session beendet."