Skip to content

dinakars777/moody

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

45 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

moody 🫠

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

Interactive demo

Moody animated dashboard 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

Using Homebrew:

brew install dinakars777/tap/moody

Developer build from source:

go install github.com/dinakars777/moody@latest
sudo cp "$(go env GOPATH)/bin/moody" /usr/local/bin/moody

Release builds report the tagged version. Source builds may report dev unless you build with -ldflags "-X main.version=<version>".

Maintainers: see docs/releasing.md for the tag release flow.

Usage

# Start moody (SFW mode)
sudo moody

# NSFW mode 😏
sudo moody --spicy

# Show live animated mood dashboard
sudo moody --dashboard

# List available sensors
sudo moody --list-sensors

# Explain sensor compatibility and fixes
moody doctor
moody doctor --json

# 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.26.1+ (if building from source)

See docs/compatibility.md for the sensor support matrix.

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 external display changes
  5. Monitors AI IDE activity (Kiro) for code generation completion
  6. Maintains a 3-axis mood engine (happiness, energy, trust)
  7. Mood persists to ~/.moody/state.json β€” your MacBook remembers
  8. Selects personality-appropriate responses based on current mood
  9. 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

# Validate a local community pack
moody pack validate ./my-pack

# Use NSFW pack
sudo moody --spicy

Built-in packs:

  • en_default β€” Passive-aggressive office coworker (SFW)
  • en_spicy β€” Your MacBook is... very friendly (NSFW πŸ”ž)
  • ja_spicy β€” Anime-inspired Japanese pack (NSFW πŸ”ž)
  • hi_default β€” Hindi default pack (SFW)
  • hi_spicy β€” Hindi spicy pack (NSFW πŸ”ž)
  • en_pirate β€” Pirate speak pack (SFW)
  • en_dramatic β€” Overly Dramatic pack (SFW)

Options

Flag Description
--spicy Enable NSFW voice pack
--pack <NAME> Use specific voice pack
--dashboard Show live animated 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-display Disable external display sensor
--no-ai Disable AI IDE monitoring
--verbose Log all events
--list-sensors Show available sensors
--json Print JSON with --list-sensors
--packs List voice packs
--version Print version

Diagnostics

moody doctor
moody doctor --json

doctor reports OS, architecture, root status, and per-sensor support details. If a sensor cannot run, the report includes a reason and suggested fix.

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

When adding a built-in personality, update the interactive demo in docs/ at the same time.

Voice pack authors can start with docs/voice-pack-authoring.md. Please read CONTRIBUTING.md before opening a PR.

Privacy

Moody runs locally and does not send telemetry. See docs/privacy.md.

License

MIT

About

🫠 Your MacBook has feelings. Every hardware event triggers a personality response.

Topics

Resources

License

Contributing

Stars

Watchers

Forks

Packages

 
 
 

Contributors