📚 moody - Awesome Go Library for Hardware

Go Gopher mascot for moody

Hardware event personality daemon for macOS. Monitors USB, charger, lid, and other hardware events and responds with customizable personalities

đŸˇī¸ Hardware
📂 Hardware
⭐ 0 stars
View on GitHub 🔗

Detailed Description of moody

moody đŸĢ 

Your MacBook has feelings. And it's not afraid to express them.

Demo

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

  1. Reads accelerometer data via IOKit HID to detect physical impacts
  2. Monitors USB, power, battery, and lid state via IOKit
  3. Monitors WiFi and Headphone connections using networksetup and CoreAudio
  4. Monitors AI IDE activity (Kiro, Cursor, Windsurf) for code generation completion
  5. Maintains a 3-axis mood engine (happiness, energy, trust)
  6. Mood persists to ~/.moody/state.json — your MacBook remembers
  7. Selects personality-appropriate responses based on current mood
  8. 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:

MoodTriggerPersonality
😊 HappyCharged, USB inCheerful, friendly
😤 GrumpySlapped, charger removedSarcastic, snippy
😰 AnxiousBattery low, WiFi lostPanicky, desperate
🎭 DramaticMultiple negative eventsOver-the-top theatrical
💀 Dead InsideSustained abuseNihilistic, 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

FlagDescription
--spicyEnable NSFW voice pack
--pack <NAME>Use specific voice pack
--dashboardShow live TUI mood dashboard
--muteTrack mood without responses
--silentDisable TTS audio (text output only)
--fastFaster polling, shorter cooldown
--min-amplitude <F>Accelerometer sensitivity (default: 0.05)
--cooldown <MS>Min ms between responses (default: 750)
--no-accelDisable accelerometer
--no-usbDisable USB sensor
--no-powerDisable power sensor
--no-lidDisable lid sensor
--no-wifiDisable WiFi sensor
--no-headphonesDisable headphone sensor
--no-aiDisable AI IDE monitoring
--verboseLog all events
--list-sensorsShow available sensors
--packsList 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:

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