Skip to main content

AI-powered command line assistant - any model, anywhere

Project description

MaShell

███╗   ███╗ █████╗ ███████╗██╗  ██╗███████╗██╗     ██╗     
████╗ ████║██╔══██╗██╔════╝██║  ██║██╔════╝██║     ██║     
██╔████╔██║███████║███████╗███████║█████╗  ██║     ██║     
██║╚██╔╝██║██╔══██║╚════██║██╔══██║██╔══╝  ██║     ██║     
██║ ╚═╝ ██║██║  ██║███████║██║  ██║███████╗███████╗███████╗
╚═╝     ╚═╝╚═╝  ╚═╝╚══════╝╚═╝  ╚═╝╚══════╝╚══════╝╚══════╝

🐚 Your AI-Powered Command Line Assistant

MaShell is an AI agent that lives in your terminal. It can run commands, write code, create projects, and accomplish complex tasks — all through natural conversation.


⚡ Quick Start

# Install with Homebrew (macOS)
brew tap jacobjiangwei/tap
brew install mashell

# Or install with pipx (macOS/Linux)
pipx install mashell

# Or with pip (in a virtual environment)
pip install mashell

# Run (first time will guide you through setup)
mashell

Note: On macOS, we recommend Homebrew or pipx for installing CLI tools. Install pipx with brew install pipx if you don't have it.

That's it! MaShell will walk you through connecting to your AI provider (OpenAI, Azure, Anthropic, or local Ollama).


� What Can MaShell Do?

Task Example
Find files "find the largest video on my computer"
Read documents "read my resume.pdf and summarize it"
Edit Word files "update my resume.docx with new job title"
Create projects "build a Python web scraper from scratch"
Run code "run this script and fix any errors"
Git operations "commit all changes with a good message"
Web scraping "scrape the HN front page for top stories"
Install tools "install ffmpeg and convert video.mp4 to gif"
System tasks "clean up files older than 30 days in Downloads"
Debug "why is my Python script failing?"

Native File Tools (No Shell Required)

MaShell has built-in tools for file operations — faster and no permission prompts for reading:

Tool Description Permission
read_file Read any file (supports PDF, Word .docx, text) Auto ✅
list_dir List directory contents with sizes Auto ✅
search_files Search/grep across files Auto ✅
write_file Write text files Requires approval
edit_docx Edit Word documents (find/replace, update paragraphs) Requires approval
shell Execute any shell command Requires approval
crawl Scrape web pages (JS rendering) Requires approval

🔧 Setup Options

Option 1: Interactive Setup (Recommended)

Just run mashell — if no config exists, it will guide you:

🐚 MaShell Configuration Wizard

Step 1: Choose your LLM provider
  1. openai    - OpenAI API (GPT-4o, etc.)
  2. azure     - Azure OpenAI Service
  3. anthropic - Anthropic API (Claude)
  4. ollama    - Local Ollama (no API key needed)

Select provider: 2

Step 2: API Endpoint URL
Enter your Azure OpenAI endpoint: https://your-resource.openai.azure.com/

Step 3: API Key
Enter your API key: ********

Step 4: Model / Deployment Name
Deployment name: gpt-4o

✅ Configuration saved!

Option 2: Command Line Arguments

# OpenAI
mashell --provider openai --url https://api.openai.com/v1 --key sk-... --model gpt-4o "your task"

# Azure OpenAI
mashell --provider azure --url https://your-resource.openai.azure.com --key xxx --model gpt-4o "your task"

# Anthropic
mashell --provider anthropic --url https://api.anthropic.com --key sk-ant-... --model claude-sonnet-4-20250514 "your task"

# Local Ollama (no key needed)
mashell --provider ollama --url http://localhost:11434 --model llama3 "your task"

Option 3: Environment Variables

export MASHELL_PROVIDER="openai"
export MASHELL_URL="https://api.openai.com/v1"
export MASHELL_KEY="sk-..."
export MASHELL_MODEL="gpt-4o"

mashell "your task"

� See It In Action

Example 1: Find the Largest Video File

You: find biggest video file on my computer

💭 I'll check common video locations first...

▶ Run:
  $ du -sh ~/Documents ~/Downloads ~/Desktop ~/Movies

📋 Output:
342G    /Users/jacob/Documents
5.4G    /Users/jacob/Downloads
4.8G    /Users/jacob/Desktop
12K     /Users/jacob/Movies

💭 Documents is huge. Let me search for videos there...

▶ Run:
  $ find ~/Documents -type f \( -iname "*.mp4" -o -iname "*.mkv" \) -exec ls -lhS {} + | head -10

📋 Output:
-rw-r--r--  3.8G  Peaky Blinders S06E06.mkv
-rw-r--r--  3.7G  The.Brutalist.2024.mp4
-rw-r--r--  3.0G  Mission.Impossible.mkv
...

MaShell: Found it! The biggest video is:
**3.8G** — ~/Documents/Bitcomet/Peaky Blinders S06E06.mkv

Example 2: Build a Project From Scratch

You: create a python project that can scrape web pages

💭 I'll set up a proper Python project structure...

▶ Run:
  $ mkdir -p python-scraper/{src,tests,outputs}
✓ Done

▶ Run:
  $ cat << 'EOF' > python-scraper/src/fetch.py
  import httpx
  def fetch(url): ...
  EOF
✓ Done

... (creates requirements.txt, README, .gitignore, venv, installs deps)

▶ Run:
  $ ./run.sh scrape https://example.com
📋 Output:
URL: https://example.com
Status: 200
Title: Example Domain

MaShell: Done! Created a Python web scraper at ./python-scraper

Try it: ./run.sh scrape https://example.com --out outputs/page.html

Example 3: Scrape a Website

You: use it to scrape www.cnn.com and see what's happening today

▶ Run:
  $ ./run.sh scrape https://www.cnn.com --out outputs/cnn.html
📋 Output:
Status: 200
Title: Breaking News, Latest News and Videos | CNN
Saved: outputs/cnn.html

💭 Let me extract the headlines...

▶ Run:
  $ python -c "from bs4 import BeautifulSoup; ..."

MaShell: Today's top story: "Trump ramps up rhetoric on ICE despite calls for de-escalation"

🔐 Permission System

MaShell always asks before running commands:

╭─────────────────── 🔐 Permission Request ───────────────────╮
│                                                              │
│  Tool: shell                                                 │
│                                                              │
│  Command:                                                    │
│  $ rm -rf ./node_modules                                     │
│                                                              │
╰──────────────────────────────────────────────────────────────╯
   Approve   Deny   Edit   Always approve this session
Choice [y/n/e/a]: 
  • y — Run this command
  • n — Block it
  • e — Edit the command first
  • A — Auto-approve all commands this session (use with caution!)

💡 Tips

  1. Be specific — "find large files" → "find video files larger than 1GB in Downloads"

  2. Let it explore — MaShell thinks step-by-step like a human, checking results before deciding what to do next

  3. Auto-approve mode — Use mashell -y "task" for trusted, quick tasks

  4. Interactive mode — Just run mashell to chat back and forth


📦 Installation from Source

git clone https://github.com/anthropics/MaShell.git
cd MaShell
pip install -e .

For development:

python -m mashell "your task"

📄 License

GPL-3.0 — Free to use, modify, and share.


Built for developers who live in the terminal 🐚

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mashell-1.0.8.tar.gz (67.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mashell-1.0.8-py3-none-any.whl (70.8 kB view details)

Uploaded Python 3

File details

Details for the file mashell-1.0.8.tar.gz.

File metadata

  • Download URL: mashell-1.0.8.tar.gz
  • Upload date:
  • Size: 67.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for mashell-1.0.8.tar.gz
Algorithm Hash digest
SHA256 286b5a1cc96df9b0870478b3c35c1ecc90b51ac2fdb562b9d0d0dc36b29fc984
MD5 cc0f21a175fe1c472d94bdc2890538a6
BLAKE2b-256 be9baa6f7a405a05b42be7980060a8ab4ab401c7f678f75ed3d531df9c8be951

See more details on using hashes here.

Provenance

The following attestation bundles were made for mashell-1.0.8.tar.gz:

Publisher: publish.yml on jacobjiangwei/MaShell

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file mashell-1.0.8-py3-none-any.whl.

File metadata

  • Download URL: mashell-1.0.8-py3-none-any.whl
  • Upload date:
  • Size: 70.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for mashell-1.0.8-py3-none-any.whl
Algorithm Hash digest
SHA256 f97c530d5427bd3b55d05efef3311c99fda40ee500f5b3b26d240c7ad926a135
MD5 782f9f310f7ccdbde10c91c1e2872359
BLAKE2b-256 728f2f846dd36589b9b628643e9acfda4f4dc639fb80a5997107b5ac1ac573c2

See more details on using hashes here.

Provenance

The following attestation bundles were made for mashell-1.0.8-py3-none-any.whl:

Publisher: publish.yml on jacobjiangwei/MaShell

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page