Jump to related tools in the same category or review the original source on GitHub.

CLI Utilities @johnmci Updated 2/26/2026

💎 Smalltalk OpenClaw Skill - ClawHub

Do you want your AI agent to automate Smalltalk workflows? This free skill from ClawHub helps with cli utilities tasks without building custom tools from scratch.

What this skill does

Interact with live Smalltalk image (Cuis or Squeak). Use for evaluating Smalltalk code, browsing classes, viewing method source, defining classes/methods, querying hierarchy and categories.

Install

npx clawhub@latest install smalltalk

Full SKILL.md

Open original
nameversiondescription
smalltalk1.7.0Interact with live Smalltalk image (Cuis or Squeak). Use for evaluating Smalltalk code, browsing classes, viewing method source, defining classes/methods, querying hierarchy and categories.

Smalltalk Skill

Execute Smalltalk code and browse live Squeak/Cuis images via MCP.

Prerequisites

Get the ClaudeSmalltalk repo first:

git clone https://github.com/CorporateSmalltalkConsultingLtd/ClaudeSmalltalk.git

This repo contains:

  • MCP server code for Squeak (MCP-Server-Squeak.st)
  • Setup documentation (SQUEAK-SETUP.md, CLAWDBOT-SETUP.md)
  • This Clawdbot skill (clawdbot/)

Setup

  1. Set up Squeak with MCP server — see SQUEAK-SETUP.md
  2. Configure Clawdbot — see CLAWDBOT-SETUP.md

Usage

# Check setup
python3 smalltalk.py --check

# Evaluate code
python3 smalltalk.py evaluate "3 factorial"
python3 smalltalk.py evaluate "Date today"

# Browse a class
python3 smalltalk.py browse OrderedCollection

# View method source (instance side)
python3 smalltalk.py method-source String asUppercase

# View method source (class side)
python3 smalltalk.py method-source "MCPServer class" version
python3 smalltalk.py method-source MCPServer version --class-side

# List classes (with optional prefix filter)
python3 smalltalk.py list-classes Collection

# Get class hierarchy
python3 smalltalk.py hierarchy OrderedCollection

# Get subclasses  
python3 smalltalk.py subclasses Collection

# List all categories
python3 smalltalk.py list-categories

# List classes in a category
python3 smalltalk.py classes-in-category "Collections-Sequenceable"

# Define a new class
python3 smalltalk.py define-class "Object subclass: #Counter instanceVariableNames: 'count' classVariableNames: '' poolDictionaries: '' category: 'MyApp'"

# Define a method
python3 smalltalk.py define-method Counter "increment
    count := (count ifNil: [0]) + 1.
    ^ count"

# Delete a method
python3 smalltalk.py delete-method Counter increment

# Delete a class
python3 smalltalk.py delete-class Counter

Operating Modes

Playground (Default)

Stock image, ephemeral. Changes are discarded when daemon stops. User says: "load Smalltalk skill" or "invoke Smalltalk" — no special flags.

# Start playground daemon
nohup python3 smalltalk-daemon.py start > /tmp/daemon.log 2>&1 &

Dev Mode

User supplies their own image/changes pair. Changes persist across sessions. User says: "load Smalltalk skill in dev mode with ~/MyProject.image"

# Start dev daemon with custom image
nohup python3 smalltalk-daemon.py start --dev --image ~/MyProject.image > /tmp/daemon.log 2>&1 &

Dev mode sets SMALLTALK_DEV_MODE=1 so the MCP server keeps the .changes file (instead of redirecting to /dev/null). The supplied image must have a matching .changes file alongside it.

Common Commands

# Check status
python3 smalltalk.py --daemon-status

# Stop daemon
python3 smalltalk-daemon.py stop

# Restart in dev mode
python3 smalltalk-daemon.py restart --dev --image ~/MyProject.image

Commands

Command Description
--check Verify VM/image paths and dependencies
--daemon-status Check if daemon is running
--debug Debug hung system (sends SIGUSR1, captures stack trace)
evaluate <code> Execute Smalltalk code, return result
browse <class> Get class metadata (superclass, ivars, instance methods and classMethods)
method-source <class> <selector> [--class-side] View method source code (supports "Class class" syntax or --class-side flag)
define-class <definition> Create or modify a class
define-method <class> <source> Add or update a method
delete-method <class> <selector> Remove a method
delete-class <class> Remove a class
list-classes [prefix] List classes, optionally filtered
hierarchy <class> Get superclass chain
subclasses <class> Get immediate subclasses
list-categories List all system categories
classes-in-category <cat> List classes in a category
explain <code> Explain Smalltalk code (requires ANTHROPIC_API_KEY or OPENAI_API_KEY)
explain-method <class> <sel> [--class-side] [--source <code>] Fetch method from image and explain it (or use --source/--source-file/--source-stdin to bypass daemon)
audit-comment <class> <sel> [--class-side] [--source <code>] Audit method comment vs implementation (or use --source/--source-file/--source-stdin to bypass daemon)
audit-class <class> Audit all methods in a class (instance + class side)
generate-sunit <targets> [--force] [--class-name <name>] Generate SUnit tests for methods and file into image

Environment Variables

Variable Description
SQUEAK_VM_PATH Path to Squeak/Cuis VM executable
SQUEAK_IMAGE_PATH Path to Smalltalk image with MCP server
ANTHROPIC_API_KEY API key for Anthropic Claude (preferred for LLM tools)
ANTHROPIC_MODEL Anthropic model (default: claude-opus-4-20250514)
OPENAI_API_KEY API key for OpenAI (fallback for LLM tools)
OPENAI_MODEL OpenAI model (default: gpt-4o)
LLM_PROVIDER Force LLM provider: anthropic or openai (auto-detected if not set)

Using with Claude Code (MCP mode)

When Claude Code has a live Smalltalk image connected via MCP, explain-method and audit-comment can use pre-fetched source code instead of requiring a running daemon. Use --source, --source-file, or --source-stdin to pass the method source directly:

# Inline source (fetched via MCP, passed on command line)
python3 smalltalk.py explain-method SmallInteger + --source "+ aNumber <primitive: 1> ^ super + aNumber"

# Source from a file
python3 smalltalk.py audit-comment Integer factorial --source-file /tmp/factorial.st

# Source piped via stdin
echo "printString ^ self printStringLimitedTo: 50000" | python3 smalltalk.py explain-method Object printString --source-stdin

The three source flags are mutually exclusive. When none is provided, the daemon is used as before.

Generating SUnit Tests

The generate-sunit command uses an LLM to generate SUnit test cases for Smalltalk methods and files them directly into the running image:

# Generate tests for a single method
python3 smalltalk.py generate-sunit "String>>asUppercase"

# Generate tests for multiple methods
python3 smalltalk.py generate-sunit "Random>>next" "Random>>nextInt:" "Random>>seed:"

# Generate tests for an entire class (all instance methods)
python3 smalltalk.py generate-sunit "OrderedCollection"

# Generate tests for class-side methods
python3 smalltalk.py generate-sunit "Date class>>today"

# Custom test class name
python3 smalltalk.py generate-sunit "String>>asUppercase" --class-name MyStringTests

# Overwrite existing test class
python3 smalltalk.py generate-sunit "String>>asUppercase" --force

# Run the generated tests
python3 smalltalk.py evaluate "StringGeneratedTest buildSuite run printString"

The generated TestCase uses standard SUnit assertions (assert:, assert:equals:, deny:, should:raise:) and is filed into a GeneratedSUnit-* category.

Notes

  • Requires xvfb for headless operation on Linux servers
  • Uses Squeak 6.0 MCP server (GUI stays responsive if display available)
  • saveImage intentionally excluded for safety
  • MCPServer version 7+ required (v7 adds class-side method support)
  • Playground mode: ephemeral, .changes → /dev/null
  • Dev mode: persistent, .changes kept, requires --dev --image PATH
Original URL: https://github.com/openclaw/skills/blob/main/skills/johnmci/smalltalk

Related skills

If this matches your use case, these are close alternatives in the same category.