mirror of
https://github.com/prometheus/alertmanager
synced 2025-01-09 07:19:42 +00:00
b3f3ecf803
We generate binaries whenever `make build-all` is run. If they already exist, we only regenerate them if they are outdated. When one makes changes to the front-end and runs the single command `make build-all` on the root level Makefile, the front-end is rebuild accordingly. `make build-all` will use Docker to build the front-end. If someone prefers to install all the dev dependencies on their local machine instead, one can add the `NO_DOCKER=true` flag. For folks that only want to make back-end changes `ui/bindata.go` is checked in, so they do not have to build the front-end. They still use the `make build` command as before.
38 lines
921 B
Makefile
38 lines
921 B
Makefile
ELM_FILES := $(shell find src -iname *.elm)
|
|
DOCKER_IMG :=elm-env
|
|
DOCKER_CMD := docker run --rm -t -v $(PWD):/app -w /app $(DOCKER_IMG)
|
|
TEMPFILE := $(shell mktemp ./elm-XXXXXXXXXX.js)
|
|
|
|
ifeq ($(NO_DOCKER), true)
|
|
DOCKER_CMD=
|
|
endif
|
|
|
|
all: test script.js
|
|
|
|
elm-env:
|
|
@(if [ "$(NO_DOCKER)" != "true" ] ; then \
|
|
echo ">> building elm-env docker image"; \
|
|
docker build -t $(DOCKER_IMG) ../. > /dev/null; \
|
|
fi; )
|
|
|
|
format: elm-env $(ELM_FILES)
|
|
@echo ">> format front-end code"
|
|
@$(DOCKER_CMD) elm-format --yes $(ELM_FILES)
|
|
|
|
test: elm-env
|
|
@$(DOCKER_CMD) elm-format $(ELM_FILES) --validate
|
|
@$(DOCKER_CMD) elm-test
|
|
|
|
dev-server:
|
|
elm-reactor
|
|
|
|
script.js: elm-env format $(ELM_FILES)
|
|
@echo ">> building script.js"
|
|
@$(DOCKER_CMD) elm make src/Main.elm --yes --output $(TEMPFILE)
|
|
@$(DOCKER_CMD) uglifyjs $(TEMPFILE) --compress unused --mangle --output $(@)
|
|
@rm $(TEMPFILE)
|
|
|
|
clean:
|
|
- @rm script.js
|
|
- @docker rmi $(DOCKER_IMG)
|