# Licensed under MIT. # Copyright (2016) by Kevin van Zonneveld https://twitter.com/kvz # # https://www.npmjs.com/package/fakefile # # Please do not edit this file directly, but propose changed upstream instead: # https://github.com/kvz/fakefile/blob/master/Makefile # # This Makefile offers convience shortcuts into any Node.js project that utilizes npm scripts. # It functions as a wrapper around the actual listed in `package.json` # So instead of typing: # # $ npm script build:assets # # you could also type: # # $ make build-assets # # Notice that colons (:) are replaced by dashes for Makefile compatibility. # # The benefits of this wrapper are: # # - You get to keep the the scripts package.json, which is more portable # (Makefiles & Windows are harder to mix) # - Offer a polite way into the project for developers coming from different # languages (npm scripts is obviously very Node centric) # - Profit from better autocomplete (make ) than npm currently offers. # OSX users will have to install bash-completion # (http://davidalger.com/development/bash-completion-on-os-x-with-brew/) ifeq ($(shell test -e ./yarn.lock && echo -n yes),yes) RUNNER=yarn INSTALLER=yarn install else RUNNER=npm run INSTALLER=npm install endif define npm_script_targets TARGETS := $(shell \ node -e 'for (var k in require("./package.json").scripts) {console.log(k.replace(/:/g, "-"));}' | grep -v -E "^install$$" ) $$(TARGETS): $(RUNNER) $(shell \ node -e 'for (var k in require("./package.json").scripts) {console.log(k.replace(/:/g, "-"), k);}' | grep -E "^$(MAKECMDGOALS)\s" | head -n1 | awk '{print $$2}' ) .PHONY: $$(TARGETS) endef $(eval $(call npm_script_targets)) # These npm run scripts are available, without needing to be mentioned in `package.json` install: $(INSTALLER)