Animated terminal pet that sits on your taskbar and reacts to AI coding assistant events
Project description
Clawd Buddy
A tiny animated terminal pet that sits on your taskbar and reacts to Claude Code events. Works on Windows and Linux.
What it does
Clawd Buddy is a small always-on-top character that lives on your taskbar while you work with Claude Code:
| State | What happens |
|---|---|
| Idle | Gently bobs, blinks, breathes — your quiet companion |
Assistant finishes (Stop hook) |
Celebrates with confetti, happy eyes, and waving arms |
Assistant needs permission (PermissionRequest hook) |
Waves at you with a floating ! so you know to check back |
Themes
Clawd Buddy supports dark and light color themes:
clawd-buddy --theme dark # default
clawd-buddy --theme light # light body, light screen
You can also toggle the theme at any time from the system tray icon menu.
Platform support
| Platform | Transparency | Always-on-top | Autostart |
|---|---|---|---|
| Windows 10/11 | Color-key (fully transparent background) | Win32 HWND_TOPMOST |
VBS in Startup folder |
| Linux (X11) | Themed background (dark or light) | _NET_WM_STATE_ABOVE |
.desktop in ~/.config/autostart/ |
Linux notes: Requires an X11 session (Wayland restricts window positioning and always-on-top). Most Wayland desktops support XWayland — set
SDL_VIDEODRIVER=x11(done automatically). Panel/dock height is auto-detected via_NET_WORKAREA; falls back to 48px.
Install
# With uv (recommended — installs as an isolated tool)
uv tool install clawd-buddy
# With pipx
pipx install clawd-buddy
# With pip (into current environment)
pip install clawd-buddy
From source
git clone https://github.com/ramymagdy-rm/clawd-buddy.git
cd clawd-buddy
uv tool install --from . clawd-buddy
Quick start
1. Launch the buddy
clawd-buddy
The buddy appears on your taskbar, centered at the bottom of the screen. It runs until you close it.
2. Run at startup (optional)
# Enable — buddy starts automatically at login
clawd-buddy --startup
# Disable — remove from startup
clawd-buddy --no-startup
- Windows: Places a VBS launcher in
shell:startup. No console window appears. - Linux: Creates a
.desktopfile in~/.config/autostart/.
3. Wire up Claude Code hooks
Add to your global Claude Code settings (~/.claude/settings.json) so every session triggers the buddy:
{
"hooks": {
"Stop": [
{
"hooks": [
{
"type": "command",
"command": "clawd-buddy --send done",
"timeout": 5000
}
]
}
],
"PermissionRequest": [
{
"hooks": [
{
"type": "command",
"command": "clawd-buddy --wave",
"timeout": 5000
}
]
}
]
}
}
Note: If you already have other hooks in your
settings.json, merge theStopandPermissionRequestentries into the existinghooksobject.
4. Done
Start a Claude Code session anywhere. When the assistant finishes or needs your attention, the buddy reacts.
CLI reference
clawd-buddy Start buddy on taskbar
clawd-buddy --test Start with a celebration animation
clawd-buddy --send MSG Signal a running buddy to celebrate
clawd-buddy --wave Signal a running buddy to wave (needs attention)
clawd-buddy --theme THEME Color theme: dark (default) or light
clawd-buddy --startup Enable run at login/startup
clawd-buddy --no-startup Disable run at login/startup
clawd-buddy --port PORT Use a custom TCP port (default: 44556)
clawd-buddy --no-topmost Don't keep the window always-on-top
clawd-buddy --fg Run in foreground (skip auto-detach)
clawd-buddy --help Show help
Controls
| Input | Action |
|---|---|
| Drag | Click anywhere on the buddy and drag to reposition |
| Space | Trigger a test celebration |
| Ctrl+1 | Scale to 100% (default) |
| Ctrl+2 | Scale to 125% |
| Ctrl+3 | Scale to 150% |
| Ctrl+4 | Scale to 200% |
| Escape | Quit the buddy |
| Tray icon | Right-click the system tray icon for a menu |
How it works
Architecture
Claude Code Clawd Buddy
----------- -----------
hooks/Stop ──> clawd-buddy --send ──> TCP:44556 ──> celebrate animation
hooks/PermissionRequest ──> clawd-buddy --wave ──> TCP:44556 ──> wave animation
- Claude Code hooks fire shell commands when events happen (response done, permission needed).
- The
clawd-buddy --send/--waveCLI connects to127.0.0.1:44556and sends a JSON action. - The running buddy process receives the signal and plays the animation.
Signal protocol
The buddy listens on a TCP socket (default port 44556). Send a JSON payload to trigger actions:
{"action": "celebrate"}
{"action": "wave"}
You can send signals from any language:
import socket, json
s = socket.socket()
s.connect(("127.0.0.1", 44556))
s.sendall(json.dumps({"action": "celebrate"}).encode())
s.close()
echo '{"action": "wave"}' | nc localhost 44556
Single instance
Only one buddy can run at a time. If you launch clawd-buddy while one is already running, it sends a signal to the existing instance and exits.
System tray
The buddy adds a system tray icon with a right-click menu:
- Test Celebration — trigger the celebrate animation
- Quit — close the buddy
Autostart
clawd-buddy --startup registers the buddy to launch at login. clawd-buddy --no-startup removes it.
- Windows: Places a VBS launcher in
%APPDATA%\Microsoft\Windows\Start Menu\Programs\Startup\. Starts with a hidden console window. - Linux: Creates a
.desktopfile in~/.config/autostart/. Uses the XDG autostart standard supported by GNOME, KDE, XFCE, and others.
Animations
Idle
- Gentle vertical bobbing (sine wave)
- Periodic blinking (every ~5 seconds)
- Pupils wander slowly
- Small mouth line with subtle movement
- Arms sway gently at sides
Celebrate (on Stop)
- Fast bouncing
- Happy arc eyes (^ ^)
- Wide smile
- Both arms waving up
- Legs kicking
- Confetti burst (40 particles with gravity and drag)
- Duration: 3.5 seconds
Wave (on PermissionRequest)
- Medium bobbing
- Wide alert eyes (large pupils, staring)
- Surprised "o" mouth
- Right arm waving high
- Pulsing floating ! indicator above head
- Duration: 5 seconds
Configuration
Custom port
If port 44556 is taken, use a different one:
clawd-buddy --port 55000
Update your hooks to match:
"command": "clawd-buddy --send done --port 55000"
Disable always-on-top
clawd-buddy --no-topmost
Troubleshooting
Buddy doesn't appear
- Windows: Make sure no other process is using port
44556:netstat -ano | findstr 44556 - Linux: Requires an X11 session. If you're on Wayland, the buddy forces
SDL_VIDEODRIVER=x11via XWayland. If it still doesn't appear, tryclawd-buddy --fgto see errors in the terminal. - macOS: Not yet supported.
Hook doesn't trigger the buddy
- Make sure the buddy is running (
clawd-buddyin a terminal or via--startup). - Test manually:
clawd-buddy --send test— if this says "No buddy on port 44556", the buddy isn't running. - Check that
clawd-buddyis on your PATH:where clawd-buddy(Windows) /which clawd-buddy(Linux)
Multiple buddies / port conflict
- The buddy uses a lock socket on port
44557(main port + 1) to prevent duplicates. - Windows:
taskkill /F /IM clawd-buddy.exe - Linux:
pkill -f clawd-buddy
Startup not working
Windows:
- Verify the VBS file exists:
dir "%APPDATA%\Microsoft\Windows\Start Menu\Programs\Startup\clawd-buddy*" - Re-run
clawd-buddy --startupto regenerate it.
Linux:
- Verify the desktop file exists:
ls ~/.config/autostart/clawd-buddy.desktop - Re-run
clawd-buddy --startupto regenerate it. - Make sure
clawd-buddyis on your PATH:which clawd-buddy
Linux: window has a visible background
On Linux, color-key transparency is not available. The buddy renders on a themed background (dark or light). Use --theme light on light panels/docks, or --theme dark on dark ones to blend in.
Disclaimer
Clawd Buddy is an independent open-source project. It is not affiliated with, endorsed by, or sponsored by Anthropic. "Claude" and "Claude Code" are trademarks of Anthropic, PBC.
License
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
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 clawd_buddy-0.1.4.tar.gz.
File metadata
- Download URL: clawd_buddy-0.1.4.tar.gz
- Upload date:
- Size: 371.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.2 {"installer":{"name":"uv","version":"0.10.2","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c93501628e19248d7dd48dd0257d7855b4822aabc41e0d82bfd1833619bc4d84
|
|
| MD5 |
fcb1daa8b29c21c9078dc66a0e2bf500
|
|
| BLAKE2b-256 |
800b7bf5d892544fc67b53b2f5df7681c242706d66f0609627661682922897e4
|
File details
Details for the file clawd_buddy-0.1.4-py3-none-any.whl.
File metadata
- Download URL: clawd_buddy-0.1.4-py3-none-any.whl
- Upload date:
- Size: 16.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.2 {"installer":{"name":"uv","version":"0.10.2","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d7224aa38c832b88c2ad2b49616b3bcbad953d3bca6b6310d4416fdd9e3b0814
|
|
| MD5 |
73c60e1e516f0abb526011514f6316d0
|
|
| BLAKE2b-256 |
207ec1e1a11566af76fff3073207ebd3514fab0c46600ba791b7e682fe596965
|