đ moody - Awesome Go Library for Hardware

Hardware event personality daemon for macOS. Monitors USB, charger, lid, and other hardware events and responds with customizable personalities
đˇī¸ Hardware
đ Hardware
â 0 stars
Detailed Description of moody
moody đĢ
Your MacBook has feelings. And it's not afraid to express them.

What Is This?
Every hardware event triggers a personality response:
- đ Slap it â it complains (and remembers)
- đ Plug in USB â it gets curious
- ⥠Connect charger â it sighs with relief
- đĒĢ Battery dying â it begs for its life
- đļ WiFi drops â existential crisis
- đ§ Plug in headphones â "just the two of us now"
- đ¤ AI finishes code â celebrates your generated code
Your MacBook's mood evolves based on how you treat it. Slap it too much? It gets grumpy. Charge it? It forgives you. Maybe.
Install
Download from releases, or build from source:
go install github.com/dinakars777/moody@latest
sudo cp "$(go env GOPATH)/bin/moody" /usr/local/bin/moody
Usage
# Start moody (SFW mode)
sudo moody
# NSFW mode đ
sudo moody --spicy
# Show live mood dashboard
sudo moody --dashboard
# List available sensors
sudo moody --list-sensors
# Adjust slap sensitivity
sudo moody --min-amplitude 0.15
# Fast mode (quicker detection, shorter cooldown)
sudo moody --fast
# Silent mode (disables TTS voice, text only)
sudo moody --silent
# Verbose logging
sudo moody --verbose
Requirements
- macOS on Apple Silicon (M2+ or M1 Pro)
sudo(for accelerometer access)- Go 1.22+ (if building from source)
How It Works
- Reads accelerometer data via IOKit HID to detect physical impacts
- Monitors USB, power, battery, and lid state via IOKit
- Monitors WiFi and Headphone connections using
networksetupandCoreAudio - Monitors AI IDE activity (Kiro, Cursor, Windsurf) for code generation completion
- Maintains a 3-axis mood engine (happiness, energy, trust)
- Mood persists to
~/.moody/state.jsonâ your MacBook remembers - Selects personality-appropriate responses based on current mood
- Speaks the response aloud using macOS Text-to-Speech (TTS) with mood-specific voices
The Mood System
Your MacBook's mood shifts with every event:
| Mood | Trigger | Personality |
|---|---|---|
| đ Happy | Charged, USB in | Cheerful, friendly |
| đ¤ Grumpy | Slapped, charger removed | Sarcastic, snippy |
| đ° Anxious | Battery low, WiFi lost | Panicky, desperate |
| đ Dramatic | Multiple negative events | Over-the-top theatrical |
| đ Dead Inside | Sustained abuse | Nihilistic, apathetic |
Voice Packs
# List installed packs
moody --packs
# Use NSFW pack
sudo moody --spicy
Built-in packs:
en_defaultâ Passive-aggressive office coworker (SFW)en_spicyâ Your MacBook is... very friendly (NSFW đ)
Options
| Flag | Description |
|---|---|
--spicy | Enable NSFW voice pack |
--pack <NAME> | Use specific voice pack |
--dashboard | Show live TUI mood dashboard |
--mute | Track mood without responses |
--silent | Disable TTS audio (text output only) |
--fast | Faster polling, shorter cooldown |
--min-amplitude <F> | Accelerometer sensitivity (default: 0.05) |
--cooldown <MS> | Min ms between responses (default: 750) |
--no-accel | Disable accelerometer |
--no-usb | Disable USB sensor |
--no-power | Disable power sensor |
--no-lid | Disable lid sensor |
--no-wifi | Disable WiFi sensor |
--no-headphones | Disable headphone sensor |
--no-ai | Disable AI IDE monitoring |
--verbose | Log all events |
--list-sensors | Show available sensors |
--packs | List voice packs |
AI IDE Integration
Moody can notify you when your AI coding assistant finishes generating code!
Supported IDEs:
- Kiro - Automatically detected
- Cursor - Coming soon
- Windsurf - Coming soon
When AI finishes generating code, your Mac celebrates (or complains, depending on its mood).
Related Projects:
- ai-done-hooks - Simple notification configs
- ai-done - Standalone menu bar app
Contributing
Contributions welcome! Especially:
- More voice packs (languages, personalities)
- More AI IDE integrations (Cursor, Windsurf)
- Gordon Ramsay voice pack
- HAL 9000 voice pack
License
MIT