Skip to content

Instantly share code, notes, and snippets.

@anoobbava
Forked from danielcgold/post-merge
Created November 17, 2017 01:21
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save anoobbava/807422edd6b89d19c3910164aff2e8e4 to your computer and use it in GitHub Desktop.
Save anoobbava/807422edd6b89d19c3910164aff2e8e4 to your computer and use it in GitHub Desktop.
#/usr/bin/env bash
# MIT © Sindre Sorhus - sindresorhus.com
# git hook to run a command after `git pull` if a specified file was changed
# Run `chmod +x post-merge` to make it executable then put it into `.git/hooks/`.
changed_files="$(git diff-tree -r --name-only --no-commit-id ORIG_HEAD HEAD)"
check_run() {
echo "$changed_files" | grep --quiet "$1" && eval "$2"
}
check_css() {
echo "$changed_files" | grep --quiet ".*\.sass" || grep --quiet ".*\.scss" && eval "$1"
}
# Example usage
# In this example it's used to run `npm install` if package.json changed and `bower install` if `bower.json` changed.
check_run package.json "npm install"
check_run bower.json "bower install"
# Compile CSS
check_css "CHANGE TO CMD LINE WAY TO COMPILE CSS"
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment