# Copyright (C) 2010-2022 Daniel Baumann # # SPDX-License-Identifier: GPL-3.0+ # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program. If not, see . SHELL := sh -e PROJECT := progress-linux SOFTWARE := progress-linux VERSION := $(shell cat VERSION.txt) all: build clean: clean-pgp clean-ssh clean-pgp: # clean pgp keyrings rm -f pgp-keys/*/*.gpg rm -f pgp-keys/*.gpg clean-ssh: # clean ssh keyrings rm -f ssh-keys/*.pub build: build-pgp build-ssh build-pgp: pgp-keys/*/*.pub # build pgp keyrings for KEY in $$(ls pgp-keys/*/*.pub); \ do \ OUTPUT="$$(dirname $${KEY})/$$(basename $${KEY} .pub).gpg"; \ echo "Creating $${OUTPUT}..."; \ gpg --output $${OUTPUT} --dearmor $${KEY}; \ done for DIRECTORY in $$(ls -d pgp-keys/*/); \ do \ OUTPUT="pgp-keys/$$(basename $${DIRECTORY}).gpg"; \ echo "Creating $${OUTPUT}..."; \ for KEY in $$(ls $${DIRECTORY}/*.gpg); \ do \ cat $${KEY} >> $${OUTPUT}; \ done; \ done build-ssh: ssh-keys/*/*.pub # build ssh keyrings for DIRECTORY in $$(ls -d ssh-keys/*/); \ do \ OUTPUT="ssh-keys/$$(basename $${DIRECTORY}).pub"; \ echo "Creating $${OUTPUT}..."; \ for KEY in $$(ls $${DIRECTORY}/*.pub); \ do \ cat $${KEY} >> $${OUTPUT}; \ done; \ done test: test-pgp test-ssh test-pgp: pgp-keys/*/*.sig # test pgp keyrings for SIG in $$(ls pgp-keys/*/*.sig); \ do \ echo "Verifying $${SIG}..."; \ gpg --no-default-keyring --keyring /usr/share/keyrings/debian-keyring.gpg --verify $${SIG}; \ done test-ssh: ssh-keys/*/*.sig # test ssh keyrings for SIG in $$(ls ssh-keys/*/*.sig); \ do \ echo "Verifying $${SIG}..."; \ gpg --no-default-keyring --keyring /usr/share/keyrings/debian-keyring.gpg --verify $${SIG}; \ done install: install-doc install-man install-pgp install-ssh install-doc: # install doc mkdir -p $(DESTDIR)/usr/share/doc/$(SOFTWARE) cp *.txt $(DESTDIR)/usr/share/doc/$(SOFTWARE) install-man: # install manpages for SECTION in $$(seq 1 8); \ do \ if ls manpages/*.$${SECTION} > /dev/null 2>&1; \ then \ mkdir -p $(DESTDIR)/usr/share/man/man$${SECTION}; \ cp manpages/*.$${SECTION} $(DESTDIR)/usr/share/man/man$${SECTION}; \ fi; \ done install-pgp: build-pgp # install pgp keyrings mkdir -p $(DESTDIR)/usr/share/$(SOFTWARE)/pgp-keys cp pgp-keys/*.gpg $(DESTDIR)/usr/share/$(SOFTWARE)/pgp-keys install-ssh: build-ssh # install ssh keyrings mkdir -p $(DESTDIR)/usr/share/$(SOFTWARE)/ssh-keys cp ssh-keys/*.pub $(DESTDIR)/usr/share/$(SOFTWARE)/ssh-keys uninstall: uninstall-doc uninstall-man uninstall-pgp uninstall-ssh uninstall-doc: # uninstall doc rm -rf $(DESTDIR)/usr/share/doc/$(SOFTWARE) uninstall-man: # uninstall manpages for SECTION in $$(seq 1 8); \ do \ for FILE in manpages/*.$${SECTION}; \ do \ rm -f $(DESTDIR)/usr/share/man/man$${SECTION}/$$(basename $${FILE}); \ done; \ rmdir --ignore-fail-on-non-empty --parents $(DESTDIR)/usr/share/man/man$${SECTION} || true; \ done uninstall-pgp: # uninstall pgp keyrings rm -rf $(DESTDIR)/usr/share/$(SOFTWARE)/pgp-keys -rmdir --parents $(DESTDIR)/usr/share/$(SOFTWARE) uninstall-ssh: # uninstall ssh keyrings rm -rf $(DESTDIR)/usr/share/$(SOFTWARE)/ssh-keys -rmdir --ignore-fail-on-non-empty --parents $(DESTDIR)/usr/share/$(SOFTWARE) reinstall: clean uninstall build install distclean: clean rm -rf $(SOFTWARE)-$(VERSION) release: distclean git commit -a -s -S -m 'Releasing version $(VERSION).' || true git tag -s -m 'Tagging version $(VERSION).' v$(VERSION) || true mkdir -p $(SOFTWARE)-$(VERSION) find . -mindepth 1 -maxdepth 1 -and -not -name ".git*" -and -not -name debian -and -not -name $(SOFTWARE)-$(VERSION) -exec cp \-a {} $(SOFTWARE)-$(VERSION) \; for FORMAT in xz lzip; \ do \ EXTENSION=$$(echo $${FORMAT} | cut -b-2); \ tar --$${FORMAT} -cf ../$(SOFTWARE)-$(VERSION).tar.$${EXTENSION} $(SOFTWARE)-$(VERSION); \ sha512sum ../$(SOFTWARE)-$(VERSION).tar.$${EXTENSION} > ../$(SOFTWARE)-$(VERSION).tar.$${EXTENSION}.sha512; \ gpg --default-key 0x3E6CA28DAAF8DD14 --armor -b ../$(SOFTWARE)-$(VERSION).tar.$${EXTENSION}; \ mv ../$(SOFTWARE)-$(VERSION).tar.$${EXTENSION}.asc ../$(SOFTWARE)-$(VERSION).tar.$${EXTENSION}.sig; \ done rm -rf $(SOFTWARE)-$(VERSION) upload: scp ../$(SOFTWARE)-$(VERSION).* get.progress-linux.org:/srv/get.progress-linux.org/packages/$(SOFTWARE)/upstream