๐Ÿ“ฆ f / guardian

Guardian watches over your files and run assigned tasks.

โ˜… 279 stars โ‘‚ 24 forks ๐Ÿ‘ 279 watching โš–๏ธ MIT License
๐Ÿ“ฅ Clone https://github.com/f/guardian.git
HTTPS git clone https://github.com/f/guardian.git
SSH git clone git@github.com:f/guardian.git
CLI gh repo clone f/guardian
Loading files...
๐Ÿ“„ README.md

๐Ÿ’‚ Guardian.cr

Guardian watches over your files and runs assigned tasks.

Guardian

Installation

OS X

brew tap f/guardian
brew install guardian

Arch Linux

Guardian is availabe as a package from the Arch User Repository called guardian-git

From Source

git clone https://github.com/f/guardian.git && cd guardian
crystal build src/guardian.cr --release

Quickstart

Crystal Libs

Guardian works seamless with Crystal Projects. It automatically binds itself to library you use.

$ crystal init lib yourlib
$ cd yourlib
$ guardian --init
Created guardian.yml of ./src/yourlib.cr

Non-Crystal Libs

You can use Guardian for other projects.

$ guardian --init
Created guardian.yml

Usage

$ guardian --init

It will create a guardian.yml file to use by Guardian.

guardian.yml

guardian.yml is a simple YAML file.

Simply it has YAML documents with seperated by --- line and each document has files and run keys.

files key needs a glob pattern, and run is a shell command what to run.

files: ./**/*.cr
run: crystal build ./src/guardian.cr
---
files: ./shard.yml
run: shards install

%file% Variable

Guardian replaces %file% variable in commands with the changed file.

files: ./**/*.txt
run: echo "%file% is changed"

Think you have a hello.txt in your directory, and Guardian will run echo "hello.txt is changed" command when it's changed.

Running Guardian

$ guardian
๐Ÿ’‚ Guardian is on duty!

Contributing

  • Fork it ( https://github.com/f/guardian/fork )
  • Create your feature branch (git checkout -b my-new-feature)
  • Commit your changes (git commit -am 'Add some feature')
  • Push to the branch (git push origin my-new-feature)
  • Create a new Pull Request

Contributors

  • f Fatih Kadir Akฤฑn - creator, maintainer