X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=dgit.git;a=blobdiff_plain;f=Makefile;h=21ccc1b79765fb0fa40856b3bcd8613d3cdc1de3;hp=c90e4200e1dd27c7f1a0a4a4889f1fc4874860ac;hb=77f1c1c558d5492e70c6121a6a8cda3f658cd9ca;hpb=63e1280c70d6a63a9744010c7ef690c14d95dd29 diff --git a/Makefile b/Makefile index c90e4200..21ccc1b7 100644 --- a/Makefile +++ b/Makefile @@ -1,7 +1,7 @@ # dgit # Integration between git and Debian-style archives # -# Copyright (C)2013-2015 Ian Jackson +# Copyright (C)2013-2016 Ian Jackson # # 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 @@ -27,27 +27,53 @@ bindir=$(prefix)/bin mandir=$(prefix)/share/man perldir=$(prefix)/share/perl5 man1dir=$(mandir)/man1 +man5dir=$(mandir)/man5 man7dir=$(mandir)/man7 infraexamplesdir=$(prefix)/share/doc/dgit-infrastructure/examples txtdocdir=$(prefix)/share/doc/dgit +absurddir=$(prefix)/share/dgit/absurd + +PROGRAMS=dgit dgit-badcommit-fixup git-debrebase +MAN1PAGES=dgit.1 \ + git-debrebase.1 + +MAN5PAGES=git-debrebase.5 + +MAN7PAGES=dgit.7 \ + dgit-user.7 dgit-nmu-simple.7 \ + dgit-maint-native.7 \ + dgit-maint-merge.7 dgit-maint-gbp.7 \ + dgit-sponsorship.7 -PROGRAMS=dgit -MAN1PAGES=dgit.1 -MAN7PAGES=dgit.7 TXTDOCS=README.dsc-import -PERLMODULES=Debian/Dgit.pm +PERLMODULES=Debian/Dgit.pm Debian/Dgit/ExitStatus.pm +ABSURDITIES=git INFRA_PROGRAMS=dgit-repos-server dgit-ssh-dispatch \ dgit-repos-policy-debian dgit-repos-admin-debian \ dgit-repos-policy-trusting dgit-mirror-rsync INFRA_EXAMPLES=get-dm-txt ssh-wrap drs-cron-wrap get-suites -INFRA_PERLMODULES=Debian/Dgit/Policy/Debian.pm +INFRA_PERLMODULES= \ + Debian/Dgit.pm \ + Debian/Dgit/Infra.pm \ + Debian/Dgit/Policy/Debian.pm + +MANPAGES=$(MAN1PAGES) $(MAN5PAGES) $(MAN7PAGES) + +all: $(MANPAGES) $(addprefix substituted/,$(PROGRAMS)) -all: +substituted/%: % + mkdir -p substituted + perl -pe 's{\bundef\b}{'\''$(absurddir)'\''} if m/###substituted###/' \ + <$< >$@ -install: installdirs - $(INSTALL_PROGRAM) $(PROGRAMS) $(DESTDIR)$(bindir) +install: installdirs all + $(INSTALL_PROGRAM) $(addprefix substituted/,$(PROGRAMS)) \ + $(DESTDIR)$(bindir) + $(INSTALL_PROGRAM) $(addprefix absurd/,$(ABSURDITIES)) \ + $(DESTDIR)$(absurddir) $(INSTALL_DATA) $(MAN1PAGES) $(DESTDIR)$(man1dir) + $(INSTALL_DATA) $(MAN5PAGES) $(DESTDIR)$(man5dir) $(INSTALL_DATA) $(MAN7PAGES) $(DESTDIR)$(man7dir) $(INSTALL_DATA) $(TXTDOCS) $(DESTDIR)$(txtdocdir) set -e; for m in $(PERLMODULES); do \ @@ -56,8 +82,9 @@ install: installdirs installdirs: $(INSTALL_DIR) $(DESTDIR)$(bindir) \ - $(DESTDIR)$(man1dir) $(DESTDIR)$(man7dir) \ - $(DESTDIR)$(txtdocdir) \ + $(DESTDIR)$(man1dir) $(DESTDIR)$(man5dir) \ + $(DESTDIR)$(man7dir) \ + $(DESTDIR)$(txtdocdir) $(DESTDIR)$(absurddir) \ $(addprefix $(DESTDIR)$(perldir)/, $(dir $(PERLMODULES))) install-infra: installdirs-infra @@ -76,4 +103,20 @@ installdirs-infra: check installcheck: clean distclean mostlyclean maintainer-clean: - rm -rf tests/tmp + rm -rf tests/tmp substituted + set -e; for m in $(MANPAGES); do \ + test -e $$m.pod && rm -f $$m; \ + done + +%.7: %.7.pod + pod2man --section=7 --date="Debian Project" --center="dgit" \ + --name=$(subst .7,,$@) \ + $^ $@ + +git-debrebase.%: git-debrebase.%.pod + pod2man --section=$* --date="Debian Project" --center="git-debrebase" \ + --name=$(subst .$*,,$@) \ + $^ $@ + +%.view: % + man -l $*