docs/public/antigravity-cli/setup.mdx
Give Antigravity CLI persistent memory across sessions.
Antigravity CLI (agy) is Google's standalone successor to Gemini CLI — it reuses Gemini CLI's ~/.gemini/ config tree and, per Google, "keeps the most critical features of Gemini CLI: Agent Skills, Hooks, Subagents, and Extensions." Claude-mem changes what happens across sessions by capturing observations, decisions, and patterns — then injecting relevant context into each new session.
agy) installed — curl -fsSL https://antigravity.google/cli/install.sh | bash~/.gemini directory must exist (created by Antigravity CLI / Gemini CLI on first run)npx claude-mem install --ide antigravity
The installer will:
agy in PATH, or an existing ~/.gemini/antigravity directory)~/.gemini/settings.json~/.gemini/GEMINI.md~/.gemini/antigravity/mcp_config.json and ~/.gemini/config/mcp_config.json~/.agents/rules/claude-mem-context.mdClaude-mem needs an AI provider to extract observations from your sessions. Choose one:
<Tabs> <Tab title="Gemini API (Free)"> The simplest option — use Gemini's own API for observation extraction:1. Get a free API key from [Google AI Studio](https://aistudio.google.com/apikey)
2. Add it to your settings:
```bash
mkdir -p ~/.claude-mem
cat > ~/.claude-mem/settings.json << 'EOF'
{
"CLAUDE_MEM_PROVIDER": "gemini",
"CLAUDE_MEM_GEMINI_API_KEY": "YOUR_API_KEY"
}
EOF
```
<Tip>
**Free tier:** 1,500 requests/day with `gemini-2.5-flash-lite`. Enable billing on Google Cloud for 4,000 RPM without charges.
</Tip>
```bash
mkdir -p ~/.claude-mem
cat > ~/.claude-mem/settings.json << 'EOF'
{
"CLAUDE_MEM_PROVIDER": "claude"
}
EOF
```
Set your API key via environment variable:
```bash
export ANTHROPIC_API_KEY="your-key"
```
```bash
mkdir -p ~/.claude-mem
cat > ~/.claude-mem/settings.json << 'EOF'
{
"CLAUDE_MEM_PROVIDER": "openrouter",
"CLAUDE_MEM_OPENROUTER_API_KEY": "YOUR_KEY"
}
EOF
```
# Check worker is running
npx claude-mem status
# Check hooks are installed — look for claude-mem entries
cat ~/.gemini/settings.json | grep claude-mem
# Check MCP registration in either candidate config path
cat ~/.gemini/antigravity/mcp_config.json | grep claude-mem
cat ~/.gemini/config/mcp_config.json | grep claude-mem
Open http://localhost:37777 to see the memory viewer.
Launch Antigravity CLI normally. Claude-mem works in the background:
agy
On session start, you'll see claude-mem context injected with your recent observations and project history.
Claude-mem registers all 8 confirmed Antigravity CLI lifecycle hooks (verified against a live install):
| Hook | Internal event | Purpose |
|---|---|---|
| SessionStart | context | Injects memory context into the session |
| BeforeAgent | session-init | Captures user prompts |
| AfterAgent | observation | Records full agent responses |
| BeforeTool | observation | Logs tool invocations before execution |
| AfterTool | observation | Captures tool results after execution |
| Notification | observation | Records system events (permissions, etc.) |
| PreCompress | summarize | Captures session summary before compression |
| SessionEnd | session-complete | Marks session complete |
All 8 events above are confirmed — verified directly against a live, already-installed Antigravity CLI's ~/.gemini/settings.json (not assumed from Gemini CLI's schema alone).
Antigravity CLI has native MCP support, but which config path it reads was genuinely ambiguous at the time of writing — two real candidate paths exist on disk with no definitive documentation resolving which one agy loads. Claude-mem writes to both, safely and idempotently:
~/.gemini/antigravity/mcp_config.json~/.gemini/config/mcp_config.jsonThis gives claude-mem's search tools (search, smart_search, timeline, etc.) a chance to register correctly regardless of which path Antigravity CLI actually reads.
Antigravity CLI ships a first-class plugin-marketplace subcommand system: agy plugin {list,import,install,uninstall,enable,disable,validate,link}. Notably, agy plugin import gemini|claude suggests native cross-tool plugin migration — structurally similar to Codex CLI's .codex-plugin/plugin.json marketplace mechanism. This could eventually be a cleaner, more idiomatic way to bundle claude-mem's hooks + MCP + skills registration than hand-editing settings.json. It isn't implemented here because its manifest schema isn't discoverable without running agy plugin import/install against a real manifest, which would mutate a user's live local plugin state. Tracked as a candidate follow-up.
Verify hooks exist in settings:
cat ~/.gemini/settings.json
You should see entries like "SessionStart", "AfterTool", etc. with claude-mem commands.
Restart Antigravity CLI after installation.
Re-run the installer:
npx claude-mem install --ide antigravity
# Check status
npx claude-mem status
# View logs
npx claude-mem logs
# Restart worker
npx claude-mem restart
~/.claude-mem/settings.jsonIf you see characters like [31m or [0m in the session context, your claude-mem version may need updating — the Antigravity CLI adapter strips ANSI color codes automatically:
npx claude-mem install --ide antigravity
npx claude-mem uninstall
This removes claude-mem's hooks from ~/.gemini/settings.json, cleans up the context section in ~/.gemini/GEMINI.md, removes claude-mem's entry from both MCP config files, and removes the rules context section — while preserving everything else in those files.