A thin, auditable MCP server wrapping the Gemini CLI. Forward-compatible with future CLI flags via extra_args passthrough.
Project description
gemini-cli-mcp-slim
A thin, auditable MCP server wrapping the Gemini CLI.
Why
Existing Gemini MCP servers tend to either hide the underlying CLI behind opaque parameters or hard-code the supported flags so new gemini CLI options require code changes. This project takes a different approach:
- Single file, ~270 lines — auditable in one sitting
- One third-party dependency (
mcp) — minimal supply-chain surface - Forward-compatible — any new or uncommon gemini CLI flag is reachable via
extra_argswithout touching this server - Configurable binary path —
$GEMINI_CMDlets you swap or wrap the gemini binary - Workspace-aware — first-class
include_directoriesso you can analyze multiple repositories from one invocation - Transparent — every invocation logs the exact argv to stderr
Installation
Requires the gemini CLI to be installed and on $PATH (or pointed to via $GEMINI_CMD).
# Run directly without installing
uvx gemini-cli-mcp-slim
# Install from PyPI
pip install gemini-cli-mcp-slim
# Run from GitHub HEAD
uvx --from git+https://github.com/tksfjt1024/gemini-cli-mcp-slim gemini-cli-mcp-slim
Usage as an MCP server
Claude Code
claude mcp add gemini-cli-mcp-slim uvx gemini-cli-mcp-slim
Or manually in ~/.claude.json:
{
"mcpServers": {
"gemini-cli-mcp-slim": {
"type": "stdio",
"command": "uvx",
"args": ["gemini-cli-mcp-slim"]
}
}
}
Other MCP clients
Any MCP-compatible client can launch the server via stdio:
uvx gemini-cli-mcp-slim
Tools
consult_gemini
Run a single Gemini CLI invocation with full forward-compatibility.
| Parameter | Type | Description |
|---|---|---|
query (required) |
string | Prompt sent verbatim to the gemini CLI |
directory (required) |
string | Working directory (gemini cwd, defines the default workspace root) |
model |
string | Model alias (flash, pro) or full model id |
approval_mode |
enum | default / auto_edit / yolo / plan |
include_directories |
string[] | Extra workspace directories (mapped to gemini --include-directories) |
yolo |
bool | Pass --yolo (auto-approve all) |
sandbox |
bool | Pass --sandbox |
extra_args |
string[] | Raw CLI flags appended verbatim. Use to access new/uncommon gemini flags |
env |
object | Extra environment variables for the gemini subprocess |
timeout_seconds |
int | Subprocess timeout in seconds (default 600) |
consult_gemini_with_files
Same parameters as consult_gemini plus a files: string[] parameter. File paths are appended to the prompt as @path tokens (gemini's file reference syntax). Absolute paths inside directory are converted to relative @-paths.
web_search
Convenience wrapper that prepends a "use your built-in web search" instruction to the query.
Configuration
| Environment variable | Default | Purpose |
|---|---|---|
GEMINI_CMD |
gemini |
Path to the gemini CLI binary |
GEMINI_CLI_MCP_SLIM_TIMEOUT |
600 |
Default subprocess timeout in seconds |
GEMINI_CLI_MCP_SLIM_LOG_LEVEL |
INFO |
Logging level for stderr diagnostics |
Cross-repository analysis example
The killer feature: analyze multiple repositories from a single MCP invocation.
{
"name": "consult_gemini",
"arguments": {
"query": "Compare the API surface between these services",
"directory": "/path/to/service-a",
"include_directories": [
"/path/to/service-b",
"/path/to/service-c"
],
"model": "flash",
"approval_mode": "plan"
}
}
This launches gemini with --include-directories=/path/to/service-b,/path/to/service-c, giving the model read access to all three workspaces in one session.
Forward-compatibility example
If a future gemini CLI release adds a new flag (say --super-mode), you can use it immediately without updating this server:
{
"name": "consult_gemini",
"arguments": {
"query": "...",
"directory": "...",
"extra_args": ["--super-mode", "--some-other-new-flag"]
}
}
Comparison with alternatives
| Project | Lines | Deps | include_directories |
extra_args passthrough |
|---|---|---|---|---|
| gemini-cli-mcp-slim (this) | ~270 | 1 (mcp) |
yes | yes |
| eLyiN/gemini-bridge | ~400 | 1 (mcp) |
no | no |
| jamubc/gemini-mcp-tool | (TS) | many | no | partial |
Development
# Install dev dependencies
pip install -e ".[test,dev]"
# Lint
ruff check .
# Test
pytest
License
MIT © tksfjt1024
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file gemini_cli_mcp_slim-0.1.0.tar.gz.
File metadata
- Download URL: gemini_cli_mcp_slim-0.1.0.tar.gz
- Upload date:
- Size: 10.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ca9427a1c437c39a9734e6b90e0770fc2df4e0714e08760ddadcfa07c626428a
|
|
| MD5 |
90d84f4b5f35dfab786ce37afe4d3444
|
|
| BLAKE2b-256 |
87288c026a824133396a605b80c5e45faa836796999b306149028c5afa113752
|
Provenance
The following attestation bundles were made for gemini_cli_mcp_slim-0.1.0.tar.gz:
Publisher:
publish.yml on tksfjt1024/gemini-cli-mcp-slim
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
gemini_cli_mcp_slim-0.1.0.tar.gz -
Subject digest:
ca9427a1c437c39a9734e6b90e0770fc2df4e0714e08760ddadcfa07c626428a - Sigstore transparency entry: 1428222891
- Sigstore integration time:
-
Permalink:
tksfjt1024/gemini-cli-mcp-slim@4868fd61a42a6dd59e342d5d718325b7660cbf03 -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/tksfjt1024
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@4868fd61a42a6dd59e342d5d718325b7660cbf03 -
Trigger Event:
push
-
Statement type:
File details
Details for the file gemini_cli_mcp_slim-0.1.0-py3-none-any.whl.
File metadata
- Download URL: gemini_cli_mcp_slim-0.1.0-py3-none-any.whl
- Upload date:
- Size: 8.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fef519cc4e1121ca51afec1202a6da2dbff1c96dc83400181ad9d6ba5e9dd09f
|
|
| MD5 |
4e8aa746ddc2a85579fe0c5569eef086
|
|
| BLAKE2b-256 |
a8093b47542a89eb54d0dec1d6992e6f9edc62fa60afc399b8e03434c92d95f5
|
Provenance
The following attestation bundles were made for gemini_cli_mcp_slim-0.1.0-py3-none-any.whl:
Publisher:
publish.yml on tksfjt1024/gemini-cli-mcp-slim
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
gemini_cli_mcp_slim-0.1.0-py3-none-any.whl -
Subject digest:
fef519cc4e1121ca51afec1202a6da2dbff1c96dc83400181ad9d6ba5e9dd09f - Sigstore transparency entry: 1428223129
- Sigstore integration time:
-
Permalink:
tksfjt1024/gemini-cli-mcp-slim@4868fd61a42a6dd59e342d5d718325b7660cbf03 -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/tksfjt1024
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@4868fd61a42a6dd59e342d5d718325b7660cbf03 -
Trigger Event:
push
-
Statement type: