1 <!DOCTYPE html PUBLIC
"-//W3C//DTD XHTML 1.0 Strict//EN"
2 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
3 <html xmlns=
"http://www.w3.org/1999/xhtml" dir=
"ltr">
5 <meta http-equiv=
"Content-Type" content=
"text/html;charset=utf-8" />
6 <title>Petter Reinholdtsen:
2013-
03-
24-docbook-shortstory
</title>
7 <link rel=
"stylesheet" type=
"text/css" media=
"screen" href=
"http://people.skolelinux.org/pere/blog/style.css" />
8 <link rel=
"stylesheet" type=
"text/css" media=
"screen" href=
"http://people.skolelinux.org/pere/blog/vim.css" />
15 <a href=
"http://people.skolelinux.org/pere/blog/">Petter Reinholdtsen
</a>
23 <div class=
"title">2013-
03-
24-docbook-shortstory
</div>
24 <div class=
"date">24th March
2013</div>
25 <div class=
"body"><p>A few days ago, during a discussion in
26 <ahref=
"http://www.efn.no/">EFN
</a> about interesting books to read
27 about copyright and the data retention directive, a suggestion to read
28 the old
1968 short story Kodémus by Tore Åge Bringsværd came up. The
29 text is only available in old paper books, and thus hard to read for
30 the current and future generations. Some of the people participating
31 in the discussion contacted the author, and reported back
2013-
03-
19
32 that he was ok with releasing the short story using a Creative Commons
33 license (CC-BY-NC-ND). The text was quickly scanned and OCR-ed, and
34 we were ready to start on the editing and typesetting.
</p>
36 <p>As I already had some experience formatting text in my project to
37 provide a Norwegian version of the Free Culture book by Lawrence
38 Lessig, I chipped in and set up a
39 <ahref=
"http://www.docbook.org/">DocBook
</a> processing framework to
40 generate a PDF, HTML and EPUB version of the short story. The tools
41 to transform DocBook to different formats are already in my Linux
42 distribution of choice,
<ahref=
"http://www.debian.org/">Debian
</a>, so
43 all I had to do was to use the dblatex, dbtoepub and xmlto tools to do
44 the conversion. After a few days, we decided to replace dblatex with
45 xsltproc/fop (aka docbook-xsl), to get the copyright information to
46 show up in the PDF and to get a nicer
<variablelist
>
49 <p>There were a few challenges, of course. We want to typeset the
50 short story to look like the original, and that require fairly good
51 control over the layout. The original short story have three
52 parts/scenes separated by a single horizontally centred star (*), and
53 the paragraphs do not contain only flowing text, but dialogs and text
54 that started on a new line in the middle of the paragraph.
</p>
56 <p>I initially solved the first challenge by using a paragraph with a
57 single star in it, ie
<para
>*
</para
>. This did not look
58 too good without the centring. The next approach was to create a new
59 preprocessor directive
<?newscene?
>, mapping to "
<hr/
&gr;"
60 for HTML and "
<fo:block
text-align="center"
><fo:leader
61 leader-pattern="rule"
rule-thickness="
0.5pt"/
></fo:block
>"
62 for FO/PDF output (did not try to implement this in dblatex, as we had
63 switched at this time). The HTML XSL file looked like this:
</p>
66 <?xml version='
1.0'?
>
67 <xsl:stylesheet xmlns:
xsl="http://www.w3.org/
1999/XSL/Transform" version='
1.0'
>
68 <xsl:template
match="processing-instruction('newscene')"
>
71 </xsl:stylesheet
>
72 </pre></blockquote></p>
74 <p>And the FO/PDF XSL file looked like this:
</p>
77 <?xml version='
1.0'?
>
78 <xsl:stylesheet xmlns:
xsl="http://www.w3.org/
1999/XSL/Transform" version='
1.0'
>
79 <xsl:template
match="processing-instruction('newscene')"
>
80 <fo:block
text-align="center"
>
81 <fo:leader
leader-pattern="rule"
rule-thickness="
0.5pt"/
>
84 </xsl:stylesheet
>
85 </pre></blockquote></p>
87 <p>Finally, I came across the
<bridgehead
> tag, which seem to be
88 a good fit for the task at hand, and I replaced
<?newscene?
>
89 with
<bridgehead
>*
</bridgehead
>. It isn't centered, but
90 we can fix that with XSL rules if the current visual layout isn't
93 <p>I did not find a good DocBook compliant way to solve the
94 linebreak/paragraph challenge, so I ended up creating a new processor
95 directive
<?linebreak?
>, mapping to
<br/
> in HTML, and
96 <fo:block/
&gr; in FO/PDF. I suspect there are better ways to do
97 this, and welcome ideas and patches on github. The HTML XSL file now
101 <?xml version='
1.0'?
>
102 <xsl:stylesheet xmlns:
xsl="http://www.w3.org/
1999/XSL/Transform" version='
1.0'
>
103 <xsl:template
match="processing-instruction('linebreak)"
>
105 </xsl:template
>
106 </xsl:stylesheet
>
107 </pre></blockquote></p>
109 <p>And the FO/PDF XSL file looked like this:
</p>
112 <?xml version='
1.0'?
>
113 <xsl:stylesheet xmlns:
xsl="http://www.w3.org/
1999/XSL/Transform" version='
1.0'
114 xmlns:
fo="http://www.w3.org/
1999/XSL/Format"
>
115 <xsl:template
match="processing-instruction('linebreak)"
>
117 </xsl:template
>
118 </xsl:stylesheet
>
119 </pre></blockquote></p>
121 <p>One unsolved challenge is our wish to expose different ISBN numbers
122 per publication format, while keeping all of them in some conditional
123 structure in the DocBook source. No idea how to do this, so we ended
124 up listing all the ISBN numbers next to their format in the colophon
127 <p>If you want to check out the finished result, check out the
128 <ahref=
"https://github.com/sickel/kodemus">source repository at
129 github
</a> (
<ahref=
"https://github.com/EFN/kodemus">future/new
153 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2013/01/">January (
11)
</a></li>
155 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2013/02/">February (
9)
</a></li>
157 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2013/03/">March (
7)
</a></li>
164 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2012/01/">January (
7)
</a></li>
166 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2012/02/">February (
10)
</a></li>
168 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2012/03/">March (
17)
</a></li>
170 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2012/04/">April (
12)
</a></li>
172 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2012/05/">May (
12)
</a></li>
174 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2012/06/">June (
20)
</a></li>
176 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2012/07/">July (
17)
</a></li>
178 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2012/08/">August (
6)
</a></li>
180 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2012/09/">September (
9)
</a></li>
182 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2012/10/">October (
17)
</a></li>
184 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2012/11/">November (
10)
</a></li>
186 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2012/12/">December (
7)
</a></li>
193 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2011/01/">January (
16)
</a></li>
195 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2011/02/">February (
6)
</a></li>
197 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2011/03/">March (
6)
</a></li>
199 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2011/04/">April (
7)
</a></li>
201 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2011/05/">May (
3)
</a></li>
203 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2011/06/">June (
2)
</a></li>
205 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2011/07/">July (
7)
</a></li>
207 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2011/08/">August (
6)
</a></li>
209 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2011/09/">September (
4)
</a></li>
211 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2011/10/">October (
2)
</a></li>
213 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2011/11/">November (
3)
</a></li>
215 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2011/12/">December (
1)
</a></li>
222 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2010/01/">January (
2)
</a></li>
224 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2010/02/">February (
1)
</a></li>
226 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2010/03/">March (
3)
</a></li>
228 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2010/04/">April (
3)
</a></li>
230 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2010/05/">May (
9)
</a></li>
232 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2010/06/">June (
14)
</a></li>
234 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2010/07/">July (
12)
</a></li>
236 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2010/08/">August (
13)
</a></li>
238 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2010/09/">September (
7)
</a></li>
240 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2010/10/">October (
9)
</a></li>
242 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2010/11/">November (
13)
</a></li>
244 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2010/12/">December (
12)
</a></li>
251 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2009/01/">January (
8)
</a></li>
253 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2009/02/">February (
8)
</a></li>
255 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2009/03/">March (
12)
</a></li>
257 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2009/04/">April (
10)
</a></li>
259 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2009/05/">May (
9)
</a></li>
261 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2009/06/">June (
3)
</a></li>
263 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2009/07/">July (
4)
</a></li>
265 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2009/08/">August (
3)
</a></li>
267 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2009/09/">September (
1)
</a></li>
269 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2009/10/">October (
2)
</a></li>
271 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2009/11/">November (
3)
</a></li>
273 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2009/12/">December (
3)
</a></li>
280 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2008/11/">November (
5)
</a></li>
282 <li><a href=
"http://people.skolelinux.org/pere/blog/archive/2008/12/">December (
7)
</a></li>
293 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/3d-printer">3d-printer (
13)
</a></li>
295 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/amiga">amiga (
1)
</a></li>
297 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/aros">aros (
1)
</a></li>
299 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/bankid">bankid (
4)
</a></li>
301 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/bitcoin">bitcoin (
6)
</a></li>
303 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/bootsystem">bootsystem (
12)
</a></li>
305 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/bsa">bsa (
2)
</a></li>
307 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/debian">debian (
70)
</a></li>
309 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/debian edu">debian edu (
121)
</a></li>
311 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/digistan">digistan (
10)
</a></li>
313 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/docbook">docbook (
7)
</a></li>
315 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/drivstoffpriser">drivstoffpriser (
4)
</a></li>
317 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/english">english (
183)
</a></li>
319 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/fiksgatami">fiksgatami (
21)
</a></li>
321 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/fildeling">fildeling (
12)
</a></li>
323 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/freeculture">freeculture (
10)
</a></li>
325 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/frikanalen">frikanalen (
11)
</a></li>
327 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/intervju">intervju (
33)
</a></li>
329 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/isenkram">isenkram (
5)
</a></li>
331 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/kart">kart (
18)
</a></li>
333 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/ldap">ldap (
8)
</a></li>
335 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/lenker">lenker (
6)
</a></li>
337 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/ltsp">ltsp (
1)
</a></li>
339 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/multimedia">multimedia (
25)
</a></li>
341 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/norsk">norsk (
226)
</a></li>
343 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/nuug">nuug (
151)
</a></li>
345 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/offentlig innsyn">offentlig innsyn (
7)
</a></li>
347 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/open311">open311 (
2)
</a></li>
349 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/opphavsrett">opphavsrett (
42)
</a></li>
351 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/personvern">personvern (
65)
</a></li>
353 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/raid">raid (
1)
</a></li>
355 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/reprap">reprap (
11)
</a></li>
357 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/rfid">rfid (
2)
</a></li>
359 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/robot">robot (
6)
</a></li>
361 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/rss">rss (
1)
</a></li>
363 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/ruter">ruter (
4)
</a></li>
365 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/scraperwiki">scraperwiki (
2)
</a></li>
367 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/sikkerhet">sikkerhet (
29)
</a></li>
369 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/sitesummary">sitesummary (
4)
</a></li>
371 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/skepsis">skepsis (
4)
</a></li>
373 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/standard">standard (
41)
</a></li>
375 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/stavekontroll">stavekontroll (
3)
</a></li>
377 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/stortinget">stortinget (
6)
</a></li>
379 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/surveillance">surveillance (
15)
</a></li>
381 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/sysadmin">sysadmin (
1)
</a></li>
383 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/valg">valg (
7)
</a></li>
385 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/video">video (
38)
</a></li>
387 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/vitenskap">vitenskap (
4)
</a></li>
389 <li><a href=
"http://people.skolelinux.org/pere/blog/tags/web">web (
26)
</a></li>
395 <p style=
"text-align: right">
396 Created by
<a href=
"http://steve.org.uk/Software/chronicle">Chronicle v4.6
</a>