3 # This handles man pages with po4a. We convert to the respective
4 # output in the source directory then copy over to the final dest. This
5 # means po4a is only needed if compiling from bzr
8 # $(LC) - The language code of the translation
10 # See defaults.mak for information about LOCAL
12 # generate a list of accepted man page translations
13 SOURCE
= $(patsubst %.xml
,%,$(wildcard *.
$(LC
).?.xml
))
14 INCLUDES
= apt.ent apt-verbatim.ent
18 # Do not use XMLTO, build the manpages directly with XSLTPROC
21 STYLESHEET
=manpage-style.xsl
23 LOCAL
:= po4a-manpage-
$(firstword $(SOURCE
))
24 $(LOCAL
)-LIST
:= $(SOURCE
)
26 # Install generation hooks
27 manpages
: $($(LOCAL
)-LIST
)
29 veryclean
: veryclean
/$(LOCAL
)
31 apt-verbatim.ent
: ..
/apt-verbatim.ent
32 cp ..
/apt-verbatim.ent .
34 manpage-style.xsl
: ..
/manpage-style.xsl
35 sed
"/<!-- LANGUAGE -->/ i\
36 <xsl:param name=\"l10n.gentext.default.language\" select=\"'$(LC)'\" />" ..
/manpage-style.xsl
> manpage-style.xsl
38 $($(LOCAL
)-LIST
) :: % : %.xml
$(STYLESHEET
) $(INCLUDES
)
39 echo Creating man page
$@
40 $(XSLTPROC
) -o
$@
$(STYLESHEET
) $< || exit
200 # why xsltproc doesn't respect the -o flag here???
41 test -f
$(subst .
$(LC
),,$@
) || echo
'FIXME: xsltproc respects the -o flag now, workaround can be removed'
42 mv
-f
$(subst .
$(LC
),,$@
) $@
45 .PHONY
: clean/$(LOCAL
) veryclean
/$(LOCAL
)
47 rm -f
$($(@F
)-LIST
) apt.ent apt-verbatim.ent
49 # we are nuking the directory we are working in as it is auto-generated
50 rm -rf
$(shell readlink
-f .
)
55 # take care of the rest
56 SOURCE
:= $(SOURCE
) $(wildcard apt.
$(LC
).8)
60 # Strip from the source list any man pages we dont have compiled already
61 SOURCE
:= $(wildcard $(SOURCE
))
64 # Chain to the manpage rule
65 ifneq ($(words $(SOURCE
)),0)
69 # Debian Doc SGML Documents
70 SOURCE
:= $(wildcard *.
$(LC
).sgml
)
71 DEBIANDOC_HTML_OPTIONS
=-l
$(LC
).UTF-8
72 include $(DEBIANDOC_H
)