MKSH_IMAGE=mobylinux/mksh:b784b685b2c39b9bed4d58a989d06d8f0281b87c@sha256:b3ca9febef294d002894b91e0ce0f794235db73a3024be3cae16d34022913de3 MKSH_BINARY=bin/mksh SH_BINARY=bin/sh CACERT_IMAGE=mobylinux/ca-certificates:e091a05fbf7c5e16f18b23602febd45dd690ba2f@sha256:a4e217ab2036bc128dc57a639a25fd285dbd68c47f9a46a91f1a9afab2bab3d3 CACERT_FILE=etc/ssl/certs/ca-certificates.crt TEST_SCRIPT=bin/test.sh MOBY_WHALE=etc/moby .PHONY: tag push clean container default: push $(MKSH_BINARY): mkdir -p $(dir $@) docker run --rm --net=none $(MKSH_IMAGE) tar cf - $@ | tar xf - $(SH_BINARY): $(MKSH_BINARY) mv $(MKSH_BINARY) $(SH_BINARY) $(CACERT_FILE): mkdir -p $(dir $@) docker run --rm --net=none $(CACERT_IMAGE) tar cf - $@ | tar xf - SHA_IMAGE=alpine:3.5@sha256:dfbd4a3a8ebca874ebd2474f044a0b33600d4523d03b0df76e5c5986cb02d7e8 IMAGE=test DIRS=dev proc sys $(DIRS): mkdir -p $@ DEPS=$(DIRS) $(SH_BINARY) $(CACERT_FILE) $(TEST_SCRIPT) $(MOBY_WHALE) container: Dockerfile $(DEPS) tar cf - $^ | docker build --no-cache -t $(IMAGE):build - hash: Dockerfile $(DEPS) find $^ -type f | xargs cat | docker run --rm -i $(SHA_IMAGE) sha1sum - | sed 's/ .*//' > hash push: hash container docker pull mobylinux/$(IMAGE):$(shell cat hash) || \ (docker tag $(IMAGE):build mobylinux/$(IMAGE):$(shell cat hash) && \ docker push mobylinux/$(IMAGE):$(shell cat hash)) docker rmi $(IMAGE):build rm -f hash tag: hash container docker pull mobylinux/$(IMAGE):$(shell cat hash) || \ docker tag $(IMAGE):build mobylinux/$(IMAGE):$(shell cat hash) docker rmi $(IMAGE):build rm -f hash clean: rm -rf hash $(DIRS) $(MKSH_BINARY) etc/ssl .DELETE_ON_ERROR: