UNPKG

@olegjs/on-change

Version:

CLI tool to run a command if file has changed since the last time that command was run

49 lines (39 loc) 1.71 kB
# on-change [![Build Status](https://travis-ci.org/olegjs/on-change.svg?branch=master)](https://travis-ci.org/olegjs/on-change) [![Coverage Status](https://coveralls.io/repos/github/olegjs/on-change/badge.svg?branch=master)](https://coveralls.io/github/olegjs/on-change?branch=master) [![dependencies Status](https://david-dm.org/olegjs/on-change/status.svg)](https://david-dm.org/olegjs/on-change) [![devDependencies Status](https://david-dm.org/olegjs/on-change/dev-status.svg)](https://david-dm.org/olegjs/on-change?type=dev) ![GitHub last commit](https://img.shields.io/github/last-commit/olegjs/on-change) CLI tool to run a command if file has changed since the last time that command was run. Forgetting to run `npm i` every time after `git pull` and getting `Error: Cannot find module...`? Add the following to `package.json` to automate this chore. ```json { "scripts": { "prestart": "on-change --file package-lock.json npm ci" } } ``` This CLI tool stores a file checksum in a hidden `sha` file every time it run a given command. Made to automate running `npm ci` after pulling modified `package-lock.json`. ## Install ```sh npm install --save-dev @olegjs/on-change ``` ## Usage ```sh npx @olegjs/on-change --help # Usage: on-file-change --file [file] [command] # # Options: # --help Show help [boolean] # --version Show version number [boolean] # --file, -f Path to file to check for changes [string] [required] # # Examples: # on-file-change --file package-lock.json Reinstall dependencies on changed # npm ci package-lock.json ```