_ _ _ _
| | | | | | |
_ __ _ _| | |________ ____ _| |_ ___| |__
| '_ \| | | | | |______\ \ /\ / / _` | __/ __| '_ \
| |_) | |_| | | | \ V V / (_| | || (__| | | |
| .__/ \__,_|_|_| \_/\_/ \__,_|\__\___|_| |_|
| |
|_|
A hobbyist-grade tool that watches a git repository for changes and runs a specified command when changes are detected.
Your friendly neighborhood Git repository watchdog! 🐕 Guards your watch, your time, avoids wasting it, get it? No? Never mind. I am just a dad. It's muscle memory at this point!
How it started: 🔄
git pull
&&./run.sh
&& CTRL/CMD+C &&git pull
&&./run.sh
&& CTRL/CMD+C && ♾️... 😵How it's going:
pull-watch -- ./run.sh
- 🕒 Configurable poll interval (because sometimes you need a coffee break)
- 🎯 Graceful process management (no rough handling here!)
- 📁 Support for different git directories (home is where your .git is)
- 📢 Smart logging levels (quiet, normal, and verbose - you choose how chatty it gets!)
- 🛡️ Proper signal handling (catches signals like a pro)
- ⏱️ Context-aware git operations with timeouts (patience is a virtue, but timeouts are better)
- 🔄 Run on start option (for the eager beavers)
- ⌚ Optional timestamps in logs (when you need to know when things happened)
Quick and easy - just like ordering pizza!
go install github.com/ship-digital/pull-watch@latest
brew tap ship-digital/tap
brew install pull-watch
choco install pull-watch
Usage: pull-watch [options] -- <command>
Watch git repository for remote changes and run commands.
It's like: 'git pull && <command>' but with polling and automatic process management.
Options:
-git-dir string
Git repository directory (default ".")
-graceful
Try graceful stop before force kill
-interval duration
Poll interval (e.g. 15s, 1m) (default 15s)
-quiet
Show only errors and warnings
-run-on-start
Run command on startup regardless of git state
-stop-timeout duration
Timeout for graceful stop before force kill (default 5s)
-timestamp
Show timestamps in logs
-verbose
Enable verbose logging
-version
Show version information
Keep your server fresh and up-to-date!
pull-watch -- go run main.go
For when you want to keep an eye on things from a distance...
pull-watch -git-dir /path/to/repo -interval 1m -- npm start
The "no time for chitchat" approach
pull-watch -- node server.js
For the gentler souls among us
pull-watch -graceful -stop-timeout 10s -- ./my-server
# Default mode - shows important info
pull-watch -- npm start
# Quiet mode - shows only errors and warnings
pull-watch -quiet -- npm start
# Verbose mode - shows all the details
pull-watch -verbose -- npm start
Made with ❤️ by @deblasis for developers who appreciate a touch of automation in their lives.