#
# Project Home:
# ============
# https://nc110.sourceforge.io
#
# Git:
# ===
# git clone https://git.code.sf.net/p/nc110/git nc110-git
#
url = https://git.code.sf.net/p/nc110/git
repo_name = netcat
pkg_name = netcat
#
# List of tags to be extracted:
# ============================
# hash | tag
# ----------------------------------------+-----
revisions = 5086ba1ade7dd8d8364e62d300aed3130c2f4896:1.10
revisions += 607401678236b608280b291ad849a109b8d9a8f2:1.10.1
git_repo = .git_clone
suffix = tar.xz
versions = $(foreach tag, $(revisions), $(shell echo $(tag) | cut -f 2 -d ':'))
tarballs = $(addsuffix .$(suffix), $(addprefix $(pkg_name)-, $(versions)))
sha1s = $(addsuffix .sha1sum, $(tarballs))
TARGETS = repository_clean
all: $(TARGETS)
.PHONY: downloads_clean repository_clean
$(git_repo):
@echo -e "\n======= Clone $(repo_name).git repository =======\n"
@rm -rf $(repo_name)
@git clone $(url) $(repo_name)
@touch $@
$(tarballs): $(git_repo)
@for revision in $(revisions) ; do \
hash=`echo $$revision | cut -f 1 -d ':'` ; \
version=`echo $$revision | cut -f 2 -d ':'` ; \
if [ ! -f $(pkg_name)-$$version.$(suffix) ]; then \
echo -e "\n======= Creating '$(pkg_name)-$$version.$(suffix)' snapshot =======" ; \
( cd $(repo_name) && \
git archive --format=tar --prefix=$(pkg_name)-$$version/ $$hash | \
xz >../$(pkg_name)-$$version.$(suffix) ) ; \
fi ; \
done
$(sha1s): %.$(suffix).sha1sum : %.$(suffix)
@for tarball in $< ; do \
echo -e "\n======= Calculation the '$$tarball' sha1sum =======" ; \
sha1sum --binary $$tarball > $$tarball.sha1sum ; \
done
repository_clean: $(sha1s)
@echo -e "\n======= Remove cloned $(repo_name).git repository =======\n"
@rm -rf $(git_repo) $(repo_name)
downloads_clean:
@rm -rf $(tarballs) $(sha1s)
@rm -rf $(git_repo) $(repo_name)