/trigger

Run a user-defined command on file changes

Primary LanguageShellMIT LicenseMIT

trigger

Usage: trigger COMMAND [FILE...]

trigger runs the given COMMAND every time one of the FILEs is changed. If no FILE argument is given, trigger watches everything in the current directory, recursively.

In the COMMAND string, #1, #2, .. can be used as synonyms for the FILEnames. The helper tg COMMAND FILE ... is a shortcut for trigger 'COMMAND #1' FILE ....

Example usage

Examples

Make

Run make every time one of the files in the current directory changes:

trigger make

Python

Run python main.py every time either main.py or config.py changes:

trigger 'python #1' main.py config.py

By using the tg helper command, this can be shortened to:

tg python main.py config.py

Markdown to PDF

Convert a Markdown document to PDF every time it is changed. Combine this with an auto-reloading PDF-viewer (e.g. okular) to get a live preview:

tg 'pandoc -t latex -o README.pdf' README.md

Less to CSS

Convert a LESS file to CSS:

trigger 'lessc #1 > main.css' main.less

Requirements

trigger is just a simple wrapper around inotifywait. It should be available for most Linux distributions (the package is typically called inotify-tools).

Installation

Keeping in mind that, in principle, you should not copy-and-paste into your shell, something like this should work:

git clone https://github.com/sharkdp/trigger ~/.trigger

echo 'export PATH="$PATH:$HOME/.trigger"' >> .bashrc

Related projects

Also have a look at these projects, to see if they fit your needs better: