Add support for an info version of the user manual
These patches use docbook2x in order to create an info version of the git user manual. No existing Makefile targets (including "all") are touched, so you need to explicitly say make info sudo make install-info to get git.info created and installed. If the info target directory does not already contain a "dir" file, no directory entry is created. This facilitates $(DESTDIR)-based installations. The same could be achieved with sudo make INSTALL_INFO=: install-info explicitly. perl is used for patching up sub-par file and directory information in the Texinfo file. It would be cleaner to place the respective info straight into user-manual.txt or the conversion configurations, but I find myself unable to find out how to do this with Asciidoc/Texinfo. Signed-off-by: David Kastrup <dak@gnu.org>
This commit is contained in:
parent
fa548703d1
commit
4739809cd0
@ -44,6 +44,11 @@ INSTALL?=install
|
|||||||
RM ?= rm -f
|
RM ?= rm -f
|
||||||
DOC_REF = origin/man
|
DOC_REF = origin/man
|
||||||
|
|
||||||
|
infodir?=$(prefix)/share/info
|
||||||
|
MAKEINFO=makeinfo
|
||||||
|
INSTALL_INFO=install-info
|
||||||
|
DOCBOOK2X_TEXI=docbook2x-texi
|
||||||
|
|
||||||
-include ../config.mak.autogen
|
-include ../config.mak.autogen
|
||||||
-include ../config.mak
|
-include ../config.mak
|
||||||
|
|
||||||
@ -67,6 +72,8 @@ man1: $(DOC_MAN1)
|
|||||||
man5: $(DOC_MAN5)
|
man5: $(DOC_MAN5)
|
||||||
man7: $(DOC_MAN7)
|
man7: $(DOC_MAN7)
|
||||||
|
|
||||||
|
info: git.info
|
||||||
|
|
||||||
install: man
|
install: man
|
||||||
$(INSTALL) -d -m755 $(DESTDIR)$(man1dir)
|
$(INSTALL) -d -m755 $(DESTDIR)$(man1dir)
|
||||||
$(INSTALL) -d -m755 $(DESTDIR)$(man5dir)
|
$(INSTALL) -d -m755 $(DESTDIR)$(man5dir)
|
||||||
@ -75,6 +82,14 @@ install: man
|
|||||||
$(INSTALL) -m644 $(DOC_MAN5) $(DESTDIR)$(man5dir)
|
$(INSTALL) -m644 $(DOC_MAN5) $(DESTDIR)$(man5dir)
|
||||||
$(INSTALL) -m644 $(DOC_MAN7) $(DESTDIR)$(man7dir)
|
$(INSTALL) -m644 $(DOC_MAN7) $(DESTDIR)$(man7dir)
|
||||||
|
|
||||||
|
install-info: info
|
||||||
|
$(INSTALL) -d -m755 $(DESTDIR)$(infodir)
|
||||||
|
$(INSTALL) -m644 git.info $(DESTDIR)$(infodir)
|
||||||
|
if test -r $(DESTDIR)$(infodir)/dir; then \
|
||||||
|
$(INSTALL_INFO) --info-dir=$(DESTDIR)$(infodir) git.info ;\
|
||||||
|
else \
|
||||||
|
echo "No directory found in $(DESTDIR)$(infodir)" >&2 ; \
|
||||||
|
fi
|
||||||
|
|
||||||
../GIT-VERSION-FILE: .FORCE-GIT-VERSION-FILE
|
../GIT-VERSION-FILE: .FORCE-GIT-VERSION-FILE
|
||||||
$(MAKE) -C ../ GIT-VERSION-FILE
|
$(MAKE) -C ../ GIT-VERSION-FILE
|
||||||
@ -110,7 +125,7 @@ cmd-list.made: cmd-list.perl $(MAN1_TXT)
|
|||||||
git.7 git.html: git.txt core-intro.txt
|
git.7 git.html: git.txt core-intro.txt
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
$(RM) *.xml *.xml+ *.html *.html+ *.1 *.5 *.7 howto-index.txt howto/*.html doc.dep
|
$(RM) *.xml *.xml+ *.html *.html+ *.1 *.5 *.7 *.texi *.texi+ howto-index.txt howto/*.html doc.dep
|
||||||
$(RM) $(cmds_txt) *.made
|
$(RM) $(cmds_txt) *.made
|
||||||
|
|
||||||
%.html : %.txt
|
%.html : %.txt
|
||||||
@ -138,6 +153,13 @@ XSLTOPTS = --xinclude --stringparam html.stylesheet docbook-xsl.css
|
|||||||
user-manual.html: user-manual.xml
|
user-manual.html: user-manual.xml
|
||||||
xsltproc $(XSLTOPTS) -o $@ $(XSLT) $<
|
xsltproc $(XSLTOPTS) -o $@ $(XSLT) $<
|
||||||
|
|
||||||
|
git.info: user-manual.xml
|
||||||
|
$(RM) $@ $*.texi $*.texi+
|
||||||
|
$(DOCBOOK2X_TEXI) user-manual.xml --to-stdout >$*.texi+
|
||||||
|
perl fix-texi.perl <$*.texi+ >$*.texi
|
||||||
|
$(MAKEINFO) --no-split $*.texi
|
||||||
|
$(RM) $*.texi $*.texi+
|
||||||
|
|
||||||
howto-index.txt: howto-index.sh $(wildcard howto/*.txt)
|
howto-index.txt: howto-index.sh $(wildcard howto/*.txt)
|
||||||
$(RM) $@+ $@
|
$(RM) $@+ $@
|
||||||
sh ./howto-index.sh $(wildcard howto/*.txt) >$@+
|
sh ./howto-index.sh $(wildcard howto/*.txt) >$@+
|
||||||
|
15
Documentation/fix-texi.perl
Executable file
15
Documentation/fix-texi.perl
Executable file
@ -0,0 +1,15 @@
|
|||||||
|
#!/usr/bin/perl -w
|
||||||
|
|
||||||
|
while (<>) {
|
||||||
|
if (/^\@setfilename/) {
|
||||||
|
$_ = "\@setfilename git.info\n";
|
||||||
|
} elsif (/^\@direntry/) {
|
||||||
|
print '@dircategory Development
|
||||||
|
@direntry
|
||||||
|
* Git: (git). A fast distributed revision control system
|
||||||
|
@end direntry
|
||||||
|
'; }
|
||||||
|
unless (/^\@direntry/../^\@end direntry/) {
|
||||||
|
print;
|
||||||
|
}
|
||||||
|
}
|
6
Makefile
6
Makefile
@ -913,6 +913,9 @@ perl/Makefile: perl/Git.pm perl/Makefile.PL GIT-CFLAGS
|
|||||||
doc:
|
doc:
|
||||||
$(MAKE) -C Documentation all
|
$(MAKE) -C Documentation all
|
||||||
|
|
||||||
|
info:
|
||||||
|
$(MAKE) -C Documentation info
|
||||||
|
|
||||||
TAGS:
|
TAGS:
|
||||||
$(RM) TAGS
|
$(RM) TAGS
|
||||||
$(FIND) . -name '*.[hcS]' -print | xargs etags -a
|
$(FIND) . -name '*.[hcS]' -print | xargs etags -a
|
||||||
@ -1005,6 +1008,9 @@ endif
|
|||||||
install-doc:
|
install-doc:
|
||||||
$(MAKE) -C Documentation install
|
$(MAKE) -C Documentation install
|
||||||
|
|
||||||
|
install-info:
|
||||||
|
$(MAKE) -C Documentation install-info
|
||||||
|
|
||||||
quick-install-doc:
|
quick-install-doc:
|
||||||
$(MAKE) -C Documentation quick-install
|
$(MAKE) -C Documentation quick-install
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user