# Tag b784b685b2c39b9bed4d58a989d06d8f0281b87c MKSH_IMAGE=mobylinux/mksh@sha256:b3ca9febef294d002894b91e0ce0f794235db73a3024be3cae16d34022913de3 MKSH_BINARY=bin/mksh SH_BINARY=bin/sh # Tag: e091a05fbf7c5e16f18b23602febd45dd690ba2f CACERT_IMAGE=mobylinux/ca-certificates@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 - # Tag: alpine:3.5 SHA_IMAGE=alpine@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: