# Valid book options are a4paper, a5paper, b5paper, letterpaper,
# legalpaper, landscape, 11pt, 12pt, oneside, twocolumn, notitlepage,
# titlepage, openany, draft, fleqn, leqno
+# -P latex.class.options=a5paper
DBLATEX = dblatex \
- -P latex.class.options=a5paper \
- -T db2latex \
- --backend=xetex \
- --param lingua=nb \
+ -T simple \
+ -b xetex \
+ -r data/dblatex-postprocess \
+ --indexstyle=myindexstyle.ist \
+ --xsl-user=data/dblatex-endnotes.xsl \
--xsl-user=data/user_param.xsl \
--xsl-user=data/xetex_param.xsl \
-p data/pdf.xsl
+
DBTOEPUB = dbtoepub
-IMAGES = images/cc.png
+IMAGES = images/cc.png images/pattern-modern-media-ownership.png images/tom-the-dancing-bug.png
+
+XSLT = \
+ data/user_param.xsl
+
+DB_XSLT = \
+ data/dblatex-endnotes.xsl \
+ data/xetex_param.xsl
+
+HTML_XSLT = \
+ $(XSLT) \
+ data/html.xsl \
+ data/stylesheet-html.xsl
-XSLTS = \
- data/user_param.xsl \
- data/xetex_param.xsl \
- data/pdf.xsl
+PDF_XSLT = \
+ $(DB_XSLT) \
+ $(XSLT) \
+ data/lulu.xsl \
+ data/licentia.xsl \
+ data/pdf.xsl \
+ data/stylesheet-fo.xsl
-all: lint lint.nb html epub pdf
+
+all: lint lint.nb html epub pdf mobi
freeculture.nb.po: freeculture.pot
po4a --no-translations --msgmerge-opt --no-location po4a.cfg
freeculture.nb.xml: freeculture.nb.po freeculture.xml
po4a --translate-only freeculture.nb.xml po4a.cfg
+freeculture.es_419.po: freeculture.pot
+ po4a --no-translations --msgmerge-opt --no-location po4a.cfg
+freeculture.es_419.xml: freeculture.es_419.po freeculture.xml
+ po4a --translate-only freeculture.es_419.xml po4a.cfg
+
pdf: freeculture.nb.pdf freeculture.pdf
-epub: freeculture.nb.epub
-html: freeculture.html freeculture.nb.html
-
-%.pdf: %.xml $(IMAGES) $(XSLTS)
- $(DBLATEX) $<
-
-# Alternative processing path to dblatex is to use xmlto using fop to
-# create PDF like this. The PDF output (visual design) is better, but
-# the PDF index and footnote handling is worse and images are missing.
-# xmlto --noautosize --stringparam paper.type=A5 \
-# --with-fop pdf $<
-
-# Third alternative is to use xsltproc and fop directly, as
-# recommended by <URL: http://www.sagehill.net/docbookxsl/index.html > .
-# This include images, but the index and footnote handling is
-# broken.
-# xsltproc \
-# --output myfile.fo \
-# --stringparam paper.type A5 \
-# /usr/share/xml/docbook/stylesheet/docbook-xsl/fo/docbook.xsl \
-# $<
-# fop -fo myfile.fo -pdf $@
-
-%.html: %.xml $(IMAGES)
- xmlto html-nochunks $<
+epub: freeculture.nb.epub freeculture.epub
+mobi: freeculture.nb.mobi freeculture.mobi
+html: freeculture.nb.html freeculture.html
+
+%.pdf: %.xml $(IMAGES) $(PDF_XSLT) Makefile
+# Possible pipelines:
+#
+# dblatex:
+# This converts the docbook content to latex and leave it to latex
+# to format it. Index ranges are broken.
+#
+# xmlto:
+# Alternative processing path to dblatex is to use xmlto using fop
+# to create PDF like this. The PDF output (visual design) is
+# better, but the footnote handling is worse and images are missing.
+#
+# docbook-xsl:
+# Third alternative is to use xsltproc and fop directly, as
+# recommended by <URL: http://www.sagehill.net/docbookxsl/index.html >.
+# This include images, but the index refs and footnote/endnote handling
+# is broken.
+
+ pipeline=dblatex; \
+ echo "Using $$pipeline pipeline" ; \
+ case "$$pipeline" in \
+ dblatex) \
+ PATH=$(PWD)/bin:$$PATH $(DBLATEX) $< ; \
+ ;; \
+ xmlto) \
+ xmlto --noautosize \
+ -x data/stylesheet-fo.xsl \
+ --with-fop pdf $< ; \
+ ;; \
+ docbook-xsl) \
+ xsltproc \
+ --output $(subst .pdf,.fo,$@) \
+ data/stylesheet-fo.xsl \
+ $< ; \
+ fop -c data/fop-params.xconf -fo $(subst .pdf,.fo,$@) -pdf $@ ; \
+ ;; \
+ esac
+
+pdf-compare: freeculture.xml $(IMAGES)
+ $(DBLATEX) -o freeculture-dblatex.pdf freeculture.xml
+ $(DBLATEX) -T db2latex \-o freeculture-dblatex-db2latex.pdf freeculture.xml
+
+ # plain xmlto fail
+ #xmlto pdf freeculture.xml && mv freeculture.pdf freeculture-xmlto.pdf
+ xmlto --with-fop pdf freeculture.xml && mv freeculture.pdf freeculture-xmlto-fop.pdf
+
+ xsltproc --output freeculture-docbook-xsl.fo \
+ /usr/share/xml/docbook/stylesheet/docbook-xsl/fo/docbook.xsl \
+ freeculture.xml
+ fop -fo freeculture-docbook-xsl.fo -pdf freeculture-docbook-xsl.pdf
+
+%.html: %.xml $(IMAGES) $(HTML_XSLT)
+ xmlto \
+ -x data/stylesheet-html.xsl \
+ html-nochunks \
+ $<
%.txt: %.xml $(IMAGES)
xmlto txt $<
-%.epub: %.xml, $(IMAGES)
- $(DBTOEPUB) $^ $<
+%.epub: %.xml $(IMAGES)
+ $(DBTOEPUB) $<
+
+%.mobi: %.epub
+ ebook-convert $< $@
freeculture.xml:
GET $(url) | gunzip > freeculture.xml
+# <beginpage> workaround can be removed when BTS #684137 is fixed in
+# po4a.
freeculture.pot: freeculture.xml
- po4a-gettextize -f docbook -m $^ > $@.new && mv $@.new $@
+ po4a-gettextize -o nodefault='<beginpage>' -o inline='<beginpage>' \
+ -f docbook -m $^ > $@.new && mv $@.new $@
stats: update-stats progress.png
-update-stats:
+update-stats: freeculture.nb.po lint.nb
( \
printf "%s " $$(date +"%Y-%m-%dT%H%M") ; \
msgfmt -o /dev/null --statistics freeculture.nb.po 2>&1 \
- ) | tee -a stats.txt
+ ) \
+ | sed -e 's/translated messages/oversatte meldinger/' -e 's/fuzzy translations/antatte oversettelser/' -e 's/untranslated messages/oversatte meldinger/' \
+ | tee -a stats.txt
progress.png: stats.txt progress.gnuplot
awk '{print $$1, $$2, $$5, $$8}' < stats.txt > stats.csv
gnuplot progress.gnuplot
images/cc.png: images/cc.svg
inkscape -z -D --export-height=200 -D --export-png=$(shell pwd)/$@ $^
+
+.xcf.png:
+ convert $^ $@
+
+clean:
+ $(RM) *~
+
+distclean: clean
+ $(RM) freeculture-docbook-xsl.pdf \
+ freeculture-docbook-xsl.fo \
+ freeculture-dblatex-db2latex.pdf \
+ freeculture-dblatex.pdf \
+ freeculture-xmlto-fop.pdf
+
+.SUFFIXES: .png .xcf .svg .xml