A vector-powered CLI for semantic search over files.
Project description
Vexor is a vector-powered CLI for semantic file search. It uses configurable embedding models and ranks results by cosine similarity.
Why Vexor?
When you remember what a file does but forget its name or location, Vexor finds it instantly—no grep patterns or directory traversal needed.
Designed for both humans and AI coding assistants, enabling semantic file discovery in autonomous agent workflows.
Install
Download standalone binary from releases (no Python required), or:
pip install vexor # also works with pipx, uv
Quick Start
1. Configure API Key
vexor config --set-api-key "YOUR_KEY"
Or via environment: VEXOR_API_KEY, OPENAI_API_KEY, or GOOGLE_GENAI_API_KEY.
2. Search
vexor search "api client config" # searches current directory
# or explicit path:
vexor search "api client config" --path ~/projects/demo --top 5
Vexor auto-indexes on first search. Example output:
Vexor semantic file search results
──────────────────────────────────
# Similarity File path Lines Preview
1 0.923 ./src/config_loader.py - config loader entrypoint
2 0.871 ./src/utils/config_parse.py - parse config helpers
3 0.809 ./tests/test_config_loader.py - tests for config loader
3. Explicit Index (Optional)
vexor index # indexes current directory
# or explicit path:
vexor index --path ~/projects/demo --mode code
Useful for CI warmup or when auto_index is disabled.
Configuration
vexor config --set-provider openai # default; also supports gemini/custom/local
vexor config --set-model text-embedding-3-small
vexor config --set-batch-size 0 # 0 = single request
vexor config --set-embed-concurrency 2 # parallel embedding requests
vexor config --set-auto-index true # auto-index before search (default)
vexor config --set-base-url https://proxy.example.com # optional proxy
vexor config --clear-base-url # reset to official endpoint
vexor config --show # view current settings
Config stored in ~/.vexor/config.json.
Providers: Remote vs Local
Vexor supports both remote API providers (openai, gemini, custom) and a local provider (local):
- Remote providers use
api_keyand optionalbase_url. customis OpenAI-compatible and requires bothmodelandbase_url.- Local provider ignores
api_key/base_urland only usesmodelpluslocal_cuda(CPU/GPU switch).
Local Model (Offline)
Install the lightweight local backend:
pip install "vexor[local]"
GPU backend (requires CUDA drivers):
pip install "vexor[local-cuda]"
Download a local embedding model and auto-configure Vexor:
vexor local --setup --model intfloat/multilingual-e5-small
Then use vexor search / vexor index as usual.
Local models are stored in ~/.vexor/models (clear with vexor local --clean-up).
GPU (optional): install onnxruntime-gpu (or vexor[local-cuda]) and use vexor local --setup --cuda (or vexor local --cuda).
Switch back with vexor local --cpu.
Index Modes
Control embedding granularity with --mode:
| Mode | Description |
|---|---|
auto |
Default. Smart routing: Python/JS/TS → code, Markdown → outline, small files → full, large files → head |
name |
Embed filename only (fastest, zero content reads) |
head |
Extract first snippet for lightweight semantic context |
brief |
Extract high-frequency keywords from PRDs/requirements docs |
full |
Chunk entire content; long documents searchable end-to-end |
code |
AST-aware chunking by module/class/function boundaries for Python and JavaScript/TypeScript; other files fall back to full |
outline |
Chunk Markdown by heading hierarchy with breadcrumbs; non-.md falls back to full |
Cache Behavior
Index cache keys derive from: --path, --mode, --include-hidden, --no-recursive, --no-respect-gitignore, --ext, --exclude-pattern.
Keep flags consistent to reuse cache; changing flags creates a separate index.
vexor config --show-index-all # list all cached indexes
vexor config --clear-index-all # clear all cached indexes
vexor index --path . --clear # clear index for specific path
Re-running vexor index only re-embeds changed files; >50% changes trigger full rebuild.
Command Reference
| Command | Description |
|---|---|
vexor search QUERY --path PATH |
Semantic search (auto-indexes if needed) |
vexor index --path PATH |
Build/refresh index manually |
vexor config --show |
Display current configuration |
vexor local --setup [--model MODEL] |
Download a local model and set provider to local |
vexor local --clean-up |
Remove local model cache under ~/.vexor/models |
vexor local --cuda |
Enable CUDA for local embeddings (requires onnxruntime-gpu) |
vexor local --cpu |
Disable CUDA and use CPU for local embeddings |
vexor install --skills claude |
Install Agent Skill for Claude Code |
vexor install --skills codex |
Install Agent Skill for Codex |
vexor doctor |
Run diagnostic checks (command, config, cache, API key, API connectivity) |
vexor update [--upgrade] [--pre] |
Check for new version (optionally upgrade; --pre includes pre-releases) |
vexor feedback |
Open GitHub issue form (or use gh) |
Common Flags
| Flag | Description |
|---|---|
--path PATH |
Target directory (default: current working directory) |
--mode MODE |
Index mode (auto/name/head/brief/full/code/outline) |
--top K / -k |
Number of results (default: 5) |
--ext .py,.md / -e |
Filter by extension (repeatable) |
--exclude-pattern PATTERN |
Exclude paths by gitignore-style pattern (repeatable; .js treated as **/*.js) |
--include-hidden / -i |
Include hidden files |
--no-recursive / -n |
Don't recurse into subdirectories |
--no-respect-gitignore |
Include gitignored files |
--format porcelain |
Script-friendly TSV output |
--format porcelain-z |
NUL-delimited output |
Porcelain output fields: rank, similarity, path, chunk_index, start_line, end_line, preview (line fields are - when unavailable).
AI Agent Skill
This repo includes a skill for AI agents to use Vexor effectively:
vexor install --skills claude # Claude Code
vexor install --skills codex # Codex
Skill source: plugins/vexor/skills/vexor-cli
Documentation
See docs for more details.
Contributions, issues, and PRs welcome! Star if you find it helpful.
License
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 vexor-0.14.0.tar.gz.
File metadata
- Download URL: vexor-0.14.0.tar.gz
- Upload date:
- Size: 62.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
96a05b9cfc6f769f826a1135df7c866e55bcb6b5c18899407fed027f254fd9f3
|
|
| MD5 |
7bbc737e6e12363f4a5e573e0a7980f8
|
|
| BLAKE2b-256 |
fd304458a2c1a068a0e48793e01d290cb3c83d3c09db955d6d3d5c89e805bdd6
|
Provenance
The following attestation bundles were made for vexor-0.14.0.tar.gz:
Publisher:
publish.yml on scarletkc/vexor
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
vexor-0.14.0.tar.gz -
Subject digest:
96a05b9cfc6f769f826a1135df7c866e55bcb6b5c18899407fed027f254fd9f3 - Sigstore transparency entry: 774035781
- Sigstore integration time:
-
Permalink:
scarletkc/vexor@1650917258ed2f828babc62f30337d9f798c5292 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/scarletkc
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@1650917258ed2f828babc62f30337d9f798c5292 -
Trigger Event:
push
-
Statement type:
File details
Details for the file vexor-0.14.0-py3-none-any.whl.
File metadata
- Download URL: vexor-0.14.0-py3-none-any.whl
- Upload date:
- Size: 72.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
912b77739adfb23f89c8d799ded2f97ec349b729c09673ec6c3cf8458419f5d1
|
|
| MD5 |
afeb27df2e6059d18457182d6e885489
|
|
| BLAKE2b-256 |
6a53b4e89d22fa73ea79d382b7ccf7fd1c7ebdfeacaefe980baee9991f0caf6f
|
Provenance
The following attestation bundles were made for vexor-0.14.0-py3-none-any.whl:
Publisher:
publish.yml on scarletkc/vexor
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
vexor-0.14.0-py3-none-any.whl -
Subject digest:
912b77739adfb23f89c8d799ded2f97ec349b729c09673ec6c3cf8458419f5d1 - Sigstore transparency entry: 774035782
- Sigstore integration time:
-
Permalink:
scarletkc/vexor@1650917258ed2f828babc62f30337d9f798c5292 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/scarletkc
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@1650917258ed2f828babc62f30337d9f798c5292 -
Trigger Event:
push
-
Statement type: