From fad526c63fb14877b9f64f9538d987e4ac1ac889 Mon Sep 17 00:00:00 2001 From: Olcan Date: Mon, 21 Apr 2025 09:17:17 -0700 Subject: make sandbox attachable, document in README (#80) --- scripts/start_sandbox.sh | 17 +++++++++++++++-- 1 file changed, 15 insertions(+), 2 deletions(-) (limited to 'scripts/start_sandbox.sh') diff --git a/scripts/start_sandbox.sh b/scripts/start_sandbox.sh index 64964600..ce405d6e 100755 --- a/scripts/start_sandbox.sh +++ b/scripts/start_sandbox.sh @@ -2,8 +2,8 @@ set -euo pipefail IMAGE=gemini-code-sandbox -CLI_DIST=/usr/local/share/npm-global/lib/node_modules/\@gemini-code/cli WORKDIR=/sandbox/$(basename "$PWD") +CLI_DIST=/usr/local/share/npm-global/lib/node_modules/\@gemini-code/cli # use docker if installed, otherwise try to use podman instead if command -v docker &> /dev/null; then @@ -15,6 +15,19 @@ else exit 1 fi +# use interactive tty mode and auto-remove container on exit +run_args=(-it --rm) + +# mount current directory as $WORKDIR inside container +run_args+=(-v "$PWD:$WORKDIR") + +# name container after image, plus numeric suffix to avoid conflicts +INDEX=0 +while $CMD ps -a --format "{{.Names}}" | grep -q "$IMAGE-$INDEX"; do + INDEX=$((INDEX + 1)) +done +run_args+=(--name "$IMAGE-$INDEX") + # run gemini-code in sandbox container # use empty --authfile to skip unnecessary auth refresh overhead -$CMD run -it --rm --authfile <(echo '{}') -v"$PWD:$WORKDIR" --workdir "$WORKDIR" "$IMAGE" node "$CLI_DIST" \ No newline at end of file +$CMD run "${run_args[@]}" --authfile <(echo '{}') --workdir "$WORKDIR" "$IMAGE" node "$CLI_DIST" \ No newline at end of file -- cgit v1.2.3